<?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>94669</bug_id>
          
          <creation_ts>2012-08-21 22:32:43 -0700</creation_ts>
          <short_desc>[GTK] contextClick and getMenuItemTitle callbacks are leaky in DRT&apos;s EventSender</short_desc>
          <delta_ts>2012-08-21 23:47:19 -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>WebKitGTK</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="Sudarsana Nagineni (babu)">naginenis</reporter>
          <assigned_to name="Sudarsana Nagineni (babu)">naginenis</assigned_to>
          <cc>cgarcia</cc>
    
    <cc>pnormand</cc>
    
    <cc>webkit.review.bot</cc>
          

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>701572</commentid>
    <comment_count>0</comment_count>
    <who name="Sudarsana Nagineni (babu)">naginenis</who>
    <bug_when>2012-08-21 22:32:43 -0700</bug_when>
    <thetext>Found new memory leaks in DRT&apos;s EventSender.cpp

==9709== 240 (24 direct, 216 indirect) bytes in 1 blocks are definitely lost in loss record 22,591 of 24,861
==9709==    at 0x4C2B6CD: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==9709==    by 0xA9EBA38: g_malloc (gmem.c:159)
==9709==    by 0xA9FEC62: g_slice_alloc (gslice.c:1003)
==9709==    by 0xA9E283D: g_list_prepend (glist.c:275)
==9709==    by 0x975D40E: gtk_container_children_callback (gtkcontainer.c:2889)
==9709==    by 0x9803E2C: gtk_menu_shell_forall (gtkmenushell.c:1218)
==9709==    by 0x976182D: gtk_container_get_children (gtkcontainer.c:2105)
==9709==    by 0x477A4A: contextClickCallback(OpaqueJSContext const*, OpaqueJSValue*, OpaqueJSValue*, unsigned long, OpaqueJSValue const* const*, OpaqueJSValue const**) (EventSender.cpp:219)

==9709== 2,670 (1,080 direct, 1,590 indirect) bytes in 45 blocks are definitely lost in loss record 24,378 of 24,861
==9709==    at 0x4C2B6CD: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==9709==    by 0x560E9E2: WTF::fastMalloc(unsigned long) (FastMalloc.cpp:268)
==9709==    by 0x52BCD5E: WTF::ThreadSafeRefCountedBase::operator new(unsigned long) (ThreadSafeRefCounted.h:72)
==9709==    by 0x52CE2D0: OpaqueJSString::create(unsigned short const*, unsigned int) (OpaqueJSString.h:46)
==9709==    by 0x52CDFE5: JSStringCreateWithUTF8CString (JSStringRef.cpp:50)
==9709==    by 0x477830: getMenuItemTitleCallback(OpaqueJSContext const*, OpaqueJSValue*, OpaqueJSString*, OpaqueJSValue const**) (EventSender.cpp:160)
==9709==    by 0x52B81F9: JSC::JSCallbackObject&lt;JSC::JSNonFinalObject&gt;::getStaticValue(JSC::ExecState*, JSC::PropertyName) (JSCallbackObjectFunctions.h:529)
==9709==    by 0x52B4E86: JSC::JSCallbackObject&lt;JSC::JSNonFinalObject&gt;::getOwnPropertySlot(JSC::JSCell*, JSC::ExecState*, JSC::PropertyName, JSC::PropertySlot&amp;) (JSCallbackObjectFunctions.h:165)
==9709==    by 0x49188E: JSC::JSCell::fastGetOwnPropertySlot(JSC::ExecState*, JSC::PropertyName, JSC::PropertySlot&amp;) (JSObject.h:618)
==9709==    by 0x53C15B3: JSC::JSValue::get(JSC::ExecState*, JSC::PropertyName, JSC::PropertySlot&amp;) const (JSObject.h:873)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>701573</commentid>
    <comment_count>1</comment_count>
      <attachid>159862</attachid>
    <who name="Sudarsana Nagineni (babu)">naginenis</who>
    <bug_when>2012-08-21 22:42:55 -0700</bug_when>
    <thetext>Created attachment 159862
Patch</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>701588</commentid>
    <comment_count>2</comment_count>
      <attachid>159862</attachid>
    <who name="Carlos Garcia Campos">cgarcia</who>
    <bug_when>2012-08-21 23:03:59 -0700</bug_when>
    <thetext>Comment on attachment 159862
Patch

Thanks!</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>701620</commentid>
    <comment_count>3</comment_count>
      <attachid>159862</attachid>
    <who name="WebKit Review Bot">webkit.review.bot</who>
    <bug_when>2012-08-21 23:47:15 -0700</bug_when>
    <thetext>Comment on attachment 159862
Patch

Clearing flags on attachment: 159862

Committed r126267: &lt;http://trac.webkit.org/changeset/126267&gt;</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>701621</commentid>
    <comment_count>4</comment_count>
    <who name="WebKit Review Bot">webkit.review.bot</who>
    <bug_when>2012-08-21 23:47:19 -0700</bug_when>
    <thetext>All reviewed patches have been landed.  Closing bug.</thetext>
  </long_desc>
      
          <attachment
              isobsolete="0"
              ispatch="1"
              isprivate="0"
          >
            <attachid>159862</attachid>
            <date>2012-08-21 22:42:55 -0700</date>
            <delta_ts>2012-08-21 23:47:15 -0700</delta_ts>
            <desc>Patch</desc>
            <filename>94669.patch</filename>
            <type>text/plain</type>
            <size>2470</size>
            <attacher name="Sudarsana Nagineni (babu)">naginenis</attacher>
            
              <data encoding="base64">ZGlmZiAtLWdpdCBhL1Rvb2xzL0NoYW5nZUxvZyBiL1Rvb2xzL0NoYW5nZUxvZwppbmRleCBhM2Ni
MDViLi43ODM0OTBmIDEwMDY0NAotLS0gYS9Ub29scy9DaGFuZ2VMb2cKKysrIGIvVG9vbHMvQ2hh
bmdlTG9nCkBAIC0xLDMgKzEsMTcgQEAKKzIwMTItMDgtMjEgIFN1ZGFyc2FuYSBOYWdpbmVuaSAg
PHN1ZGFyc2FuYS5uYWdpbmVuaUBsaW51eC5pbnRlbC5jb20+CisKKyAgICAgICAgW0dUS10gY29u
dGV4dENsaWNrIGFuZCBnZXRNZW51SXRlbVRpdGxlIGNhbGxiYWNrcyBhcmUgbGVha3kgaW4gRFJU
J3MgRXZlbnRTZW5kZXIKKyAgICAgICAgaHR0cHM6Ly9idWdzLndlYmtpdC5vcmcvc2hvd19idWcu
Y2dpP2lkPTk0NjY5CisKKyAgICAgICAgUmV2aWV3ZWQgYnkgTk9CT0RZIChPT1BTISkuCisKKyAg
ICAgICAgRml4IG1lbW9yeSBsZWFrcyBpbiBEUlQncyBFdmVudFNlbmRlciBjb2RlLgorCisgICAg
ICAgICogRHVtcFJlbmRlclRyZWUvZ3RrL0V2ZW50U2VuZGVyLmNwcDoKKyAgICAgICAgKGdldE1l
bnVJdGVtVGl0bGVDYWxsYmFjayk6IFVzZSBKU1JldGFpblB0ciBhbmQgZG9uJ3QgbGVhay4KKyAg
ICAgICAgKGNvbnRleHRDbGlja0NhbGxiYWNrKTogVXNlIEdPd25QdHIgdG8gbWFuYWdlIG1lbW9y
eSBvZiBhCisgICAgICAgIG5ld2x5LWFsbG9jYXRlZCBsaXN0IGF1dG9tYXRpY2FsbHkuCisKIDIw
MTItMDgtMjEgIFNpbW9uIEhhdXNtYW5uICA8c2ltb24uaGF1c21hbm5Abm9raWEuY29tPgogCiAg
ICAgICAgIFVucmV2aWV3ZWQgYnVpbGQgZml4IGZvciBuZXdlciBRdCA1OiBUaGUgbWVhbmluZyBv
ZiBwcml2YXRlX2luY2x1ZGVzIGNoYW5nZWQgdG8gYmUgZnVsbHkKZGlmZiAtLWdpdCBhL1Rvb2xz
L0R1bXBSZW5kZXJUcmVlL2d0ay9FdmVudFNlbmRlci5jcHAgYi9Ub29scy9EdW1wUmVuZGVyVHJl
ZS9ndGsvRXZlbnRTZW5kZXIuY3BwCmluZGV4IDRjYzJhYjMuLmQ3OGRiOTMgMTAwNjQ0Ci0tLSBh
L1Rvb2xzL0R1bXBSZW5kZXJUcmVlL2d0ay9FdmVudFNlbmRlci5jcHAKKysrIGIvVG9vbHMvRHVt
cFJlbmRlclRyZWUvZ3RrL0V2ZW50U2VuZGVyLmNwcApAQCAtMTU3LDcgKzE1Nyw4IEBAIHN0YXRp
YyBKU1ZhbHVlUmVmIGdldE1lbnVJdGVtVGl0bGVDYWxsYmFjayhKU0NvbnRleHRSZWYgY29udGV4
dCwgSlNPYmplY3RSZWYgb2JqCiAgICAgZWxzZQogICAgICAgICBsYWJlbCA9IGd0a19tZW51X2l0
ZW1fZ2V0X2xhYmVsKEdUS19NRU5VX0lURU0od2lkZ2V0KSk7CiAKLSAgICByZXR1cm4gSlNWYWx1
ZU1ha2VTdHJpbmcoY29udGV4dCwgSlNTdHJpbmdDcmVhdGVXaXRoVVRGOENTdHJpbmcobGFiZWwu
ZGF0YSgpKSk7CisgICAgSlNSZXRhaW5QdHI8SlNTdHJpbmdSZWY+IGl0ZW1UZXh0KEFkb3B0LCBK
U1N0cmluZ0NyZWF0ZVdpdGhVVEY4Q1N0cmluZyhsYWJlbC5kYXRhKCkpKTsKKyAgICByZXR1cm4g
SlNWYWx1ZU1ha2VTdHJpbmcoY29udGV4dCwgaXRlbVRleHQuZ2V0KCkpOwogfQogCiBzdGF0aWMg
Ym9vbCBzZXRNZW51SXRlbVRpdGxlQ2FsbGJhY2soSlNDb250ZXh0UmVmIGNvbnRleHQsIEpTT2Jq
ZWN0UmVmIG9iamVjdCwgSlNTdHJpbmdSZWYgcHJvcGVydHlOYW1lLCBKU1ZhbHVlUmVmIHZhbHVl
LCBKU1ZhbHVlUmVmKiBleGNlcHRpb24pCkBAIC0yMTYsMTAgKzIxNywxMCBAQCBzdGF0aWMgSlNW
YWx1ZVJlZiBjb250ZXh0Q2xpY2tDYWxsYmFjayhKU0NvbnRleHRSZWYgY29udGV4dCwgSlNPYmpl
Y3RSZWYgZnVuY3RpbwogICAgIFdlYktpdFdlYlZpZXcqIHZpZXcgPSB3ZWJraXRfd2ViX2ZyYW1l
X2dldF93ZWJfdmlldyhtYWluRnJhbWUpOwogICAgIEd0a01lbnUqIGd0a01lbnUgPSB3ZWJraXRf
d2ViX3ZpZXdfZ2V0X2NvbnRleHRfbWVudSh2aWV3KTsKICAgICBpZiAoZ3RrTWVudSkgewotICAg
ICAgICBHTGlzdCogaXRlbXMgPSBndGtfY29udGFpbmVyX2dldF9jaGlsZHJlbihHVEtfQ09OVEFJ
TkVSKGd0a01lbnUpKTsKLSAgICAgICAgSlNWYWx1ZVJlZiBhcnJheVZhbHVlc1tnX2xpc3RfbGVu
Z3RoKGl0ZW1zKV07CisgICAgICAgIEdPd25QdHI8R0xpc3Q+IGl0ZW1zKGd0a19jb250YWluZXJf
Z2V0X2NoaWxkcmVuKEdUS19DT05UQUlORVIoZ3RrTWVudSkpKTsKKyAgICAgICAgSlNWYWx1ZVJl
ZiBhcnJheVZhbHVlc1tnX2xpc3RfbGVuZ3RoKGl0ZW1zLmdldCgpKV07CiAgICAgICAgIGludCBp
bmRleCA9IDA7Ci0gICAgICAgIGZvciAoR0xpc3QqIGl0ZW0gPSBnX2xpc3RfZmlyc3QoaXRlbXMp
OyBpdGVtOyBpdGVtID0gZ19saXN0X25leHQoaXRlbSkpIHsKKyAgICAgICAgZm9yIChHTGlzdCog
aXRlbSA9IGdfbGlzdF9maXJzdChpdGVtcy5nZXQoKSk7IGl0ZW07IGl0ZW0gPSBnX2xpc3RfbmV4
dChpdGVtKSkgewogICAgICAgICAgICAgYXJyYXlWYWx1ZXNbaW5kZXhdID0gSlNPYmplY3RNYWtl
KGNvbnRleHQsIGdldE1lbnVJdGVtQ2xhc3MoKSwgaXRlbS0+ZGF0YSk7CiAgICAgICAgICAgICBp
bmRleCsrOwogICAgICAgICB9Cg==
</data>

          </attachment>
      

    </bug>

</bugzilla>