summaryrefslogtreecommitdiffstats
path: root/ext
diff options
context:
space:
mode:
Diffstat (limited to 'ext')
-rw-r--r--ext/flac/gstflactag.c12
-rw-r--r--ext/libpng/gstpngenc.c5
-rw-r--r--ext/mikmod/gstmikmod.c7
3 files changed, 19 insertions, 5 deletions
diff --git a/ext/flac/gstflactag.c b/ext/flac/gstflactag.c
index f2d178d0..5d1c56c2 100644
--- a/ext/flac/gstflactag.c
+++ b/ext/flac/gstflactag.c
@@ -264,7 +264,11 @@ gst_flac_tag_chain (GstPad *pad, GstData *data)
tag = GST_FLAC_TAG (gst_pad_get_parent (pad));
if (tag->buffer) {
- tag->buffer = gst_buffer_merge (tag->buffer, buffer);
+ GstBuffer *merge;
+ merge = gst_buffer_merge (tag->buffer, buffer);
+ gst_buffer_unref (buffer);
+ gst_buffer_unref (tag->buffer);
+ tag->buffer = merge;
} else {
tag->buffer = buffer;
}
@@ -365,7 +369,11 @@ gst_flac_tag_chain (GstPad *pad, GstData *data)
if (tag->vorbiscomment == NULL) {
tag->vorbiscomment = sub;
} else {
- tag->vorbiscomment = gst_buffer_merge (tag->vorbiscomment, sub);
+ GstBuffer *merge;
+ merge = gst_buffer_merge (tag->vorbiscomment, sub);
+ gst_buffer_unref (tag->vorbiscomment);
+ gst_buffer_unref (sub);
+ tag->vorbiscomment = merge;
}
}
diff --git a/ext/libpng/gstpngenc.c b/ext/libpng/gstpngenc.c
index 8af25d38..393e642c 100644
--- a/ext/libpng/gstpngenc.c
+++ b/ext/libpng/gstpngenc.c
@@ -207,8 +207,11 @@ void user_write_data (png_structp png_ptr, png_bytep data, png_uint_32 length)
if (pngenc->buffer_out)
{
- pngenc->buffer_out = gst_buffer_merge (pngenc->buffer_out, buffer);
+ GstBuffer *merge;
+ merge = gst_buffer_merge (pngenc->buffer_out, buffer);
gst_buffer_unref (buffer);
+ gst_buffer_unref (pngenc->buffer_out);
+ pngenc->buffer_out = merge;
}
else
pngenc->buffer_out = buffer;
diff --git a/ext/mikmod/gstmikmod.c b/ext/mikmod/gstmikmod.c
index c777ef46..cec788d5 100644
--- a/ext/mikmod/gstmikmod.c
+++ b/ext/mikmod/gstmikmod.c
@@ -298,8 +298,11 @@ gst_mikmod_loop (GstElement *element)
else
{
if ( mikmod->Buffer ) {
- mikmod->Buffer = gst_buffer_merge( mikmod->Buffer, buffer_in );
- gst_buffer_unref( buffer_in );
+ GstBuffer *merge;
+ merge = gst_buffer_merge( mikmod->Buffer, buffer_in );
+ gst_buffer_unref( buffer_in );
+ gst_buffer_unref( mikmod->Buffer );
+ mikmod->Buffer = merge;
}
else
mikmod->Buffer = buffer_in;