<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<!DOCTYPE bugzilla SYSTEM "https://bugs.webkit.org/page.cgi?id=bugzilla.dtd">

<bugzilla version="5.0.4.1"
          urlbase="https://bugs.webkit.org/"
          
          maintainer="admin@webkit.org"
>

    <bug>
          <bug_id>113343</bug_id>
          
          <creation_ts>2013-03-26 14:41:50 -0700</creation_ts>
          <short_desc>border-radius clipping a canvas does not always clip</short_desc>
          <delta_ts>2013-05-02 16:32:22 -0700</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>1</classification_id>
          <classification>Unclassified</classification>
          <product>WebKit</product>
          <component>Canvas</component>
          <version>528+ (Nightly build)</version>
          <rep_platform>Unspecified</rep_platform>
          <op_sys>Unspecified</op_sys>
          <bug_status>RESOLVED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P2</priority>
          <bug_severity>Normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Rafael Brandao">rafael.lobo</reporter>
          <assigned_to name="arno.">a.renevier</assigned_to>
          <cc>a.renevier</cc>
    
    <cc>commit-queue</cc>
    
    <cc>esprehn+autocc</cc>
    
    <cc>glenn</cc>
    
    <cc>hugo.lima</cc>
    
    <cc>jesus</cc>
    
    <cc>luis.gabriel</cc>
    
    <cc>noam</cc>
    
    <cc>simon.fraser</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>864015</commentid>
    <comment_count>0</comment_count>
      <attachid>195167</attachid>
    <who name="Rafael Brandao">rafael.lobo</who>
    <bug_when>2013-03-26 14:41:50 -0700</bug_when>
    <thetext>Created attachment 195167
test case, second render done after a timeout does not clip.

When we paint the canvas area, if there&apos;s an element as parent that overflows and clips using a border-radius, then the clip does not respect the radius on following render calls. I have a test case that shows this issue on Chrome, Qt and Nix. It may be an issue in other ports.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>864024</commentid>
    <comment_count>1</comment_count>
    <who name="Simon Fraser (smfr)">simon.fraser</who>
    <bug_when>2013-03-26 14:47:40 -0700</bug_when>
    <thetext>Possibly related to the fact that composited elements don&apos;t respect border-radius clipping.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>864097</commentid>
    <comment_count>2</comment_count>
    <who name="Rafael Brandao">rafael.lobo</who>
    <bug_when>2013-03-26 16:42:14 -0700</bug_when>
    <thetext>If I change the test to do the following, then the second render clips as expected:

render = function() {
    ctx.fillStyle = &quot;#ff0000&quot;;
    ctx.fillRect(0, 0, 400, 300);
}

render2 = function() {
    render();
    document.getElementById(&quot;box&quot;).style.overflow = &quot;hidden&quot;;
}

render();
setTimeout(&quot;render2()&quot;, 2000);</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>864098</commentid>
    <comment_count>3</comment_count>
    <who name="Rafael Brandao">rafael.lobo</who>
    <bug_when>2013-03-26 16:43:38 -0700</bug_when>
    <thetext>A small correction: it only properly clips on the second render if the box initially not set &quot;overflow: hidden&quot;. It looks like the clip only happens in the first render after &quot;overflow: hidden&quot; is set.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>883618</commentid>
    <comment_count>4</comment_count>
      <attachid>200260</attachid>
    <who name="arno.">a.renevier</who>
    <bug_when>2013-05-01 17:28:49 -0700</bug_when>
    <thetext>Created attachment 200260
patch proposal</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>884010</commentid>
    <comment_count>5</comment_count>
      <attachid>200260</attachid>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2013-05-02 16:32:20 -0700</bug_when>
    <thetext>Comment on attachment 200260
patch proposal

Clearing flags on attachment: 200260

