[FFmpeg-devel] [PATCH 11/19] avformat/matroskadec: Support FlagOriginal
Andreas Rheinhardt
andreas.rheinhardt at gmail.com
Sun Feb 28 17:33:01 EET 2021
Anton Khirnov:
> Quoting Andreas Rheinhardt (2021-02-22 05:05:29)
>> Andreas Rheinhardt:
>>> Needs a CountedElement in order to distinguish the case of the element
>>> not being present and the element being present with a value of zero.
>>>
>>> Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at gmail.com>
>>> ---
>>> libavformat/matroska.h | 1 +
>>> libavformat/matroskadec.c | 7 ++++++-
>>> 2 files changed, 7 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/libavformat/matroska.h b/libavformat/matroska.h
>>> index 191c4f6149..8ab87eff20 100644
>>> --- a/libavformat/matroska.h
>>> +++ b/libavformat/matroska.h
>>> @@ -100,6 +100,7 @@
>>> #define MATROSKA_ID_TRACKFLAGDEFAULT 0x88
>>> #define MATROSKA_ID_TRACKFLAGFORCED 0x55AA
>>> #define MATROSKA_ID_TRACKFLAGLACING 0x9C
>>> +#define MATROSKA_ID_TRACKFLAGORIGINAL 0x55AE
>>> #define MATROSKA_ID_TRACKMINCACHE 0x6DE7
>>> #define MATROSKA_ID_TRACKMAXCACHE 0x6DF8
>>> #define MATROSKA_ID_TRACKDEFAULTDURATION 0x23E383
>>> diff --git a/libavformat/matroskadec.c b/libavformat/matroskadec.c
>>> index fa266fcaec..f15bf8f9d2 100644
>>> --- a/libavformat/matroskadec.c
>>> +++ b/libavformat/matroskadec.c
>>> @@ -251,6 +251,7 @@ typedef struct MatroskaTrack {
>>> uint64_t flag_default;
>>> uint64_t flag_forced;
>>> uint64_t flag_comment;
>>> + CountedElement flag_original;
>>> uint64_t seek_preroll;
>>> MatroskaTrackVideo video;
>>> MatroskaTrackAudio audio;
>>> @@ -410,7 +411,7 @@ typedef struct MatroskaDemuxContext {
>>> // incomplete type (6.7.2 in C90, 6.9.2 in C99).
>>> // Removing the sizes breaks MSVC.
>>> static EbmlSyntax ebml_syntax[3], matroska_segment[9], matroska_track_video_color[15], matroska_track_video[19],
>>> - matroska_track[28], matroska_track_encoding[6], matroska_track_encodings[2],
>>> + matroska_track[29], matroska_track_encoding[6], matroska_track_encodings[2],
>>> matroska_track_combine_planes[2], matroska_track_operation[2], matroska_tracks[2],
>>> matroska_attachments[2], matroska_chapter_entry[9], matroska_chapter[6], matroska_chapters[2],
>>> matroska_index_entry[3], matroska_index[2], matroska_tag[3], matroska_tags[2], matroska_seekhead[2],
>>> @@ -575,6 +576,7 @@ static EbmlSyntax matroska_track[] = {
>>> { MATROSKA_ID_TRACKFLAGCOMMENTARY, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_comment), { .u = 0 } },
>>> { MATROSKA_ID_TRACKFLAGDEFAULT, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_default), { .u = 1 } },
>>> { MATROSKA_ID_TRACKFLAGFORCED, EBML_UINT, 0, 0, offsetof(MatroskaTrack, flag_forced), { .u = 0 } },
>>> + { MATROSKA_ID_TRACKFLAGORIGINAL, EBML_UINT, 1, 0, offsetof(MatroskaTrack, flag_original), {.u = 0 } },
>>> { MATROSKA_ID_TRACKVIDEO, EBML_NEST, 0, 0, offsetof(MatroskaTrack, video), { .n = matroska_track_video } },
>>> { MATROSKA_ID_TRACKAUDIO, EBML_NEST, 0, 0, offsetof(MatroskaTrack, audio), { .n = matroska_track_audio } },
>>> { MATROSKA_ID_TRACKOPERATION, EBML_NEST, 0, 0, offsetof(MatroskaTrack, operation), { .n = matroska_track_operation } },
>>> @@ -2746,6 +2748,9 @@ static int matroska_parse_tracks(AVFormatContext *s)
>>> st->disposition |= AV_DISPOSITION_FORCED;
>>> if (track->flag_comment)
>>> st->disposition |= AV_DISPOSITION_COMMENT;
>>> + if (track->flag_original.count > 0)
>>> + st->disposition |= track->flag_original.el.u ? AV_DISPOSITION_ORIGINAL
>>> + : AV_DISPOSITION_DUB;
>>>
>>> if (!st->codecpar->extradata) {
>>> if (extradata) {
>>>
>> Ridley Combs reviewed this set via IRC and approved it with one
>> exception: It makes no sense to use AV_DISPOSITION_DUB for something
>> else than an audio track, so if FlagOriginal is set to zero (meaning the
>> track is not in the content's original language), it should not be
>> exported at all. And the muxer should ignore AV_DISPOSITION_DUB for
>> non-audio-tracks. How do others think about this?
>
> AV_DISPOSITION_DUB is not documented, so you can interpret it pretty
> widely. One interpretation that I can think of is:
> - there are two audio tracks - let's say japanese original and english
> dub
> - there are also two english subtitle tracks:
> * one that translates everything, meant to be used with the original
> audio;
> * the other one translating just the text in the video (and possibly
> things that were meant to be subtitled in the original, like
> speech in Klingon), meant to be used with the english dub
>
> Then it can make sense to tag the second subtitle track with
> AV_DISPOSITION_DUB to indicate it is supposed to be used with the dubbed
> audio track.
>
That is also pretty much what I thought; furthermore, I'd really hate if
something was lost during a remuxing. I will therefore apply this as-is
tomorrow unless more comes up.
(I will leave the matroska-wtv-remux fate test out of this for reasons
explained here:
https://ffmpeg.org/pipermail/ffmpeg-devel/2021-February/276986.html)
- Andreas
More information about the ffmpeg-devel
mailing list