From: Thibault Saunier Date: Thu, 24 Sep 2015 13:51:28 +0000 (+0200) Subject: gtk: Do not forget to release OBJECT_LOCK on error path X-Git-Tag: 1.19.3~509^2~1701^2~33 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f08f8d77f8dd14daf9d2a3cb79ef35d53546c993;p=platform%2Fupstream%2Fgstreamer.git gtk: Do not forget to release OBJECT_LOCK on error path https://bugzilla.gnome.org/show_bug.cgi?id=755542 --- diff --git a/ext/gtk/gstgtkbasesink.c b/ext/gtk/gstgtkbasesink.c index 9ce6f7c..57c5a06 100644 --- a/ext/gtk/gstgtkbasesink.c +++ b/ext/gtk/gstgtkbasesink.c @@ -347,7 +347,7 @@ gst_gtk_base_sink_stop (GstBaseSink * bsink) } static void -gst_gtk_widget_show_all_and_unref (GtkWidget *widget) +gst_gtk_widget_show_all_and_unref (GtkWidget * widget) { gtk_widget_show_all (widget); g_object_unref (widget); @@ -378,7 +378,8 @@ gst_gtk_base_sink_change_state (GstElement * element, GstStateChange transition) GST_OBJECT_UNLOCK (gtk_sink); if (window) - gst_gtk_invoke_on_main ((GThreadFunc) gst_gtk_widget_show_all_and_unref, window); + gst_gtk_invoke_on_main ((GThreadFunc) gst_gtk_widget_show_all_and_unref, + window); break; } @@ -437,9 +438,10 @@ gst_gtk_base_sink_set_caps (GstBaseSink * bsink, GstCaps * caps) return FALSE; } - if (!gtk_gst_base_widget_set_format (gtk_sink->widget, >k_sink->v_info)) + if (!gtk_gst_base_widget_set_format (gtk_sink->widget, >k_sink->v_info)) { + GST_OBJECT_UNLOCK (gtk_sink); return FALSE; - + } GST_OBJECT_UNLOCK (gtk_sink); return TRUE;