X-Git-Url: https://git.kaliko.me/?a=blobdiff_plain;f=sima%2Fplugins%2Finternal%2Ftags.py;h=ad326ef3a1f3f587c3ba6c89332a847aaa072426;hb=76faf2eccfe59a86fa6636973fdcb21d81f47387;hp=0af81ef3f0b7699dfc408b9e931d1203359e1848;hpb=d0232dae194becb33696266083df400a54afbd27;p=mpd-sima.git diff --git a/sima/plugins/internal/tags.py b/sima/plugins/internal/tags.py index 0af81ef..ad326ef 100644 --- a/sima/plugins/internal/tags.py +++ b/sima/plugins/internal/tags.py @@ -110,36 +110,6 @@ class Tags(AdvancedPlugin): raise PluginException('Badly formated filter in tags plugin configuration: "%s"' % self.plugin_conf['filter']) - 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') - tracks = self.player.find(self.mpd_filter) - random.shuffle(tracks) - history = self.get_history() - while tracks: - trk = tracks.pop() - if trk in self.player.queue or \ - trk in candidates: - self.log.debug('%s already queued', trk) - continue - if trk in history: - self.log.debug('%s in history', trk) - continue - candidates.append(trk) - self.log.info('Tags candidate: {}'.format(trk)) - if len(candidates) >= target: - break - if queue_mode == 'track': - return candidates - if queue_mode == 'album': - for trk in candidates: - self.log.info(trk.Artist) - _ = self.album_candidate(trk.Artist) - if not candidates: - self.log.info('Tags plugin failed to find some tracks') - return candidates - def callback_need_track(self): candidates = [] queue_mode = self.plugin_conf.get('queue_mode', 'track') @@ -148,16 +118,15 @@ class Tags(AdvancedPlugin): artists = self.player.list('artist', self.mpd_filter) random.shuffle(artists) artists = self.get_reorg_artists_list(artists) - self.log.debug('Tags candidates: %s', ' / '.join(artists)) + self.log.debug('Tags artists found: %s', ' / '.join(artists)) for artist in artists: - if artist in {t.Artist for t in self.player.queue}: - continue self.log.debug('looking for %s', artist) - trk = self.filter_track(self.player.find_tracks(Artist(name=artist))) + tracks = self.player.find_tracks(Artist(name=artist)) + trk = self.filter_track(tracks) if not trk: continue if queue_mode == 'track': - self.log.info('Tags candidate: {}'.format(trk)) + self.log.info('Tags plugin chose: {}'.format(trk)) candidates.append(trk) if len(candidates) == target: break