[FFmpeg-devel] [PATCH] fftools/opt_common.c: Display muxer/demuxer flags in help screen.
toots at rastageeks.org
toots at rastageeks.org
Fri Apr 22 03:11:39 EEST 2022
From: Romain Beauxis <toots at rastageeks.org>
---
Showing muxer/demuxer flags can be very useful to quickly glance at specific
properties, in particular global headers flags. This patch adds a display of
these flags in the -h muxer=... and -h demuxer=... calls.
fftools/opt_common.c | 78 ++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 78 insertions(+)
diff --git a/fftools/opt_common.c b/fftools/opt_common.c
index c303db4d09..c0daf0840a 100644
--- a/fftools/opt_common.c
+++ b/fftools/opt_common.c
@@ -424,6 +424,80 @@ static void show_help_codec(const char *name, int encoder)
}
}
+const int fmt_flags[] = {
+ AVFMT_NOFILE,
+ AVFMT_NEEDNUMBER,
+ AVFMT_EXPERIMENTAL,
+ AVFMT_SHOW_IDS,
+ AVFMT_GLOBALHEADER,
+ AVFMT_NOTIMESTAMPS,
+ AVFMT_GENERIC_INDEX,
+ AVFMT_TS_DISCONT,
+ AVFMT_VARIABLE_FPS,
+ AVFMT_NODIMENSIONS,
+ AVFMT_NOSTREAMS,
+ AVFMT_NOBINSEARCH,
+ AVFMT_NOGENSEARCH,
+ AVFMT_NO_BYTE_SEEK,
+ AVFMT_ALLOW_FLUSH,
+ AVFMT_TS_NONSTRICT,
+ AVFMT_TS_NEGATIVE,
+ AVFMT_SEEK_TO_PTS
+};
+
+const char *fmt_flags_name[] = {
+ "AVFMT_NOFILE",
+ "AVFMT_NEEDNUMBER",
+ "AVFMT_EXPERIMENTAL",
+ "AVFMT_SHOW_IDS",
+ "AVFMT_GLOBALHEADER",
+ "AVFMT_NOTIMESTAMPS",
+ "AVFMT_GENERIC_INDEX",
+ "AVFMT_TS_DISCONT",
+ "AVFMT_VARIABLE_FPS",
+ "AVFMT_NODIMENSIONS",
+ "AVFMT_NOSTREAMS",
+ "AVFMT_NOBINSEARCH",
+ "AVFMT_NOGENSEARCH",
+ "AVFMT_NO_BYTE_SEEK",
+ "AVFMT_ALLOW_FLUSH",
+ "AVFMT_TS_NONSTRICT",
+ "AVFMT_TS_NEGATIVE",
+ "AVFMT_SEEK_TO_PTS"
+};
+
+const char *fmt_flags_help[] = {
+ "Demuxer will use avio_open, no opened file should be provided by the caller.",
+ "Needs 'd' in filename.",
+ "The muxer/demuxer is experimental and should be used with caution.",
+ "Show format stream IDs numbers.",
+ "Format wants global header.",
+ "Format does not need / have any timestamps.",
+ "Use generic index building code.",
+ "Format allows timestamp discontinuities.",
+ "Format allows variable fps.",
+ "Format does not need width/height.",
+ "Format does not require any streams.",
+ "Format does not allow to fall back on binary search via read_timestamp.",
+ "Format does not allow to fall back on generic search.",
+ "Format does not allow seeking by bytes.",
+ "Format allows flushing.",
+ "Format does not require strictly increasing timestamps, but they must still be monotonic.",
+ "Format allows muxing negative timestamps.",
+ "Seeking is based on PTS."
+};
+
+static void show_help_fmt_flags(int flags) {
+ int i;
+
+ printf("flags:\n");
+
+ for (i = 0; i < sizeof(fmt_flags) / sizeof(fmt_flags[0]); i++) {
+ if (flags & fmt_flags[i])
+ printf(" %s: %s\n", fmt_flags_name[i], fmt_flags_help[i]);
+ }
+}
+
static void show_help_demuxer(const char *name)
{
const AVInputFormat *fmt = av_find_input_format(name);
@@ -438,6 +512,8 @@ static void show_help_demuxer(const char *name)
if (fmt->extensions)
printf(" Common extensions: %s.\n", fmt->extensions);
+ show_help_fmt_flags(fmt->flags);
+
if (fmt->priv_class)
show_help_children(fmt->priv_class, AV_OPT_FLAG_DECODING_PARAM);
}
@@ -489,6 +565,8 @@ static void show_help_muxer(const char *name)
printf(" Default subtitle codec: %s.\n", desc->name);
}
+ show_help_fmt_flags(fmt->flags);
+
if (fmt->priv_class)
show_help_children(fmt->priv_class, AV_OPT_FLAG_ENCODING_PARAM);
}
--
2.32.0 (Apple Git-132)
More information about the ffmpeg-devel
mailing list