mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-01 21:18:52 +00:00
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:
parent
27988d4031
commit
dfa22f08c6
2 changed files with 92 additions and 7 deletions
|
@ -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>
|
||||
|
||||
* ext/libmms/gstmms.c:
|
||||
|
|
|
@ -113,6 +113,75 @@ static void gst_swfdec_render (GstSwfdec * swfdec, int ret);
|
|||
static GstElementClass *parent_class = NULL;
|
||||
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
|
||||
gst_swfdec_get_type (void)
|
||||
{
|
||||
|
@ -242,6 +311,19 @@ gst_swfdec_buffer_to_swf (GstBuffer * buffer)
|
|||
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
|
||||
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;
|
||||
|
||||
videobuf = gst_buffer_new ();
|
||||
GST_BUFFER_DATA (videobuf) = video_buffer->data;
|
||||
GST_BUFFER_SIZE (videobuf) = video_buffer->length;
|
||||
videobuf = gst_swfdec_buffer_from_swf (video_buffer);
|
||||
GST_BUFFER_TIMESTAMP (videobuf) = swfdec->timestamp;
|
||||
gst_buffer_set_caps (videobuf, GST_PAD_CAPS (swfdec->videopad));
|
||||
|
||||
gst_pad_push (swfdec->videopad, videobuf);
|
||||
|
||||
}
|
||||
|
||||
audio_buffer = swfdec_render_get_audio (swfdec->decoder);
|
||||
|
||||
if (audio_buffer) {
|
||||
|
||||
audiobuf = gst_buffer_new ();
|
||||
GST_BUFFER_DATA (audiobuf) = audio_buffer->data;
|
||||
GST_BUFFER_SIZE (audiobuf) = audio_buffer->length;
|
||||
audiobuf = gst_swfdec_buffer_from_swf (audio_buffer);
|
||||
GST_BUFFER_TIMESTAMP (audiobuf) = swfdec->timestamp;
|
||||
gst_buffer_set_caps (audiobuf, GST_PAD_CAPS (swfdec->audiopad));
|
||||
|
||||
|
|
Loading…
Reference in a new issue