X-Git-Url: https://git.kaliko.me/?a=blobdiff_plain;f=sima%2Fplugins%2Finternal%2Ftags.py;h=c891b779893f50f232d3d3b2bfab7f6d8e151b37;hb=e86c25ed9e97c5dd3e0672d5b17bed01d4a23fdf;hp=76a2b7bf695364605ef6ca93a1434c003aaf8829;hpb=c806cb3dbeee61c9c4d023f75a862a33d32ef026;p=mpd-sima.git diff --git a/sima/plugins/internal/tags.py b/sima/plugins/internal/tags.py index 76a2b7b..c891b77 100644 --- a/sima/plugins/internal/tags.py +++ b/sima/plugins/internal/tags.py @@ -1,5 +1,5 @@ # -*- coding: utf-8 -*- -# Copyright (c) 2020 kaliko +# Copyright (c) 2020, 2021 kaliko # # This file is part of sima # @@ -22,6 +22,7 @@ Add titles based on tags """ # standard library import +import logging import random # third parties components @@ -33,6 +34,26 @@ from ...lib.meta import Artist, MetaContainer from ...utils.utils import PluginException +def control_config(tags_config): + log = logging.getLogger('sima') + sup_tags = Tags.supported_tags + config_tags = {k for k, v in tags_config.items() + if (v and k in Tags.supported_tags)} + if not tags_config.get('filter', None) and \ + config_tags.isdisjoint(sup_tags): + log.warning('Found no config for Tags plugin! ' + 'Need at least "filter" or a supported tag') + log.info('Supported Tags are : %s', ', '.join(sup_tags)) + # raise PluginException('plugin misconfiguration') + return False + if config_tags.difference(sup_tags): + log.error('Found unsupported tag in config: %s', + config_tags.difference(sup_tags)) + # raise PluginException('plugin misconfiguration') + return False + return True + + def forge_filter(cfg): tags = set(cfg.keys()) & Tags.supported_tags cfg_filter = cfg.get('filter', None) @@ -57,7 +78,8 @@ class Tags(AdvancedPlugin): """Add track based on tags content """ supported_tags = {'comment', 'date', 'genre', 'label', 'originaldate'} - options = {'queue_mode', 'priority', 'filter', 'track_to_add', 'album_to_add'} + # options = {'queue_mode', 'priority', 'filter', 'track_to_add', + # 'album_to_add'} def __init__(self, daemon): super().__init__(daemon) @@ -67,18 +89,7 @@ class Tags(AdvancedPlugin): self.log.debug('mpd filter: %s', self.mpd_filter) def _control_conf(self): - sup_tags = Tags.supported_tags - config_tags = {k for k, v in self.plugin_conf.items() - if (v and k not in Tags.options)} - if not self.plugin_conf.get('filter', None) and \ - config_tags.isdisjoint(sup_tags): - self.log.error('Found no config for %s plugin! ' - 'Need at least "filter" or a supported tag', self) - self.log.info('Supported Tags are : %s', ', '.join(sup_tags)) - raise PluginException('plugin misconfiguration') - if config_tags.difference(sup_tags): - self.log.error('Found unsupported tag in config: %s', - config_tags.difference(sup_tags)) + if not control_config(self.plugin_conf): raise PluginException('plugin misconfiguration') def _setup_tagsneeded(self): @@ -106,16 +117,18 @@ class Tags(AdvancedPlugin): if self.plugin_conf['filter']: # Use window to limit response size self.player.find(self.plugin_conf['filter'], "window", (0, 1)) - except CommandError: + except CommandError as err: raise PluginException('Badly formated filter in tags plugin configuration: "%s"' - % self.plugin_conf['filter']) + % self.plugin_conf['filter']) from err def callback_need_track(self): candidates = [] queue_mode = self.plugin_conf.get('queue_mode', 'track') target = self.plugin_conf.getint(f'{queue_mode}_to_add') # look for artists acording to filter - artists = MetaContainer([Artist(name=a) for a in self.player.list('artist', self.mpd_filter)]) + artists = [Artist(name=a) for a in self.player.list('artist', self.mpd_filter)] + random.shuffle(artists) + artists = MetaContainer(artists) if not artists: self.log.info('Tags plugin found nothing to queue') return candidates @@ -124,7 +137,9 @@ class Tags(AdvancedPlugin): for artist in artists: self.log.debug('looking for %s', artist) tracks = self.player.find_tracks(artist) - trk = self.filter_track(tracks) + if not tracks: + continue + trk = self.filter_track(tracks, candidates) if not trk: continue if queue_mode == 'track':