mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
avprobe: move formatter functions in the context
Avoid possible clashes.
This commit is contained in:
parent
c9cc76290f
commit
528995589f
112
avprobe.c
112
avprobe.c
@ -93,6 +93,16 @@ typedef struct {
|
|||||||
typedef struct {
|
typedef struct {
|
||||||
ProbeElement *prefix;
|
ProbeElement *prefix;
|
||||||
int level;
|
int level;
|
||||||
|
void (*print_header)(void);
|
||||||
|
void (*print_footer)(void);
|
||||||
|
|
||||||
|
void (*print_array_header) (const char *name);
|
||||||
|
void (*print_array_footer) (const char *name);
|
||||||
|
void (*print_object_header)(const char *name);
|
||||||
|
void (*print_object_footer)(const char *name);
|
||||||
|
|
||||||
|
void (*print_integer) (const char *key, int64_t value);
|
||||||
|
void (*print_string) (const char *key, const char *value);
|
||||||
} OutputContext;
|
} OutputContext;
|
||||||
|
|
||||||
static AVIOContext *probe_out = NULL;
|
static AVIOContext *probe_out = NULL;
|
||||||
@ -346,19 +356,6 @@ static void show_format_entry_string(const char *key, const char *value)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void (*print_header)(void) = ini_print_header;
|
|
||||||
void (*print_footer)(void) = ini_print_footer;
|
|
||||||
|
|
||||||
void (*print_array_header) (const char *name) = ini_print_array_header;
|
|
||||||
void (*print_array_footer) (const char *name);
|
|
||||||
void (*print_object_header)(const char *name) = ini_print_object_header;
|
|
||||||
void (*print_object_footer)(const char *name);
|
|
||||||
|
|
||||||
void (*print_integer) (const char *key, int64_t value) = ini_print_integer;
|
|
||||||
void (*print_string) (const char *key, const char *value) = ini_print_string;
|
|
||||||
|
|
||||||
|
|
||||||
static void probe_group_enter(const char *name, int type)
|
static void probe_group_enter(const char *name, int type)
|
||||||
{
|
{
|
||||||
int64_t count = -1;
|
int64_t count = -1;
|
||||||
@ -388,23 +385,23 @@ static void probe_group_leave(void)
|
|||||||
|
|
||||||
static void probe_header(void)
|
static void probe_header(void)
|
||||||
{
|
{
|
||||||
if (print_header)
|
if (octx.print_header)
|
||||||
print_header();
|
octx.print_header();
|
||||||
probe_group_enter("root", OBJECT);
|
probe_group_enter("root", OBJECT);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void probe_footer(void)
|
static void probe_footer(void)
|
||||||
{
|
{
|
||||||
if (print_footer)
|
if (octx.print_footer)
|
||||||
print_footer();
|
octx.print_footer();
|
||||||
probe_group_leave();
|
probe_group_leave();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void probe_array_header(const char *name)
|
static void probe_array_header(const char *name)
|
||||||
{
|
{
|
||||||
if (print_array_header)
|
if (octx.print_array_header)
|
||||||
print_array_header(name);
|
octx.print_array_header(name);
|
||||||
|
|
||||||
probe_group_enter(name, ARRAY);
|
probe_group_enter(name, ARRAY);
|
||||||
}
|
}
|
||||||
@ -412,14 +409,14 @@ static void probe_array_header(const char *name)
|
|||||||
static void probe_array_footer(const char *name)
|
static void probe_array_footer(const char *name)
|
||||||
{
|
{
|
||||||
probe_group_leave();
|
probe_group_leave();
|
||||||
if (print_array_footer)
|
if (octx.print_array_footer)
|
||||||
print_array_footer(name);
|
octx.print_array_footer(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void probe_object_header(const char *name)
|
static void probe_object_header(const char *name)
|
||||||
{
|
{
|
||||||
if (print_object_header)
|
if (octx.print_object_header)
|
||||||
print_object_header(name);
|
octx.print_object_header(name);
|
||||||
|
|
||||||
probe_group_enter(name, OBJECT);
|
probe_group_enter(name, OBJECT);
|
||||||
}
|
}
|
||||||
@ -427,19 +424,19 @@ static void probe_object_header(const char *name)
|
|||||||
static void probe_object_footer(const char *name)
|
static void probe_object_footer(const char *name)
|
||||||
{
|
{
|
||||||
probe_group_leave();
|
probe_group_leave();
|
||||||
if (print_object_footer)
|
if (octx.print_object_footer)
|
||||||
print_object_footer(name);
|
octx.print_object_footer(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void probe_int(const char *key, int64_t value)
|
static void probe_int(const char *key, int64_t value)
|
||||||
{
|
{
|
||||||
print_integer(key, value);
|
octx.print_integer(key, value);
|
||||||
octx.prefix[octx.level -1].nb_elems++;
|
octx.prefix[octx.level -1].nb_elems++;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void probe_str(const char *key, const char *value)
|
static void probe_str(const char *key, const char *value)
|
||||||
{
|
{
|
||||||
print_string(key, value);
|
octx.print_string(key, value);
|
||||||
octx.prefix[octx.level -1].nb_elems++;
|
octx.prefix[octx.level -1].nb_elems++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -810,29 +807,29 @@ static int opt_output_format(const char *opt, const char *arg)
|
|||||||
{
|
{
|
||||||
|
|
||||||
if (!strcmp(arg, "json")) {
|
if (!strcmp(arg, "json")) {
|
||||||
print_header = json_print_header;
|
octx.print_header = json_print_header;
|
||||||
print_footer = json_print_footer;
|
octx.print_footer = json_print_footer;
|
||||||
print_array_header = json_print_array_header;
|
octx.print_array_header = json_print_array_header;
|
||||||
print_array_footer = json_print_array_footer;
|
octx.print_array_footer = json_print_array_footer;
|
||||||
print_object_header = json_print_object_header;
|
octx.print_object_header = json_print_object_header;
|
||||||
print_object_footer = json_print_object_footer;
|
octx.print_object_footer = json_print_object_footer;
|
||||||
|
|
||||||
print_integer = json_print_integer;
|
octx.print_integer = json_print_integer;
|
||||||
print_string = json_print_string;
|
octx.print_string = json_print_string;
|
||||||
} else if (!strcmp(arg, "ini")) {
|
} else if (!strcmp(arg, "ini")) {
|
||||||
print_header = ini_print_header;
|
octx.print_header = ini_print_header;
|
||||||
print_footer = ini_print_footer;
|
octx.print_footer = ini_print_footer;
|
||||||
print_array_header = ini_print_array_header;
|
octx.print_array_header = ini_print_array_header;
|
||||||
print_object_header = ini_print_object_header;
|
octx.print_object_header = ini_print_object_header;
|
||||||
|
|
||||||
print_integer = ini_print_integer;
|
octx.print_integer = ini_print_integer;
|
||||||
print_string = ini_print_string;
|
octx.print_string = ini_print_string;
|
||||||
} else if (!strcmp(arg, "old")) {
|
} else if (!strcmp(arg, "old")) {
|
||||||
print_header = NULL;
|
octx.print_header = NULL;
|
||||||
print_object_header = old_print_object_header;
|
octx.print_object_header = old_print_object_header;
|
||||||
print_object_footer = old_print_object_footer;
|
octx.print_object_footer = old_print_object_footer;
|
||||||
|
|
||||||
print_string = old_print_string;
|
octx.print_string = old_print_string;
|
||||||
} else {
|
} else {
|
||||||
av_log(NULL, AV_LOG_ERROR, "Unsupported formatter %s\n", arg);
|
av_log(NULL, AV_LOG_ERROR, "Unsupported formatter %s\n", arg);
|
||||||
return AVERROR(EINVAL);
|
return AVERROR(EINVAL);
|
||||||
@ -844,15 +841,15 @@ static int opt_show_format_entry(const char *opt, const char *arg)
|
|||||||
{
|
{
|
||||||
do_show_format = 1;
|
do_show_format = 1;
|
||||||
nb_fmt_entries_to_show++;
|
nb_fmt_entries_to_show++;
|
||||||
print_header = NULL;
|
octx.print_header = NULL;
|
||||||
print_footer = NULL;
|
octx.print_footer = NULL;
|
||||||
print_array_header = NULL;
|
octx.print_array_header = NULL;
|
||||||
print_array_footer = NULL;
|
octx.print_array_footer = NULL;
|
||||||
print_object_header = NULL;
|
octx.print_object_header = NULL;
|
||||||
print_object_footer = NULL;
|
octx.print_object_footer = NULL;
|
||||||
|
|
||||||
print_integer = show_format_entry_integer;
|
octx.print_integer = show_format_entry_integer;
|
||||||
print_string = show_format_entry_string;
|
octx.print_string = show_format_entry_string;
|
||||||
av_dict_set(&fmt_entries_to_show, arg, "", 0);
|
av_dict_set(&fmt_entries_to_show, arg, "", 0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -952,6 +949,15 @@ int main(int argc, char **argv)
|
|||||||
if (!probe_out)
|
if (!probe_out)
|
||||||
exit(1);
|
exit(1);
|
||||||
|
|
||||||
|
octx.print_header = ini_print_header;
|
||||||
|
octx.print_footer = ini_print_footer;
|
||||||
|
|
||||||
|
octx.print_array_header = ini_print_array_header;
|
||||||
|
octx.print_object_header = ini_print_object_header;
|
||||||
|
|
||||||
|
octx.print_integer = ini_print_integer;
|
||||||
|
octx.print_string = ini_print_string;
|
||||||
|
|
||||||
probe_header();
|
probe_header();
|
||||||
ret = probe_file(input_filename);
|
ret = probe_file(input_filename);
|
||||||
probe_footer();
|
probe_footer();
|
||||||
|
Loading…
Reference in New Issue
Block a user