X-Git-Url: https://git.kaliko.me/?a=blobdiff_plain;f=sima%2Fcore.py;h=ead1ba8e9563d1e2ad61465854b508e192c596e3;hb=88706f0a1a79e669068162d6a38d9820afacbe64;hp=eea108d3a078eb15ecc88913b8bd98a532b21abc;hpb=75611a590e62f82a6f2651ac176ff619052eaa89;p=mpd-sima.git diff --git a/sima/core.py b/sima/core.py index eea108d..ead1ba8 100644 --- a/sima/core.py +++ b/sima/core.py @@ -31,6 +31,7 @@ from .lib.simadb import SimaDB from .lib.daemon import Daemon from .utils.utils import SigHup + class Sima(Daemon): """Main class, plugin and player management """ @@ -93,9 +94,13 @@ class Sima(Daemon): if not self.enabled: self.log.debug('Queueing disabled!') return False - queue = self.player.queue queue_trigger = self.config.getint('sima', 'queue_length') - self.log.debug('Currently %s track(s) ahead. (target %s)', len(queue), queue_trigger) + if self.player.playmode.get('random'): + queue = self.player.playlist + self.log.debug('Currently %s track(s) in the playlist. (target %s)', len(queue), queue_trigger) + else: + queue = self.player.queue + self.log.debug('Currently %s track(s) ahead. (target %s)', len(queue), queue_trigger) if len(queue) < queue_trigger: return True return False @@ -103,7 +108,7 @@ class Sima(Daemon): def queue(self): to_add = list() for plugin in self.plugins: - self.log.info('running %s', plugin) + self.log.info('callback_need_track: %s', plugin) pl_candidates = getattr(plugin, 'callback_need_track')() if pl_candidates: to_add.extend(pl_candidates) @@ -172,8 +177,8 @@ class Sima(Daemon): #TODO: unhandled Player exceptions self.log.warning('Unhandled player exception: %s', err) del self.player - self.player = PlayerClient() - time.sleep(10) + self.player = self.__get_player() + time.sleep(5) except PlayerError as err: self.log.warning('Player error: %s', err) self.reconnect_player()