from ...lib.track import Track
from ...utils.utils import PluginException
+
def forge_filter(cfg):
tags = set(cfg.keys()) & Tags.supported_tags
cfg_filter = cfg.get('filter', None)
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 ['filter', 'priority'])}
+ if (v and k not in ['filter', 'priority', 'track_to_add'])}
if not self.plugin_conf.get('filter', None) and \
config_tags.isdisjoint(sup_tags):
self.log.error('Found no config for %s plugin! '
def _setup_tagsneeded(self):
config_tags = {k for k, v in self.plugin_conf.items() if v}
self.log.debug('%s plugin needs the followinng metadata: %s',
- self, config_tags & Tags.supported_tags)
+ self, config_tags & Tags.supported_tags)
tags = config_tags & Tags.supported_tags
self.player.needed_tags |= tags
def start(self):
if (0, 21, 0) > tuple(map(int, self.player.mpd_version.split('.'))):
self.log.warning('MPD protocol version: %s < 0.21.0',
- self.player.mpd_version)
- self.log.error('Need at least MPD 0.21 to use Tags plugin (filters required)')
+ self.player.mpd_version)
+ self.log.error(
+ 'Need at least MPD 0.21 to use Tags plugin (filters required)')
self.player.disconnect()
raise PluginException('MPD >= 0.21 required')
# Check filter is valid
try:
- self.player.find(self.plugin_conf['filter'])
+ if self.plugin_conf['filter']:
+ self.player.find(self.plugin_conf['filter'])
except CommandError:
raise PluginException('Badly formated filter in tags plugin configuration: "%s"'
% self.plugin_conf['filter'])