cplay

changeset 2:c7d8ec7da73b 1.49-meillo

Add mplayer as a backend player Plus: exchange PCM and Master mixer.
author markus schnalke <meillo@marmaro.de>
date Thu, 27 Jul 2017 07:08:00 +0200 (2017-07-27)
parents 7db0dc9d32d3
children 07e746bdb6bb
files cplay
diffstat 1 files changed, 30 insertions(+), 5 deletions(-) [+]
line diff
     1.1 --- a/cplay	Wed Sep 27 09:25:24 2017 +0200
     1.2 +++ b/cplay	Thu Jul 27 07:08:00 2017 +0200
     1.3 @@ -1,7 +1,7 @@
     1.4  #!/usr/bin/env python
     1.5  # -*- python -*-
     1.6  
     1.7 -__version__ = "cplay 1.49"
     1.8 +__version__ = "cplay 1.49-meillo"
     1.9  
    1.10  """
    1.11  cplay - A curses front-end for various audio players
    1.12 @@ -1206,6 +1206,7 @@
    1.13          self.stopped = 0
    1.14          self.paused = 0
    1.15          self.step = 0
    1.16 +        self.setlength()
    1.17          self.update_status()
    1.18  
    1.19      def stop(self, quiet=0):
    1.20 @@ -1277,6 +1278,9 @@
    1.21          else:
    1.22              app.set_default_status(_("Playing: %s") % self.entry.vp())
    1.23  
    1.24 +    def setlength(self):
    1.25 +        return
    1.26 +
    1.27  # ------------------------------------------
    1.28  class FrameOffsetPlayer(Player):
    1.29      re_progress = re.compile("Time.*\s(\d+):(\d+).*\[(\d+):(\d+)")
    1.30 @@ -1301,6 +1305,26 @@
    1.31              self.set_position(head, head+tail, [head, tail])
    1.32  
    1.33  # ------------------------------------------
    1.34 +class TimeOffsetMplayer(Player):
    1.35 +    re_progress = re.compile("A: *(\d+)")
    1.36 +
    1.37 +    def parse_buf(self):
    1.38 +        match = self.re_progress.search(self.buf)
    1.39 +        if match:
    1.40 +            head = string.atoi(match.groups()[0])
    1.41 +            tail = max(self.length, head) - head
    1.42 +            self.set_position(head, head+tail, [head, tail])
    1.43 +
    1.44 +    def setlength(self):
    1.45 +        while 1:
    1.46 +            self.buf = os.read(self.stdout_r, 512)
    1.47 +            re_length = re.compile("ID_LENGTH=(\d+)")
    1.48 +            match = re_length.search(self.buf)
    1.49 +            if match:
    1.50 +                self.length = string.atoi(match.groups()[0])
    1.51 +                break
    1.52 +
    1.53 +# ------------------------------------------
    1.54  class NoOffsetPlayer(Player):
    1.55  
    1.56      def parse_buf(self):
    1.57 @@ -1508,15 +1532,15 @@
    1.58              mixer = ossaudiodev.openmixer()
    1.59              get, set = mixer.get, mixer.set
    1.60              self.channels = self.channels or \
    1.61 -                [['MASTER', ossaudiodev.SOUND_MIXER_VOLUME],
    1.62 -                 ['PCM', ossaudiodev.SOUND_MIXER_PCM]]
    1.63 +                [['PCM', ossaudiodev.SOUND_MIXER_PCM],
    1.64 +                 ['MASTER', ossaudiodev.SOUND_MIXER_VOLUME]]
    1.65          except ImportError:
    1.66              import oss
    1.67              mixer = oss.open_mixer()
    1.68              get, set = mixer.read_channel, mixer.write_channel
    1.69              self.channels = self.channels or \
    1.70 -                [['MASTER', oss.SOUND_MIXER_VOLUME],
    1.71 -                 ['PCM', oss.SOUND_MIXER_PCM]]
    1.72 +                [['PCM', oss.SOUND_MIXER_PCM],
    1.73 +                 ['MASTER', oss.SOUND_MIXER_VOLUME]]
    1.74          if cmd is "toggle": self.channels.insert(0, self.channels.pop())
    1.75          name, channel = self.channels[0]
    1.76          if cmd is "cue": arg = min(100, max(0, get(channel)[0] + arg))
    1.77 @@ -1627,6 +1651,7 @@
    1.78  
    1.79  # ------------------------------------------
    1.80  PLAYERS = [
    1.81 +    TimeOffsetMplayer("mplayer -vo null -identify -ss %d %s", "(^http://|\.(mp[1-4]|flv|mkv|m4a)$)"),
    1.82      FrameOffsetPlayer("ogg123 -q -v -k %d %s", "\.ogg$"),
    1.83      FrameOffsetPlayer("splay -f -k %d %s", "(^http://|\.mp[123]$)", 38.28),
    1.84      FrameOffsetPlayer("mpg123 -q -v -k %d %s", "(^http://|\.mp[123]$)", 38.28),