[FFmpeg-devel] [PATCH] avformat/utils: fix stream ordering for program ID stream specifiers
Marton Balint
cus at passwd.hu
Thu May 23 22:29:52 EEST 2019
On Sun, 19 May 2019, Marton Balint wrote:
> Fixes a regression introduced in dbfd042983eed8586d4048795c00af820f5b6b1f.
Will apply soon.
Thanks,
Marton
>
> Signed-off-by: Marton Balint <cus at passwd.hu>
> ---
> doc/fftools-common-opts.texi | 5 ++++-
> libavformat/utils.c | 16 +++++++++++-----
> 2 files changed, 15 insertions(+), 6 deletions(-)
>
> diff --git a/doc/fftools-common-opts.texi b/doc/fftools-common-opts.texi
> index e75bec4354..4359526f19 100644
> --- a/doc/fftools-common-opts.texi
> +++ b/doc/fftools-common-opts.texi
> @@ -36,7 +36,10 @@ Possible forms of stream specifiers are:
> Matches the stream with this index. E.g. @code{-threads:1 4} would set the
> thread count for the second stream to 4. If @var{stream_index} is used as an
> additional stream specifier (see below), then it selects stream number
> - at var{stream_index} from the matching streams.
> + at var{stream_index} from the matching streams. Stream numbering is based on the
> +order of the streams as detected by libavformat except when a program ID is
> +specified. In this case it is based on the ordering of the streams in the
> +program.
> @item @var{stream_type}[:@var{additional_stream_specifier}]
> @var{stream_type} is one of following: 'v' or 'V' for video, 'a' for audio, 's'
> for subtitle, 'd' for data, and 't' for attachments. 'v' matches all video
> diff --git a/libavformat/utils.c b/libavformat/utils.c
> index 6ef94239a4..3d764c18d6 100644
> --- a/libavformat/utils.c
> +++ b/libavformat/utils.c
> @@ -5107,7 +5107,7 @@ AVRational av_guess_frame_rate(AVFormatContext *format, AVStream *st, AVFrame *f
> * >0 if st is a matching stream
> */
> static int match_stream_specifier(AVFormatContext *s, AVStream *st,
> - const char *spec, const char **indexptr)
> + const char *spec, const char **indexptr, AVProgram **p)
> {
> int match = 1; /* Stores if the specifier matches so far. */
> while (*spec) {
> @@ -5162,6 +5162,8 @@ FF_DISABLE_DEPRECATION_WARNINGS
> for (j = 0; j < s->programs[i]->nb_stream_indexes; j++) {
> if (st->index == s->programs[i]->stream_index[j]) {
> found = 1;
> + if (p)
> + *p = s->programs[i];
> i = s->nb_programs;
> break;
> }
> @@ -5264,8 +5266,10 @@ int avformat_match_stream_specifier(AVFormatContext *s, AVStream *st,
> int ret, index;
> char *endptr;
> const char *indexptr = NULL;
> + AVProgram *p = NULL;
> + int nb_streams;
>
> - ret = match_stream_specifier(s, st, spec, &indexptr);
> + ret = match_stream_specifier(s, st, spec, &indexptr, &p);
> if (ret < 0)
> goto error;
>
> @@ -5283,11 +5287,13 @@ int avformat_match_stream_specifier(AVFormatContext *s, AVStream *st,
> return (index == st->index);
>
> /* If we requested a matching stream index, we have to ensure st is that. */
> - for (int i = 0; i < s->nb_streams && index >= 0; i++) {
> - ret = match_stream_specifier(s, s->streams[i], spec, NULL);
> + nb_streams = p ? p->nb_stream_indexes : s->nb_streams;
> + for (int i = 0; i < nb_streams && index >= 0; i++) {
> + AVStream *candidate = p ? s->streams[p->stream_index[i]] : s->streams[i];
> + ret = match_stream_specifier(s, candidate, spec, NULL, NULL);
> if (ret < 0)
> goto error;
> - if (ret > 0 && index-- == 0 && st == s->streams[i])
> + if (ret > 0 && index-- == 0 && st == candidate)
> return 1;
> }
> return 0;
> --
> 2.16.4
>
> _______________________________________________
> ffmpeg-devel mailing list
> ffmpeg-devel at ffmpeg.org
> https://ffmpeg.org/mailman/listinfo/ffmpeg-devel
>
> To unsubscribe, visit link above, or email
> ffmpeg-devel-request at ffmpeg.org with subject "unsubscribe".
More information about the ffmpeg-devel
mailing list