Commit 6d5d33d4 authored by Rémi Duraffort's avatar Rémi Duraffort

codec: use var_Get(Integer|Float|String) when applicable.

parent 2987efc5
...@@ -202,7 +202,9 @@ int OpenEncoder( vlc_object_t *p_this ) ...@@ -202,7 +202,9 @@ int OpenEncoder( vlc_object_t *p_this )
AVCodec *p_codec; AVCodec *p_codec;
int i_codec_id, i_cat; int i_codec_id, i_cat;
const char *psz_namecodec; const char *psz_namecodec;
vlc_value_t val; float f_val;
char *psz_val;
int i_val;
if( !GetFfmpegCodec( p_enc->fmt_out.i_codec, &i_cat, &i_codec_id, if( !GetFfmpegCodec( p_enc->fmt_out.i_codec, &i_cat, &i_codec_id,
&psz_namecodec ) ) &psz_namecodec ) )
...@@ -306,106 +308,77 @@ int OpenEncoder( vlc_object_t *p_this ) ...@@ -306,106 +308,77 @@ int OpenEncoder( vlc_object_t *p_this )
config_ChainParse( p_enc, ENC_CFG_PREFIX, ppsz_enc_options, p_enc->p_cfg ); config_ChainParse( p_enc, ENC_CFG_PREFIX, ppsz_enc_options, p_enc->p_cfg );
var_Get( p_enc, ENC_CFG_PREFIX "keyint", &val ); p_sys->i_key_int = var_GetInteger( p_enc, ENC_CFG_PREFIX "keyint" );
p_sys->i_key_int = val.i_int; p_sys->i_b_frames = var_GetInteger( p_enc, ENC_CFG_PREFIX "bframes" );
p_sys->i_vtolerance = var_GetInteger( p_enc, ENC_CFG_PREFIX "vt" ) * 1000;
p_sys->b_interlace = var_GetBool( p_enc, ENC_CFG_PREFIX "interlace" );
p_sys->b_interlace_me = var_GetBool( p_enc, ENC_CFG_PREFIX "interlace-me" );
p_sys->b_pre_me = var_GetBool( p_enc, ENC_CFG_PREFIX "pre-me" );
p_sys->b_hurry_up = var_GetBool( p_enc, ENC_CFG_PREFIX "hurry-up" );
var_Get( p_enc, ENC_CFG_PREFIX "bframes", &val );
p_sys->i_b_frames = val.i_int;
var_Get( p_enc, ENC_CFG_PREFIX "vt", &val );
p_sys->i_vtolerance = val.i_int * 1000;
var_Get( p_enc, ENC_CFG_PREFIX "interlace", &val );
p_sys->b_interlace = val.b_bool;
var_Get( p_enc, ENC_CFG_PREFIX "interlace-me", &val );
p_sys->b_interlace_me = val.b_bool;
var_Get( p_enc, ENC_CFG_PREFIX "pre-me", &val );
p_sys->b_pre_me = val.b_bool;
var_Get( p_enc, ENC_CFG_PREFIX "hurry-up", &val );
p_sys->b_hurry_up = val.b_bool;
if( p_sys->b_hurry_up ) if( p_sys->b_hurry_up )
{ {
/* hurry up mode needs noise reduction, even small */ /* hurry up mode needs noise reduction, even small */
p_sys->i_noise_reduction = 1; p_sys->i_noise_reduction = 1;
} }
var_Get( p_enc, ENC_CFG_PREFIX "rc-buffer-size", &val ); p_sys->i_rc_buffer_size = var_GetInteger( p_enc, ENC_CFG_PREFIX "rc-buffer-size" );
p_sys->i_rc_buffer_size = val.i_int; p_sys->f_rc_buffer_aggressivity = var_GetFloat( p_enc, ENC_CFG_PREFIX "rc-buffer-aggressivity" );
var_Get( p_enc, ENC_CFG_PREFIX "rc-buffer-aggressivity", &val ); p_sys->f_i_quant_factor = var_GetFloat( p_enc, ENC_CFG_PREFIX "i-quant-factor" );
p_sys->f_rc_buffer_aggressivity = val.f_float; p_sys->i_noise_reduction = var_GetInteger( p_enc, ENC_CFG_PREFIX "noise-reduction" );
p_sys->b_mpeg4_matrix = var_GetBool( p_enc, ENC_CFG_PREFIX "mpeg4-matrix" );
var_Get( p_enc, ENC_CFG_PREFIX "i-quant-factor", &val );
p_sys->f_i_quant_factor = val.f_float;
var_Get( p_enc, ENC_CFG_PREFIX "noise-reduction", &val ); f_val = var_GetFloat( p_enc, ENC_CFG_PREFIX "qscale" );
p_sys->i_noise_reduction = val.i_int; if( f_val < 0.01 || f_val > 255.0 ) f_val = 0;
p_sys->i_quality = (int)(FF_QP2LAMBDA * f_val + 0.5);
var_Get( p_enc, ENC_CFG_PREFIX "mpeg4-matrix", &val ); psz_val = var_GetString( p_enc, ENC_CFG_PREFIX "hq" );
p_sys->b_mpeg4_matrix = val.b_bool;
var_Get( p_enc, ENC_CFG_PREFIX "qscale", &val );
if( val.f_float < 0.01 || val.f_float > 255.0 ) val.f_float = 0;
p_sys->i_quality = (int)(FF_QP2LAMBDA * val.f_float + 0.5);
var_Get( p_enc, ENC_CFG_PREFIX "hq", &val );
p_sys->i_hq = FF_MB_DECISION_RD; p_sys->i_hq = FF_MB_DECISION_RD;
if( val.psz_string && *val.psz_string ) if( psz_val && *psz_val )
{ {
if( !strcmp( val.psz_string, "rd" ) ) if( !strcmp( psz_val, "rd" ) )
p_sys->i_hq = FF_MB_DECISION_RD; p_sys->i_hq = FF_MB_DECISION_RD;
else if( !strcmp( val.psz_string, "bits" ) ) else if( !strcmp( psz_val, "bits" ) )
p_sys->i_hq = FF_MB_DECISION_BITS; p_sys->i_hq = FF_MB_DECISION_BITS;
else if( !strcmp( val.psz_string, "simple" ) ) else if( !strcmp( psz_val, "simple" ) )
p_sys->i_hq = FF_MB_DECISION_SIMPLE; p_sys->i_hq = FF_MB_DECISION_SIMPLE;
else else
p_sys->i_hq = FF_MB_DECISION_RD; p_sys->i_hq = FF_MB_DECISION_RD;
} }
else else
p_sys->i_hq = FF_MB_DECISION_RD; p_sys->i_hq = FF_MB_DECISION_RD;
free( val.psz_string ); free( psz_val );
var_Get( p_enc, ENC_CFG_PREFIX "qmin", &val ); p_sys->i_qmin = var_GetInteger( p_enc, ENC_CFG_PREFIX "qmin" );
p_sys->i_qmin = val.i_int; p_sys->i_qmax = var_GetInteger( p_enc, ENC_CFG_PREFIX "qmax" );
var_Get( p_enc, ENC_CFG_PREFIX "qmax", &val ); p_sys->b_trellis = var_GetBool( p_enc, ENC_CFG_PREFIX "trellis" );
p_sys->i_qmax = val.i_int;
var_Get( p_enc, ENC_CFG_PREFIX "trellis", &val ); i_val = var_GetInteger( p_enc, ENC_CFG_PREFIX "strict" );
p_sys->b_trellis = val.b_bool; if( i_val < - 1 || i_val > 1 ) i_val = 0;
p_context->strict_std_compliance = i_val;
var_Get( p_enc, ENC_CFG_PREFIX "strict", &val );
if( val.i_int < - 1 || val.i_int > 1 ) val.i_int = 0; p_sys->f_lumi_masking = var_GetFloat( p_enc, ENC_CFG_PREFIX "lumi-masking" );
p_context->strict_std_compliance = val.i_int; p_sys->f_dark_masking = var_GetFloat( p_enc, ENC_CFG_PREFIX "dark-masking" );
p_sys->f_p_masking = var_GetFloat( p_enc, ENC_CFG_PREFIX "p-masking" );
var_Get( p_enc, ENC_CFG_PREFIX "lumi-masking", &val ); p_sys->f_border_masking = var_GetFloat( p_enc, ENC_CFG_PREFIX "border-masking" );
p_sys->f_lumi_masking = val.f_float; p_sys->i_luma_elim = var_GetInteger( p_enc, ENC_CFG_PREFIX "luma-elim-threshold" );
var_Get( p_enc, ENC_CFG_PREFIX "dark-masking", &val ); p_sys->i_chroma_elim = var_GetInteger( p_enc, ENC_CFG_PREFIX "chroma-elim-threshold" );
p_sys->f_dark_masking = val.f_float;
var_Get( p_enc, ENC_CFG_PREFIX "p-masking", &val ); psz_val = var_GetString( p_enc, ENC_CFG_PREFIX "aac-profile" );
p_sys->f_p_masking = val.f_float;
var_Get( p_enc, ENC_CFG_PREFIX "border-masking", &val );
p_sys->f_border_masking = val.f_float;
var_Get( p_enc, ENC_CFG_PREFIX "luma-elim-threshold", &val );
p_sys->i_luma_elim = val.i_int;
var_Get( p_enc, ENC_CFG_PREFIX "chroma-elim-threshold", &val );
p_sys->i_chroma_elim = val.i_int;
var_Get( p_enc, ENC_CFG_PREFIX "aac-profile", &val );
/* ffmpeg uses faac encoder atm, and it has issues with /* ffmpeg uses faac encoder atm, and it has issues with
* other than low-complexity profile, so default to that */ * other than low-complexity profile, so default to that */
p_sys->i_aac_profile = FF_PROFILE_AAC_LOW; p_sys->i_aac_profile = FF_PROFILE_AAC_LOW;
if( val.psz_string && *val.psz_string ) if( psz_val && *psz_val )
{ {
if( !strncmp( val.psz_string, "main", 4 ) ) if( !strncmp( psz_val, "main", 4 ) )
p_sys->i_aac_profile = FF_PROFILE_AAC_MAIN; p_sys->i_aac_profile = FF_PROFILE_AAC_MAIN;
else if( !strncmp( val.psz_string, "low", 3 ) ) else if( !strncmp( psz_val, "low", 3 ) )
p_sys->i_aac_profile = FF_PROFILE_AAC_LOW; p_sys->i_aac_profile = FF_PROFILE_AAC_LOW;
#if 0 /* Not supported by FAAC encoder */ #if 0 /* Not supported by FAAC encoder */
else if( !strncmp( val.psz_string, "ssr", 3 ) ) else if( !strncmp( psz_val, "ssr", 3 ) )
p_sys->i_aac_profile = FF_PROFILE_AAC_SSR; p_sys->i_aac_profile = FF_PROFILE_AAC_SSR;
#endif #endif
else if( !strncmp( val.psz_string, "ltp", 3 ) ) else if( !strncmp( psz_val, "ltp", 3 ) )
p_sys->i_aac_profile = FF_PROFILE_AAC_LTP; p_sys->i_aac_profile = FF_PROFILE_AAC_LTP;
else else
{ {
...@@ -413,7 +386,7 @@ int OpenEncoder( vlc_object_t *p_this ) ...@@ -413,7 +386,7 @@ int OpenEncoder( vlc_object_t *p_this )
p_sys->i_aac_profile = FF_PROFILE_AAC_LOW; p_sys->i_aac_profile = FF_PROFILE_AAC_LOW;
} }
} }
free( val.psz_string ); free( psz_val );
if( p_enc->fmt_in.i_cat == VIDEO_ES ) if( p_enc->fmt_in.i_cat == VIDEO_ES )
{ {
......
...@@ -323,7 +323,6 @@ static int Open( vlc_object_t *p_this ) ...@@ -323,7 +323,6 @@ static int Open( vlc_object_t *p_this )
{ {
decoder_t *p_dec = (decoder_t *) p_this; decoder_t *p_dec = (decoder_t *) p_this;
decoder_sys_t *p_sys; decoder_sys_t *p_sys;
vlc_value_t val;
int i_posx, i_posy; int i_posx, i_posy;
if( p_dec->fmt_in.i_codec != VLC_CODEC_DVBS ) if( p_dec->fmt_in.i_codec != VLC_CODEC_DVBS )
...@@ -332,10 +331,9 @@ static int Open( vlc_object_t *p_this ) ...@@ -332,10 +331,9 @@ static int Open( vlc_object_t *p_this )
} }
p_dec->pf_decode_sub = Decode; p_dec->pf_decode_sub = Decode;
p_sys = p_dec->p_sys = malloc( sizeof(decoder_sys_t) ); p_sys = p_dec->p_sys = calloc( 1, sizeof(decoder_sys_t) );
if( !p_sys ) if( !p_sys )
return VLC_ENOMEM; return VLC_ENOMEM;
memset( p_sys, 0, sizeof(decoder_sys_t) );
p_sys->i_pts = (mtime_t) 0; p_sys->i_pts = (mtime_t) 0;
p_sys->i_id = p_dec->fmt_in.subs.dvb.i_id & 0xFFFF; p_sys->i_id = p_dec->fmt_in.subs.dvb.i_id & 0xFFFF;
...@@ -348,18 +346,10 @@ static int Open( vlc_object_t *p_this ) ...@@ -348,18 +346,10 @@ static int Open( vlc_object_t *p_this )
/* configure for SD res in case DDS is not present */ /* configure for SD res in case DDS is not present */
default_dds_init( p_dec ); default_dds_init( p_dec );
var_Create( p_this, DVBSUB_CFG_PREFIX "position", p_sys->i_spu_position = var_CreateGetInteger( p_this,
VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); DVBSUB_CFG_PREFIX "position" );
var_Get( p_this, DVBSUB_CFG_PREFIX "position", &val ); i_posx = var_CreateGetInteger( p_this, DVBSUB_CFG_PREFIX "x" );
p_sys->i_spu_position = val.i_int; i_posy = var_CreateGetInteger( p_this, DVBSUB_CFG_PREFIX "y" );
var_Create( p_this, DVBSUB_CFG_PREFIX "x",
VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
var_Get( p_this, DVBSUB_CFG_PREFIX "x", &val );
i_posx = val.i_int;
var_Create( p_this, DVBSUB_CFG_PREFIX "y",
VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
var_Get( p_this, DVBSUB_CFG_PREFIX "y", &val );
i_posy = val.i_int;
/* Check if subpicture position was overridden */ /* Check if subpicture position was overridden */
p_sys->b_absolute = true; p_sys->b_absolute = true;
...@@ -876,10 +866,9 @@ static void decode_region_composition( decoder_t *p_dec, bs_t *s ) ...@@ -876,10 +866,9 @@ static void decode_region_composition( decoder_t *p_dec, bs_t *s )
#ifdef DEBUG_DVBSUB #ifdef DEBUG_DVBSUB
msg_Dbg( p_dec, "new region: %i", i_id ); msg_Dbg( p_dec, "new region: %i", i_id );
#endif #endif
p_region = *pp_region = malloc( sizeof(dvbsub_region_t) ); p_region = *pp_region = calloc( 1, sizeof(dvbsub_region_t) );
if( !p_region ) if( !p_region )
return; return;
memset( p_region, 0, sizeof(dvbsub_region_t) );
p_region->p_object_defs = NULL; p_region->p_object_defs = NULL;
p_region->p_pixbuf = NULL; p_region->p_pixbuf = NULL;
p_region->p_next = NULL; p_region->p_next = NULL;
...@@ -1708,7 +1697,6 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -1708,7 +1697,6 @@ static int OpenEncoder( vlc_object_t *p_this )
{ {
encoder_t *p_enc = (encoder_t *)p_this; encoder_t *p_enc = (encoder_t *)p_this;
encoder_sys_t *p_sys; encoder_sys_t *p_sys;
vlc_value_t val;
if( ( p_enc->fmt_out.i_codec != VLC_CODEC_DVBS ) && if( ( p_enc->fmt_out.i_codec != VLC_CODEC_DVBS ) &&
!p_enc->b_force ) !p_enc->b_force )
...@@ -1733,12 +1721,8 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -1733,12 +1721,8 @@ static int OpenEncoder( vlc_object_t *p_this )
p_sys->i_regions = 0; p_sys->i_regions = 0;
p_sys->p_regions = 0; p_sys->p_regions = 0;
var_Create( p_this, ENC_CFG_PREFIX "x", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); p_sys->i_offset_x = var_CreateGetInteger( p_this, ENC_CFG_PREFIX "x" );
var_Get( p_this, ENC_CFG_PREFIX "x", &val ); p_sys->i_offset_y = var_CreateGetInteger( p_this, ENC_CFG_PREFIX "y" );
p_sys->i_offset_x = val.i_int;
var_Create( p_this, ENC_CFG_PREFIX "y", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT );
var_Get( p_this, ENC_CFG_PREFIX "y", &val );
p_sys->i_offset_y = val.i_int;
return VLC_SUCCESS; return VLC_SUCCESS;
} }
......
...@@ -228,7 +228,6 @@ static int OpenDecoder( vlc_object_t *p_this ) ...@@ -228,7 +228,6 @@ static int OpenDecoder( vlc_object_t *p_this )
{ {
decoder_t *p_dec = (decoder_t*)p_this; decoder_t *p_dec = (decoder_t*)p_this;
decoder_sys_t *p_sys; decoder_sys_t *p_sys;
vlc_value_t val;
switch( p_dec->fmt_in.i_codec ) switch( p_dec->fmt_in.i_codec )
{ {
...@@ -312,9 +311,7 @@ static int OpenDecoder( vlc_object_t *p_this ) ...@@ -312,9 +311,7 @@ static int OpenDecoder( vlc_object_t *p_this )
} }
free (psz_charset); free (psz_charset);
var_Create( p_dec, "subsdec-align", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); p_sys->i_align = var_CreateGetInteger( p_dec, "subsdec-align" );
var_Get( p_dec, "subsdec-align", &val );
p_sys->i_align = val.i_int;
if( p_dec->fmt_in.i_codec == VLC_CODEC_SSA if( p_dec->fmt_in.i_codec == VLC_CODEC_SSA
&& var_CreateGetBool( p_dec, "subsdec-formatted" ) ) && var_CreateGetBool( p_dec, "subsdec-formatted" ) )
...@@ -685,6 +682,7 @@ static char *CreateHtmlSubtitle( int *pi_align, char *psz_subtitle ) ...@@ -685,6 +682,7 @@ static char *CreateHtmlSubtitle( int *pi_align, char *psz_subtitle )
psz_tag[ 0 ] = '\0'; psz_tag[ 0 ] = '\0';
/* */ /* */
//Oo + 100 ???
size_t i_buf_size = strlen( psz_subtitle ) + 100; size_t i_buf_size = strlen( psz_subtitle ) + 100;
char *psz_html_start = malloc( i_buf_size ); char *psz_html_start = malloc( i_buf_size );
char *psz_html = psz_html_start; char *psz_html = psz_html_start;
......
...@@ -171,8 +171,8 @@ static int Open( vlc_object_t *p_this ) ...@@ -171,8 +171,8 @@ static int Open( vlc_object_t *p_this )
{ {
decoder_t *p_dec = (decoder_t *) p_this; decoder_t *p_dec = (decoder_t *) p_this;
decoder_sys_t *p_sys = NULL; decoder_sys_t *p_sys = NULL;
vlc_value_t val; int i_val;
int i;
if( p_dec->fmt_in.i_codec != VLC_CODEC_TELETEXT) if( p_dec->fmt_in.i_codec != VLC_CODEC_TELETEXT)
{ {
...@@ -187,25 +187,21 @@ static int Open( vlc_object_t *p_this ) ...@@ -187,25 +187,21 @@ static int Open( vlc_object_t *p_this )
p_dec->fmt_out.i_codec = 0; p_dec->fmt_out.i_codec = 0;
p_sys->i_align = 0; p_sys->i_align = 0;
for ( i = 0; i < 9; i++ ) for ( int i = 0; i < 9; i++ )
p_sys->pi_active_national_set[i] = ppi_national_subsets[1]; p_sys->pi_active_national_set[i] = ppi_national_subsets[1];
var_Create( p_dec, "telx-override-page", i_val = var_CreateGetInteger( p_dec, "telx-override-page" );
VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); if( i_val == -1 && p_dec->fmt_in.subs.teletext.i_magazine != -1 &&
var_Get( p_dec, "telx-override-page", &val );
if( val.i_int == -1 &&
p_dec->fmt_in.subs.teletext.i_magazine != -1 &&
( p_dec->fmt_in.subs.teletext.i_magazine != 1 || ( p_dec->fmt_in.subs.teletext.i_magazine != 1 ||
p_dec->fmt_in.subs.teletext.i_page != 0 ) ) /* ignore if TS demux wants page 100 (unlikely to be sub) */ p_dec->fmt_in.subs.teletext.i_page != 0 ) ) /* ignore if TS demux wants page 100 (unlikely to be sub) */
{ {
bool b_val;
p_sys->i_wanted_magazine = p_dec->fmt_in.subs.teletext.i_magazine; p_sys->i_wanted_magazine = p_dec->fmt_in.subs.teletext.i_magazine;
p_sys->i_wanted_page = p_dec->fmt_in.subs.teletext.i_page; p_sys->i_wanted_page = p_dec->fmt_in.subs.teletext.i_page;
var_Create( p_dec, "telx-french-workaround", b_val = var_CreateGetBool( p_dec, "telx-french-workaround" );
VLC_VAR_BOOL | VLC_VAR_DOINHERIT );
var_Get( p_dec, "telx-french-workaround", &val );
if( p_sys->i_wanted_page < 100 && if( p_sys->i_wanted_page < 100 &&
(val.b_bool || (p_sys->i_wanted_page % 16) >= 10)) (b_val || (p_sys->i_wanted_page % 16) >= 10))
{ {
/* See http://www.nada.kth.se/~ragge/vdr/ttxtsubs/TROUBLESHOOTING.txt /* See http://www.nada.kth.se/~ragge/vdr/ttxtsubs/TROUBLESHOOTING.txt
* paragraph about French channels - they mix up decimal and * paragraph about French channels - they mix up decimal and
...@@ -214,21 +210,19 @@ static int Open( vlc_object_t *p_this ) ...@@ -214,21 +210,19 @@ static int Open( vlc_object_t *p_this )
(p_sys->i_wanted_page % 10); (p_sys->i_wanted_page % 10);
} }
} }
else if( val.i_int <= 0 ) else if( i_val <= 0 )
{ {
p_sys->i_wanted_magazine = -1; p_sys->i_wanted_magazine = -1;
p_sys->i_wanted_page = -1; p_sys->i_wanted_page = -1;
} }
else else
{ {
p_sys->i_wanted_magazine = val.i_int / 100; p_sys->i_wanted_magazine = i_val / 100;
p_sys->i_wanted_page = (((val.i_int % 100) / 10) << 4) p_sys->i_wanted_page = (((i_val % 100) / 10) << 4)
| ((val.i_int % 100) % 10); |((i_val % 100) % 10);
} }
var_Create( p_dec, "telx-ignore-subtitle-flag", p_sys->b_ignore_sub_flag = var_CreateGetBool( p_dec,
VLC_VAR_BOOL | VLC_VAR_DOINHERIT ); "telx-ignore-subtitle-flag" );
var_Get( p_dec, "telx-ignore-subtitle-flag", &val );
p_sys->b_ignore_sub_flag = val.b_bool;
msg_Dbg( p_dec, "starting telx on magazine %d page %02x flag %d", msg_Dbg( p_dec, "starting telx on magazine %d page %02x flag %d",
p_sys->i_wanted_magazine, p_sys->i_wanted_page, p_sys->i_wanted_magazine, p_sys->i_wanted_page,
......
...@@ -605,7 +605,6 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -605,7 +605,6 @@ static int OpenEncoder( vlc_object_t *p_this )
encoder_sys_t *p_sys; encoder_sys_t *p_sys;
ogg_packet header; ogg_packet header;
uint8_t *p_extra; uint8_t *p_extra;
vlc_value_t val;
int i_quality, i; int i_quality, i;
if( p_enc->fmt_out.i_codec != VLC_CODEC_THEORA && if( p_enc->fmt_out.i_codec != VLC_CODEC_THEORA &&
...@@ -625,8 +624,7 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -625,8 +624,7 @@ static int OpenEncoder( vlc_object_t *p_this )
config_ChainParse( p_enc, ENC_CFG_PREFIX, ppsz_enc_options, p_enc->p_cfg ); config_ChainParse( p_enc, ENC_CFG_PREFIX, ppsz_enc_options, p_enc->p_cfg );
var_Get( p_enc, ENC_CFG_PREFIX "quality", &val ); i_quality = var_GetInteger( p_enc, ENC_CFG_PREFIX "quality" );
i_quality = val.i_int;
if( i_quality > 10 ) i_quality = 10; if( i_quality > 10 ) i_quality = 10;
if( i_quality < 0 ) i_quality = 0; if( i_quality < 0 ) i_quality = 0;
......
...@@ -129,7 +129,6 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -129,7 +129,6 @@ static int OpenEncoder( vlc_object_t *p_this )
{ {
encoder_t *p_enc = (encoder_t *)p_this; encoder_t *p_enc = (encoder_t *)p_this;
encoder_sys_t *p_sys; encoder_sys_t *p_sys;
vlc_value_t val;
int i_frequency; int i_frequency;
if( p_enc->fmt_out.i_codec != VLC_CODEC_MPGA && if( p_enc->fmt_out.i_codec != VLC_CODEC_MPGA &&
...@@ -216,8 +215,7 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -216,8 +215,7 @@ static int OpenEncoder( vlc_object_t *p_this )
else else
{ {
twolame_set_num_channels( p_sys->p_twolame, 2 ); twolame_set_num_channels( p_sys->p_twolame, 2 );
var_Get( p_enc, ENC_CFG_PREFIX "mode", &val ); switch( var_GetInteger( p_enc, ENC_CFG_PREFIX "mode" ) )
switch ( val.i_int )
{ {
case 1: case 1:
twolame_set_mode( p_sys->p_twolame, TWOLAME_DUAL_CHANNEL ); twolame_set_mode( p_sys->p_twolame, TWOLAME_DUAL_CHANNEL );
...@@ -232,8 +230,8 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -232,8 +230,8 @@ static int OpenEncoder( vlc_object_t *p_this )
} }
} }
var_Get( p_enc, ENC_CFG_PREFIX "psy", &val ); twolame_set_psymodel( p_sys->p_twolame,
twolame_set_psymodel( p_sys->p_twolame, val.i_int ); var_GetInteger( p_enc, ENC_CFG_PREFIX "psy" ) );
if ( twolame_init_params( p_sys->p_twolame ) ) if ( twolame_init_params( p_sys->p_twolame ) )
{ {
......
...@@ -786,7 +786,6 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -786,7 +786,6 @@ static int OpenEncoder( vlc_object_t *p_this )
encoder_sys_t *p_sys; encoder_sys_t *p_sys;
int i_quality, i_min_bitrate, i_max_bitrate, i; int i_quality, i_min_bitrate, i_max_bitrate, i;
ogg_packet header[3]; ogg_packet header[3];
vlc_value_t val;
uint8_t *p_extra; uint8_t *p_extra;
if( p_enc->fmt_out.i_codec != VLC_CODEC_VORBIS && if( p_enc->fmt_out.i_codec != VLC_CODEC_VORBIS &&
...@@ -806,16 +805,13 @@ static int OpenEncoder( vlc_object_t *p_this ) ...@@ -806,16 +805,13 @@ static int OpenEncoder( vlc_object_t *p_this )
config_ChainParse( p_enc, ENC_CFG_PREFIX, ppsz_enc_options, p_enc->p_cfg ); config_ChainParse( p_enc, ENC_CFG_PREFIX, ppsz_enc_options, p_enc->p_cfg );
var_Get( p_enc, ENC_CFG_PREFIX "quality", &val ); i_quality = var_GetInteger( p_enc, ENC_CFG_PREFIX "quality" );
i_quality = val.i_int;
if( i_quality > 10 ) i_quality = 10; if( i_quality > 10 ) i_quality = 10;
if( i_quality < 0 ) i_quality = 0; if( i_quality < 0 ) i_quality = 0;
var_Get( p_enc, ENC_CFG_PREFIX "cbr", &val );
if( val.b_bool ) i_quality = 0; if( var_GetBool( p_enc, ENC_CFG_PREFIX "cbr" ) ) i_quality = 0;
var_Get( p_enc, ENC_CFG_PREFIX "max-bitrate", &val ); i_max_bitrate = var_GetInteger( p_enc, ENC_CFG_PREFIX "max-bitrate" );
i_max_bitrate = val.i_int; i_min_bitrate = var_GetInteger( p_enc, ENC_CFG_PREFIX "min-bitrate" );
var_Get( p_enc, ENC_CFG_PREFIX "min-bitrate", &val );
i_min_bitrate = val.i_int;
/* Initialize vorbis encoder */ /* Initialize vorbis encoder */
vorbis_info_init( &p_sys->vi ); vorbis_info_init( &p_sys->vi );
......
...@@ -644,7 +644,8 @@ static int Open ( vlc_object_t *p_this ) ...@@ -644,7 +644,8 @@ static int Open ( vlc_object_t *p_this )
{ {
encoder_t *p_enc = (encoder_t *)p_this; encoder_t *p_enc = (encoder_t *)p_this;
encoder_sys_t *p_sys; encoder_sys_t *p_sys;
vlc_value_t val; int i_val;
char *psz_val;
int i_qmin = 0, i_qmax = 0; int i_qmin = 0, i_qmax = 0;
x264_nal_t *nal; x264_nal_t *nal;
int i, i_nal; int i, i_nal;
...@@ -676,8 +677,7 @@ static int Open ( vlc_object_t *p_this ) ...@@ -676,8 +677,7 @@ static int Open ( vlc_object_t *p_this )
p_sys->param.i_width = p_enc->fmt_in.video.i_width; p_sys->param.i_width = p_enc->fmt_in.video.i_width;
p_sys->param.i_height = p_enc->fmt_in.video.i_height; p_sys->param.i_height = p_enc->fmt_in.video.i_height;
var_Get( p_enc, SOUT_CFG_PREFIX "qcomp", &val ); p_sys->param.rc.f_qcompress = var_GetFloat( p_enc, SOUT_CFG_PREFIX "qcomp" );
p_sys->param.rc.f_qcompress = val.f_float;
/* transcode-default bitrate is 0, /* transcode-default bitrate is 0,
* set more to ABR if user specifies bitrate */ * set more to ABR if user specifies bitrate */
...@@ -688,275 +688,249 @@ static int Open ( vlc_object_t *p_this ) ...@@ -688,275 +688,249 @@ static int Open ( vlc_object_t *p_this )
} }
else /* Set default to CRF */ else /* Set default to CRF */
{ {
var_Get( p_enc, SOUT_CFG_PREFIX "crf", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "crf" );
if( val.i_int > 0 && val.i_int <= 51 ) if( i_val > 0 && i_val <= 51 )
{ {
p_sys->param.rc.f_rf_constant = val.i_int; p_sys->param.rc.f_rf_constant = i_val;
p_sys->param.rc.i_rc_method = X264_RC_CRF; p_sys->param.rc.i_rc_method = X264_RC_CRF;
} }
} }
var_Get( p_enc, SOUT_CFG_PREFIX "qpstep", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "qpstep" );
if( val.i_int >= 0 && val.i_int <= 51 ) p_sys->param.rc.i_qp_step = val.i_int; if( i_val >= 0 && i_val <= 51 ) p_sys->param.rc.i_qp_step = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "qpmin", &val );
if( val.i_int >= 0 && val.i_int <= 51 ) i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "qpmin" );
if( i_val >= 0 && i_val <= 51 )
{ {
i_qmin = val.i_int; i_qmin = i_val;
p_sys->param.rc.i_qp_min = i_qmin; p_sys->param.rc.i_qp_min = i_qmin;
} }
var_Get( p_enc, SOUT_CFG_PREFIX "qpmax", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "qpmax" );
if( val.i_int >= 0 && val.i_int <= 51 ) if( i_val >= 0 && i_val <= 51 )
{ {
i_qmax = val.i_int; i_qmax = i_val;
p_sys->param.rc.i_qp_max = i_qmax; p_sys->param.rc.i_qp_max = i_qmax;
} }
var_Get( p_enc, SOUT_CFG_PREFIX "qp", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "qp" );
if( val.i_int >= 0 && val.i_int <= 51 ) if( i_val >= 0 && i_val <= 51 )
{ {
if( i_qmin > val.i_int ) i_qmin = val.i_int; if( i_qmin > i_val ) i_qmin = i_val;
if( i_qmax < val.i_int ) i_qmax = val.i_int; if( i_qmax < i_val ) i_qmax = i_val;
/* User defined QP-value, so change ratecontrol method */ /* User defined QP-value, so change ratecontrol method */
p_sys->param.rc.i_rc_method = X264_RC_CQP; p_sys->param.rc.i_rc_method = X264_RC_CQP;
p_sys->param.rc.i_qp_constant = val.i_int; p_sys->param.rc.i_qp_constant = i_val;
p_sys->param.rc.i_qp_min = i_qmin; p_sys->param.rc.i_qp_min = i_qmin;
p_sys->param.rc.i_qp_max = i_qmax; p_sys->param.rc.i_qp_max = i_qmax;
} }
var_Get( p_enc, SOUT_CFG_PREFIX "ratetol", &val ); p_sys->param.rc.f_rate_tolerance = var_GetFloat( p_enc,
p_sys->param.rc.f_rate_tolerance = val.f_float; SOUT_CFG_PREFIX "ratetol" );
p_sys->param.rc.f_vbv_buffer_init = var_GetFloat( p_enc,
var_Get( p_enc, SOUT_CFG_PREFIX "vbv-init", &val ); SOUT_CFG_PREFIX "vbv-init" );
p_sys->param.rc.f_vbv_buffer_init = val.f_float; p_sys->param.rc.i_vbv_buffer_size = var_GetInteger( p_enc,
SOUT_CFG_PREFIX "vbv-bufsize" );
var_Get( p_enc, SOUT_CFG_PREFIX "vbv-bufsize", &val );
p_sys->param.rc.i_vbv_buffer_size = val.i_int;
/* max bitrate = average bitrate -> CBR */ /* max bitrate = average bitrate -> CBR */
var_Get( p_enc, SOUT_CFG_PREFIX "vbv-maxrate", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "vbv-maxrate" );
if( !val.i_int && p_sys->param.rc.i_rc_method == X264_RC_ABR ) if( !i_val && p_sys->param.rc.i_rc_method == X264_RC_ABR )
p_sys->param.rc.i_vbv_max_bitrate = p_sys->param.rc.i_bitrate; p_sys->param.rc.i_vbv_max_bitrate = p_sys->param.rc.i_bitrate;
else if ( val.i_int ) else if ( i_val )
p_sys->param.rc.i_vbv_max_bitrate = val.i_int; p_sys->param.rc.i_vbv_max_bitrate = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "cabac", &val ); p_sys->param.b_cabac = var_GetBool( p_enc, SOUT_CFG_PREFIX "cabac" );
p_sys->param.b_cabac = val.b_bool;
/* disable deblocking when nf (no loop filter) is enabled */ /* disable deblocking when nf (no loop filter) is enabled */
var_Get( p_enc, SOUT_CFG_PREFIX "nf", &val ); p_sys->param.b_deblocking_filter = !var_GetBool( p_enc, SOUT_CFG_PREFIX "nf" );
p_sys->param.b_deblocking_filter = !val.b_bool;
var_Get( p_enc, SOUT_CFG_PREFIX "deblock", &val ); psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "deblock" );
if( val.psz_string ) if( psz_val )
{ {
char *p = strchr( val.psz_string, ':' ); char *p = strchr( psz_val, ':' );
p_sys->param.i_deblocking_filter_alphac0 = atoi( val.psz_string ); p_sys->param.i_deblocking_filter_alphac0 = atoi( psz_val );
p_sys->param.i_deblocking_filter_beta = p ? atoi( p+1 ) : p_sys->param.i_deblocking_filter_alphac0; p_sys->param.i_deblocking_filter_beta = p ?
free( val.psz_string ); atoi( p+1 ) : p_sys->param.i_deblocking_filter_alphac0;
free( psz_val );
} }
var_Get( p_enc, SOUT_CFG_PREFIX "psy-rd", &val ); psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "psy-rd" );
if( val.psz_string ) if( psz_val )
{ {
char *p = strchr( val.psz_string, ':' ); char *p = strchr( psz_val, ':' );
p_sys->param.analyse.f_psy_rd = us_atof( val.psz_string ); p_sys->param.analyse.f_psy_rd = us_atof( psz_val );
p_sys->param.analyse.f_psy_trellis = p ? us_atof( p+1 ) : 0; p_sys->param.analyse.f_psy_trellis = p ? us_atof( p+1 ) : 0;
free( val.psz_string ); free( psz_val );
} }
psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "level" );
var_Get( p_enc, SOUT_CFG_PREFIX "level", &val ); if( psz_val )
if( val.psz_string )
{ {
if( us_atof (val.psz_string) < 6 ) if( us_atof (psz_val) < 6 )
p_sys->param.i_level_idc = (int) (10 * us_atof (val.psz_string) p_sys->param.i_level_idc = (int) (10 * us_atof (psz_val)
+ .5); + .5);
else else
p_sys->param.i_level_idc = atoi (val.psz_string); p_sys->param.i_level_idc = atoi (psz_val);
free( val.psz_string ); free( psz_val );
} }
var_Get( p_enc, SOUT_CFG_PREFIX "interlaced", &val ); p_sys->param.b_interlaced = var_GetBool( p_enc, SOUT_CFG_PREFIX "interlaced" );
p_sys->param.b_interlaced = val.b_bool; p_sys->param.rc.f_ip_factor = var_GetFloat( p_enc, SOUT_CFG_PREFIX "ipratio" );
p_sys->param.rc.f_pb_factor = var_GetFloat( p_enc, SOUT_CFG_PREFIX "pbratio" );
var_Get( p_enc, SOUT_CFG_PREFIX "ipratio", &val ); p_sys->param.rc.f_complexity_blur = var_GetFloat( p_enc, SOUT_CFG_PREFIX "cplxblur" );
p_sys->param.rc.f_ip_factor = val.f_float; p_sys->param.rc.f_qblur = var_GetFloat( p_enc, SOUT_CFG_PREFIX "qblur" );
p_sys->param.rc.i_aq_mode = var_GetInteger( p_enc, SOUT_CFG_PREFIX "aq-mode" );
var_Get( p_enc, SOUT_CFG_PREFIX "pbratio", &val ); p_sys->param.rc.f_aq_strength = var_GetFloat( p_enc, SOUT_CFG_PREFIX "aq-strength" );
p_sys->param.rc.f_pb_factor = val.f_float;
var_Get( p_enc, SOUT_CFG_PREFIX "cplxblur", &val );
p_sys->param.rc.f_complexity_blur = val.f_float;
var_Get( p_enc, SOUT_CFG_PREFIX "qblur", &val );
p_sys->param.rc.f_qblur = val.f_float;
var_Get( p_enc, SOUT_CFG_PREFIX "aq-mode", &val ); if( var_GetBool( p_enc, SOUT_CFG_PREFIX "verbose" ) )
p_sys->param.rc.i_aq_mode = val.i_int; p_sys->param.i_log_level = X264_LOG_DEBUG;
var_Get( p_enc, SOUT_CFG_PREFIX "aq-strength", &val ); if( var_GetBool( p_enc, SOUT_CFG_PREFIX "quiet" ) )
p_sys->param.rc.f_aq_strength = val.f_float; p_sys->param.i_log_level = X264_LOG_NONE;
var_Get( p_enc, SOUT_CFG_PREFIX "verbose", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "sps-id" );
if( val.b_bool ) p_sys->param.i_log_level = X264_LOG_DEBUG; if( i_val >= 0 ) p_sys->param.i_sps_id = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "quiet", &val ); if( var_GetBool( p_enc, SOUT_CFG_PREFIX "aud" ) )
if( val.b_bool ) p_sys->param.i_log_level = X264_LOG_NONE; p_sys->param.b_aud = true;
var_Get( p_enc, SOUT_CFG_PREFIX "sps-id", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "keyint" );
if( val.i_int >= 0 ) p_sys->param.i_sps_id = val.i_int; if(( i_val > 0 ) p_sys->param.i_keyint_max = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "aud", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "min-keyint" );
if( val.b_bool ) p_sys->param.b_aud = val.b_bool; if( i_val > 0 ) p_sys->param.i_keyint_min = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "keyint", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "bframes" );
if( val.i_int > 0 ) p_sys->param.i_keyint_max = val.i_int; if( i_val >= 0 && i_val <= 16 )
p_sys->param.i_bframe = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "min-keyint", &val ); p_sys->param.b_bframe_pyramid = var_GetBool( p_enc, SOUT_CFG_PREFIX "bpyramid" );
if( val.i_int > 0 ) p_sys->param.i_keyint_min = val.i_int;
var_Get( p_enc, SOUT_CFG_PREFIX "bframes", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "ref" );
if( val.i_int >= 0 && val.i_int <= 16 ) if( i_val > 0 && i_val <= 15 )
p_sys->param.i_bframe = val.i_int; p_sys->param.i_frame_reference = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "bpyramid", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "scenecut" );
p_sys->param.b_bframe_pyramid = val.b_bool; if( i_val >= -1 && i_val <= 100 )
p_sys->param.i_scenecut_threshold = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "ref", &val ); p_sys->param.b_deterministic = var_GetBool( p_enc,
if( val.i_int > 0 && val.i_int <= 15 ) SOUT_CFG_PREFIX "non-deterministic" );
p_sys->param.i_frame_reference = val.i_int;
var_Get( p_enc, SOUT_CFG_PREFIX "scenecut", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "subme" );
if( val.i_int >= -1 && val.i_int <= 100 ) if( i_val >= 1 && i_val <= SUBME_MAX )
p_sys->param.i_scenecut_threshold = val.i_int; p_sys->param.analyse.i_subpel_refine = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "non-deterministic", &val ); //TODO: psz_val == NULL ?
p_sys->param.b_deterministic = val.b_bool; psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "me" );
if( !strcmp( psz_val, "dia" ) )
var_Get( p_enc, SOUT_CFG_PREFIX "subme", &val );
if( val.i_int >= 1 && val.i_int <= SUBME_MAX )
p_sys->param.analyse.i_subpel_refine = val.i_int;
var_Get( p_enc, SOUT_CFG_PREFIX "me", &val );
if( !strcmp( val.psz_string, "dia" ) )
{ {
p_sys->param.analyse.i_me_method = X264_ME_DIA; p_sys->param.analyse.i_me_method = X264_ME_DIA;
} }
else if( !strcmp( val.psz_string, "hex" ) ) else if( !strcmp( psz_val, "hex" ) )
{ {
p_sys->param.analyse.i_me_method = X264_ME_HEX; p_sys->param.analyse.i_me_method = X264_ME_HEX;
} }
else if( !strcmp( val.psz_string, "umh" ) ) else if( !strcmp( psz_val, "umh" ) )
{ {
p_sys->param.analyse.i_me_method = X264_ME_UMH; p_sys->param.analyse.i_me_method = X264_ME_UMH;
} }
else if( !strcmp( val.psz_string, "esa" ) ) else if( !strcmp( psz_val, "esa" ) )
{ {
p_sys->param.analyse.i_me_method = X264_ME_ESA; p_sys->param.analyse.i_me_method = X264_ME_ESA;
} }
else if( !strcmp( val.psz_string, "tesa" ) ) else if( !strcmp( psz_val, "tesa" ) )
{ {
p_sys->param.analyse.i_me_method = X264_ME_TESA; p_sys->param.analyse.i_me_method = X264_ME_TESA;
} }
free( val.psz_string ); free( psz_val );
var_Get( p_enc, SOUT_CFG_PREFIX "merange", &val );
if( val.i_int >= 0 && val.i_int <= 64 )
p_sys->param.analyse.i_me_range = val.i_int;
var_Get( p_enc, SOUT_CFG_PREFIX "mvrange", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "merange" );
p_sys->param.analyse.i_mv_range = val.i_int; if( i_val >= 0 && i_val <= 64 )
p_sys->param.analyse.i_me_range = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "mvrange-thread", &val ); p_sys->param.analyse.i_mv_range = var_GetInteger( p_enc,
p_sys->param.analyse.i_mv_range_thread = val.i_int; SOUT_CFG_PREFIX "mvrange" );
p_sys->param.analyse.i_mv_range_thread = var_GetInteger( p_enc,
SOUT_CFG_PREFIX "mvrange-thread" );
var_Get( p_enc, SOUT_CFG_PREFIX "direct", &val ); psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "direct" );
if( !strcmp( val.psz_string, "none" ) ) if( !strcmp( psz_val, "none" ) )
{ {
p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_NONE; p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_NONE;
} }
else if( !strcmp( val.psz_string, "spatial" ) ) else if( !strcmp( psz_val, "spatial" ) )
{ {
p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_SPATIAL; p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_SPATIAL;
} }
else if( !strcmp( val.psz_string, "temporal" ) ) else if( !strcmp( psz_val, "temporal" ) )
{ {
p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_TEMPORAL; p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_TEMPORAL;
} }
else if( !strcmp( val.psz_string, "auto" ) ) else if( !strcmp( psz_val, "auto" ) )
{ {
p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_AUTO; p_sys->param.analyse.i_direct_mv_pred = X264_DIRECT_PRED_AUTO;
} }
free( val.psz_string ); free( psz_val );
var_Get( p_enc, SOUT_CFG_PREFIX "psnr", &val );
p_sys->param.analyse.b_psnr = val.b_bool;
var_Get( p_enc, SOUT_CFG_PREFIX "ssim", &val );
p_sys->param.analyse.b_ssim = val.b_bool;
var_Get( p_enc, SOUT_CFG_PREFIX "weightb", &val );
p_sys->param.analyse.b_weighted_bipred = val.b_bool;
var_Get( p_enc, SOUT_CFG_PREFIX "b-adapt", &val );
p_sys->param.i_bframe_adaptive = val.i_int;
var_Get( p_enc, SOUT_CFG_PREFIX "b-bias", &val );
if( val.i_int >= -100 && val.i_int <= 100 )
p_sys->param.i_bframe_bias = val.i_int;
var_Get( p_enc, SOUT_CFG_PREFIX "chroma-me", &val );
p_sys->param.analyse.b_chroma_me = val.b_bool;
var_Get( p_enc, SOUT_CFG_PREFIX "chroma-qp-offset", &val );
p_sys->param.analyse.i_chroma_qp_offset = val.i_int;
var_Get( p_enc, SOUT_CFG_PREFIX "mixed-refs", &val ); p_sys->param.analyse.b_psnr = var_GetBool( p_enc, SOUT_CFG_PREFIX "psnr" );
p_sys->param.analyse.b_mixed_references = val.b_bool; p_sys->param.analyse.b_ssim = var_GetBool( p_enc, SOUT_CFG_PREFIX "ssim" );
p_sys->param.analyse.b_weighted_bipred = var_GetBool( p_enc,
SOUT_CFG_PREFIX "weightb" );
p_sys->param.i_bframe_adaptive = var_GetInteger( p_enc,
SOUT_CFG_PREFIX "b-adapt" );
i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "b-bias" );
if( i_val >= -100 && i_val <= 100 )
p_sys->param.i_bframe_bias = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "trellis", &val ); p_sys->param.analyse.b_chroma_me = var_GetBool( p_enc,
if( val.i_int >= 0 && val.i_int <= 2 ) SOUT_CFG_PREFIX "chroma-me" );
p_sys->param.analyse.i_trellis = val.i_int; p_sys->param.analyse.i_chroma_qp_offset = var_GetInteger( p_enc,
SOUT_CFG_PREFIX "chroma-qp-offset" );
p_sys->param.analyse.b_mixed_references = var_GetBool( p_enc,
SOUT_CFG_PREFIX "mixed-refs" );
var_Get( p_enc, SOUT_CFG_PREFIX "fast-pskip", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "trellis" );
p_sys->param.analyse.b_fast_pskip = val.b_bool; if( i_val >= 0 && i_val <= 2 )
p_sys->param.analyse.i_trellis = i_val;
p_sys->param.analyse.b_fast_pskip = var_GetBool( p_enc,
SOUT_CFG_PREFIX "fast-pskip" );
var_Get( p_enc, SOUT_CFG_PREFIX "nr", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "nr" );
if( val.i_int >= 0 && val.i_int <= 1000 ) if( i_val >= 0 && i_val <= 1000 )
p_sys->param.analyse.i_noise_reduction = val.i_int; p_sys->param.analyse.i_noise_reduction = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "dct-decimate", &val ); p_sys->param.analyse.b_dct_decimate = var_GetBool( p_enc,
p_sys->param.analyse.b_dct_decimate = val.b_bool; SOUT_CFG_PREFIX "dct-decimate" );
var_Get( p_enc, SOUT_CFG_PREFIX "deadzone-inter", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "deadzone-inter" );
if( val.i_int >= 0 && val.i_int <= 32 ) if( i_val >= 0 && i_val <= 32 )
p_sys->param.analyse.i_luma_deadzone[0] = val.i_int; p_sys->param.analyse.i_luma_deadzone[0] = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "deadzone-intra", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "deadzone-intra" );
if( val.i_int >= 0 && val.i_int <= 32 ) if( i_val >= 0 && i_val <= 32 )
p_sys->param.analyse.i_luma_deadzone[1] = val.i_int; p_sys->param.analyse.i_luma_deadzone[1] = i_val;
var_Get( p_enc, SOUT_CFG_PREFIX "asm", &val ); if( !var_GetBool( p_enc, SOUT_CFG_PREFIX "asm" ) )
if( !val.b_bool ) p_sys->param.cpu = 0; p_sys->param.cpu = 0;
#ifndef X264_ANALYSE_BSUB16x16 #ifndef X264_ANALYSE_BSUB16x16
# define X264_ANALYSE_BSUB16x16 0 # define X264_ANALYSE_BSUB16x16 0
#endif #endif
var_Get( p_enc, SOUT_CFG_PREFIX "partitions", &val ); psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "partitions" );
if( !strcmp( val.psz_string, "none" ) ) if( !strcmp( psz_val, "none" ) )
{ {
p_sys->param.analyse.inter = 0; p_sys->param.analyse.inter = 0;
} }
else if( !strcmp( val.psz_string, "fast" ) ) else if( !strcmp( psz_val, "fast" ) )
{ {
p_sys->param.analyse.inter = X264_ANALYSE_I4x4; p_sys->param.analyse.inter = X264_ANALYSE_I4x4;
} }
else if( !strcmp( val.psz_string, "normal" ) ) else if( !strcmp( psz_val, "normal" ) )
{ {
p_sys->param.analyse.inter = p_sys->param.analyse.inter =
X264_ANALYSE_I4x4 | X264_ANALYSE_I4x4 |
...@@ -965,7 +939,7 @@ static int Open ( vlc_object_t *p_this ) ...@@ -965,7 +939,7 @@ static int Open ( vlc_object_t *p_this )
p_sys->param.analyse.inter |= X264_ANALYSE_I8x8; p_sys->param.analyse.inter |= X264_ANALYSE_I8x8;
#endif #endif
} }
else if( !strcmp( val.psz_string, "slow" ) ) else if( !strcmp( psz_val, "slow" ) )
{ {
p_sys->param.analyse.inter = p_sys->param.analyse.inter =
X264_ANALYSE_I4x4 | X264_ANALYSE_I4x4 |
...@@ -975,14 +949,14 @@ static int Open ( vlc_object_t *p_this ) ...@@ -975,14 +949,14 @@ static int Open ( vlc_object_t *p_this )
p_sys->param.analyse.inter |= X264_ANALYSE_I8x8; p_sys->param.analyse.inter |= X264_ANALYSE_I8x8;
#endif #endif
} }
else if( !strcmp( val.psz_string, "all" ) ) else if( !strcmp( psz_val, "all" ) )
{ {
p_sys->param.analyse.inter = ~0; p_sys->param.analyse.inter = ~0;
} }
free( val.psz_string ); free( psz_val );
var_Get( p_enc, SOUT_CFG_PREFIX "8x8dct", &val ); p_sys->param.analyse.b_transform_8x8 = var_GetBool( p_enc,
p_sys->param.analyse.b_transform_8x8 = val.b_bool; SOUT_CFG_PREFIX "8x8dct" );
if( p_enc->fmt_in.video.i_aspect > 0 ) if( p_enc->fmt_in.video.i_aspect > 0 )
{ {
...@@ -1020,24 +994,24 @@ static int Open ( vlc_object_t *p_this ) ...@@ -1020,24 +994,24 @@ static int Open ( vlc_object_t *p_this )
/* Check if user has given some profile (baseline,main,high) to limit /* Check if user has given some profile (baseline,main,high) to limit
* settings, and apply those*/ * settings, and apply those*/
var_Get( p_enc, SOUT_CFG_PREFIX "profile", &val ); psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "profile" );
if( val.psz_string ) if( psz_val )
{ {
if( !strcasecmp( val.psz_string, "baseline" ) ) if( !strcasecmp( psz_val, "baseline" ) )
{ {
msg_Dbg( p_enc, "Limiting to baseline profile"); msg_Dbg( p_enc, "Limiting to baseline profile");
p_sys->param.analyse.b_transform_8x8 = 0; p_sys->param.analyse.b_transform_8x8 = 0;
p_sys->param.b_cabac = 0; p_sys->param.b_cabac = 0;
p_sys->param.i_bframe = 0; p_sys->param.i_bframe = 0;
} }
else if (!strcasecmp( val.psz_string, "main" ) ) else if (!strcasecmp( psz_val, "main" ) )
{ {
msg_Dbg( p_enc, "Limiting to main-profile"); msg_Dbg( p_enc, "Limiting to main-profile");
p_sys->param.analyse.b_transform_8x8 = 0; p_sys->param.analyse.b_transform_8x8 = 0;
} }
/* high profile don't restrict stuff*/ /* high profile don't restrict stuff*/
} }
free( val.psz_string ); free( psz_val );
unsigned i_cpu = vlc_CPU(); unsigned i_cpu = vlc_CPU();
...@@ -1065,19 +1039,19 @@ static int Open ( vlc_object_t *p_this ) ...@@ -1065,19 +1039,19 @@ static int Open ( vlc_object_t *p_this )
default unless ofcourse transcode threads is explicitly specified.. */ default unless ofcourse transcode threads is explicitly specified.. */
p_sys->param.i_threads = p_enc->i_threads; p_sys->param.i_threads = p_enc->i_threads;
var_Get( p_enc, SOUT_CFG_PREFIX "stats", &val ); psz_val = var_GetString( p_enc, SOUT_CFG_PREFIX "stats" );
if( val.psz_string ) if( psz_val )
{ {
p_sys->param.rc.psz_stat_in = p_sys->param.rc.psz_stat_in =
p_sys->param.rc.psz_stat_out = p_sys->param.rc.psz_stat_out =
p_sys->psz_stat_name = val.psz_string; p_sys->psz_stat_name = psz_val;
} }
var_Get( p_enc, SOUT_CFG_PREFIX "pass", &val ); i_val = var_GetInteger( p_enc, SOUT_CFG_PREFIX "pass" );
if( val.i_int > 0 && val.i_int <= 3 ) if( i_val > 0 && i_val <= 3 )
{ {
p_sys->param.rc.b_stat_write = val.i_int & 1; p_sys->param.rc.b_stat_write = i_val & 1;
p_sys->param.rc.b_stat_read = val.i_int & 2; p_sys->param.rc.b_stat_read = i_val & 2;
} }
/* We need to initialize pthreadw32 before we open the encoder, /* We need to initialize pthreadw32 before we open the encoder,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment