gst/playback/gstplaybasebin.c: Remove hack to get rid of assert and get rid of unlinked signals properly.

Original commit message from CVS:
* gst/playback/gstplaybasebin.c: (group_destroy):
Remove hack to get rid of assert and get rid of unlinked
signals properly.
This commit is contained in:
Ronald S. Bultje 2005-01-09 19:41:07 +00:00
parent 7506b79230
commit 2ad3dc3e48
2 changed files with 17 additions and 17 deletions

View file

@ -1,3 +1,9 @@
2005-01-09 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
* gst/playback/gstplaybasebin.c: (group_destroy):
Remove hack to get rid of assert and get rid of unlinked
signals properly.
2005-01-09 Ronald S. Bultje <rbultje@ronald.bitfreak.net> 2005-01-09 Ronald S. Bultje <rbultje@ronald.bitfreak.net>
* gst/playback/gstplaybasebin.c: (setup_source): * gst/playback/gstplaybasebin.c: (setup_source):

View file

@ -294,17 +294,21 @@ group_destroy (GstPlayBaseGroup * group)
/* remove the preroll queues */ /* remove the preroll queues */
for (n = 0; n < NUM_TYPES; n++) { for (n = 0; n < NUM_TYPES; n++) {
GstElement *element = group->type[n].preroll; GstElement *element = group->type[n].preroll;
GstPad *pad;
guint sig_id;
GstElement *fakesrc; GstElement *fakesrc;
const GList *item; const GList *item;
if (!element) if (!element)
continue; continue;
/* have to unlink the unlink handler first because else we /* remove any fakesrc elements for this preroll element */
* are going to link an element in the finalize handler */ for (item = gst_element_get_pad_list (group->type[n].selector);
pad = gst_element_get_pad (element, "sink"); item != NULL; item = item->next) {
GstPad *pad = GST_PAD (item->data);
guint sig_id;
if (GST_PAD_DIRECTION (pad) != GST_PAD_SINK)
continue;
sig_id = sig_id =
GPOINTER_TO_INT (g_object_get_data (G_OBJECT (pad), "unlinked_id")); GPOINTER_TO_INT (g_object_get_data (G_OBJECT (pad), "unlinked_id"));
@ -314,22 +318,12 @@ group_destroy (GstPlayBaseGroup * group)
g_object_set_data (G_OBJECT (pad), "unlinked_id", GINT_TO_POINTER (0)); g_object_set_data (G_OBJECT (pad), "unlinked_id", GINT_TO_POINTER (0));
} }
/* remove any fakesrc elements for this preroll element */
for (item = gst_element_get_pad_list (group->type[n].selector);
item != NULL; item = item->next) {
GstPad *pad = item->data;
if (GST_PAD_DIRECTION (pad) != GST_PAD_SINK)
continue;
fakesrc = (GstElement *) g_object_get_data (G_OBJECT (pad), "fakesrc"); fakesrc = (GstElement *) g_object_get_data (G_OBJECT (pad), "fakesrc");
if (fakesrc != NULL) { if (fakesrc != NULL) {
GST_LOG ("removing fakesrc from %s:%s", GST_LOG ("removing fakesrc from %s:%s",
gst_pad_get_name (pad), gst_pad_get_name (pad),
GST_ELEMENT_NAME (gst_pad_get_parent (pad))); GST_ELEMENT_NAME (gst_pad_get_parent (pad)));
gst_bin_remove (GST_BIN (play_base_bin->thread), fakesrc); gst_bin_remove (GST_BIN (play_base_bin->thread), fakesrc);
} else if (GST_PAD_PEER (pad)) {
gst_pad_unlink (GST_PAD_PEER (pad), pad);
} }
} }