mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 14:38:48 +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>
|
2005-12-11 Edgard Lima <edgard.lima@indt.org.br>
|
||||||
|
|
||||||
* ext/libmms/gstmms.c:
|
* ext/libmms/gstmms.c:
|
||||||
|
|
|
@ -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));
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue