from .meta import Artist, MetaContainer
from ..utils.utils import WSError, WSNotFound, WSTimeout
+
def cache(func):
"""Caching decorator"""
def wrapper(*args, **kwargs):
else:
results = func(*args, **kwargs)
cls.log.debug('caching request')
- cls._cache.get('asearch').update({hashedlst:list(results)})
+ cls._cache.get('asearch').update({hashedlst: list(results)})
random.shuffle(results)
return results
return wrapper
class WebService(AdvancedPlugin):
"""similar artists webservice
"""
- # pylint: disable=bad-builtin
def __init__(self, daemon):
super().__init__(daemon)
Look in player library for availability of similar artists in
similarities
"""
- dynamic = self.plugin_conf.getint('max_art') # pylint: disable=no-member
+ dynamic = self.plugin_conf.getint('max_art')
if dynamic <= 0:
dynamic = 100
results = list()
similarities.reverse()
- while (len(results) < dynamic
- and len(similarities) > 0):
+ while (len(results) < dynamic and similarities):
art_pop = similarities.pop()
res = self.player.search_artist(art_pop)
if res:
else:
history = self.player.queue + history
history = deque(history)
- last_trk = history.popleft() # remove
+ last_trk = history.popleft() # remove
extra_arts = list()
ret_extra = list()
depth = 0
- while depth < self.plugin_conf.getint('depth'): # pylint: disable=no-member
- if len(history) == 0:
+ while depth < self.plugin_conf.getint('depth'):
+ if not history:
break
trk = history.popleft()
if (trk.Artist in extra_arts
self.log.debug('Got nothing similar from library!')
ret_extra = None
if len(self.history) >= 2:
- if self.plugin_conf.getint('depth') > 1: # pylint: disable=no-member
+ if self.plugin_conf.getint('depth') > 1:
ret_extra = self.get_recursive_similar_artist()
if ret_extra:
# get them reorg to pick up best element
ret_extra = self.get_reorg_artists_list(ret_extra)
# tries to pickup less artist from extra art
- if len(ret) < 4:
- ret_extra = MetaContainer(ret_extra)
- else:
+ if len(ret) > 4:
ret_extra = MetaContainer(ret_extra[:max(4, len(ret))//2])
if ret_extra:
self.log.debug('extra found in library: %s',
return []
# In random play mode use complete playlist to filter
if self.player.playmode.get('random'):
- queued_artists = MetaContainer([trk.Artist for trk in self.player.playlist])
+ queued_artists = MetaContainer([trk.Artist for trk
+ in self.player.playlist])
else:
- queued_artists = MetaContainer([trk.Artist for trk in self.player.queue])
+ queued_artists = MetaContainer([trk.Artist for trk
+ in self.player.queue])
self.log.trace('Already queued: %s', queued_artists)
self.log.trace('Candidate: %s', ret)
if ret & queued_artists:
# Move around similars items to get in unplayed|not recently played
# artist first.
self.log.info('Got %d artists in library', len(ret))
- candidates = self.get_reorg_artists_list(list(ret))
+ candidates = self.get_reorg_artists_list(ret)
if candidates:
self.log.info(' / '.join(map(str, candidates)))
return candidates
"""
self.to_add = list()
nb_album_add = 0
- target_album_to_add = self.plugin_conf.getint('album_to_add') # pylint: disable=no-member
+ target_album_to_add = self.plugin_conf.getint('album_to_add')
for artist in artists:
- album = self.album_candidate(artist)
+ album = self.album_candidate(artist, unplayed=True)
+ if not album:
+ continue
nb_album_add += 1
candidates = self.player.find_tracks(album)
if self.plugin_conf.getboolean('shuffle_album'):
candidates = candidates[0:nbtracks]
self.to_add.extend(candidates)
if nb_album_add == target_album_to_add:
- return True
+ return
def find_top(self, artists):
"""
find top tracks for artists in artists list.
"""
self.to_add = list()
- nbtracks_target = self.plugin_conf.getint('track_to_add') # pylint: disable=no-member
+ nbtracks_target = self.plugin_conf.getint('track_to_add')
for artist in artists:
if len(self.to_add) == nbtracks_target:
return
"""Get some tracks for track queue mode
"""
artists = self.get_local_similar_artists()
- nbtracks_target = self.plugin_conf.getint('track_to_add') # pylint: disable=no-member
+ nbtracks_target = self.plugin_conf.getint('track_to_add')
for artist in artists:
self.log.debug('Trying to find titles to add for "%r"', artist)
found = self.player.find_tracks(artist)
- random.shuffle(found)
if not found:
self.log.debug('Found nothing to queue for %s', artist)
continue
+ random.shuffle(found)
# find tracks not in history for artist
track_candidate = self.filter_track(found)
if track_candidate:
break
if not self.to_add:
self.log.debug('Found no tracks to queue!')
- return None
+ return
for track in self.to_add:
- self.log.info('%s candidates: %s', track, self.ws.name)
+ self.log.info('%s plugin chose: %s', self.ws.name, track)
def _album(self):
"""Get albums for album queue mode
def callback_need_track(self):
self._cleanup_cache()
- if len(self.player.playlist) == 0:
+ if not self.player.playlist:
self.log.info('No last track, cannot queue')
return None
if not self.player.playlist[-1].artist:
msg = ' '.join(['{0}: {1:>3d}'.format(k, v) for
k, v in sorted(self.ws.stats.items())])
self.log.debug('http stats: ' + msg)
+ if not self.to_add:
+ self.log.info('%s plugin found nothing to queue', self.ws.name)
candidates = self.to_add
self.to_add = list()
if self.plugin_conf.get('queue_mode') != 'album':