}
/* Here's where the strings are passed to avutil for parsing. */
- ret = av_set_string3( context, name, value, 1, NULL );
+ ret = hb_av_set_string( context, codec, name, value );
/* Let avutil sanity check the options for us*/
if( ret == AVERROR_OPTION_NOT_FOUND )
hb_log( "avcodec options: Unknown option %s", name );
+
if( ret == AVERROR(EINVAL) )
- hb_log( "avcodec options: Bad argument %s=%s", name, value ? value : "(null)" );
+ hb_log( "avcodec options: Bad argument %s=%s",
+ name, value ? value : "(null)" );
}
}
free(opts_start);
}
context = avcodec_alloc_context3(codec);
- int ret = av_set_string3( context, "stereo_mode", "ms_off", 1, NULL );
- /* Let avutil sanity check the options for us*/
- if( ret == AVERROR(ENOENT) )
- hb_log( "avcodec options: Unknown option %s", "stereo_mode" );
- if( ret == AVERROR(EINVAL) )
- hb_log( "avcodec options: Bad argument %s=%s", "stereo_mode", "ms_off" ? "ms_off" : "(null)" );
+ if ( w->codec_param == CODEC_ID_AAC )
+ {
+ int ret = hb_av_set_string( context, codec, "stereo_mode", "ms_off" );
+ /* Let avutil sanity check the options for us*/
+ if( ret == AVERROR_OPTION_NOT_FOUND )
+ hb_log( "avcodec options: Unknown option %s", "stereo_mode" );
+
+ if( ret == AVERROR(EINVAL) )
+ hb_log( "avcodec options: Bad argument %s=%s",
+ "stereo_mode", "ms_off" ? "ms_off" : "(null)" );
+ }
context->channel_layout = AV_CH_LAYOUT_STEREO;
switch( audio->config.out.mixdown )
return ret;
}
+int hb_av_set_string( AVCodecContext *c, AVCodec *codec, const char *name, const char *val )
+{
+ void * priv_context = NULL;
+
+ if ( c && codec && codec->priv_class && c->priv_data )
+ priv_context = c->priv_data;
+
+ int ret = av_set_string3( c, name, val, 1, NULL );
+ if ( ret == AVERROR_OPTION_NOT_FOUND && priv_context )
+ ret = av_set_string3( priv_context, name, val, 1, NULL );
+
+ return ret;
+}
+
static int handle_jpeg(enum PixelFormat *format)
{
switch (*format) {
int dstW, int dstH, enum PixelFormat dstFormat,
int flags);
void hb_ff_set_sample_fmt(AVCodecContext *context, AVCodec *codec);
+int hb_av_set_string( AVCodecContext *c, AVCodec *codec, const char *name, const char *val );
case HB_VCODEC_X264:
hb_log( " + encoder: x264" );
- if( job->advanced_opts != NULL && *job->advanced_opts != '\0' )
- hb_log( " + options: %s", job->advanced_opts);
break;
case HB_VCODEC_THEORA:
break;
}
+ if ( job->advanced_opts && *job->advanced_opts &&
+ ( ( job->vcodec & HB_VCODEC_FFMPEG_MASK ) ||
+ job->vcodec == HB_VCODEC_X264 ) )
+ {
+ hb_log( " + options: %s", job->advanced_opts);
+ }
+
if( job->vquality >= 0 )
{
hb_log( " + quality: %.2f %s", job->vquality, job->vcodec == HB_VCODEC_X264 ? "(RF)" : "(QP)" );