mpegaudioparse: Implement ::get_sink_caps vfunc to propagate downstream caps constraints upstream
This commit is contained in:
parent
996b4eb4cc
commit
c114e7c073
@ -100,6 +100,7 @@ static GstFlowReturn gst_mpeg_audio_parse_pre_push_frame (GstBaseParse * parse,
|
|||||||
static gboolean gst_mpeg_audio_parse_convert (GstBaseParse * parse,
|
static gboolean gst_mpeg_audio_parse_convert (GstBaseParse * parse,
|
||||||
GstFormat src_format, gint64 src_value,
|
GstFormat src_format, gint64 src_value,
|
||||||
GstFormat dest_format, gint64 * dest_value);
|
GstFormat dest_format, gint64 * dest_value);
|
||||||
|
static GstCaps *gst_mpeg_audio_parse_get_sink_caps (GstBaseParse * parse);
|
||||||
|
|
||||||
GST_BOILERPLATE (GstMpegAudioParse, gst_mpeg_audio_parse, GstBaseParse,
|
GST_BOILERPLATE (GstMpegAudioParse, gst_mpeg_audio_parse, GstBaseParse,
|
||||||
GST_TYPE_BASE_PARSE);
|
GST_TYPE_BASE_PARSE);
|
||||||
@ -177,6 +178,8 @@ gst_mpeg_audio_parse_class_init (GstMpegAudioParseClass * klass)
|
|||||||
parse_class->pre_push_frame =
|
parse_class->pre_push_frame =
|
||||||
GST_DEBUG_FUNCPTR (gst_mpeg_audio_parse_pre_push_frame);
|
GST_DEBUG_FUNCPTR (gst_mpeg_audio_parse_pre_push_frame);
|
||||||
parse_class->convert = GST_DEBUG_FUNCPTR (gst_mpeg_audio_parse_convert);
|
parse_class->convert = GST_DEBUG_FUNCPTR (gst_mpeg_audio_parse_convert);
|
||||||
|
parse_class->get_sink_caps =
|
||||||
|
GST_DEBUG_FUNCPTR (gst_mpeg_audio_parse_get_sink_caps);
|
||||||
|
|
||||||
/* register tags */
|
/* register tags */
|
||||||
#define GST_TAG_CRC "has-crc"
|
#define GST_TAG_CRC "has-crc"
|
||||||
@ -1269,3 +1272,36 @@ gst_mpeg_audio_parse_pre_push_frame (GstBaseParse * parse,
|
|||||||
|
|
||||||
return GST_FLOW_OK;
|
return GST_FLOW_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GstCaps *
|
||||||
|
gst_mpeg_audio_parse_get_sink_caps (GstBaseParse * parse)
|
||||||
|
{
|
||||||
|
GstCaps *peercaps;
|
||||||
|
GstCaps *res;
|
||||||
|
|
||||||
|
peercaps = gst_pad_get_allowed_caps (GST_BASE_PARSE_SRC_PAD (parse));
|
||||||
|
if (peercaps) {
|
||||||
|
guint i, n;
|
||||||
|
|
||||||
|
/* Remove the parsed field */
|
||||||
|
peercaps = gst_caps_make_writable (peercaps);
|
||||||
|
n = gst_caps_get_size (peercaps);
|
||||||
|
for (i = 0; i < n; i++) {
|
||||||
|
GstStructure *s = gst_caps_get_structure (peercaps, i);
|
||||||
|
|
||||||
|
gst_structure_remove_field (s, "parsed");
|
||||||
|
}
|
||||||
|
|
||||||
|
res =
|
||||||
|
gst_caps_intersect_full (peercaps,
|
||||||
|
gst_pad_get_pad_template_caps (GST_BASE_PARSE_SRC_PAD (parse)),
|
||||||
|
GST_CAPS_INTERSECT_FIRST);
|
||||||
|
gst_caps_unref (peercaps);
|
||||||
|
} else {
|
||||||
|
res =
|
||||||
|
gst_caps_copy (gst_pad_get_pad_template_caps (GST_BASE_PARSE_SRC_PAD
|
||||||
|
(parse)));
|
||||||
|
}
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user