5 import variables as var
8 FORMAT OF A MUSIC INTO THE PLAYLIST
17 ready (validation, no, downloading, yes, failed)
18 from_playlist (yes,no)
40 version = 0 # increase by one after each change
41 mode = "one-shot" # "repeat", "random"
44 def __init__(self, *args):
45 super().__init__(*args)
48 return True if len(self) == 0 else False
50 def set_mode(self, mode):
51 # modes are "one-shot", "repeat", "random"
57 elif mode == "one-shot" and self.current_index > 0:
58 # remove items before current item
60 for i in range(self.current_index):
61 super().__delitem__(0)
62 self.current_index = 0
64 def append(self, item):
66 item = util.get_music_tag_info(item)
71 def insert(self, index, item):
75 index = self.current_index
77 item = util.get_music_tag_info(item)
78 super().insert(index, item)
80 if index <= self.current_index:
81 self.current_index += 1
88 def extend(self, items):
91 lambda item: util.get_music_tag_info(item),
101 #logging.debug("playlist: Next into the queue")
103 if self.current_index < len(self) - 1:
104 if self.mode == "one-shot" and self.current_index != -1:
105 super().__delitem__(self.current_index)
107 self.current_index += 1
109 return self[self.current_index]
111 self.current_index = 0
112 if self.mode == "one-shot":
115 elif self.mode == "repeat":
117 elif self.mode == "random":
121 raise TypeError("Unknown playlist mode '%s'." % self.mode)
123 def update(self, item, index=-1):
126 index = self.current_index
129 def __delitem__(self, key):
130 return self.remove(key)
132 def remove(self, index=-1):
134 if index > len(self) - 1:
138 index = self.current_index
140 removed = self[index]
141 super().__delitem__(index)
143 if self.current_index > index:
144 self.current_index -= 1
148 def current_item(self):
152 return self[self.current_index]
154 def current_item_downloading(self):
158 if self[self.current_index]['type'] == 'url' and self[self.current_index]['ready'] == 'downloading':
162 def next_index(self):
163 if len(self) == 0 or (len(self) == 1 and self.mode == 'one_shot'):
166 if self.current_index < len(self) - 1:
167 return self.current_index + 1
172 if len(self) == 0 or (len(self) == 1 and self.mode == 'one_shot'):
175 return self[self.next_index()]
177 def jump(self, index):
178 if self.mode == "one-shot":
179 for i in range(index):
180 super().__delitem__(0)
181 self.current_index = 0
183 self.current_index = index
186 return self[self.current_index]
189 # current_index will lose track after shuffling, thus we take current music out before shuffling
190 #current = self.current_item()
191 #del self[self.current_index]
195 #self.insert(0, current)
196 self.current_index = -1
201 self.current_index = -1
205 var.db.remove_section("playlist_item")
206 var.db.set("playlist", "current_index", self.current_index)
208 for index, music in enumerate(self):
210 if music['type'] == 'url' and music['ready'] == 'downloading':
211 music['ready'] = 'no'
213 var.db.set("playlist_item", str(index), json.dumps(music))
216 current_index = var.db.getint("playlist", "current_index", fallback=-1)
217 if current_index == -1:
220 items = list(var.db.items("playlist_item"))
221 items.sort(key=lambda v: int(v[0]))
222 self.extend(list(map(lambda v: json.loads(v[1]), items)))
224 self.current_index = current_index
226 def _debug_print(self):
227 print("===== Playlist(%d) ====" % self.current_index)
228 for index, item in enumerate(self):
229 if index == self.current_index:
230 print("-> %d %s" % (index, item['title']))
232 print("%d %s" % (index, item['title']))
233 print("===== End ====")