[FFmpeg-cvslog] r26199 - in trunk: cmdutils.c ffmpeg.c
cehoyos
subversion
Sun Jan 2 17:00:47 CET 2011
Author: cehoyos
Date: Sun Jan 2 17:00:47 2011
New Revision: 26199
Log:
Use AVOption for muxers in ffmpeg.
Patch by Anssi Hannula, anssi d hannula d iki d fi
Modified:
trunk/cmdutils.c
trunk/ffmpeg.c
Modified: trunk/cmdutils.c
==============================================================================
--- trunk/cmdutils.c Sun Jan 2 13:42:49 2011 (r26198)
+++ trunk/cmdutils.c Sun Jan 2 17:00:47 2011 (r26199)
@@ -241,12 +241,20 @@ int opt_default(const char *opt, const c
}
if (!o) {
AVCodec *p = NULL;
+ AVOutputFormat *oformat = NULL;
while ((p=av_codec_next(p))){
AVClass *c= p->priv_class;
if(c && av_find_opt(&c, opt, NULL, 0, 0))
break;
}
- if(!p){
+ if (!p) {
+ while ((oformat = av_oformat_next(oformat))) {
+ const AVClass *c = oformat->priv_class;
+ if (c && av_find_opt(&c, opt, NULL, 0, 0))
+ break;
+ }
+ }
+ if(!p && !oformat){
fprintf(stderr, "Unrecognized option '%s'\n", opt);
exit(1);
}
@@ -322,7 +330,13 @@ void set_context_opts(void *ctx, void *o
if(codec && codec->priv_class && avctx->priv_data){
priv_ctx= avctx->priv_data;
}
+ } else if (!strcmp("AVFormatContext", (*(AVClass**)ctx)->class_name)) {
+ AVFormatContext *avctx = ctx;
+ if (avctx->oformat && avctx->oformat->priv_class) {
+ priv_ctx = avctx->priv_data;
+ }
}
+
for(i=0; i<opt_name_count; i++){
char buf[256];
const AVOption *opt;
Modified: trunk/ffmpeg.c
==============================================================================
--- trunk/ffmpeg.c Sun Jan 2 13:42:49 2011 (r26198)
+++ trunk/ffmpeg.c Sun Jan 2 17:00:47 2011 (r26199)
@@ -3904,6 +3904,7 @@ static void show_usage(void)
static void show_help(void)
{
AVCodec *c;
+ AVOutputFormat *oformat = NULL;
av_log_set_callback(log_callback_help);
show_usage();
@@ -3945,6 +3946,15 @@ static void show_help(void)
av_opt_show2(avformat_opts, NULL, AV_OPT_FLAG_ENCODING_PARAM|AV_OPT_FLAG_DECODING_PARAM, 0);
printf("\n");
+
+ /* individual muxer options */
+ while ((oformat = av_oformat_next(oformat))) {
+ if (oformat->priv_class) {
+ av_opt_show2(&oformat->priv_class, NULL, AV_OPT_FLAG_ENCODING_PARAM, 0);
+ printf("\n");
+ }
+ }
+
av_opt_show2(sws_opts, NULL, AV_OPT_FLAG_ENCODING_PARAM|AV_OPT_FLAG_DECODING_PARAM, 0);
}
More information about the ffmpeg-cvslog
mailing list