From 8271f55bd7d6f4e06786dc8dd7c9538d83ad026a Mon Sep 17 00:00:00 2001 From: Anton Khirnov Date: Sat, 26 May 2012 08:54:25 +0200 Subject: [PATCH] avprobe: restore pseudo-INI old style format for compatibility. --- Changelog | 3 ++- avprobe.c | 50 ++++++++++++++++++++++++++++++++++++++++++++++++ doc/avprobe.texi | 13 +++++++++++-- 3 files changed, 63 insertions(+), 3 deletions(-) diff --git a/Changelog b/Changelog index 822f062d83..358662bfed 100644 --- a/Changelog +++ b/Changelog @@ -21,7 +21,8 @@ version : - add fps filter - audio split filter - audio mix filter -- avprobe output is now standard INI or JSON. +- avprobe output is now standard INI or JSON. The old format can still + be used with -of old. version 0.8: diff --git a/avprobe.c b/avprobe.c index acf0ab9d49..867d10d1f7 100644 --- a/avprobe.c +++ b/avprobe.c @@ -280,6 +280,50 @@ static void json_print_string(const char *key, const char *value) avio_w8(probe_out, '\"'); } +/* + * old-style pseudo-INI + */ +static void old_print_object_header(const char *name) +{ + char *str, *p; + + if (!strcmp(name, "tags")) + return; + + str = p = av_strdup(name); + while (*p) { + *p = toupper(*p); + p++; + } + + avio_printf(probe_out, "[%s]\n", str); + av_freep(&str); +} + +static void old_print_object_footer(const char *name) +{ + char *str, *p; + + if (!strcmp(name, "tags")) + return; + + str = p = av_strdup(name); + while (*p) { + *p = toupper(*p); + p++; + } + + avio_printf(probe_out, "[/%s]\n", str); + av_freep(&str); +} + +static void old_print_string(const char *key, const char *value) +{ + if (!strcmp(octx.prefix[octx.level - 1].name, "tags")) + avio_printf(probe_out, "TAG:"); + ini_print_string(key, value); +} + /* * Simple Formatter for single entries. */ @@ -783,6 +827,12 @@ static int opt_output_format(const char *opt, const char *arg) print_integer = ini_print_integer; print_string = ini_print_string; + } else if (!strcmp(arg, "old")) { + print_header = NULL; + print_object_header = old_print_object_header; + print_object_footer = old_print_object_footer; + + print_string = old_print_string; } else { av_log(NULL, AV_LOG_ERROR, "Unsupported formatter %s\n", arg); return AVERROR(EINVAL); diff --git a/doc/avprobe.texi b/doc/avprobe.texi index 9c28125784..7e6fedf5c4 100644 --- a/doc/avprobe.texi +++ b/doc/avprobe.texi @@ -59,8 +59,17 @@ parsers. Force format to use. @item -of @var{formatter} -Use a specific formatter to output the document, either @var{ini} or -@var{json} available. +Use a specific formatter to output the document. The following +formatters are available +@table @option +@item ini + +@item json + +@item old +Pseudo-INI format that used to be the only one available in old +avprobe versions. +@end table @item -unit Show the unit of the displayed values.