]> git.sesse.net Git - vlc/commitdiff
aout: move input restart on filter change from playlist code
authorRémi Denis-Courmont <remi@remlab.net>
Sat, 24 May 2014 05:01:44 +0000 (13:01 +0800)
committerRémi Denis-Courmont <remi@remlab.net>
Sat, 24 May 2014 05:01:44 +0000 (13:01 +0800)
So that it works for LibVLC too.

src/audio_output/output.c
src/playlist/aout.c

index bfaad8e9e2927bbd88ffceb463cdc02b4a552c12..04d84f420bcbc7fc8e0f945813f82ea5c808fc5a 100644 (file)
@@ -153,6 +153,14 @@ static int aout_GainNotify (audio_output_t *aout, float gain)
     return 0;
 }
 
+static int FilterCallback (vlc_object_t *obj, const char *var,
+                           vlc_value_t prev, vlc_value_t cur, void *data)
+{
+    aout_InputRequestRestart ((audio_output_t *)obj);
+    (void) var; (void) prev; (void) cur; (void) data;
+    return VLC_SUCCESS;
+}
+
 #undef aout_New
 /**
  * Creates an audio output object and initializes an output module.
@@ -267,6 +275,7 @@ audio_output_t *aout_New (vlc_object_t *parent)
     }
 
     var_Create (aout, "audio-filter", VLC_VAR_STRING | VLC_VAR_DOINHERIT);
+    var_AddCallback (aout, "audio-filter", FilterCallback, NULL);
     text.psz_string = _("Audio filters");
     var_Change (aout, "audio-filter", VLC_VAR_SETTEXT, &text, NULL);
 
@@ -313,6 +322,7 @@ void aout_Destroy (audio_output_t *aout)
     aout->device_select = NULL;
     aout_OutputUnlock (aout);
 
+    var_DelCallback (aout, "audio-filter", FilterCallback, NULL);
     var_DelCallback (aout, "mute", var_Copy, aout->p_parent);
     var_SetFloat (aout, "volume", -1.f);
     var_DelCallback (aout, "volume", var_Copy, aout->p_parent);
index f00eaa247d6d191af72e9bdbfe87f419f3a5febb..f55c3458fe63829903b794cb20d34c28f9968c27 100644 (file)
@@ -133,12 +133,8 @@ void playlist_EnableAudioFilter (playlist_t *pl, const char *name, bool add)
 {
     audio_output_t *aout = playlist_GetAout (pl);
 
-    if (aout_ChangeFilterString (VLC_OBJECT(pl), VLC_OBJECT(aout),
-                                 "audio-filter", name, add))
-    {
-        if (aout != NULL)
-            aout_InputRequestRestart (aout);
-    }
+    aout_ChangeFilterString (VLC_OBJECT(pl), VLC_OBJECT(aout),
+                             "audio-filter", name, add);
     if (aout != NULL)
         vlc_object_release (aout);
 }