X-Git-Url: https://git.kaliko.me/?a=blobdiff_plain;f=sima%2Flib%2Fplugin.py;h=2cc284ff1eb043e1a6a0e58b74bb940ffee14d88;hb=b2341c5c948f731c9247706db09646eb6c61eec5;hp=6ffff1affe5d56ffaf0398fa1047c026c15038ea;hpb=e53888ac95b4b58947a21becfc2282fc42d35da4;p=mpd-sima.git diff --git a/sima/lib/plugin.py b/sima/lib/plugin.py index 6ffff1a..2cc284f 100644 --- a/sima/lib/plugin.py +++ b/sima/lib/plugin.py @@ -23,8 +23,7 @@ Plugin object to derive from import random -from .track import Track -from .meta import Album, Artist, MetaContainer +from .meta import Artist, MetaContainer class Plugin: @@ -126,29 +125,15 @@ class AdvancedPlugin(Plugin): """ # Query History - def get_history(self, artist=False): - """Constructs Track list of already played artists. - - :param Artist artist: Artist object to look history for - """ + def get_history(self): + """Returns a Track list of already played artists.""" duration = self.main_conf.getint('sima', 'history_duration') - name = None - if artist: - name = artist.name - from_db = self.sdb.get_history(duration=duration, artist=name) - hist = [Track(artist=tr[0], album=tr[1], title=tr[2], - file=tr[3]) for tr in from_db] - return hist + return self.sdb.fetch_history(duration=duration) def get_album_history(self, artist): """Retrieve album history""" - hist = [] - tracks_from_db = self.get_history(artist=artist) - for trk in tracks_from_db: - if trk.album and trk.album in hist: - continue - hist.append(Album(name=trk.album, artist=Artist(trk.artist))) - return hist + duration = self.main_conf.getint('sima', 'history_duration') + return self.sdb.fetch_albums_history(needle=artist, duration=duration) def get_reorg_artists_list(self, alist): """ @@ -162,7 +147,7 @@ class AdvancedPlugin(Plugin): not_queued_artist = alist - queued_artist duration = self.main_conf.getint('sima', 'history_duration') hist = [] - for art in self.sdb.get_artists_history(alist, duration=duration): + for art in self.sdb.fetch_artists_history(alist, duration=duration): if art not in hist: if art not in queued_artist: hist.insert(0, art) @@ -185,7 +170,7 @@ class AdvancedPlugin(Plugin): albums = self.player.search_albums(artist) if not albums: return None - self.log.debug('Albums candidates: %s', albums) + self.log.debug('Albums to choose from: %s', albums) albums_hist = self.get_album_history(artist) self.log.trace('Albums history: %s', [a.name for a in albums_hist]) albums_not_in_hist = [a for a in albums if a.name not in albums_hist] @@ -196,16 +181,17 @@ class AdvancedPlugin(Plugin): return None random.shuffle(albums_not_in_hist) albums_not_in_hist.extend(albums_hist) - self.log.debug('Albums candidate: %s', albums_not_in_hist) + self.log.trace('Album candidates: %s', albums_not_in_hist) album_to_queue = [] for album in albums_not_in_hist: # Controls the album found is not already queued - if album in {t.album for t in self.player.queue}: + if album in {t.Album.name for t in self.player.queue}: self.log.debug('"%s" already queued, skipping!', album) continue # In random play mode use complete playlist to filter + # Yes indeed, some users play in random with album mode :| if self.player.playmode.get('random'): - if album in {t.album for t in self.player.playlist}: + if album in {t.Album.name for t in self.player.playlist}: self.log.debug('"%s" already in playlist, skipping!', album) continue @@ -214,15 +200,21 @@ class AdvancedPlugin(Plugin): if not album_to_queue: self.log.info('No album found for "%s"', artist) return None - self.log.info('%s album candidate: %s - %s', self.__class__.__name__, - artist, album_to_queue) + self.log.info('%s plugin chose album: %s - %s', + self.__class__.__name__, artist, album_to_queue) return album_to_queue - def filter_track(self, tracks, unplayed=False): + def filter_track(self, tracks, chosen=None, unplayed=False): """ Extract one unplayed track from a Track object list. * not in history * not already in the queue + + :param list(Track) tracks: List of tracks to chose from + :param list(Track) chosen: List of tracks previously chosen + :param bool unplayed: chose only unplayed (honoring history duration setting) + :return: A Track + :rtype: Track """ artist = tracks[0].Artist # In random play mode use complete playlist to filter @@ -230,7 +222,7 @@ class AdvancedPlugin(Plugin): deny_list = self.player.playlist else: deny_list = self.player.queue - not_in_hist = list(set(tracks) - set(self.get_history(artist=artist))) + not_in_hist = list(set(tracks) - set(self.sdb.fetch_history(artist=artist))) if not not_in_hist: self.log.debug('All tracks already played for "%s"', artist) if unplayed: @@ -240,8 +232,10 @@ class AdvancedPlugin(Plugin): for trk in [_ for _ in not_in_hist if _ not in deny_list]: # Should use albumartist heuristic as well if self.plugin_conf.getboolean('single_album', False): # pylint: disable=no-member - if (trk.album == self.player.current.album or - trk.album in [tr.album for tr in deny_list]): + albums = [tr.Album for tr in deny_list] + albums += [tr.Album for tr in chosen] + if (trk.Album == self.player.current.Album or + trk.Album in albums): self.log.debug('Found unplayed track ' + 'but from an album already queued: %s', trk) continue