From 790235e29f601091b847e7118f0f340c0e8eddba Mon Sep 17 00:00:00 2001 From: Stefan Kost Date: Mon, 20 Apr 2009 09:49:32 +0300 Subject: [PATCH] fpsdisplay: remove iface proxy When we get bus messages for setting the xid, we have the real sink element instance as message_src. No need to proxy the xoverlay iface therefore (autovideosink does not do it either). Also we don't need to rewrite the message src of all messages from that sink. --- gst/debugutils/fpsdisplaysink.c | 72 +-------------------------------- 1 file changed, 1 insertion(+), 71 deletions(-) diff --git a/gst/debugutils/fpsdisplaysink.c b/gst/debugutils/fpsdisplaysink.c index 4cc9da0157..0768b8a2d1 100644 --- a/gst/debugutils/fpsdisplaysink.c +++ b/gst/debugutils/fpsdisplaysink.c @@ -22,7 +22,7 @@ * |[ * gst-launch videotestsrc ! fpsdisplaysink * gst-launch videotestsrc ! fpsdisplaysink text-overlay=false - * gst-launch filesrc location=video.avi ! decodebin2 name=d ! queue ! fpsdisplaysink d. ! queue ! fakesink sync=true + * gst-launch filesrc location=video.avi ! decodebin2 name=d ! queue ! fpsdisplaysink d. ! queue ! fakesink sync=true * ]| */ /* FIXME: @@ -92,64 +92,11 @@ static void fps_display_sink_get_property (GObject * object, guint prop_id, GValue * value, GParamSpec * pspec); static void fps_display_sink_dispose (GObject * object); -static gboolean -fps_display_sink_interface_supported (GstImplementsInterface * iface, - GType type) -{ - g_assert (type == GST_TYPE_X_OVERLAY); - return TRUE; -} - -static void -fps_display_sink_interface_init (GstImplementsInterfaceClass * klass) -{ - klass->supported = fps_display_sink_interface_supported; -} - -static void -fps_display_sink_set_xwindow_id (GstXOverlay * overlay, gulong xwindow_id) -{ - FPSDisplaySink *self = FPS_DISPLAY_SINK (overlay); - - gst_x_overlay_set_xwindow_id (GST_X_OVERLAY (self->priv->xvimagesink), - xwindow_id); -} - -static void -fps_display_sink_expose (GstXOverlay * overlay) -{ - FPSDisplaySink *self = FPS_DISPLAY_SINK (overlay); - - gst_x_overlay_expose (GST_X_OVERLAY (self->priv->xvimagesink)); -} - -static void -fps_display_sink_xoverlay_init (GstXOverlayClass * iface) -{ - iface->set_xwindow_id = fps_display_sink_set_xwindow_id; - iface->expose = fps_display_sink_expose; -} - -static void -fps_display_sink_handle_message (GstBin * bin, GstMessage * message) -{ - FPSDisplaySink *self = FPS_DISPLAY_SINK (bin); - - if (GST_MESSAGE_SRC (message) != NULL && - GST_MESSAGE_SRC (message) == GST_OBJECT (self->priv->xvimagesink)) { - gst_object_unref (GST_MESSAGE_SRC (message)); - GST_MESSAGE_SRC (message) = gst_object_ref (GST_OBJECT (bin)); - } - - GST_BIN_CLASS (parent_class)->handle_message (bin, message); -} - static void fps_display_sink_class_init (FPSDisplaySinkClass * klass) { GObjectClass *gobject_klass = G_OBJECT_CLASS (klass); GstElementClass *gstelement_klass = GST_ELEMENT_CLASS (klass); - GstBinClass *gstbin_klass = GST_BIN_CLASS (klass); parent_class = g_type_class_peek_parent (klass); @@ -168,8 +115,6 @@ fps_display_sink_class_init (FPSDisplaySinkClass * klass) gstelement_klass->change_state = fps_display_sink_change_state; - gstbin_klass->handle_message = fps_display_sink_handle_message; - gst_element_class_add_pad_template (gstelement_klass, gst_static_pad_template_get (&fps_display_sink_template)); @@ -487,24 +432,9 @@ fps_display_sink_get_type (void) 0, (GInstanceInitFunc) fps_display_sink_init, }; - static const GInterfaceInfo iface_info = { - (GInterfaceInitFunc) fps_display_sink_interface_init, - NULL, - NULL, - }; - static const GInterfaceInfo overlay_info = { - (GInterfaceInitFunc) fps_display_sink_xoverlay_init, - NULL, - NULL, - }; fps_display_sink_type = g_type_register_static (GST_TYPE_BIN, "FPSDisplaySink", &fps_display_sink_info, 0); - - g_type_add_interface_static (fps_display_sink_type, - GST_TYPE_IMPLEMENTS_INTERFACE, &iface_info); - g_type_add_interface_static (fps_display_sink_type, GST_TYPE_X_OVERLAY, - &overlay_info); } return fps_display_sink_type;