diff options
author | Florent Le Coz <louiz@louiz.org> | 2011-11-06 20:30:41 +0100 |
---|---|---|
committer | Florent Le Coz <louiz@louiz.org> | 2011-11-06 20:30:41 +0100 |
commit | 8a8284ae0615ddff18f94ee391e579d65f8915de (patch) | |
tree | 2052ab72e03cca4ca3b30df560b4452253dafac2 /plugins/mpd_client.py | |
parent | 6a0ac419c5c1d259171a5d49e323f23cd181462c (diff) | |
parent | d62a3a1b1bf2eda1186aa8bf94bd33c1b54c4d59 (diff) | |
download | poezio-8a8284ae0615ddff18f94ee391e579d65f8915de.tar.gz poezio-8a8284ae0615ddff18f94ee391e579d65f8915de.tar.bz2 poezio-8a8284ae0615ddff18f94ee391e579d65f8915de.tar.xz poezio-8a8284ae0615ddff18f94ee391e579d65f8915de.zip |
Merge branch 'plugins' of http://git.louiz.org/poezio into plugins
Diffstat (limited to 'plugins/mpd_client.py')
-rw-r--r-- | plugins/mpd_client.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/plugins/mpd_client.py b/plugins/mpd_client.py new file mode 100644 index 00000000..5207a0d6 --- /dev/null +++ b/plugins/mpd_client.py @@ -0,0 +1,37 @@ +# a plugin adding a command to manipulate an MPD instance + +from plugin import BasePlugin +from common import shell_split +import mpd + +class Plugin(BasePlugin): + def init(self): + self.add_command('mpd', self.command_mpd, "Usage: /mpd [full]\nMpd: sends a message showing the current song of an MPD instance. If full is provided, teh message is more verbose.", self.completion_mpd) + + def command_mpd(self, args): + args = shell_split(args) + c = mpd.MPDClient() + try: + c.connect(host=self.config.get('host', 'localhost'), port=self.config.get('host', '6600')) + except Exception as e: + self.core.information('%s' % (e,), 'Error') + return + password = self.config.get('password', '') + if password: + try: + c.password(password) + except Exception as e: + self.core.information('%s' % (e,), 'Error') + return + current = c.currentsong() + current_time = float(c.status()['elapsed']) + + s = '%(artist)s - %(title)s (%(album)s)' % current + if 'full' in args: + pourcentage = int(current_time / float(current['time']) * 10) + s += ' \x192[\x191' + '-'*(pourcentage-1) + '\x193+' + '\x191' + '-' * (10-pourcentage-1) + '\x192]\x19o' + if not self.core.send_message('%s' % (s,)): + self.core.information('Cannot send result (%s), this is not a conversation tab' % result) + + def completion_mpd(self, the_input): + return the_input.auto_completion(['full']) |