]> git.immae.eu Git - perso/Immae/Projets/Python/MusicSampler.git/blobdiff - helpers/action.py
Reorder MusicFile methods
[perso/Immae/Projets/Python/MusicSampler.git] / helpers / action.py
index 1a2abe203567a496802824c68c1ae3113b57eb47..ec8fcb6f0b43748873eb2e8568589c62cfd36f58 100644 (file)
@@ -6,6 +6,7 @@ from . import debug_print
 class Action:
     action_types = [
         'command',
+        'interrupt_wait',
         'pause',
         'play',
         'seek',
@@ -29,7 +30,7 @@ class Action:
 
     def ready(self):
         if 'music' in self.arguments:
-            return self.arguments['music'].check_is_loaded()
+            return self.arguments['music'].is_loaded(allow_substates=True)
         else:
             return True
 
@@ -51,58 +52,76 @@ class Action:
             return self.mapping.open_files.values()
 
     # Actions
-    def command(self, command = "", **kwargs):
+    def command(self, command="", **kwargs):
         # FIXME: todo
         pass
 
-    def pause(self, music = None, **kwargs):
+    def pause(self, music=None, **kwargs):
         for music in self.music_list(music):
             if music.is_loaded_playing():
                 music.pause()
 
-    def unpause(self, music = None, **kwargs):
+    def unpause(self, music=None, **kwargs):
         for music in self.music_list(music):
             if music.is_loaded_paused():
                 music.unpause()
 
-    def play(self, music = None, fade_in = 0, start_at = 0,
-            restart_if_running = False, volume = 100,
-            loop = 0,
-            **kwargs):
+    def play(self, music=None, fade_in=0, start_at=0,
+            restart_if_running=False, volume=100,
+            loop=0, **kwargs):
         for music in self.music_list(music):
             if restart_if_running:
-                if music.is_not_stopped():
+                if music.is_in_use():
                     music.stop()
-                music.play(volume = volume, fade_in = fade_in, start_at = start_at, loop = loop)
-            else:
-                if not music.is_not_stopped():
-                    music.play(volume = volume, fade_in = fade_in, start_at = start_at, loop = loop)
-
-    def seek(self, music = None, value = 0, delta = False, **kwargs):
+                music.play(
+                        volume=volume,
+                        fade_in=fade_in,
+                        start_at=start_at,
+                        loop=loop)
+            elif not music.is_in_use():
+                music.play(
+                        volume=volume,
+                        fade_in=fade_in,
+                        start_at=start_at,
+                        loop=loop)
+
+    def seek(self, music=None, value=0, delta=False, **kwargs):
         for music in self.music_list(music):
-            music.seek(value = value, delta = delta)
+            music.seek(value=value, delta=delta)
+
+    def interrupt_wait(self, wait_id=None):
+        self.mapping.interrupt_wait(wait_id)
 
-    def stop(self, music = None, fade_out = 0, wait = False, **kwargs):
+    def stop(self, music=None, fade_out=0, wait=False,
+            set_wait_id=None, **kwargs):
         previous = None
         for music in self.music_list(music):
             if music.is_loaded_paused() or music.is_loaded_playing():
                 if previous is not None:
-                    previous.stop(fade_out = fade_out)
+                    previous.stop(fade_out=fade_out)
                 previous = music
+            else:
+                music.stop(fade_out=fade_out)
 
         if previous is not None:
-            previous.stop(fade_out = fade_out, wait = wait)
+            previous.stop(
+                    fade_out=fade_out,
+                    wait=wait,
+                    set_wait_id=set_wait_id)
 
     def stop_all_actions(self, **kwargs):
         self.mapping.stop_all_running()
 
-    def volume(self, music = None, value = 100, delta = False, **kwargs):
+    def volume(self, music=None, value=100, fade=0, delta=False, **kwargs):
         if music is not None:
-            music.set_volume(value, delta = delta)
+            music.set_volume(value, delta=delta, fade=fade)
         else:
-            self.mapping.set_master_volume(value, delta = delta)
+            self.mapping.set_master_volume(value, delta=delta, fade=fade)
+
+    def wait(self, duration=0, music=None, set_wait_id=None, **kwargs):
+        if set_wait_id is not None:
+            self.mapping.add_wait_id(set_wait_id, self)
 
-    def wait(self, duration = 0, music = None, **kwargs):
         self.sleep_event = threading.Event()
 
         if music is not None:
@@ -112,23 +131,26 @@ class Action:
         self.sleep_event.wait()
 
     # Action messages
-    def command_print(self, command = "", **kwargs):
+    def command_print(self, command="", **kwargs):
         return "running command {}".format(command)
 
-    def pause_print(self, music = None, **kwargs):
+    def interrupt_wait_print(self, wait_id=None, **kwargs):
+        return "interrupt wait with id {}".format(wait_id)
+
+    def pause_print(self, music=None, **kwargs):
         if music is not None:
             return "pausing « {} »".format(music.name)
         else:
             return "pausing all musics"
 
-    def unpause_print(self, music = None, **kwargs):
+    def unpause_print(self, music=None, **kwargs):
         if music is not None:
             return "unpausing « {} »".format(music.name)
         else:
             return "unpausing all musics"
 
-    def play_print(self, music = None, fade_in = 0, start_at = 0,
-            restart_if_running = False, volume = 100, loop = 0, **kwargs):
+    def play_print(self, music=None, fade_in=0, start_at=0,
+            restart_if_running=False, volume=100, loop=0, **kwargs):
         message = "starting "
         if music is not None:
             message += "« {} »".format(music.name)
@@ -153,7 +175,9 @@ class Action:
 
         return message
 
-    def stop_print(self, music = None, fade_out = 0, wait = False, **kwargs):
+    def stop_print(self, music=None, fade_out=0, wait=False,
+            set_wait_id=None, **kwargs):
+
         message = "stopping "
         if music is not None:
             message += "music « {} »".format(music.name)
@@ -163,48 +187,75 @@ class Action:
         if fade_out > 0:
             message += " with {}s fadeout".format(fade_out)
             if wait:
-                message += " (waiting the end of fadeout)"
+                if set_wait_id is not None:
+                    message += " (waiting the end of fadeout, with id {})"\
+                            .format(set_wait_id)
+                else:
+                    message += " (waiting the end of fadeout)"
 
         return message
 
     def stop_all_actions_print(self, **kwargs):
         return "stopping all actions"
 
-    def seek_print(self, music = None, value = 0, delta = False, **kwargs):
+    def seek_print(self, music=None, value=0, delta=False, **kwargs):
         if delta:
             if music is not None:
-                return "moving music « {} » by {:+d}s".format(music.name, value)
+                return "moving music « {} » by {:+d}s" \
+                        .format(music.name, value)
             else:
-                return "moving all musics by {:+d}s".format(value)
+                return "moving all musics by {:+d}s" \
+                        .format(value)
         else:
             if music is not None:
-                return "moving music « {} » to position {}s".format(music.name, value)
+                return "moving music « {} » to position {}s" \
+                        .format(music.name, value)
             else:
-                return "moving all musics to position {}s".format(value)
+                return "moving all musics to position {}s" \
+                        .format(value)
 
-    def volume_print(self, music = None, value = 100, delta = False, **kwargs):
+    def volume_print(self, music=None,
+            value=100, delta=False, fade=0, **kwargs):
+        message = ""
         if delta:
             if music is not None:
-                return "{:+d}% to volume of « {} »".format(value, music.name)
+                message += "{:+d}% to volume of « {} »" \
+                        .format(value, music.name)
             else:
-                return "{:+d}% to volume".format(value)
+                message += "{:+d}% to volume" \
+                        .format(value)
         else:
             if music is not None:
-                return "setting volume of « {} » to {}%".format(music.name, value)
+                message += "setting volume of « {} » to {}%" \
+                        .format(music.name, value)
             else:
-                return "setting volume to {}%".format(value)
+                message += "setting volume to {}%" \
+                        .format(value)
+
+        if fade > 0:
+            message += " with {}s fade".format(fade)
+
+        return message
 
-    def wait_print(self, duration = 0, music = None, **kwargs):
+    def wait_print(self, duration=0, music=None, set_wait_id=None, **kwargs):
+        message = ""
         if music is None:
-            return "waiting {}s".format(duration)
+            message += "waiting {}s" \
+                    .format(duration)
         elif duration == 0:
-            return "waiting the end of « {} »".format(music.name)
+            message += "waiting the end of « {} »" \
+                    .format(music.name)
         else:
-            return "waiting the end of « {} » + {}s".format(music.name, duration)
+            message += "waiting the end of « {} » + {}s" \
+                    .format(music.name, duration)
+
+        if set_wait_id is not None:
+            message += " (setting id = {})".format(set_wait_id)
 
+        return message
 
     # Interruptions
-    def wait_interrupt(self, duration = 0, music = None, **kwargs):
+    def wait_interrupt(self, duration=0, music=None, **kwargs):
         if self.sleep_event is not None:
             self.sleep_event.set()
         if music is not None: