diff options
Diffstat (limited to 'gst/proxy')
-rw-r--r-- | gst/proxy/gstproxy-priv.h | 3 | ||||
-rw-r--r-- | gst/proxy/gstproxysink.c | 56 | ||||
-rw-r--r-- | gst/proxy/gstproxysink.h | 9 | ||||
-rw-r--r-- | gst/proxy/gstproxysrc.c | 78 | ||||
-rw-r--r-- | gst/proxy/gstproxysrc.h | 17 |
5 files changed, 75 insertions, 88 deletions
diff --git a/gst/proxy/gstproxy-priv.h b/gst/proxy/gstproxy-priv.h index d15da9aa5..e2b50ddea 100644 --- a/gst/proxy/gstproxy-priv.h +++ b/gst/proxy/gstproxy-priv.h @@ -26,10 +26,13 @@ G_BEGIN_DECLS +G_GNUC_INTERNAL void gst_proxy_sink_set_proxysrc (GstProxySink *sink, GstProxySrc *src); +G_GNUC_INTERNAL GstPad* gst_proxy_sink_get_internal_sinkpad (GstProxySink *sink); +G_GNUC_INTERNAL GstPad* gst_proxy_src_get_internal_srcpad (GstProxySrc *src); G_END_DECLS diff --git a/gst/proxy/gstproxysink.c b/gst/proxy/gstproxysink.c index 8976783df..b1a015d9e 100644 --- a/gst/proxy/gstproxysink.c +++ b/gst/proxy/gstproxysink.c @@ -48,15 +48,6 @@ static GstStaticPadTemplate sink_template = GST_STATIC_PAD_TEMPLATE ("sink", GST_PAD_ALWAYS, GST_STATIC_CAPS_ANY); -struct _GstProxySinkPrivate -{ - GstPad *sinkpad; - /* The proxysrc that we push events, buffers, queries to */ - GWeakRef proxysrc; - /* Whether there are sticky events pending */ - gboolean pending_sticky_events; -}; - /* We're not subclassing from basesink because we don't want any of the special * handling it has for events/queries/etc. We just pass-through everything. */ @@ -83,8 +74,6 @@ gst_proxy_sink_class_init (GstProxySinkClass * klass) GST_DEBUG_CATEGORY_INIT (gst_proxy_sink_debug, "proxysink", 0, "proxy sink"); - g_type_class_add_private (klass, sizeof (GstProxySinkPrivate)); - gstelement_class->change_state = gst_proxy_sink_change_state; gst_element_class_add_pad_template (gstelement_class, @@ -98,19 +87,16 @@ gst_proxy_sink_class_init (GstProxySinkClass * klass) static void gst_proxy_sink_init (GstProxySink * self) { - self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GST_TYPE_PROXY_SINK, - GstProxySinkPrivate); - self->priv->sinkpad = - gst_pad_new_from_static_template (&sink_template, "sink"); - gst_pad_set_chain_function (self->priv->sinkpad, + self->sinkpad = gst_pad_new_from_static_template (&sink_template, "sink"); + gst_pad_set_chain_function (self->sinkpad, GST_DEBUG_FUNCPTR (gst_proxy_sink_sink_chain)); - gst_pad_set_chain_list_function (self->priv->sinkpad, + gst_pad_set_chain_list_function (self->sinkpad, GST_DEBUG_FUNCPTR (gst_proxy_sink_sink_chain_list)); - gst_pad_set_event_function (self->priv->sinkpad, + gst_pad_set_event_function (self->sinkpad, GST_DEBUG_FUNCPTR (gst_proxy_sink_sink_event)); - gst_pad_set_query_function (self->priv->sinkpad, + gst_pad_set_query_function (self->sinkpad, GST_DEBUG_FUNCPTR (gst_proxy_sink_sink_query)); - gst_element_add_pad (GST_ELEMENT (self), self->priv->sinkpad); + gst_element_add_pad (GST_ELEMENT (self), self->sinkpad); } static GstStateChangeReturn @@ -123,7 +109,7 @@ gst_proxy_sink_change_state (GstElement * element, GstStateChange transition) switch (transition) { case GST_STATE_CHANGE_READY_TO_PAUSED: - self->priv->pending_sticky_events = FALSE; + self->pending_sticky_events = FALSE; break; default: break; @@ -144,7 +130,7 @@ gst_proxy_sink_sink_query (GstPad * pad, GstObject * parent, GstQuery * query) GST_LOG_OBJECT (pad, "Handling query of type '%s'", gst_query_type_get_name (GST_QUERY_TYPE (query))); - src = g_weak_ref_get (&self->priv->proxysrc); + src = g_weak_ref_get (&self->proxysrc); if (src) { GstPad *srcpad; srcpad = gst_proxy_src_get_internal_srcpad (src); @@ -185,18 +171,18 @@ gst_proxy_sink_sink_event (GstPad * pad, GstObject * parent, GstEvent * event) GST_LOG_OBJECT (pad, "Got %s event", GST_EVENT_TYPE_NAME (event)); if (GST_EVENT_TYPE (event) == GST_EVENT_FLUSH_STOP) - self->priv->pending_sticky_events = FALSE; + self->pending_sticky_events = FALSE; - src = g_weak_ref_get (&self->priv->proxysrc); + src = g_weak_ref_get (&self->proxysrc); if (src) { GstPad *srcpad; srcpad = gst_proxy_src_get_internal_srcpad (src); - if (sticky && self->priv->pending_sticky_events) { + if (sticky && self->pending_sticky_events) { CopyStickyEventsData data = { srcpad, GST_FLOW_OK }; gst_pad_sticky_events_foreach (pad, copy_sticky_events, &data); - self->priv->pending_sticky_events = data.ret != GST_FLOW_OK; + self->pending_sticky_events = data.ret != GST_FLOW_OK; } ret = gst_pad_push_event (srcpad, event); @@ -204,7 +190,7 @@ gst_proxy_sink_sink_event (GstPad * pad, GstObject * parent, GstEvent * event) gst_object_unref (src); if (!ret && sticky) { - self->priv->pending_sticky_events = TRUE; + self->pending_sticky_events = TRUE; ret = TRUE; } } else @@ -222,16 +208,16 @@ gst_proxy_sink_sink_chain (GstPad * pad, GstObject * parent, GstBuffer * buffer) GST_LOG_OBJECT (pad, "Chaining buffer %p", buffer); - src = g_weak_ref_get (&self->priv->proxysrc); + src = g_weak_ref_get (&self->proxysrc); if (src) { GstPad *srcpad; srcpad = gst_proxy_src_get_internal_srcpad (src); - if (self->priv->pending_sticky_events) { + if (self->pending_sticky_events) { CopyStickyEventsData data = { srcpad, GST_FLOW_OK }; gst_pad_sticky_events_foreach (pad, copy_sticky_events, &data); - self->priv->pending_sticky_events = data.ret != GST_FLOW_OK; + self->pending_sticky_events = data.ret != GST_FLOW_OK; } ret = gst_pad_push (srcpad, buffer); @@ -258,16 +244,16 @@ gst_proxy_sink_sink_chain_list (GstPad * pad, GstObject * parent, GST_LOG_OBJECT (pad, "Chaining buffer list %p", list); - src = g_weak_ref_get (&self->priv->proxysrc); + src = g_weak_ref_get (&self->proxysrc); if (src) { GstPad *srcpad; srcpad = gst_proxy_src_get_internal_srcpad (src); - if (self->priv->pending_sticky_events) { + if (self->pending_sticky_events) { CopyStickyEventsData data = { srcpad, GST_FLOW_OK }; gst_pad_sticky_events_foreach (pad, copy_sticky_events, &data); - self->priv->pending_sticky_events = data.ret != GST_FLOW_OK; + self->pending_sticky_events = data.ret != GST_FLOW_OK; } ret = gst_pad_push_list (srcpad, list); @@ -290,12 +276,12 @@ GstPad * gst_proxy_sink_get_internal_sinkpad (GstProxySink * self) { g_return_val_if_fail (self, NULL); - return gst_object_ref (self->priv->sinkpad); + return gst_object_ref (self->sinkpad); } void gst_proxy_sink_set_proxysrc (GstProxySink * self, GstProxySrc * src) { g_return_if_fail (self); - g_weak_ref_set (&self->priv->proxysrc, src); + g_weak_ref_set (&self->proxysrc, src); } diff --git a/gst/proxy/gstproxysink.h b/gst/proxy/gstproxysink.h index 9952cfdef..9da4b3917 100644 --- a/gst/proxy/gstproxysink.h +++ b/gst/proxy/gstproxysink.h @@ -41,8 +41,13 @@ struct _GstProxySink { GstElement parent; /* < private > */ - GstProxySinkPrivate *priv; - gpointer _gst_reserved[GST_PADDING]; + GstPad *sinkpad; + + /* The proxysrc that we push events, buffers, queries to */ + GWeakRef proxysrc; + + /* Whether there are sticky events pending */ + gboolean pending_sticky_events; }; struct _GstProxySinkClass { diff --git a/gst/proxy/gstproxysrc.c b/gst/proxy/gstproxysrc.c index e2c4af0ba..2d016513f 100644 --- a/gst/proxy/gstproxysrc.c +++ b/gst/proxy/gstproxysrc.c @@ -93,20 +93,6 @@ enum PROP_PROXYSINK, }; -struct _GstProxySrcPrivate -{ - /* Queue to hold buffers from proxysink */ - GstElement *queue; - /* Source pad of the above queue and the proxysrc element itself */ - GstPad *srcpad; - /* Our internal srcpad that proxysink pushes buffers/events/queries into */ - GstPad *internal_srcpad; - /* An unlinked dummy sinkpad; see gst_proxy_src_init() */ - GstPad *dummy_sinkpad; - /* The matching proxysink; queries and events are sent to its sinkpad */ - GWeakRef proxysink; -}; - /* We're not subclassing from basesrc because we don't want any of the special * handling it has for events/queries/etc. We just pass-through everything. */ @@ -132,7 +118,7 @@ gst_proxy_src_get_property (GObject * object, guint prop_id, GValue * value, switch (prop_id) { case PROP_PROXYSINK: - g_value_take_object (value, g_weak_ref_get (&self->priv->proxysink)); + g_value_take_object (value, g_weak_ref_get (&self->proxysink)); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, spec); @@ -153,16 +139,16 @@ gst_proxy_src_set_property (GObject * object, guint prop_id, if (sink == NULL) { /* Unset proxysrc property on the existing proxysink to break the * connection in that direction */ - GstProxySink *old_sink = g_weak_ref_get (&self->priv->proxysink); + GstProxySink *old_sink = g_weak_ref_get (&self->proxysink); if (old_sink) { gst_proxy_sink_set_proxysrc (old_sink, NULL); g_object_unref (old_sink); } - g_weak_ref_set (&self->priv->proxysink, NULL); + g_weak_ref_set (&self->proxysink, NULL); } else { /* Set proxysrc property on the new proxysink to point to us */ gst_proxy_sink_set_proxysrc (sink, self); - g_weak_ref_set (&self->priv->proxysink, sink); + g_weak_ref_set (&self->proxysink, sink); g_object_unref (sink); } break; @@ -179,8 +165,6 @@ gst_proxy_src_class_init (GstProxySrcClass * klass) GST_DEBUG_CATEGORY_INIT (gst_proxy_src_debug, "proxysrc", 0, "proxy sink"); - g_type_class_add_private (klass, sizeof (GstProxySrcPrivate)); - gobject_class->dispose = gst_proxy_src_dispose; gobject_class->get_property = gst_proxy_src_get_property; @@ -207,34 +191,30 @@ gst_proxy_src_init (GstProxySrc * self) GST_OBJECT_FLAG_SET (self, GST_ELEMENT_FLAG_SOURCE); - self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, GST_TYPE_PROXY_SRC, - GstProxySrcPrivate); - /* We feed incoming buffers into a queue to decouple the downstream pipeline * from the upstream pipeline */ - self->priv->queue = gst_element_factory_make ("queue", NULL); - gst_bin_add (GST_BIN (self), self->priv->queue); + self->queue = gst_element_factory_make ("queue", NULL); + gst_bin_add (GST_BIN (self), self->queue); - srcpad = gst_element_get_static_pad (self->priv->queue, "src"); + srcpad = gst_element_get_static_pad (self->queue, "src"); templ = gst_static_pad_template_get (&src_template); - self->priv->srcpad = gst_ghost_pad_new_from_template ("src", srcpad, templ); + self->srcpad = gst_ghost_pad_new_from_template ("src", srcpad, templ); gst_object_unref (templ); gst_object_unref (srcpad); - gst_element_add_pad (GST_ELEMENT (self), self->priv->srcpad); + gst_element_add_pad (GST_ELEMENT (self), self->srcpad); /* A dummy sinkpad that's not actually used anywhere * Explanation for why this is needed is below */ - self->priv->dummy_sinkpad = gst_pad_new ("dummy_sinkpad", GST_PAD_SINK); - gst_object_set_parent (GST_OBJECT (self->priv->dummy_sinkpad), - GST_OBJECT (self)); - - self->priv->internal_srcpad = gst_pad_new ("internal_src", GST_PAD_SRC); - gst_object_set_parent (GST_OBJECT (self->priv->internal_srcpad), - GST_OBJECT (self->priv->dummy_sinkpad)); - gst_pad_set_event_function (self->priv->internal_srcpad, + self->dummy_sinkpad = gst_pad_new ("dummy_sinkpad", GST_PAD_SINK); + gst_object_set_parent (GST_OBJECT (self->dummy_sinkpad), GST_OBJECT (self)); + + self->internal_srcpad = gst_pad_new ("internal_src", GST_PAD_SRC); + gst_object_set_parent (GST_OBJECT (self->internal_srcpad), + GST_OBJECT (self->dummy_sinkpad)); + gst_pad_set_event_function (self->internal_srcpad, gst_proxy_src_internal_src_event); - gst_pad_set_query_function (self->priv->internal_srcpad, + gst_pad_set_query_function (self->internal_srcpad, gst_proxy_src_internal_src_query); /* We need to link internal_srcpad from proxysink to the sinkpad of our @@ -243,8 +223,8 @@ gst_proxy_src_init (GstProxySrc * self) * the parent of internal_srcpad as dummy_sinkpad. This causes both these pads * to share a parent allowing us to link them. * Yes, this is a hack/workaround. */ - sinkpad = gst_element_get_static_pad (self->priv->queue, "sink"); - gst_pad_link (self->priv->internal_srcpad, sinkpad); + sinkpad = gst_element_get_static_pad (self->queue, "sink"); + gst_pad_link (self->internal_srcpad, sinkpad); gst_object_unref (sinkpad); } @@ -253,13 +233,13 @@ gst_proxy_src_dispose (GObject * object) { GstProxySrc *self = GST_PROXY_SRC (object); - gst_object_unparent (GST_OBJECT (self->priv->dummy_sinkpad)); - self->priv->dummy_sinkpad = NULL; + gst_object_unparent (GST_OBJECT (self->dummy_sinkpad)); + self->dummy_sinkpad = NULL; - gst_object_unparent (GST_OBJECT (self->priv->internal_srcpad)); - self->priv->internal_srcpad = NULL; + gst_object_unparent (GST_OBJECT (self->internal_srcpad)); + self->internal_srcpad = NULL; - g_weak_ref_set (&self->priv->proxysink, NULL); + g_weak_ref_set (&self->proxysink, NULL); G_OBJECT_CLASS (gst_proxy_src_parent_class)->dispose (object); } @@ -279,10 +259,10 @@ gst_proxy_src_change_state (GstElement * element, GstStateChange transition) switch (transition) { case GST_STATE_CHANGE_READY_TO_PAUSED: ret = GST_STATE_CHANGE_NO_PREROLL; - gst_pad_set_active (self->priv->internal_srcpad, TRUE); + gst_pad_set_active (self->internal_srcpad, TRUE); break; case GST_STATE_CHANGE_PAUSED_TO_READY: - gst_pad_set_active (self->priv->internal_srcpad, FALSE); + gst_pad_set_active (self->internal_srcpad, FALSE); break; default: break; @@ -305,7 +285,7 @@ gst_proxy_src_internal_src_query (GstPad * pad, GstObject * parent, GST_LOG_OBJECT (pad, "Handling query of type '%s'", gst_query_type_get_name (GST_QUERY_TYPE (query))); - sink = g_weak_ref_get (&self->priv->proxysink); + sink = g_weak_ref_get (&self->proxysink); if (sink) { GstPad *sinkpad; sinkpad = gst_proxy_sink_get_internal_sinkpad (sink); @@ -333,7 +313,7 @@ gst_proxy_src_internal_src_event (GstPad * pad, GstObject * parent, GST_LOG_OBJECT (pad, "Got %s event", GST_EVENT_TYPE_NAME (event)); - sink = g_weak_ref_get (&self->priv->proxysink); + sink = g_weak_ref_get (&self->proxysink); if (sink) { GstPad *sinkpad; sinkpad = gst_proxy_sink_get_internal_sinkpad (sink); @@ -354,5 +334,5 @@ gst_proxy_src_internal_src_event (GstPad * pad, GstObject * parent, GstPad * gst_proxy_src_get_internal_srcpad (GstProxySrc * self) { - return gst_object_ref (self->priv->internal_srcpad); + return gst_object_ref (self->internal_srcpad); } diff --git a/gst/proxy/gstproxysrc.h b/gst/proxy/gstproxysrc.h index cc8577fc2..4f5c3021a 100644 --- a/gst/proxy/gstproxysrc.h +++ b/gst/proxy/gstproxysrc.h @@ -41,8 +41,21 @@ struct _GstProxySrc { GstBin parent; /* < private > */ - GstProxySrcPrivate *priv; - gpointer _gst_reserved[GST_PADDING]; + + /* Queue to hold buffers from proxysink */ + GstElement *queue; + + /* Source pad of the above queue and the proxysrc element itself */ + GstPad *srcpad; + + /* Our internal srcpad that proxysink pushes buffers/events/queries into */ + GstPad *internal_srcpad; + + /* An unlinked dummy sinkpad; see gst_proxy_src_init() */ + GstPad *dummy_sinkpad; + + /* The matching proxysink; queries and events are sent to its sinkpad */ + GWeakRef proxysink; }; struct _GstProxySrcClass { |