forked from albertz/music-player
-
Notifications
You must be signed in to change notification settings - Fork 0
/
tracker.py
30 lines (23 loc) · 882 Bytes
/
tracker.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
from utils import *
import sys, time
from State import state
from player import PlayerEventCallbacks
import appinfo
def track(event, args, kwargs):
#print "track:", repr(event), repr(args), repr(kwargs)
if event is PlayerEventCallbacks.onSongChange:
oldSong = kwargs["oldSong"]
newSong = kwargs["newSong"]
print "new song:", newSong.userLongString.encode("utf-8")
if oldSong: oldSong.close() # in case anyone is holding any ref to it, close at least the file
if kwargs["skipped"]: oldSong.update("skipCount", lambda n: n+1, default=0)
if oldSong: oldSong.lastPlayedDate = time.time()
if event is PlayerEventCallbacks.onSongFinished:
song = kwargs["song"]
song.update("completedCount", lambda n: n+1, default=0)
def trackerMain():
for ev,args,kwargs in state.updates.read():
try:
track(ev, args, kwargs)
except:
sys.excepthook(*sys.exc_info())