mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-02-22 22:16:22 +00:00
proxy: remove unneeded object private structs
Plugin headers are not installed. Also mark internal funcs as internal.
This commit is contained in:
parent
e9bfb4edc2
commit
843f118523
5 changed files with 74 additions and 87 deletions
|
@ -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
|
||||
|
|
|
@ -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);
|
||||
}
|
||||
|
|
|
@ -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 {
|
||||
|
|
|
@ -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->dummy_sinkpad = gst_pad_new ("dummy_sinkpad", GST_PAD_SINK);
|
||||
gst_object_set_parent (GST_OBJECT (self->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->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);
|
||||
}
|
||||
|
|
|
@ -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 {
|
||||
|
|
Loading…
Reference in a new issue