mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-04-26 06:54:49 +00:00
plugins/elements/gstoutputselector.c: Fix changing to same pad twice before a chain call.
Original commit message from CVS: * plugins/elements/gstoutputselector.c: Fix changing to same pad twice before a chain call.
This commit is contained in:
parent
7b742d1cf4
commit
eaff78cc08
1 changed files with 5 additions and 0 deletions
|
@ -210,6 +210,7 @@ gst_output_selector_set_property (GObject * object, guint prop_id,
|
||||||
g_value_get_string (value));
|
g_value_get_string (value));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
GST_LOG ("Activating pad %s", g_value_get_string (value));
|
||||||
if (next_pad != sel->active_srcpad) {
|
if (next_pad != sel->active_srcpad) {
|
||||||
/* switch to new srcpad in next chain run */
|
/* switch to new srcpad in next chain run */
|
||||||
if (sel->pending_srcpad != NULL) {
|
if (sel->pending_srcpad != NULL) {
|
||||||
|
@ -219,6 +220,10 @@ gst_output_selector_set_property (GObject * object, guint prop_id,
|
||||||
sel->pending_srcpad = next_pad;
|
sel->pending_srcpad = next_pad;
|
||||||
} else {
|
} else {
|
||||||
GST_INFO ("pad already active");
|
GST_INFO ("pad already active");
|
||||||
|
if (sel->pending_srcpad != NULL) {
|
||||||
|
gst_object_unref (sel->pending_srcpad);
|
||||||
|
sel->pending_srcpad = NULL;
|
||||||
|
}
|
||||||
gst_object_unref (next_pad);
|
gst_object_unref (next_pad);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue