diff options
author | Anton Khirnov <anton@khirnov.net> | 2022-03-14 12:30:31 +0100 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2024-01-20 10:23:24 +0100 |
commit | 4ce1987abca4140d2f04f3de3412cbc59a08f322 (patch) | |
tree | 04bfa533c33f6f28faee2749d96092ff7c35d5f5 | |
parent | 568dfed06fa38c6cff3a33a444906792055cd2a9 (diff) | |
download | ffmpeg-4ce1987abca4140d2f04f3de3412cbc59a08f322.tar.gz |
fftools/ffprobe: make option strings dynamically allocated
Do not store the supplied arg pointer directly. While that is valid for
now, arg will become ephemeral in the future commits.
-rw-r--r-- | fftools/ffprobe.c | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/fftools/ffprobe.c b/fftools/ffprobe.c index f00ba48620..ea1365688d 100644 --- a/fftools/ffprobe.c +++ b/fftools/ffprobe.c @@ -3828,7 +3828,9 @@ static int opt_input_file(void *optctx, const char *arg) } if (!strcmp(arg, "-")) arg = "fd:"; - input_filename = arg; + input_filename = av_strdup(arg); + if (!input_filename) + return AVERROR(ENOMEM); return 0; } @@ -3849,15 +3851,18 @@ static int opt_output_file_o(void *optctx, const char *opt, const char *arg) } if (!strcmp(arg, "-")) arg = "fd:"; - output_filename = arg; + output_filename = av_strdup(arg); + if (!output_filename) + return AVERROR(ENOMEM); return 0; } static int opt_print_filename(void *optctx, const char *opt, const char *arg) { - print_input_filename = arg; - return 0; + av_freep(&print_input_filename); + print_input_filename = av_strdup(arg); + return print_input_filename ? 0 : AVERROR(ENOMEM); } void show_help_default(const char *opt, const char *arg) @@ -4287,6 +4292,9 @@ int main(int argc, char **argv) end: av_freep(&output_format); + av_freep(&output_filename); + av_freep(&input_filename); + av_freep(&print_input_filename); av_freep(&read_intervals); av_hash_freep(&hash); |