From: Sebastian Dröge Date: Fri, 23 Oct 2015 12:42:24 +0000 (+0300) Subject: aggregator: Add create_new_pad() vfunc to allow subclasses to override the default... X-Git-Tag: 1.19.3~507^2~7757 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=4eef8424b96192ea4972c549a649485c6dc4224d;p=platform%2Fupstream%2Fgstreamer.git aggregator: Add create_new_pad() vfunc to allow subclasses to override the default behaviour Not all aggregator subclasses will have a single pad template called sink_%u and might do something special depending on what the application requests. https://bugzilla.gnome.org/show_bug.cgi?id=757018 --- diff --git a/gst-libs/gst/base/gstaggregator.c b/gst-libs/gst/base/gstaggregator.c index d974cfd5d9..cffda524eb 100644 --- a/gst-libs/gst/base/gstaggregator.c +++ b/gst-libs/gst/base/gstaggregator.c @@ -1308,23 +1308,19 @@ gst_aggregator_release_pad (GstElement * element, GstPad * pad) SRC_UNLOCK (self); } -static GstPad * -gst_aggregator_request_new_pad (GstElement * element, +static GstAggregatorPad * +gst_aggregator_default_create_new_pad (GstAggregator * self, GstPadTemplate * templ, const gchar * req_name, const GstCaps * caps) { - GstAggregator *self; GstAggregatorPad *agg_pad; - - GstElementClass *klass = GST_ELEMENT_GET_CLASS (element); - GstAggregatorPrivate *priv = GST_AGGREGATOR (element)->priv; - - self = GST_AGGREGATOR (element); + GstElementClass *klass = GST_ELEMENT_GET_CLASS (self); + GstAggregatorPrivate *priv = self->priv; if (templ == gst_element_class_get_pad_template (klass, "sink_%u")) { gint serial = 0; gchar *name = NULL; - GST_OBJECT_LOCK (element); + GST_OBJECT_LOCK (self); if (req_name == NULL || strlen (req_name) < 6 || !g_str_has_prefix (req_name, "sink_")) { /* no name given when requesting the pad, use next available int */ @@ -1341,11 +1337,30 @@ gst_aggregator_request_new_pad (GstElement * element, "name", name, "direction", GST_PAD_SINK, "template", templ, NULL); g_free (name); - GST_OBJECT_UNLOCK (element); + GST_OBJECT_UNLOCK (self); + return agg_pad; } else { return NULL; } +} + +static GstPad * +gst_aggregator_request_new_pad (GstElement * element, + GstPadTemplate * templ, const gchar * req_name, const GstCaps * caps) +{ + GstAggregator *self; + GstAggregatorPad *agg_pad; + GstAggregatorClass *klass = GST_AGGREGATOR_GET_CLASS (element); + GstAggregatorPrivate *priv = GST_AGGREGATOR (element)->priv; + + self = GST_AGGREGATOR (element); + + agg_pad = klass->create_new_pad (self, templ, req_name, caps); + if (!agg_pad) { + GST_ERROR_OBJECT (element, "Couldn't create new pad"); + return NULL; + } GST_DEBUG_OBJECT (element, "Adding pad %s", GST_PAD_NAME (agg_pad)); self->priv->has_peer_latency = FALSE; @@ -1949,6 +1964,8 @@ gst_aggregator_class_init (GstAggregatorClass * klass) klass->src_event = gst_aggregator_default_src_event; klass->src_query = gst_aggregator_default_src_query; + klass->create_new_pad = gst_aggregator_default_create_new_pad; + gstelement_class->request_new_pad = GST_DEBUG_FUNCPTR (gst_aggregator_request_new_pad); gstelement_class->send_event = GST_DEBUG_FUNCPTR (gst_aggregator_send_event); diff --git a/gst-libs/gst/base/gstaggregator.h b/gst-libs/gst/base/gstaggregator.h index 8eda7dc38f..e1afea495f 100644 --- a/gst-libs/gst/base/gstaggregator.h +++ b/gst-libs/gst/base/gstaggregator.h @@ -245,6 +245,11 @@ struct _GstAggregatorClass { GstClockTime (*get_next_time) (GstAggregator * aggregator); + GstAggregatorPad * (*create_new_pad) (GstAggregator * self, + GstPadTemplate * templ, + const gchar * req_name, + const GstCaps * caps); + /*< private >*/ gpointer _gst_reserved[GST_PADDING_LARGE]; };