diff --git a/ChangeLog b/ChangeLog index f460b17ecf..acc2ae2760 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,12 @@ +2006-02-05 Julien MOUTTE + + * libs/gst/base/gstcollectpads.c: (gst_collect_pads_finalize), + (gst_collect_pads_add_pad), (gst_collect_pads_remove_pad), + (gst_collect_pads_start), (gst_collect_pads_stop), + (gst_collect_pads_event): Collectpads now holds a reference + to the GstPad that was added. Indeed we don't want to look + at pads that might just go away with no warning... + 2006-02-05 Julien MOUTTE * libs/gst/base/gstcollectpads.c: (gst_collect_pads_add_pad), diff --git a/libs/gst/base/gstcollectpads.c b/libs/gst/base/gstcollectpads.c index 2be453c37c..ca9a8dc78e 100644 --- a/libs/gst/base/gstcollectpads.c +++ b/libs/gst/base/gstcollectpads.c @@ -112,10 +112,23 @@ gst_collect_pads_init (GstCollectPads * pads, GstCollectPadsClass * g_class) static void gst_collect_pads_finalize (GObject * object) { + GSList *collected; GstCollectPads *pads = GST_COLLECT_PADS (object); gst_collect_pads_stop (pads); g_cond_free (pads->cond); + + /* Remove pads */ + for (collected = pads->data; collected; collected = g_slist_next (collected)) { + GstCollectData *pdata = (GstCollectData *) collected->data; + + if (pdata->pad) { + gst_object_unref (pdata->pad); + } + } + /* Free pads list */ + g_slist_free (pads->data); + /* FIXME, free data */ G_OBJECT_CLASS (parent_class)->finalize (object); @@ -194,7 +207,7 @@ gst_collect_pads_add_pad (GstCollectPads * pads, GstPad * pad, guint size) data = g_malloc0 (size); data->collect = pads; - data->pad = pad; + data->pad = gst_object_ref (pad); data->buffer = NULL; gst_segment_init (&data->segment, GST_FORMAT_UNDEFINED); data->abidata.ABI.flushing = FALSE; @@ -246,6 +259,7 @@ gst_collect_pads_remove_pad (GstCollectPads * pads, GstPad * pad) if (list) { g_free (list->data); pads->data = g_slist_delete_link (pads->data, list); + gst_object_unref (pad); } pads->numpads--; /* FIXME : if the pad has data queued we should decrease the number of