X-Git-Url: http://git.kaliko.me/?a=blobdiff_plain;f=sima%2Fplugins%2Finternal%2Fcrop.py;h=5ac8f0f84d6693e1e19c5cebf315a1c302842571;hb=331b1c5fe8f997a59eb0662e1dd29c63cfd7c5d6;hp=8ea889e7810d08c7b88664c8b3bf86b87f087467;hpb=7854938788e0af521edd7199e40db796d3256351;p=mpd-sima.git diff --git a/sima/plugins/internal/crop.py b/sima/plugins/internal/crop.py index 8ea889e..5ac8f0f 100644 --- a/sima/plugins/internal/crop.py +++ b/sima/plugins/internal/crop.py @@ -2,10 +2,10 @@ """Crops playlist """ -# standart library import +# standard library import #from select import select -# third parties componants +# third parties components # local import from ...lib.plugin import Plugin @@ -15,12 +15,27 @@ class Crop(Plugin): Crop playlist on next track kinda MPD's consume """ + def __init__(self, daemon): + super().__init__(daemon) + self.target = None + if not self.plugin_conf: + return + target = self.plugin_conf.get('consume', None) + if not target: + return + if not target.isdigit(): + self.log.warning('Bad value for consume, ' + 'expecting an integer, not "{}"'.format(target)) + else: + self.target = int(target) def callback_playlist(self): + if not self.target: + return player = self._Plugin__daemon.player - target_lengh = 10 - while player.currentsong().pos > target_lengh: + if player.currentsong().pos > self.target: self.log.debug('cropping playlist') + while player.currentsong().pos > self.target: player.remove()