X-Git-Url: https://git.kaliko.me/?a=blobdiff_plain;f=sima%2Fplugins%2Finternal%2Fcrop.py;h=59e45c2c998f4a16d2ea46c77c39c65ed4bbbf4c;hb=5155de9f17342ee68f19196d7658751883f4145a;hp=1f8ab2c1936f9d39cd0c898d7a40e0c1973859f5;hpb=24993cd99b847733894f57fd004ed52b5390244a;p=mpd-sima.git diff --git a/sima/plugins/internal/crop.py b/sima/plugins/internal/crop.py index 1f8ab2c..59e45c2 100644 --- a/sima/plugins/internal/crop.py +++ b/sima/plugins/internal/crop.py @@ -1,5 +1,5 @@ # -*- coding: utf-8 -*- -# Copyright (c) 2013, 2014 Jack Kaliko +# Copyright (c) 2013-2015, 2020 kaliko # # This file is part of sima # @@ -31,30 +31,38 @@ from ...lib.plugin import Plugin class Crop(Plugin): """ Crop playlist on next track - kinda MPD's consume """ def __init__(self, daemon): super().__init__(daemon) + self.daemon = daemon self.target = None if not self.plugin_conf: return - target = self.plugin_conf.get('consume', None) + target = self.plugin_conf.get('consume') if not target: return - if not target.isdigit(): + try: + if int(target) < 0: + self.log.info('Negative value for consume, not cropping') + return + except ValueError: self.log.warning('Bad value for consume, ' - 'expecting an integer, not "{}"'.format(target)) + 'expecting an integer, not "%s"', target) else: self.target = int(target) + self.log.debug('Cropping at 15') def callback_next_song(self): if not self.target: return - player = self._Plugin__daemon.player + if not self.daemon.enabled: + self.log.debug('Queueing disabled, not cropping') + return False + player = self.daemon.player if player.currentsong().pos > self.target: self.log.debug('cropping playlist') while player.currentsong().pos > self.target: - player.remove() + player.delete(0) # VIM MODLINE