Committed r149504: &lt;http://trac.webkit.org/changeset/149504&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>884011</commentid>
    <comment_count>6</comment_count>
    <who name="WebKit Commit Bot">commit-queue</who>
    <bug_when>2013-05-02 16:32:22 -0700</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="0"
              isprivate="0"
          >
            <attachid>195167</attachid>
            <date>2013-03-26 14:41:50 -0700</date>
            <delta_ts>2013-03-26 14:41:50 -0700</delta_ts>
            <desc>test case, second render done after a timeout does not clip.</desc>
            <filename>canvas-bug.html</filename>
            <type>text/html</type>
            <size>552</size>
            <attacher name="Rafael Brandao">rafael.lobo</attacher>
            
              <data encoding="base64">PGh0bWw+CjxoZWFkPjx0aXRsZT5idWcgb24gb3ZlcmZsb3c8L3RpdGxlPjwvaGVhZD4KPGJvZHk+
Cgo8ZGl2IGlkPSJib3giIHN0eWxlPSJwb3NpdGlvbjogYWJzb2x1dGU7IGRpc3BsYXk6IGJsb2Nr
OyB3aWR0aDogMzAwcHg7IGhlaWdodDogMjAwcHg7IHRvcDogMDsgbGVmdDogMDsgYm9yZGVyLXJh
ZGl1czogNDBweDsgb3ZlcmZsb3c6IGhpZGRlbjsiPgo8Y2FudmFzIGlkPSJjbnYiIHdpZHRoPSI1
MDBweCIgaGVpZ2h0PSI4MDBweCI+CjwvY2FudmFzPgo8L2Rpdj4KCjxzY3JpcHQ+CnZhciBjbnYg
PSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiY252Iik7CnZhciBib3ggPSBkb2N1bWVudC5nZXRF
bGVtZW50QnlJZCgiYm94Iik7CnZhciBjdHggPSBjbnYuZ2V0Q29udGV4dCgiMmQiKTsKCnJlbmRl
ciA9IGZ1bmN0aW9uKCkgewogICAgY3R4LmZpbGxTdHlsZSA9ICIjZmYwMDAwIjsKICAgIGN0eC5m
aWxsUmVjdCgwLCAwLCA0MDAsIDMwMCk7Cn0KCnJlbmRlcigpOwpzZXRUaW1lb3V0KCJyZW5kZXIo
KSIsIDIwMDApOwo8L3NjcmlwdD4KCgo8L2JvZHk+CjwvaHRtbD4K
</data>

          </attachment>
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>200260</attachid>
            <date>2013-05-01 17:28:49 -0700</date>
            <delta_ts>2013-05-02 16:32:20 -0700</delta_ts>
            <desc>patch proposal</desc>
            <filename>bug-113343-20130501172800.patch</filename>
            <type>text/plain</type>
            <size>5269</size>
            <attacher name="arno.">a.renevier</attacher>
            
              <data encoding="base64">U3VidmVyc2lvbiBSZXZpc2lvbjogMTQ5NDM1CmRpZmYgLS1naXQgYS9Tb3VyY2UvV2ViQ29yZS9D
