mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-09-30 07:42:32 +00:00
baseparse: add vfuncs to intercept queries
Useful for video parses that want to attach matter or find out if downstream supports certain metas. API: GstBaseParseClass::src_query() API: GstBaseParseClass::sink_query() https://bugzilla.gnome.org/show_bug.cgi?id=691475
This commit is contained in:
parent
2b1facfe1d
commit
1702623b20
2 changed files with 82 additions and 16 deletions
|
@ -436,6 +436,11 @@ static gboolean gst_base_parse_sink_event_default (GstBaseParse * parse,
|
||||||
static gboolean gst_base_parse_src_event_default (GstBaseParse * parse,
|
static gboolean gst_base_parse_src_event_default (GstBaseParse * parse,
|
||||||
GstEvent * event);
|
GstEvent * event);
|
||||||
|
|
||||||
|
static gboolean gst_base_parse_sink_query_default (GstBaseParse * parse,
|
||||||
|
GstQuery * query);
|
||||||
|
static gboolean gst_base_parse_src_query_default (GstBaseParse * parse,
|
||||||
|
GstQuery * query);
|
||||||
|
|
||||||
static void gst_base_parse_drain (GstBaseParse * parse);
|
static void gst_base_parse_drain (GstBaseParse * parse);
|
||||||
|
|
||||||
static void gst_base_parse_post_bitrates (GstBaseParse * parse,
|
static void gst_base_parse_post_bitrates (GstBaseParse * parse,
|
||||||
|
@ -540,6 +545,8 @@ gst_base_parse_class_init (GstBaseParseClass * klass)
|
||||||
/* Default handlers */
|
/* Default handlers */
|
||||||
klass->sink_event = gst_base_parse_sink_event_default;
|
klass->sink_event = gst_base_parse_sink_event_default;
|
||||||
klass->src_event = gst_base_parse_src_event_default;
|
klass->src_event = gst_base_parse_src_event_default;
|
||||||
|
klass->sink_query = gst_base_parse_sink_query_default;
|
||||||
|
klass->src_query = gst_base_parse_src_query_default;
|
||||||
klass->convert = gst_base_parse_convert_default;
|
klass->convert = gst_base_parse_convert_default;
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_INIT (gst_base_parse_debug, "baseparse", 0,
|
GST_DEBUG_CATEGORY_INIT (gst_base_parse_debug, "baseparse", 0,
|
||||||
|
@ -1159,18 +1166,20 @@ gst_base_parse_sink_event_default (GstBaseParse * parse, GstEvent * event)
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_base_parse_sink_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
gst_base_parse_sink_query_default (GstBaseParse * parse, GstQuery * query)
|
||||||
{
|
{
|
||||||
GstBaseParse *parse;
|
GstPad *pad;
|
||||||
GstBaseParseClass *bclass;
|
|
||||||
gboolean res;
|
gboolean res;
|
||||||
|
|
||||||
parse = GST_BASE_PARSE (parent);
|
pad = GST_BASE_PARSE_SINK_PAD (parse);
|
||||||
bclass = GST_BASE_PARSE_GET_CLASS (parse);
|
|
||||||
|
|
||||||
switch (GST_QUERY_TYPE (query)) {
|
switch (GST_QUERY_TYPE (query)) {
|
||||||
case GST_QUERY_CAPS:
|
case GST_QUERY_CAPS:
|
||||||
{
|
{
|
||||||
|
GstBaseParseClass *bclass;
|
||||||
|
|
||||||
|
bclass = GST_BASE_PARSE_GET_CLASS (parse);
|
||||||
|
|
||||||
if (bclass->get_sink_caps) {
|
if (bclass->get_sink_caps) {
|
||||||
GstCaps *caps, *filter;
|
GstCaps *caps, *filter;
|
||||||
|
|
||||||
|
@ -1204,7 +1213,7 @@ gst_base_parse_sink_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
res = gst_pad_query_default (pad, parent, query);
|
res = gst_pad_query_default (pad, GST_OBJECT_CAST (parse), query);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1212,6 +1221,52 @@ gst_base_parse_sink_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_base_parse_sink_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
|
{
|
||||||
|
GstBaseParseClass *bclass;
|
||||||
|
GstBaseParse *parse;
|
||||||
|
gboolean ret;
|
||||||
|
|
||||||
|
parse = GST_BASE_PARSE (parent);
|
||||||
|
bclass = GST_BASE_PARSE_GET_CLASS (parse);
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (parse, "%s query", GST_QUERY_TYPE_NAME (query));
|
||||||
|
|
||||||
|
if (bclass->sink_query)
|
||||||
|
ret = bclass->sink_query (parse, query);
|
||||||
|
else
|
||||||
|
ret = FALSE;
|
||||||
|
|
||||||
|
GST_LOG_OBJECT (parse, "%s query result: %d %" GST_PTR_FORMAT,
|
||||||
|
GST_QUERY_TYPE_NAME (query), ret, query);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gst_base_parse_src_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
|
{
|
||||||
|
GstBaseParseClass *bclass;
|
||||||
|
GstBaseParse *parse;
|
||||||
|
gboolean ret;
|
||||||
|
|
||||||
|
parse = GST_BASE_PARSE (parent);
|
||||||
|
bclass = GST_BASE_PARSE_GET_CLASS (parse);
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (parse, "%s query: %" GST_PTR_FORMAT,
|
||||||
|
GST_QUERY_TYPE_NAME (query), query);
|
||||||
|
|
||||||
|
if (bclass->src_query)
|
||||||
|
ret = bclass->src_query (parse, query);
|
||||||
|
else
|
||||||
|
ret = FALSE;
|
||||||
|
|
||||||
|
GST_LOG_OBJECT (parse, "%s query result: %d %" GST_PTR_FORMAT,
|
||||||
|
GST_QUERY_TYPE_NAME (query), ret, query);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
/* gst_base_parse_src_event:
|
/* gst_base_parse_src_event:
|
||||||
* @pad: #GstPad that received the event.
|
* @pad: #GstPad that received the event.
|
||||||
|
@ -3444,14 +3499,12 @@ gst_base_parse_get_duration (GstBaseParse * parse, GstFormat format,
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_base_parse_src_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
gst_base_parse_src_query_default (GstBaseParse * parse, GstQuery * query)
|
||||||
{
|
{
|
||||||
GstBaseParse *parse;
|
|
||||||
gboolean res = FALSE;
|
gboolean res = FALSE;
|
||||||
|
GstPad *pad;
|
||||||
|
|
||||||
parse = GST_BASE_PARSE (parent);
|
pad = GST_BASE_PARSE_SRC_PAD (parse);
|
||||||
|
|
||||||
GST_LOG_OBJECT (parse, "handling query: %" GST_PTR_FORMAT, query);
|
|
||||||
|
|
||||||
switch (GST_QUERY_TYPE (query)) {
|
switch (GST_QUERY_TYPE (query)) {
|
||||||
case GST_QUERY_POSITION:
|
case GST_QUERY_POSITION:
|
||||||
|
@ -3463,7 +3516,7 @@ gst_base_parse_src_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
gst_query_parse_position (query, &format, NULL);
|
gst_query_parse_position (query, &format, NULL);
|
||||||
|
|
||||||
/* try upstream first */
|
/* try upstream first */
|
||||||
res = gst_pad_query_default (pad, parent, query);
|
res = gst_pad_query_default (pad, GST_OBJECT_CAST (parse), query);
|
||||||
if (!res) {
|
if (!res) {
|
||||||
/* Fall back on interpreting segment */
|
/* Fall back on interpreting segment */
|
||||||
GST_OBJECT_LOCK (parse);
|
GST_OBJECT_LOCK (parse);
|
||||||
|
@ -3497,7 +3550,7 @@ gst_base_parse_src_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
gst_query_parse_duration (query, &format, NULL);
|
gst_query_parse_duration (query, &format, NULL);
|
||||||
|
|
||||||
/* consult upstream */
|
/* consult upstream */
|
||||||
res = gst_pad_query_default (pad, parent, query);
|
res = gst_pad_query_default (pad, GST_OBJECT_CAST (parse), query);
|
||||||
|
|
||||||
/* otherwise best estimate from us */
|
/* otherwise best estimate from us */
|
||||||
if (!res) {
|
if (!res) {
|
||||||
|
@ -3517,7 +3570,7 @@ gst_base_parse_src_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
gst_query_parse_seeking (query, &fmt, NULL, NULL, NULL);
|
gst_query_parse_seeking (query, &fmt, NULL, NULL, NULL);
|
||||||
|
|
||||||
/* consult upstream */
|
/* consult upstream */
|
||||||
res = gst_pad_query_default (pad, parent, query);
|
res = gst_pad_query_default (pad, GST_OBJECT_CAST (parse), query);
|
||||||
|
|
||||||
/* we may be able to help if in TIME */
|
/* we may be able to help if in TIME */
|
||||||
if (fmt == GST_FORMAT_TIME && gst_base_parse_is_seekable (parse)) {
|
if (fmt == GST_FORMAT_TIME && gst_base_parse_is_seekable (parse)) {
|
||||||
|
@ -3586,7 +3639,7 @@ gst_base_parse_src_query (GstPad * pad, GstObject * parent, GstQuery * query)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
res = gst_pad_query_default (pad, parent, query);
|
res = gst_pad_query_default (pad, GST_OBJECT_CAST (parse), query);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
|
|
|
@ -213,6 +213,13 @@ struct _GstBaseParse {
|
||||||
* Called until it doesn't return GST_FLOW_OK anymore for
|
* Called until it doesn't return GST_FLOW_OK anymore for
|
||||||
* the first buffers. Can be used by the subclass to detect
|
* the first buffers. Can be used by the subclass to detect
|
||||||
* the stream format.
|
* the stream format.
|
||||||
|
* @sink_query: Optional.
|
||||||
|
* Query handler on the sink pad. This function should chain
|
||||||
|
* up to the parent implementation to let the default handler
|
||||||
|
* run (Since 1.2)
|
||||||
|
* @src_query: Optional.
|
||||||
|
* Query handler on the source pad. Should chain up to the
|
||||||
|
* parent to let the default handler run (Since 1.2)
|
||||||
*
|
*
|
||||||
* Subclasses can override any of the available virtual methods or not, as
|
* Subclasses can override any of the available virtual methods or not, as
|
||||||
* needed. At minimum @check_valid_frame and @parse_frame needs to be
|
* needed. At minimum @check_valid_frame and @parse_frame needs to be
|
||||||
|
@ -256,8 +263,14 @@ struct _GstBaseParseClass {
|
||||||
GstFlowReturn (*detect) (GstBaseParse * parse,
|
GstFlowReturn (*detect) (GstBaseParse * parse,
|
||||||
GstBuffer * buffer);
|
GstBuffer * buffer);
|
||||||
|
|
||||||
|
gboolean (*sink_query) (GstBaseParse * parse,
|
||||||
|
GstQuery * query);
|
||||||
|
|
||||||
|
gboolean (*src_query) (GstBaseParse * parse,
|
||||||
|
GstQuery * query);
|
||||||
|
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
gpointer _gst_reserved[GST_PADDING_LARGE];
|
gpointer _gst_reserved[GST_PADDING_LARGE - 2];
|
||||||
};
|
};
|
||||||
|
|
||||||
GType gst_base_parse_get_type (void);
|
GType gst_base_parse_get_type (void);
|
||||||
|
|
Loading…
Reference in a new issue