ext/swfdec/gstswfdec.c: Add a subclass of GstBuffer that wraps SwfdecBuffers. Fix a massive memleak because the vide...

Original commit message from CVS:
* ext/swfdec/gstswfdec.c: (gst_swfdecbuffer_get_type),
(gst_swfdecbuffer_class_init), (gst_swfdecbuffer_finalize),
(gst_swfdec_buffer_from_swf), (gst_swfdec_render): Add a subclass
of GstBuffer that wraps SwfdecBuffers.  Fix a massive memleak
because the video buffers previously never got freed.
This commit is contained in:
David Schleef 2005-12-12 09:29:21 +00:00
parent 27988d4031
commit dfa22f08c6
2 changed files with 92 additions and 7 deletions

View file

@ -1,3 +1,11 @@
2005-12-12 David Schleef <ds@schleef.org>
* ext/swfdec/gstswfdec.c: (gst_swfdecbuffer_get_type),
(gst_swfdecbuffer_class_init), (gst_swfdecbuffer_finalize),
(gst_swfdec_buffer_from_swf), (gst_swfdec_render): Add a subclass
of GstBuffer that wraps SwfdecBuffers. Fix a massive memleak
because the video buffers previously never got freed.
2005-12-11 Edgard Lima <edgard.lima@indt.org.br> 2005-12-11 Edgard Lima <edgard.lima@indt.org.br>
* ext/libmms/gstmms.c: * ext/libmms/gstmms.c:

View file

@ -113,6 +113,75 @@ static void gst_swfdec_render (GstSwfdec * swfdec, int ret);
static GstElementClass *parent_class = NULL; static GstElementClass *parent_class = NULL;
static guint gst_swfdec_signals[LAST_SIGNAL]; static guint gst_swfdec_signals[LAST_SIGNAL];
/* GstSwfdecBuffer */
typedef struct _GstSwfdecBuffer GstSwfdecBuffer;
struct _GstSwfdecBuffer
{
GstBuffer buffer;
SwfdecBuffer *swfdec_buffer;
};
static GstBufferClass *buffer_parent_class = NULL;
static void gst_swfdecbuffer_class_init (gpointer g_class, gpointer class_data);
static void gst_swfdecbuffer_finalize (GstSwfdecBuffer * swfdecbuffer);
GType
gst_swfdecbuffer_get_type (void)
{
static GType _gst_swfdecbuffer_type;
if (G_UNLIKELY (_gst_swfdecbuffer_type == 0)) {
static const GTypeInfo swfdecbuffer_info = {
sizeof (GstBufferClass),
NULL,
NULL,
gst_swfdecbuffer_class_init,
NULL,
NULL,
sizeof (GstSwfdecBuffer),
0,
NULL,
NULL
};
_gst_swfdecbuffer_type = g_type_register_static (GST_TYPE_BUFFER,
"GstSwfdecBuffer", &swfdecbuffer_info, 0);
}
return _gst_swfdecbuffer_type;
}
static void
gst_swfdecbuffer_class_init (gpointer g_class, gpointer class_data)
{
GstBufferClass *swfdecbuffer_class = GST_BUFFER_CLASS (g_class);
swfdecbuffer_class->mini_object_class.finalize =
(GstMiniObjectFinalizeFunction) gst_swfdecbuffer_finalize;
buffer_parent_class = g_type_class_ref (GST_TYPE_BUFFER);
}
static void
gst_swfdecbuffer_finalize (GstSwfdecBuffer * swfdecbuffer)
{
g_return_if_fail (swfdecbuffer != NULL);
GST_LOG ("finalize %p", swfdecbuffer);
swfdec_buffer_unref (swfdecbuffer->swfdec_buffer);
((GstMiniObjectClass *) buffer_parent_class)->
finalize ((GstMiniObject *) swfdecbuffer);
}
/* GstSwfdec */
GType GType
gst_swfdec_get_type (void) gst_swfdec_get_type (void)
{ {
@ -242,6 +311,19 @@ gst_swfdec_buffer_to_swf (GstBuffer * buffer)
return sbuf; return sbuf;
} }
static GstBuffer *
gst_swfdec_buffer_from_swf (SwfdecBuffer * buffer)
{
GstSwfdecBuffer *buf;
buf = (GstSwfdecBuffer *) gst_mini_object_new (gst_swfdecbuffer_get_type ());
GST_BUFFER_DATA (buf) = buffer->data;
GST_BUFFER_SIZE (buf) = buffer->length;
buf->swfdec_buffer = buffer;
return GST_BUFFER (buf);
}
GstFlowReturn GstFlowReturn
gst_swfdec_chain (GstPad * pad, GstBuffer * buffer) gst_swfdec_chain (GstPad * pad, GstBuffer * buffer)
{ {
@ -410,23 +492,18 @@ gst_swfdec_render (GstSwfdec * swfdec, int ret)
swfdec->skip_index = swfdec->skip_frames - 1; swfdec->skip_index = swfdec->skip_frames - 1;
videobuf = gst_buffer_new (); videobuf = gst_swfdec_buffer_from_swf (video_buffer);
GST_BUFFER_DATA (videobuf) = video_buffer->data;
GST_BUFFER_SIZE (videobuf) = video_buffer->length;
GST_BUFFER_TIMESTAMP (videobuf) = swfdec->timestamp; GST_BUFFER_TIMESTAMP (videobuf) = swfdec->timestamp;
gst_buffer_set_caps (videobuf, GST_PAD_CAPS (swfdec->videopad)); gst_buffer_set_caps (videobuf, GST_PAD_CAPS (swfdec->videopad));
gst_pad_push (swfdec->videopad, videobuf); gst_pad_push (swfdec->videopad, videobuf);
} }
audio_buffer = swfdec_render_get_audio (swfdec->decoder); audio_buffer = swfdec_render_get_audio (swfdec->decoder);
if (audio_buffer) { if (audio_buffer) {
audiobuf = gst_buffer_new (); audiobuf = gst_swfdec_buffer_from_swf (audio_buffer);
GST_BUFFER_DATA (audiobuf) = audio_buffer->data;
GST_BUFFER_SIZE (audiobuf) = audio_buffer->length;
GST_BUFFER_TIMESTAMP (audiobuf) = swfdec->timestamp; GST_BUFFER_TIMESTAMP (audiobuf) = swfdec->timestamp;
gst_buffer_set_caps (audiobuf, GST_PAD_CAPS (swfdec->audiopad)); gst_buffer_set_caps (audiobuf, GST_PAD_CAPS (swfdec->audiopad));