make AVOptions default value field work.
authorPanagiotis Issaris <takis.issaris@uhasselt.be>
Sun, 10 Sep 2006 20:21:40 +0000 (20:21 +0000)
committerGuillaume Poirier <gpoirier@mplayerhq.hu>
Sun, 10 Sep 2006 20:21:40 +0000 (20:21 +0000)
Patch by Panagiotis Issaris % takis P issaris A uhasselt P be %
Original thread:
Date: Sep 8, 2006 3:22 PM
Subject: [Ffmpeg-devel] [PATCH 1/2] Enable usage of AVOption default value

Originally committed as revision 6224 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/opt.c
libavcodec/opt.h
libavcodec/utils.c
libavformat/utils.c

index 0bdef5c984aeabffa248e483e1215e855f3b6e68..84ea19117d0641eee98430b062afcb0e855c2bb4 100644 (file)
@@ -299,3 +299,40 @@ int av_opt_show(void *obj, void *av_log_obj){
     }
     return 0;
 }
+
+void av_opt_set_defaults(void *s)
+{
+    AVOption *opt = NULL;
+    while ((opt = av_next_option(s, opt)) != NULL) {
+        switch(opt->type) {
+            case FF_OPT_TYPE_CONST:
+                /* Nothing to be done here */
+            break;
+            case FF_OPT_TYPE_FLAGS:
+            case FF_OPT_TYPE_INT: {
+                int val;
+                val = opt->default_val;
+                av_set_int(s, opt->name, val);
+            }
+            break;
+            case FF_OPT_TYPE_FLOAT: {
+                double val;
+                val = opt->default_val;
+                av_set_double(s, opt->name, val);
+            }
+            break;
+            case FF_OPT_TYPE_RATIONAL: {
+                AVRational val;
+                val = av_d2q(opt->default_val, INT_MAX);
+                av_set_q(s, opt->name, val);
+            }
+            break;
+            case FF_OPT_TYPE_STRING:
+                /* Cannot set default for string as default_val is of type * double */
+            break;
+            default:
+                av_log(s, AV_LOG_DEBUG, "AVOption type %d of option %s not implemented yet\n", opt->type, opt->name);
+        }
+    }
+}
+
index 92a4535ecf08dafa7c61589a3f63e8dae5edca29..e7be7b54f41e292e1334ab08c3e3cf5220be5602 100644 (file)
@@ -76,5 +76,6 @@ int64_t av_get_int(void *obj, const char *name, AVOption **o_out);
 const char *av_get_string(void *obj, const char *name, AVOption **o_out, char *buf, int buf_len);
 AVOption *av_next_option(void *obj, AVOption *last);
 int av_opt_show(void *obj, void *av_log_obj);
+void av_opt_set_defaults(void *s);
 
 #endif
index 0e59852eaefb530feb662bc6c1fdb007b74c4945..5aba3dac8a2be789c70686b92cf930fabda1cdfd 100644 (file)
@@ -765,6 +765,9 @@ void avcodec_get_context_defaults(AVCodecContext *s){
     memset(s, 0, sizeof(AVCodecContext));
 
     s->av_class= &av_codec_context_class;
+
+    av_opt_set_defaults(s);
+
     s->bit_rate= 800*1000;
     s->bit_rate_tolerance= s->bit_rate*10;
     s->qmin= 2;
index d9b57897dc83e5ca5189c18696bc2ceac06a6c8f..a9adb2b3f466f38396256649eaa7e0c661911836 100644 (file)
@@ -486,6 +486,10 @@ static
 void avformat_get_context_defaults(AVFormatContext *s){
     memset(s, 0, sizeof(AVFormatContext));
 
+    s->av_class = &av_format_context_class;
+
+    av_opt_set_defaults(s);
+
     /* from mpegts.c: 1.0 second at 24Mbit/s */
     s->probesize=32000;
 }