2004-02-15 Julien MOUTTE <julien@moutte.net>
+ * gst/switch/gstswitch.c: (gst_switch_loop): More fixes for
+ correct data refcounting.
+
+2004-02-15 Julien MOUTTE <julien@moutte.net>
+
* gst/switch/gstswitch.c: (gst_switch_change_state),
(gst_switch_class_init): Cleaning the sinkpads correctly on state
change, mostly the EOS flag.
switchpad = g_list_nth_data (gstswitch->sinkpads, gstswitch->active_sinkpad);
if (switchpad && switchpad->data) {
+ GstData *data = switchpad->data;
/* Loose our reference to that data */
gst_data_unref (switchpad->data);
+ switchpad->data = NULL;
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, gstswitch,
"using data from active pad %p",
switchpad->sinkpad);
- if (GST_IS_EVENT (switchpad->data)) {
- GstEvent *event = GST_EVENT (switchpad->data);
+ if (GST_IS_EVENT (data)) {
+ GstEvent *event = GST_EVENT (data);
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, gstswitch,
"handling event from active pad %p",
switchpad->sinkpad);
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, gstswitch,
"pushing data from active pad %p to %p",
switchpad->sinkpad, gstswitch->srcpad);
- gst_pad_push (gstswitch->srcpad, switchpad->data);
+ gst_pad_push (gstswitch->srcpad, data);
}
/* Mark this data as forwarded so that it won't get unrefed on next poll */
switchpad->forwarded = TRUE;
- switchpad->data = NULL;
}
}