]> git.sesse.net Git - ffmpeg/blobdiff - libavutil/opt.c
Merge commit '89923e418b494e337683442ab896d754bc07341a'
[ffmpeg] / libavutil / opt.c
index 4fd25ff86fdff39eedc4dcb8458589adaf2b16fe..eae4f75dcd37f8889f40d5d528f33a7a221eef51 100644 (file)
@@ -1476,10 +1476,11 @@ int av_opt_set_dict2(void *obj, AVDictionary **options, int search_flags)
     while ((t = av_dict_get(*options, "", t, AV_DICT_IGNORE_SUFFIX))) {
         ret = av_opt_set(obj, t->key, t->value, search_flags);
         if (ret == AVERROR_OPTION_NOT_FOUND)
-            av_dict_set(&tmp, t->key, t->value, 0);
-        else if (ret < 0) {
+            ret = av_dict_set(&tmp, t->key, t->value, 0);
+        if (ret < 0) {
             av_log(obj, AV_LOG_ERROR, "Error setting option %s to value %s.\n", t->key, t->value);
-            break;
+            av_dict_free(&tmp);
+            return ret;
         }
         ret = 0;
     }