mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-07 07:55:41 +00:00
parsebin: Ensure non-time subtitle streams get "parsed"
Since https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6153 , subtitle "decoders" (i.e. which decode to raw text) are no longer auto-plugged by parsebin. But if a given format does not have a parser at all, we would end up outputting non-time/non-parsed outputs. In order to mitigate the issue, until such parsers are available, we check if the subtitle stream is in TIME format or not (i.e. whether it comes from a parser or demuxer). If not, we attempt to plug in a subtitle "decoder". Fixes #3463 Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6597>
This commit is contained in:
parent
934af761fd
commit
6302931e70
1 changed files with 35 additions and 2 deletions
|
@ -1765,10 +1765,41 @@ connect_pad (GstParseBin * parsebin, GstElement * src, GstParsePad * parsepad,
|
|||
{
|
||||
gboolean res = FALSE;
|
||||
GString *error_details = NULL;
|
||||
GstFormat segment_format = GST_FORMAT_TIME;
|
||||
GstPbUtilsCapsDescriptionFlags caps_flags =
|
||||
gst_pb_utils_get_caps_description_flags (caps);
|
||||
|
||||
g_return_val_if_fail (factories != NULL, FALSE);
|
||||
g_return_val_if_fail (factories->n_values > 0, FALSE);
|
||||
|
||||
/* For subtitles, which can come from standalone files, we need to ensure we
|
||||
* output a timed/parsed stream. But not all formats have a parser, so we also
|
||||
* want to try plugging in subtitle "decoders" like `subparse`.
|
||||
*
|
||||
* In order to ensure that, if the caps are subtitles, we query the stream
|
||||
* format to check if it's in time or not. If it's not in time format, we will
|
||||
* attempt to plugin in a "decoder" (if present). */
|
||||
if (caps_flags == GST_PBUTILS_CAPS_DESCRIPTION_FLAG_SUBTITLE) {
|
||||
GstEvent *segment_event =
|
||||
gst_pad_get_sticky_event (pad, GST_EVENT_SEGMENT, 0);
|
||||
const GstSegment *segment = NULL;
|
||||
|
||||
segment_format = GST_FORMAT_UNDEFINED;
|
||||
if (segment_event) {
|
||||
gst_event_parse_segment (segment_event, &segment);
|
||||
if (segment)
|
||||
segment_format = segment->format;
|
||||
}
|
||||
if (segment == GST_FORMAT_UNDEFINED) {
|
||||
GstQuery *segment_query = gst_query_new_segment (GST_FORMAT_TIME);
|
||||
if (gst_pad_query (pad, segment_query)) {
|
||||
gst_query_parse_segment (segment_query, NULL, &segment_format, NULL,
|
||||
NULL);
|
||||
}
|
||||
gst_query_unref (segment_query);
|
||||
}
|
||||
}
|
||||
|
||||
GST_DEBUG_OBJECT (parsebin,
|
||||
"pad %s:%s , chain:%p, %d factories, caps %" GST_PTR_FORMAT,
|
||||
GST_DEBUG_PAD_NAME (pad), chain, factories->n_values, caps);
|
||||
|
@ -1888,9 +1919,11 @@ connect_pad (GstParseBin * parsebin, GstElement * src, GstParsePad * parsepad,
|
|||
|
||||
}
|
||||
|
||||
/* Expose pads if the next factory is a decoder */
|
||||
/* Expose pads if the next factory is a decoder. segment_format might be not
|
||||
* time for subtitle streams */
|
||||
if (gst_element_factory_list_is_type (factory,
|
||||
GST_ELEMENT_FACTORY_TYPE_DECODER)) {
|
||||
GST_ELEMENT_FACTORY_TYPE_DECODER)
|
||||
&& segment_format == GST_FORMAT_TIME) {
|
||||
ret = GST_AUTOPLUG_SELECT_EXPOSE;
|
||||
} else {
|
||||
/* emit autoplug-select to see what we should do with it. */
|
||||
|
|
Loading…
Reference in a new issue