X-Git-Url: https://git.kaliko.me/?a=blobdiff_plain;f=sima%2Flib%2Fplayer.py;h=1d1f69315301e681933ea73a376118cacfd3876c;hb=80162143f725cbe604f7241e4dfc4929833470e5;hp=37b3c7202dc392b842e25ff783effd34a7c6081f;hpb=4f1b17d6b72946b60f79b8c3f5fa5557710b9aac;p=mpd-sima.git diff --git a/sima/lib/player.py b/sima/lib/player.py index 37b3c72..1d1f693 100644 --- a/sima/lib/player.py +++ b/sima/lib/player.py @@ -23,9 +23,38 @@ # standard library import import logging +from itertools import dropwhile # local import -#from sima.lib.track import Track + +def blacklist(artist=False, album=False, track=False): + #pylint: disable=C0111,W0212 + field = (album, track) + def decorated(func): + def wrapper(*args, **kwargs): + if not args[0].database: + return func(*args, **kwargs) + cls = args[0] + boolgen = (bl for bl in field) + bl_fun = (cls.database.get_bl_album, + cls.database.get_bl_track,) + #bl_getter = next(fn for fn, bl in zip(bl_fun, boolgen) if bl is True) + bl_getter = next(dropwhile(lambda _: not next(boolgen), bl_fun)) + #cls.log.debug('using {0} as bl filter'.format(bl_getter.__name__)) + results = list() + for elem in func(*args, **kwargs): + if bl_getter(elem, add_not=True): + #cls.log.debug('Blacklisted "{0}"'.format(elem)) + continue + if track and cls.database.get_bl_album(elem, add_not=True): + # filter album as well in track mode + # (artist have already been) + cls.log.debug('Blacklisted alb. "{0.album}"'.format(elem)) + continue + results.append(elem) + return results + return wrapper + return decorated class Player(object): @@ -40,7 +69,6 @@ class Player(object): * current * queue * playlist - * """ def __init__(self): @@ -69,8 +97,8 @@ class Player(object): def find_track(self, artist, title=None): """ Find tracks for a specific artist or filtering with a track title - >>> player.find_track('The Beatles') - >>> player.find_track('Nirvana', title='Smells Like Teen Spirit') + >>> player.find_track(Artist('The Beatles')) + >>> player.find_track(Artist('Nirvana'), title='Smells Like Teen Spirit') Returns a list of Track objects """ @@ -85,23 +113,25 @@ class Player(object): """ raise NotImplementedError - def find_albums(self, artist): + def search_albums(self, artist): """ Find albums by artist's name - >>> player.find_alums('Nirvana') + >>> art = Artist(name='Nirvana') + >>> player.search_albums(art) Returns a list of string objects """ raise NotImplementedError - def fuzzy_find_artist(self, artist): + def search_artist(self, artist): """ - Find artists based on a fuzzy search in the media library - >>> bea = player.fuzzy_find_artist('beatles') - >>> print(bea) - >>> ['The Beatles'] + Search artists based on a fuzzy search in the media library + >>> art = Artist(name='the beatles', mbid=) # mbid optional + >>> bea = player.search_artist(art) + >>> print(bea.names) + >>> ['The Beatles', 'Beatles', 'the beatles'] - Returns a list of strings (artist names) + Returns an Artist object """ raise NotImplementedError @@ -115,5 +145,45 @@ class Player(object): """ raise NotImplementedError + @property + def artists(self): + #pylint: disable=C0111 + raise NotImplementedError + + @property + def state(self): + """Returns (play|stop|pause)""" + #pylint: disable=C0111 + raise NotImplementedError + + @property + def playmode(self): + """Returns a mapping + { + 'repeat': boolean, + 'random': boolean, + 'single': boolean, + 'consume': boolean, + … + } + """ + #pylint: disable=C0111 + raise NotImplementedError + + @property + def current(self): + #pylint: disable=C0111 + raise NotImplementedError + + @property + def queue(self): + #pylint: disable=C0111 + raise NotImplementedError + + @property + def playlist(self): + #pylint: disable=C0111 + raise NotImplementedError + # VIM MODLINE # vim: ai ts=4 sw=4 sts=4 expandtab