Commit b545b947 authored by Clément Bœsch's avatar Clément Bœsch

ffprobe: replace fast_asprintf() with bprint utils.

Also remove the unused print_fmt_opt() in the process.
parent 9548deee
...@@ -358,44 +358,6 @@ static const Writer *writer_get_by_name(const char *name) ...@@ -358,44 +358,6 @@ static const Writer *writer_get_by_name(const char *name)
return NULL; return NULL;
} }
/* Print helpers */
struct print_buf {
char *s;
int len;
};
static char *fast_asprintf(struct print_buf *pbuf, const char *fmt, ...)
{
va_list va;
int len;
va_start(va, fmt);
len = vsnprintf(NULL, 0, fmt, va);
va_end(va);
if (len < 0)
goto fail;
if (pbuf->len < len) {
char *p = av_realloc(pbuf->s, len + 1);
if (!p)
goto fail;
pbuf->s = p;
pbuf->len = len;
}
va_start(va, fmt);
len = vsnprintf(pbuf->s, len + 1, fmt, va);
va_end(va);
if (len < 0)
goto fail;
return pbuf->s;
fail:
av_freep(&pbuf->s);
pbuf->len = 0;
return NULL;
}
/* WRITERS */ /* WRITERS */
...@@ -1214,13 +1176,9 @@ static void writer_register_all(void) ...@@ -1214,13 +1176,9 @@ static void writer_register_all(void)
} }
#define print_fmt(k, f, ...) do { \ #define print_fmt(k, f, ...) do { \
if (fast_asprintf(&pbuf, f, __VA_ARGS__)) \ av_bprint_clear(&pbuf); \
writer_print_string(w, k, pbuf.s, 0); \ av_bprintf(&pbuf, f, __VA_ARGS__); \
} while (0) writer_print_string(w, k, pbuf.str, 0); \
#define print_fmt_opt(k, f, ...) do { \
if (fast_asprintf(&pbuf, f, __VA_ARGS__)) \
writer_print_string(w, k, pbuf.s, 1); \
} while (0) } while (0)
#define print_int(k, v) writer_print_integer(w, k, v) #define print_int(k, v) writer_print_integer(w, k, v)
...@@ -1238,9 +1196,11 @@ static void show_packet(WriterContext *w, AVFormatContext *fmt_ctx, AVPacket *pk ...@@ -1238,9 +1196,11 @@ static void show_packet(WriterContext *w, AVFormatContext *fmt_ctx, AVPacket *pk
{ {
char val_str[128]; char val_str[128];
AVStream *st = fmt_ctx->streams[pkt->stream_index]; AVStream *st = fmt_ctx->streams[pkt->stream_index];
struct print_buf pbuf = {.s = NULL}; AVBPrint pbuf;
const char *s; const char *s;
av_bprint_init(&pbuf, 1, AV_BPRINT_SIZE_UNLIMITED);
print_section_header("packet"); print_section_header("packet");
s = av_get_media_type_string(st->codec->codec_type); s = av_get_media_type_string(st->codec->codec_type);
if (s) print_str ("codec_type", s); if (s) print_str ("codec_type", s);
...@@ -1258,15 +1218,17 @@ static void show_packet(WriterContext *w, AVFormatContext *fmt_ctx, AVPacket *pk ...@@ -1258,15 +1218,17 @@ static void show_packet(WriterContext *w, AVFormatContext *fmt_ctx, AVPacket *pk
print_fmt("flags", "%c", pkt->flags & AV_PKT_FLAG_KEY ? 'K' : '_'); print_fmt("flags", "%c", pkt->flags & AV_PKT_FLAG_KEY ? 'K' : '_');
print_section_footer("packet"); print_section_footer("packet");
av_free(pbuf.s); av_bprint_finalize(&pbuf, NULL);
fflush(stdout); fflush(stdout);
} }
static void show_frame(WriterContext *w, AVFrame *frame, AVStream *stream) static void show_frame(WriterContext *w, AVFrame *frame, AVStream *stream)
{ {
struct print_buf pbuf = {.s = NULL}; AVBPrint pbuf;
const char *s; const char *s;
av_bprint_init(&pbuf, 1, AV_BPRINT_SIZE_UNLIMITED);
print_section_header("frame"); print_section_header("frame");
s = av_get_media_type_string(stream->codec->codec_type); s = av_get_media_type_string(stream->codec->codec_type);
...@@ -1313,7 +1275,7 @@ static void show_frame(WriterContext *w, AVFrame *frame, AVStream *stream) ...@@ -1313,7 +1275,7 @@ static void show_frame(WriterContext *w, AVFrame *frame, AVStream *stream)
print_section_footer("frame"); print_section_footer("frame");
av_free(pbuf.s); av_bprint_finalize(&pbuf, NULL);
fflush(stdout); fflush(stdout);
} }
...@@ -1392,7 +1354,9 @@ static void show_stream(WriterContext *w, AVFormatContext *fmt_ctx, int stream_i ...@@ -1392,7 +1354,9 @@ static void show_stream(WriterContext *w, AVFormatContext *fmt_ctx, int stream_i
char val_str[128]; char val_str[128];
const char *s; const char *s;
AVRational display_aspect_ratio; AVRational display_aspect_ratio;
struct print_buf pbuf = {.s = NULL}; AVBPrint pbuf;
av_bprint_init(&pbuf, 1, AV_BPRINT_SIZE_UNLIMITED);
print_section_header("stream"); print_section_header("stream");
...@@ -1492,7 +1456,7 @@ static void show_stream(WriterContext *w, AVFormatContext *fmt_ctx, int stream_i ...@@ -1492,7 +1456,7 @@ static void show_stream(WriterContext *w, AVFormatContext *fmt_ctx, int stream_i
show_tags(stream->metadata); show_tags(stream->metadata);
print_section_footer("stream"); print_section_footer("stream");
av_free(pbuf.s); av_bprint_finalize(&pbuf, NULL);
fflush(stdout); fflush(stdout);
} }
...@@ -1640,7 +1604,8 @@ static void show_usage(void) ...@@ -1640,7 +1604,8 @@ static void show_usage(void)
static void ffprobe_show_program_version(WriterContext *w) static void ffprobe_show_program_version(WriterContext *w)
{ {
struct print_buf pbuf = {.s = NULL}; AVBPrint pbuf;
av_bprint_init(&pbuf, 1, AV_BPRINT_SIZE_UNLIMITED);
writer_print_chapter_header(w, "program_version"); writer_print_chapter_header(w, "program_version");
print_section_header("program_version"); print_section_header("program_version");
...@@ -1655,7 +1620,7 @@ static void ffprobe_show_program_version(WriterContext *w) ...@@ -1655,7 +1620,7 @@ static void ffprobe_show_program_version(WriterContext *w)
print_section_footer("program_version"); print_section_footer("program_version");
writer_print_chapter_footer(w, "program_version"); writer_print_chapter_footer(w, "program_version");
av_free(pbuf.s); av_bprint_finalize(&pbuf, NULL);
} }
#define SHOW_LIB_VERSION(libname, LIBNAME) \ #define SHOW_LIB_VERSION(libname, LIBNAME) \
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment