autoconvert: Simple fixes.

Free the plugin feature list on dispose.
Output a debug message when downstream returns a fatal flow result
Fix awkward wording in a debug warning.
This commit is contained in:
Jan Schmidt 2009-10-24 11:05:47 +01:00
parent de829eb7d0
commit 77e017143e

View file

@ -178,7 +178,7 @@ gst_auto_convert_class_init (GstAutoConvertClass * klass)
GObjectClass *gobject_class = (GObjectClass *) klass; GObjectClass *gobject_class = (GObjectClass *) klass;
GstElementClass *gstelement_class = (GstElementClass *) klass; GstElementClass *gstelement_class = (GstElementClass *) klass;
gobject_class->dispose = gst_auto_convert_dispose; gobject_class->dispose = GST_DEBUG_FUNCPTR (gst_auto_convert_dispose);
gobject_class->set_property = gst_auto_convert_set_property; gobject_class->set_property = gst_auto_convert_set_property;
gobject_class->get_property = gst_auto_convert_get_property; gobject_class->get_property = gst_auto_convert_get_property;
@ -248,6 +248,11 @@ gst_auto_convert_dispose (GObject * object)
NULL); NULL);
g_list_free (autoconvert->cached_events); g_list_free (autoconvert->cached_events);
autoconvert->cached_events = NULL; autoconvert->cached_events = NULL;
if (autoconvert->factories) {
gst_plugin_feature_list_free (autoconvert->factories);
autoconvert->factories = NULL;
}
GST_AUTOCONVERT_UNLOCK (autoconvert); GST_AUTOCONVERT_UNLOCK (autoconvert);
G_OBJECT_CLASS (parent_class)->dispose (object); G_OBJECT_CLASS (parent_class)->dispose (object);
@ -949,6 +954,14 @@ gst_auto_convert_sink_chain (GstPad * pad, GstBuffer * buffer)
ret = gst_pad_push (internal_srcpad, buffer); ret = gst_pad_push (internal_srcpad, buffer);
gst_object_unref (internal_srcpad); gst_object_unref (internal_srcpad);
if (GST_FLOW_IS_FATAL (ret)) {
GstElement *child = gst_auto_convert_get_subelement (autoconvert);
GST_DEBUG_OBJECT (autoconvert,
"Child element %" GST_PTR_FORMAT "returned flow %s", child,
gst_flow_get_name (ret));
if (child)
gst_object_unref (child);
}
} else { } else {
GST_ERROR_OBJECT (autoconvert, "Got buffer without an negotiated element," GST_ERROR_OBJECT (autoconvert, "Got buffer without an negotiated element,"
" returning not-negotiated"); " returning not-negotiated");
@ -1221,8 +1234,8 @@ gst_auto_convert_src_event (GstPad * pad, GstEvent * event)
ret = gst_pad_push_event (internal_sinkpad, event); ret = gst_pad_push_event (internal_sinkpad, event);
gst_object_unref (internal_sinkpad); gst_object_unref (internal_sinkpad);
} else { } else {
GST_WARNING_OBJECT (autoconvert, "Got event while not element was selected," GST_WARNING_OBJECT (autoconvert,
"letting through"); "Got upstream event while no element was selected," "forwarding.");
ret = gst_pad_push_event (autoconvert->sinkpad, event); ret = gst_pad_push_event (autoconvert->sinkpad, event);
} }
@ -1248,8 +1261,8 @@ gst_auto_convert_src_query (GstPad * pad, GstQuery * query)
gst_object_unref (sub_srcpad); gst_object_unref (sub_srcpad);
gst_object_unref (subelement); gst_object_unref (subelement);
} else { } else {
GST_WARNING_OBJECT (autoconvert, "Got query while not element was selected," GST_WARNING_OBJECT (autoconvert,
"letting through"); "Got upstream query while no element was selected," "forwarding.");
ret = gst_pad_peer_query (autoconvert->sinkpad, query); ret = gst_pad_peer_query (autoconvert->sinkpad, query);
} }