]> git.sesse.net Git - vlc/commitdiff
Added INPUT_EVENT_TELETEXT.
authorLaurent Aimar <fenrir@videolan.org>
Sun, 23 Nov 2008 13:29:50 +0000 (14:29 +0100)
committerLaurent Aimar <fenrir@videolan.org>
Sun, 23 Nov 2008 13:29:50 +0000 (14:29 +0100)
include/vlc_input.h
src/input/es_out.c
src/input/event.c
src/input/event.h

index 7386d7841397175277840c3195a4ffd43ec52281..9500b4cba3a47539dd7959e9866e4fe5fed8a69b 100644 (file)
@@ -442,7 +442,7 @@ struct input_thread_t
  *  - "can-rate"
  *  - "can-rewind"
  *  - "can-record" (if a stream can be recorded while playing)
- *  - "teletext-es" to get the index of spu track that is teletext --1 if no teletext)
+ *  - "teletext-es" to get the index of spu track that is teletext -1 if no teletext)
  *  - "signal-quality"
  *  - "signal-strength"
  *
@@ -541,6 +541,8 @@ typedef enum input_event_type_e
     INPUT_EVENT_PROGRAM,
     /* A ES has been added or removed or selected */
     INPUT_EVENT_ES,
+    /* "teletext-es" has changed */
+    INPUT_EVENT_TELETEXT,
 
     /* "record" has changed */
     INPUT_EVENT_RECORD,
index 37e6035870450ea3f35d5b16745ea59de4be36e4..8ac7abb7347e6bddbde55c7a3d308df88551f21b 100644 (file)
@@ -800,9 +800,9 @@ static void EsOutESVarUpdateGeneric( es_out_t *out, int i_id, es_format_t *fmt,
 
     if( b_delete )
     {
-        /* TODO event */
+        /* TODO it should probably be a list */
         if( b_teletext )
-            var_SetInteger( p_sys->p_input, "teletext-es", -1 );
+            input_SendEventTeletext( p_sys->p_input, -1 );
 
         input_SendEventEsDel( p_input, SPU_ES, i_id );
         return;
@@ -860,9 +860,9 @@ static void EsOutESVarUpdateGeneric( es_out_t *out, int i_id, es_format_t *fmt,
 
     if( b_teletext )
     {
-        /* TODO event */
+        /* TODO it should probably be a list */
         if( var_GetInteger( p_sys->p_input, "teletext-es" ) < 0 )
-            var_SetInteger( p_sys->p_input, "teletext-es", i_id );
+            input_SendEventTeletext( p_sys->p_input, i_id );
     }
 }
 
index 4c4e3c913d898d0a590a64dd36441c372a2dc6d1..8c9613b86a1182b9371e1e40def653bb06d06e4b 100644 (file)
@@ -288,6 +288,16 @@ void input_SendEventEsSelect( input_thread_t *p_input, int i_cat, int i_id )
     vlc_event_send( &p_input->p->event_manager, &event );
 }
 
+void input_SendEventTeletext( input_thread_t *p_input, int i_id )
+{
+    vlc_value_t val;
+
+    val.i_int = i_id;
+    var_Change( p_input, "teletext-es", VLC_VAR_SETVALUE, &val, NULL );
+
+    Trigger( p_input, INPUT_EVENT_TELETEXT );
+}
+
 void input_SendEventVout( input_thread_t *p_input )
 {
     Trigger( p_input, INPUT_EVENT_VOUT );
index e4ad966c67dbeae1ac7c476f7184d2e9245baec1..541e598a76d46301fa4a9c0f8a235773bab82714 100644 (file)
@@ -63,10 +63,13 @@ void input_SendEventProgramAdd( input_thread_t *p_input,
                                 int i_program, const char *psz_text );
 void input_SendEventProgramDel( input_thread_t *p_input, int i_program );
 void input_SendEventProgramSelect( input_thread_t *p_input, int i_program );
+
 void input_SendEventEsDel( input_thread_t *p_input, int i_cat, int i_id );
 void input_SendEventEsAdd( input_thread_t *p_input, int i_cat, int i_id, const char *psz_text );
 void input_SendEventEsSelect( input_thread_t *p_input, int i_cat, int i_id ); /* i_id == -1 will unselect */
 
+void input_SendEventTeletext( input_thread_t *p_input, int i_id );
+
 /*****************************************************************************
  * Event for decoder.c
  *****************************************************************************/