diff options
author | Anton Khirnov <anton@khirnov.net> | 2023-01-29 22:13:33 +0100 |
---|---|---|
committer | Anton Khirnov <anton@khirnov.net> | 2023-01-31 09:08:03 +0100 |
commit | 5c36f4ef8410008d508b9ca348441903a15a6f7c (patch) | |
tree | 27126e1d3ade4191027a496b3d38ecfa5f1d9ef5 | |
parent | e3a99041b80e915efc021f93eef1c3fddf41199c (diff) | |
download | ffmpeg-5c36f4ef8410008d508b9ca348441903a15a6f7c.tar.gz |
lavu/opt: use AV_DICT_MULTIKEY in av_opt_set_dict2()
If the dictionary provided on input contains multiple entries for an
option (relevant for flags modifying the previous value with '+' or
'-') and the option is not found in the target object, only the last
entry would be returned to the caller.
Pass AV_DICT_MULTIKEY to av_dict_set() to make sure all such entries are
returned.
-rw-r--r-- | libavutil/opt.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/libavutil/opt.c b/libavutil/opt.c index 0a909a8b22..0908751752 100644 --- a/libavutil/opt.c +++ b/libavutil/opt.c @@ -1752,7 +1752,7 @@ int av_opt_set_dict2(void *obj, AVDictionary **options, int search_flags) while ((t = av_dict_iterate(*options, t))) { ret = av_opt_set(obj, t->key, t->value, search_flags); if (ret == AVERROR_OPTION_NOT_FOUND) - ret = av_dict_set(&tmp, t->key, t->value, 0); + ret = av_dict_set(&tmp, t->key, t->value, AV_DICT_MULTIKEY); if (ret < 0) { av_log(obj, AV_LOG_ERROR, "Error setting option %s to value %s.\n", t->key, t->value); av_dict_free(&tmp); |