aGFuZ2VMb2cgYi9Tb3VyY2UvV2ViQ29yZS9DaGFuZ2VMb2cKaW5kZXggY2I2NThmMWVjMDcxMmMy
MjBkMGMxZjg4MTExZWFlMDMzZmJjYzdmYS4uOGE3NjYyY2JmMzJiNTAzMzdlN2I0ZDI3Nzg2MmRh
MmQ5ZWIxY2YxNCAxMDA2NDQKLS0tIGEvU291cmNlL1dlYkNvcmUvQ2hhbmdlTG9nCisrKyBiL1Nv
dXJjZS9XZWJDb3JlL0NoYW5nZUxvZwpAQCAtMSw1ICsxLDI0IEBACiAyMDEzLTA1LTAxICBBcm5h
dWQgUmVuZXZpZXIgIDxhLnJlbmV2aWVyQHNpc2Euc2Ftc3VuZy5jb20+CiAKKyAgICAgICAgYm9y
ZGVyLXJhZGl1cyBjbGlwcGluZyBhIGNhbnZhcyBkb2VzIG5vdCBhbHdheXMgY2xpcAorICAgICAg
ICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5jZ2k/aWQ9MTEzMzQzCisKKyAgICAg
ICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BTISkuCisKKyAgICAgICAgY2xpcFRvUmVjdCBtZXRo
b2QgY2xpcCBjb250ZXh0IHRvIGNsaXBSZWN0LCBhbmQgdGhlbiBjbGlwIHRvIHJvdW5kZWQKKyAg
ICAgICAgcmVjdCBpZiBjbGlwUmVjdCBoYXMgYSByYWRpdXMuIEJ1dCBjdXJyZW50bHksIGNsaXBU
b1JlY3QgZXhpdCBlYXJseSBpZgorICAgICAgICBjbGlwVG9SZWN0IGlzIGVxdWFsIHRvIHBhaW50
RGlydHlSZWN0LgorCisgICAgICAgIFRoaXMgcGF0Y2ggYWxsb3dzIGNsaXBwaW5nIHRvIHJvdW5k
ZWQgY29ybmVyIGV2ZXIgaWYgY2xpcFRvUmVjdCBpcworICAgICAgICBlcXVhbCB0byBwYWludERp
cnR5UmVjdC4KKworICAgICAgICBUZXN0OiBmYXN0L292ZXJmbG93L2JvcmRlci1yYWRpdXMtY2xp
cHBpbmctMi5odG1sCisKKyAgICAgICAgKiByZW5kZXJpbmcvUmVuZGVyTGF5ZXIuY3BwOgorICAg
ICAgICAoV2ViQ29yZTo6UmVuZGVyTGF5ZXI6OmNsaXBUb1JlY3QpOgorCisyMDEzLTA1LTAxICBB
cm5hdWQgUmVuZXZpZXIgIDxhLnJlbmV2aWVyQHNpc2Euc2Ftc3VuZy5jb20+CisKICAgICAgICAg
aGFuZGxlIGVudW0gaW4gb3ZlcmxvYWRlZCBtZXRob2RzCiAgICAgICAgIGh0dHBzOi8vYnVncy53
ZWJraXQub3JnL3Nob3dfYnVnLmNnaT9pZD0xMTU0NzcKIApkaWZmIC0tZ2l0IGEvU291cmNlL1dl
YkNvcmUvcmVuZGVyaW5nL1JlbmRlckxheWVyLmNwcCBiL1NvdXJjZS9XZWJDb3JlL3JlbmRlcmlu
Zy9SZW5kZXJMYXllci5jcHAKaW5kZXggY2M2YTljOTg5NmU0MzZkOGIzYWRmMmFhYTQzNGJiNzA5
NTcxOWI3Zi4uYzg2ZjdiYjI1MjljMjRkOWIzMjNkZDZkOTdlYTRiOGJiOGVmNmMzNiAxMDA2NDQK
LS0tIGEvU291cmNlL1dlYkNvcmUvcmVuZGVyaW5nL1JlbmRlckxheWVyLmNwcAorKysgYi9Tb3Vy
Y2UvV2ViQ29yZS9yZW5kZXJpbmcvUmVuZGVyTGF5ZXIuY3BwCkBAIC0zNTE0LDE1ICszNTE0LDE1
IEBAIHN0YXRpYyBib29sIGluQ29udGFpbmluZ0Jsb2NrQ2hhaW4oUmVuZGVyTGF5ZXIqIHN0YXJ0
TGF5ZXIsIFJlbmRlckxheWVyKiBlbmRMYXllCiB2b2lkIFJlbmRlckxheWVyOjpjbGlwVG9SZWN0
KFJlbmRlckxheWVyKiByb290TGF5ZXIsIEdyYXBoaWNzQ29udGV4dCogY29udGV4dCwgY29uc3Qg
TGF5b3V0UmVjdCYgcGFpbnREaXJ0eVJlY3QsIGNvbnN0IENsaXBSZWN0JiBjbGlwUmVjdCwKICAg
ICAgICAgICAgICAgICAgICAgICAgICAgICAgQm9yZGVyUmFkaXVzQ2xpcHBpbmdSdWxlIHJ1bGUp
CiB7Ci0gICAgaWYgKGNsaXBSZWN0LnJlY3QoKSA9PSBwYWludERpcnR5UmVjdCkKLSAgICAgICAg
cmV0dXJuOwotICAgIGNvbnRleHQtPnNhdmUoKTsKLSAgICBjb250ZXh0LT5jbGlwKHBpeGVsU25h
cHBlZEludFJlY3QoY2xpcFJlY3QucmVjdCgpKSk7CisgICAgaWYgKGNsaXBSZWN0LnJlY3QoKSAh
PSBwYWludERpcnR5UmVjdCkgeworICAgICAgICBjb250ZXh0LT5zYXZlKCk7CisgICAgICAgIGNv
bnRleHQtPmNsaXAocGl4ZWxTbmFwcGVkSW50UmVjdChjbGlwUmVjdC5yZWN0KCkpKTsKKyAgICB9
CiAgICAgCisjaWZuZGVmIERJU0FCTEVfUk9VTkRFRF9DT1JORVJfQ0xJUFBJTkcKICAgICBpZiAo
IWNsaXBSZWN0Lmhhc1JhZGl1cygpKQogICAgICAgICByZXR1cm47CiAKLSNpZm5kZWYgRElTQUJM
RV9ST1VOREVEX0NPUk5FUl9DTElQUElORwogICAgIC8vIElmIHRoZSBjbGlwIHJlY3QgaGFzIGJl
ZW4gdGFpbnRlZCBieSBhIGJvcmRlciByYWRpdXMsIHRoZW4gd2UgaGF2ZSB0byB3YWxrIHVwIG91
ciBsYXllciBjaGFpbiBhcHBseWluZyB0aGUgY2xpcHMgZnJvbQogICAgIC8vIGFueSBsYXllcnMg
d2l0aCBvdmVyZmxvdy4gVGhlIGNvbmRpdGlvbiBmb3IgYmVpbmcgYWJsZSB0byBhcHBseSB0aGVz
ZSBjbGlwcyBpcyB0aGF0IHRoZSBvdmVyZmxvdyBvYmplY3QgYmUgaW4gb3VyCiAgICAgLy8gY29u
dGFpbmluZyBibG9jayBjaGFpbiBzbyB3ZSBjaGVjayB0aGF0IGFsc28uCmRpZmYgLS1naXQgYS9M
YXlvdXRUZXN0cy9DaGFuZ2VMb2cgYi9MYXlvdXRUZXN0cy9DaGFuZ2VMb2cKaW5kZXggY2RhZDdh
NzUwNzQ1MzNlMWViN2ZmMjBjOGYyMDUzMTdhZTFkNWY5Ni4uODFlYTY4YWFjNTcyYjE1MDJhNGIw
ZjQ3N2E0NjU3MmY1NzAzOTNhOCAxMDA2NDQKLS0tIGEvTGF5b3V0VGVzdHMvQ2hhbmdlTG9nCisr
KyBiL0xheW91dFRlc3RzL0NoYW5nZUxvZwpAQCAtMSwzICsxLDE3IEBACisyMDEzLTA1LTAxICBB
cm5hdWQgUmVuZXZpZXIgIDxhLnJlbmV2aWVyQHNpc2Euc2Ftc3VuZy5jb20+CisKKyAgICAgICAg
Ym9yZGVyLXJhZGl1cyBjbGlwcGluZyBhIGNhbnZhcyBkb2VzIG5vdCBhbHdheXMgY2xpcAorICAg
ICAgICBodHRwczovL2J1Z3Mud2Via2l0Lm9yZy9zaG93X2J1Zy5jZ2k/aWQ9MTEzMzQzCisKKyAg
ICAgICAgQ3JlYXRlIGEgdGVzdCB0aGF0IGRyYXdzIGEgY2FudmFzIGludG8gYSBjbGlwcGVkIG92
ZXJmbG93biBkaXYgd2l0aAorICAgICAgICByYWRpdXMgY29ybmVyLiBUaGVuIHJlZHJhdyB0aGF0
IHNhbWUgdGhpbmcgYSBtb21lbnQgbGF0ZXIuIFRoZSBjYW52YXMKKyAgICAgICAgc2hvdWxkIHN0
YXkgY29ycmVjdGx5IGNsaXBwZWQgdGhlIHNlY29uZCB0aW1lLgorCisgICAgICAgIFJldmlld2Vk
IGJ5IE5PQk9EWSAoT09QUyEpLgorCisgICAgICAgICogZmFzdC9vdmVyZmxvdy9ib3JkZXItcmFk
aXVzLWNsaXBwaW5nLTItZXhwZWN0ZWQuaHRtbDogQWRkZWQuCisgICAgICAgICogZmFzdC9vdmVy
Zmxvdy9ib3JkZXItcmFkaXVzLWNsaXBwaW5nLTIuaHRtbDogQWRkZWQuCisKIDIwMTMtMDMtMjgg
IEFybmF1ZCBSZW5ldmllciAgPGEucmVuZXZpZXJAc2lzYS5zYW1zdW5nLmNvbT4KIAogICAgICAg
ICBtZWFzdXJlVGV4dCgpIGltcHJvdmVtZW50cwpkaWZmIC0tZ2l0IGEvTGF5b3V0VGVzdHMvZmFz
dC9vdmVyZmxvdy9ib3JkZXItcmFkaXVzLWNsaXBwaW5nLTItZXhwZWN0ZWQuaHRtbCBiL0xheW91
dFRlc3RzL2Zhc3Qvb3ZlcmZsb3cvYm9yZGVyLXJhZGl1cy1jbGlwcGluZy0yLWV4cGVjdGVkLmh0
bWwKbmV3IGZpbGUgbW9kZSAxMDA2NDQKaW5kZXggMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAw
MDAwMDAwMDAwMDAwMC4uY2I5ZTUxNDA4ZGYyOTE2NGUzMjVlZDYwZTRlMzhlNzM2ODg5NzViYgot
LS0gL2Rldi9udWxsCisrKyBiL0xheW91dFRlc3RzL2Zhc3Qvb3ZlcmZsb3cvYm9yZGVyLXJhZGl1
cy1jbGlwcGluZy0yLWV4cGVjdGVkLmh0bWwKQEAgLTAsMCArMSwyMSBAQAorPCFET0NUWVBFIGh0
bWw+Cis8aHRtbD4KKzxoZWFkPgorICAgIDxzY3JpcHQ+CisgICAgZnVuY3Rpb24gc3RhcnQoKSB7
CisgICAgICAgIHZhciBjYW52YXMgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgiY252Iik7Cisg
ICAgICAgIHZhciBjdHggPSBjYW52YXMuZ2V0Q29udGV4dCgiMmQiKTsKKyAgICAgICAgY3R4LmZp
bGxTdHlsZSA9ICIjZmYwMDAwIjsKKyAgICAgICAgY3R4LmZpbGxSZWN0KDAsIDAsIGNhbnZhcy53
aWR0aCwgY2FudmFzLmhlaWdodCk7CisgICAgfQorICAgIDwvc2NyaXB0PgorPC9oZWFkPgorPGJv
ZHkgb25sb2FkPSJzdGFydCgpIj4KKworPGRpdiBpZD0iYm94IiBzdHlsZT0icG9zaXRpb246IGFi
c29sdXRlOyB3aWR0aDogMzAwcHg7IGhlaWdodDogMjAwcHg7IGJvcmRlci1yYWRpdXM6IDQwcHg7
IG92ZXJmbG93OiBoaWRkZW47Ij4KKzxjYW52YXMgaWQ9ImNudiIgd2lkdGg9IjQwMHB4IiBoZWln
aHQ9IjQwMHB4Ij48L2NhbnZhcz4KKzwvZGl2PgorCis8L2JvZHk+Cis8L2h0bWw+CisKZGlmZiAt
LWdpdCBhL0xheW91dFRlc3RzL2Zhc3Qvb3ZlcmZsb3cvYm9yZGVyLXJhZGl1cy1jbGlwcGluZy0y
Lmh0bWwgYi9MYXlvdXRUZXN0cy9mYXN0L292ZXJmbG93L2JvcmRlci1yYWRpdXMtY2xpcHBpbmct
Mi5odG1sCm5ldyBmaWxlIG1vZGUgMTAwNjQ0CmluZGV4IDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAw
MDAwMDAwMDAwMDAwMDAwMDAuLjk4NDJiYWNkYzhlMzBiM2QxZmYzMTI3M2QyZjUxMjY5MDE5NTRl
ZDQKLS0tIC9kZXYvbnVsbAorKysgYi9MYXlvdXRUZXN0cy9mYXN0L292ZXJmbG93L2JvcmRlci1y
YWRpdXMtY2xpcHBpbmctMi5odG1sCkBAIC0wLDAgKzEsMjkgQEAKKzwhRE9DVFlQRSBodG1sPgor
PGh0bWw+Cis8aGVhZD4KKyAgICA8c2NyaXB0PgorICAgIGlmICh3aW5kb3cudGVzdFJ1bm5lcikK
KyAgICAgICAgdGVzdFJ1bm5lci53YWl0VW50aWxEb25lKCk7CisKKyAgICBmdW5jdGlvbiBzdGFy
dCgpIHsKKyAgICAgICAgdmFyIGNhbnZhcyA9IGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCJjbnYi
KTsKKyAgICAgICAgdmFyIGN0eCA9IGNhbnZhcy5nZXRDb250ZXh0KCIyZCIpOworCisgICAgICAg
IHNldFRpbWVvdXQoZnVuY3Rpb24oKSB7CisgICAgICAgICAgICBjdHguZmlsbFN0eWxlID0gIiNm
ZjAwMDAiOworICAgICAgICAgICAgY3R4LmZpbGxSZWN0KDAsIDAsIGNhbnZhcy53aWR0aCwgY2Fu
dmFzLmhlaWdodCk7CisgICAgICAgICAgICBpZiAod2luZG93LnRlc3RSdW5uZXIpIAorICAgICAg
ICAgICAgICAgIHRlc3RSdW5uZXIubm90aWZ5RG9uZSgpOworICAgICAgICB9LCA1MDApOworICAg
IH0KKworICAgIDwvc2NyaXB0PgorPC9oZWFkPgorPGJvZHkgb25sb2FkPSJzdGFydCgpIj4KKwor
PGRpdiBpZD0iYm94IiBzdHlsZT0icG9zaXRpb246IGFic29sdXRlOyB3aWR0aDogMzAwcHg7IGhl
aWdodDogMjAwcHg7IGJvcmRlci1yYWRpdXM6IDQwcHg7IG92ZXJmbG93OiBoaWRkZW47Ij4KKzxj
YW52YXMgaWQ9ImNudiIgd2lkdGg9IjQwMHB4IiBoZWlnaHQ9IjQwMHB4Ij48L2NhbnZhcz4KKzwv
ZGl2PgorCis8L2JvZHk+Cis8L2h0bWw+Cg==
</data>

          </attachment>
      

    </bug>

</bugzilla>