X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Finput%2Fvar.c;h=9b919b636d2f315fb565052ee6b6ca6b89792536;hb=29d44b6a239c79c83fcd05401c33640768f50f38;hp=e2092fcf1c390b42ae8d098699cc59e3fed17e9c;hpb=d6e99cf906a56811de0ad043dc6e29a6088b6ec4;p=vlc diff --git a/src/input/var.c b/src/input/var.c index e2092fcf1c..9b919b636d 100644 --- a/src/input/var.c +++ b/src/input/var.c @@ -64,12 +64,16 @@ static int BookmarkCallback( vlc_object_t *p_this, char const *psz_cmd, static int RecordCallback( vlc_object_t *p_this, char const *psz_cmd, vlc_value_t oldval, vlc_value_t newval, void *p_data ); +static int FrameNextCallback( vlc_object_t *p_this, char const *psz_cmd, + vlc_value_t oldval, vlc_value_t newval, + void *p_data ); typedef struct { const char *psz_name; vlc_callback_t callback; } vlc_input_callback_t; + static void InputAddCallbacks( input_thread_t *, const vlc_input_callback_t * ); static void InputDelCallbacks( input_thread_t *, const vlc_input_callback_t * ); @@ -98,6 +102,7 @@ static const vlc_input_callback_t p_input_callbacks[] = CALLBACK( "audio-es", ESCallback ), CALLBACK( "spu-es", ESCallback ), CALLBACK( "record", RecordCallback ), + CALLBACK( "frame-next", FrameNextCallback ), CALLBACK( NULL, NULL ) }; @@ -127,18 +132,20 @@ void input_ControlVarInit ( input_thread_t *p_input ) /* State */ var_Create( p_input, "state", VLC_VAR_INTEGER ); - val.i_int = p_input->i_state; + val.i_int = p_input->p->i_state; var_Change( p_input, "state", VLC_VAR_SETVALUE, &val, NULL ); /* Rate */ - var_Create( p_input, "rate", VLC_VAR_INTEGER ); - val.i_int = p_input->p->i_rate; + var_Create( p_input, "rate", VLC_VAR_FLOAT ); + val.f_float = (float)INPUT_RATE_DEFAULT / (float)p_input->p->i_rate; var_Change( p_input, "rate", VLC_VAR_SETVALUE, &val, NULL ); var_Create( p_input, "rate-slower", VLC_VAR_VOID ); var_Create( p_input, "rate-faster", VLC_VAR_VOID ); + var_Create( p_input, "frame-next", VLC_VAR_VOID ); + /* Position */ var_Create( p_input, "position", VLC_VAR_FLOAT ); var_Create( p_input, "position-offset", VLC_VAR_FLOAT ); @@ -188,7 +195,7 @@ void input_ControlVarInit ( input_thread_t *p_input ) /* Delay */ var_Create( p_input, "audio-delay", VLC_VAR_TIME ); - val.i_time = 0; + val.i_time = INT64_C(1000) * var_GetInteger( p_input, "audio-desync" ); var_Change( p_input, "audio-delay", VLC_VAR_SETVALUE, &val, NULL ); var_Create( p_input, "spu-delay", VLC_VAR_TIME ); val.i_time = 0; @@ -209,6 +216,8 @@ void input_ControlVarInit ( input_thread_t *p_input ) text.psz_string = _("Subtitles Track"); var_Change( p_input, "spu-es", VLC_VAR_SETTEXT, &text, NULL ); + var_Create( p_input, "sub-margin", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); + /* Special read only objects variables for intf */ var_Create( p_input, "bookmarks", VLC_VAR_STRING | VLC_VAR_DOINHERIT ); @@ -216,21 +225,13 @@ void input_ControlVarInit ( input_thread_t *p_input ) val.i_time = 0; var_Change( p_input, "length", VLC_VAR_SETVALUE, &val, NULL ); + var_Create( p_input, "bit-rate", VLC_VAR_INTEGER ); + var_Create( p_input, "sample-rate", VLC_VAR_INTEGER ); + if( !p_input->b_preparsing ) { - /* Special "intf-change" variable, it allows intf to set up a callback - * to be notified of some changes. - * - * Add rate-change to inform about rate changin - * - * TODO list all changes warn by this callbacks */ - var_Create( p_input, "intf-change", VLC_VAR_BOOL ); - var_SetBool( p_input, "intf-change", true ); - var_Create( p_input, "rate-change", VLC_VAR_BOOL ); - var_SetBool( p_input, "rate-change", true ); - - var_Create( p_input, "intf-change-vout", VLC_VAR_BOOL ); - var_SetBool( p_input, "intf-change-vout", true ); + /* Special "intf-event" variable. */ + var_Create( p_input, "intf-event", VLC_VAR_INTEGER ); } /* Add all callbacks @@ -245,7 +246,8 @@ void input_ControlVarInit ( input_thread_t *p_input ) *****************************************************************************/ void input_ControlVarStop( input_thread_t *p_input ) { - InputDelCallbacks( p_input, p_input_callbacks ); + if( !p_input->b_preparsing ) + InputDelCallbacks( p_input, p_input_callbacks ); if( p_input->p->i_title > 0 ) { @@ -447,32 +449,34 @@ void input_ConfigVarInit ( input_thread_t *p_input ) var_Create( p_input, "input-repeat", VLC_VAR_INTEGER|VLC_VAR_DOINHERIT ); - var_Create( p_input, "start-time", VLC_VAR_INTEGER|VLC_VAR_DOINHERIT ); - var_Create( p_input, "stop-time", VLC_VAR_INTEGER|VLC_VAR_DOINHERIT ); - var_Create( p_input, "run-time", VLC_VAR_INTEGER|VLC_VAR_DOINHERIT ); + var_Create( p_input, "start-time", VLC_VAR_FLOAT|VLC_VAR_DOINHERIT ); + var_Create( p_input, "stop-time", VLC_VAR_FLOAT|VLC_VAR_DOINHERIT ); + var_Create( p_input, "run-time", VLC_VAR_FLOAT|VLC_VAR_DOINHERIT ); + var_Create( p_input, "input-fast-seek", VLC_VAR_BOOL|VLC_VAR_DOINHERIT ); var_Create( p_input, "input-slave", VLC_VAR_STRING | VLC_VAR_DOINHERIT ); - var_Create( p_input, "minimize-threads", - VLC_VAR_BOOL|VLC_VAR_DOINHERIT ); - var_Create( p_input, "audio-desync", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); var_Create( p_input, "cr-average", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT ); var_Create( p_input, "clock-synchro", VLC_VAR_INTEGER | VLC_VAR_DOINHERIT); - var_Create( p_input, "auto-adjust-pts-delay", - VLC_VAR_BOOL | VLC_VAR_DOINHERIT); } - var_Create( p_input, "seekable", VLC_VAR_BOOL ); - var_SetBool( p_input, "seekable", true ); /* Fixed later*/ + var_Create( p_input, "can-seek", VLC_VAR_BOOL ); + var_SetBool( p_input, "can-seek", true ); /* Fixed later*/ var_Create( p_input, "can-pause", VLC_VAR_BOOL ); var_SetBool( p_input, "can-pause", true ); /* Fixed later*/ + var_Create( p_input, "can-rate", VLC_VAR_BOOL ); + var_SetBool( p_input, "can-rate", false ); + + var_Create( p_input, "can-rewind", VLC_VAR_BOOL ); + var_SetBool( p_input, "can-rewind", false ); + var_Create( p_input, "can-record", VLC_VAR_BOOL ); var_SetBool( p_input, "can-record", false ); /* Fixed later*/ @@ -482,10 +486,25 @@ void input_ConfigVarInit ( input_thread_t *p_input ) var_Create( p_input, "teletext-es", VLC_VAR_INTEGER ); var_SetInteger( p_input, "teletext-es", -1 ); + var_Create( p_input, "signal-quality", VLC_VAR_FLOAT ); + var_SetFloat( p_input, "signal-quality", -1 ); + + var_Create( p_input, "signal-strength", VLC_VAR_FLOAT ); + var_SetFloat( p_input, "signal-strength", -1 ); + + var_Create( p_input, "program-scrambled", VLC_VAR_BOOL ); + var_SetBool( p_input, "program-scrambled", false ); + + var_Create( p_input, "cache", VLC_VAR_FLOAT ); + var_SetFloat( p_input, "cache", 0.0 ); + + /* */ + var_Create( p_input, "input-record-native", VLC_VAR_BOOL | VLC_VAR_DOINHERIT ); + /* */ - var_Create( p_input, "access-filter", VLC_VAR_STRING | VLC_VAR_DOINHERIT ); var_Create( p_input, "access", VLC_VAR_STRING | VLC_VAR_DOINHERIT ); var_Create( p_input, "demux", VLC_VAR_STRING | VLC_VAR_DOINHERIT ); + var_Create( p_input, "stream-filter", VLC_VAR_STRING | VLC_VAR_DOINHERIT ); /* Meta */ var_Create( p_input, "meta-title", VLC_VAR_STRING | VLC_VAR_DOINHERIT ); @@ -510,6 +529,7 @@ static void InputAddCallbacks( input_thread_t *p_input, p_callbacks[i].psz_name, p_callbacks[i].callback, NULL ); } + static void InputDelCallbacks( input_thread_t *p_input, const vlc_input_callback_t *p_callbacks ) { @@ -519,6 +539,7 @@ static void InputDelCallbacks( input_thread_t *p_input, p_callbacks[i].psz_name, p_callbacks[i].callback, NULL ); } + /***************************************************************************** * All Callbacks: *****************************************************************************/ @@ -544,7 +565,9 @@ static int RateCallback( vlc_object_t *p_this, char const *psz_cmd, input_thread_t *p_input = (input_thread_t*)p_this; VLC_UNUSED(oldval); VLC_UNUSED(p_data); - /* Problem with this way: the "rate" variable is update after the input thread do the change */ + /* Problem with this way: the "rate" variable is updated after the + * input thread did the change */ + if( !strcmp( psz_cmd, "rate-slower" ) ) { input_ControlPush( p_input, INPUT_CONTROL_SET_RATE_SLOWER, NULL ); @@ -555,9 +578,9 @@ static int RateCallback( vlc_object_t *p_this, char const *psz_cmd, } else { + newval.i_int = INPUT_RATE_DEFAULT / newval.f_float; input_ControlPush( p_input, INPUT_CONTROL_SET_RATE, &newval ); } - return VLC_SUCCESS; } @@ -566,32 +589,32 @@ static int PositionCallback( vlc_object_t *p_this, char const *psz_cmd, void *p_data ) { input_thread_t *p_input = (input_thread_t*)p_this; - vlc_value_t val, length; VLC_UNUSED(oldval); VLC_UNUSED(p_data); if( !strcmp( psz_cmd, "position-offset" ) ) { - input_ControlPush( p_input, INPUT_CONTROL_SET_POSITION_OFFSET, &newval ); - - val.f_float = var_GetFloat( p_input, "position" ) + newval.f_float; - if( val.f_float < 0.0 ) val.f_float = 0.0; - if( val.f_float > 1.0 ) val.f_float = 1.0; - var_Change( p_input, "position", VLC_VAR_SETVALUE, &val, NULL ); + float f_position = var_GetFloat( p_input, "position" ) + newval.f_float; + if( f_position < 0.0 ) + f_position = 0.0; + else if( f_position > 1.0 ) + f_position = 1.0; + var_SetFloat( p_this, "position", f_position ); } else { - val.f_float = newval.f_float; - input_ControlPush( p_input, INPUT_CONTROL_SET_POSITION, &newval ); - } + /* Update "length" for better intf behavour */ + const mtime_t i_length = var_GetTime( p_input, "length" ); + if( i_length > 0 && newval.f_float >= 0.0 && newval.f_float <= 1.0 ) + { + vlc_value_t val; - /* Update "position" for better intf behavour */ - var_Get( p_input, "length", &length ); - if( length.i_time > 0 && val.f_float >= 0.0 && val.f_float <= 1.0 ) - { - val.i_time = length.i_time * val.f_float; - var_Change( p_input, "time", VLC_VAR_SETVALUE, &val, NULL ); - } + val.i_time = i_length * newval.f_float; + var_Change( p_input, "time", VLC_VAR_SETVALUE, &val, NULL ); + } + /* */ + input_ControlPush( p_input, INPUT_CONTROL_SET_POSITION, &newval ); + } return VLC_SUCCESS; } @@ -599,31 +622,30 @@ static int TimeCallback( vlc_object_t *p_this, char const *psz_cmd, vlc_value_t oldval, vlc_value_t newval, void *p_data ) { input_thread_t *p_input = (input_thread_t*)p_this; - vlc_value_t val, length; VLC_UNUSED(oldval); VLC_UNUSED(p_data); if( !strcmp( psz_cmd, "time-offset" ) ) { - input_ControlPush( p_input, INPUT_CONTROL_SET_TIME_OFFSET, &newval ); - val.i_time = var_GetTime( p_input, "time" ) + newval.i_time; - if( val.i_time < 0 ) val.i_time = 0; - /* TODO maybe test against i_length ? */ - var_Change( p_input, "time", VLC_VAR_SETVALUE, &val, NULL ); + mtime_t i_time = var_GetTime( p_input, "time" ) + newval.i_time; + if( i_time < 0 ) + i_time = 0; + var_SetTime( p_this, "time", i_time ); } else { - val.i_time = newval.i_time; - input_ControlPush( p_input, INPUT_CONTROL_SET_TIME, &newval ); - } + /* Update "position" for better intf behavour */ + const mtime_t i_length = var_GetTime( p_input, "length" ); + if( i_length > 0 && newval.i_time >= 0 && newval.i_time <= i_length ) + { + vlc_value_t val; - /* Update "position" for better intf behavour */ - var_Get( p_input, "length", &length ); - if( length.i_time > 0 && val.i_time >= 0 && val.i_time <= length.i_time ) - { - val.f_float = (double)val.i_time/(double)length.i_time; - var_Change( p_input, "position", VLC_VAR_SETVALUE, &val, NULL ); - } + val.f_float = (double)newval.i_time/(double)i_length; + var_Change( p_input, "position", VLC_VAR_SETVALUE, &val, NULL ); + } + /* */ + input_ControlPush( p_input, INPUT_CONTROL_SET_TIME, &newval ); + } return VLC_SUCCESS; } @@ -764,15 +786,12 @@ static int EsDelayCallback ( vlc_object_t *p_this, char const *psz_cmd, if( !strcmp( psz_cmd, "audio-delay" ) ) { - /*Change i_pts_delay to make sure es are decoded in time*/ - if (newval.i_int < 0 || oldval.i_int < 0 ) - { - p_input->i_pts_delay -= newval.i_int - oldval.i_int; - } input_ControlPush( p_input, INPUT_CONTROL_SET_AUDIO_DELAY, &newval ); } else if( !strcmp( psz_cmd, "spu-delay" ) ) + { input_ControlPush( p_input, INPUT_CONTROL_SET_SPU_DELAY, &newval ); + } return VLC_SUCCESS; } @@ -799,3 +818,17 @@ static int RecordCallback( vlc_object_t *p_this, char const *psz_cmd, return VLC_SUCCESS; } + +static int FrameNextCallback( vlc_object_t *p_this, char const *psz_cmd, + vlc_value_t oldval, vlc_value_t newval, + void *p_data ) +{ + input_thread_t *p_input = (input_thread_t*)p_this; + VLC_UNUSED(psz_cmd); VLC_UNUSED(oldval); VLC_UNUSED(p_data); + VLC_UNUSED(newval); + + input_ControlPush( p_input, INPUT_CONTROL_SET_FRAME_NEXT, NULL ); + + return VLC_SUCCESS; +} +