Changeset 102791 in webkit
- Timestamp:
- Dec 14, 2011, 9:26:08 AM (14 years ago)
- Location:
- trunk/Source/WebCore
- Files:
- 
      - 4 edited
 
 - 
          
  ChangeLog (modified) (1 diff)
- 
          
  platform/audio/gstreamer/WebKitWebAudioSourceGStreamer.cpp (modified) (1 diff)
- 
          
  platform/graphics/gstreamer/GRefPtrGStreamer.cpp (modified) (1 diff)
- 
          
  platform/graphics/gstreamer/GRefPtrGStreamer.h (modified) (2 diffs)
 
Legend:
- Unmodified
- Added
- Removed
- 
      trunk/Source/WebCore/ChangeLogr102787 r102791 1 2011-12-14 Philippe Normand <pnormand@igalia.com> 2 3 [GStreamer] padTemplate leak in webkitwebaudiosrc 4 https://bugs.webkit.org/show_bug.cgi?id=74495 5 6 Reviewed by Martin Robinson. 7 8 Use a GstPadTemplate smart pointer in webkit_web_audio_src_init to 9 avoid a memory leak after the ghost pad creation. 10 11 * platform/audio/gstreamer/WebKitWebAudioSourceGStreamer.cpp: 12 (webkit_web_audio_src_init): 13 * platform/graphics/gstreamer/GRefPtrGStreamer.cpp: 14 (WTF::adoptGRef): 15 (WTF::GstPadTemplate): 16 * platform/graphics/gstreamer/GRefPtrGStreamer.h: 17 1 18 2011-12-14 Julien Chaffraix <jchaffraix@webkit.org> 2 19 
- 
      trunk/Source/WebCore/platform/audio/gstreamer/WebKitWebAudioSourceGStreamer.cppr101138 r102791 180 180 new (priv) WebKitWebAudioSourcePrivate(); 181 181 182 G stPadTemplate* padTemplate = gst_static_pad_template_get(&srcTemplate);183 priv->sourcePad = gst_ghost_pad_new_no_target_from_template("src", padTemplate );182 GRefPtr<GstPadTemplate> padTemplate = adoptGRef(gst_static_pad_template_get(&srcTemplate)); 183 priv->sourcePad = gst_ghost_pad_new_no_target_from_template("src", padTemplate.get()); 184 184 gst_element_add_pad(GST_ELEMENT(src), priv->sourcePad); 185 185 
- 
      trunk/Source/WebCore/platform/graphics/gstreamer/GRefPtrGStreamer.cppr101138 r102791 69 69 } 70 70 71 template <> GRefPtr<GstPadTemplate> adoptGRef(GstPadTemplate* ptr) 72 { 73 ASSERT(!ptr || !GST_OBJECT_IS_FLOATING(GST_OBJECT(ptr))); 74 return GRefPtr<GstPadTemplate>(ptr, GRefPtrAdopt); 75 } 76 77 template <> GstPadTemplate* refGPtr<GstPadTemplate>(GstPadTemplate* ptr) 78 { 79 if (ptr) { 80 gst_object_ref(GST_OBJECT(ptr)); 81 gst_object_sink(GST_OBJECT(ptr)); 82 } 83 return ptr; 84 } 85 86 template <> void derefGPtr<GstPadTemplate>(GstPadTemplate* ptr) 87 { 88 if (ptr) 89 gst_object_unref(GST_OBJECT(ptr)); 90 } 91 71 92 template <> GstCaps* refGPtr<GstCaps>(GstCaps* ptr) 72 93 { 
- 
      trunk/Source/WebCore/platform/graphics/gstreamer/GRefPtrGStreamer.hr101138 r102791 26 26 typedef struct _GstElement GstElement; 27 27 typedef struct _GstPad GstPad; 28 typedef struct _GstPadTemplate GstPadTemplate; 28 29 typedef struct _GstCaps GstCaps; 29 30 typedef struct _GstTask GstTask; … … 39 40 template<> void derefGPtr<GstPad>(GstPad* ptr); 40 41 42 template<> GRefPtr<GstPadTemplate> adoptGRef(GstPadTemplate* ptr); 43 template<> GstPadTemplate* refGPtr<GstPadTemplate>(GstPadTemplate* ptr); 44 template<> void derefGPtr<GstPadTemplate>(GstPadTemplate* ptr); 45 41 46 template<> GstCaps* refGPtr<GstCaps>(GstCaps* ptr); 42 47 template<> void derefGPtr<GstCaps>(GstCaps* ptr); 
  Note:
 See   TracChangeset
 for help on using the changeset viewer.
  
