mirror of
https://github.com/SoongNoonien/mpdevil.git
synced 2023-08-10 21:12:44 +03:00
small performance improvements
This commit is contained in:
parent
11ec902319
commit
94cb95e1f7
94
bin/mpdevil
94
bin/mpdevil
@ -513,9 +513,7 @@ class ClientHelper():
|
|||||||
return base_song
|
return base_song
|
||||||
|
|
||||||
def calc_display_length(songs):
|
def calc_display_length(songs):
|
||||||
length=float(0)
|
length=sum([float(song.get("duration", 0.0)) for song in songs])
|
||||||
for song in songs:
|
|
||||||
length=length+float(song.get("duration", 0.0))
|
|
||||||
return ClientHelper.seconds_to_display_time(int(length))
|
return ClientHelper.seconds_to_display_time(int(length))
|
||||||
|
|
||||||
def binary_to_pixbuf(binary, size):
|
def binary_to_pixbuf(binary, size):
|
||||||
@ -2848,6 +2846,7 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
self._client=client
|
self._client=client
|
||||||
self._settings=settings
|
self._settings=settings
|
||||||
self._playlist_version=None
|
self._playlist_version=None
|
||||||
|
self._selected_path=None # currently marked song (bold text)
|
||||||
self._icon_size=self._settings.get_int("icon-size-sec")
|
self._icon_size=self._settings.get_int("icon-size-sec")
|
||||||
self._inserted_path=None # needed for drag and drop
|
self._inserted_path=None # needed for drag and drop
|
||||||
|
|
||||||
@ -2876,8 +2875,8 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
style_context.add_provider(provider, 600)
|
style_context.add_provider(provider, 600)
|
||||||
|
|
||||||
# treeview
|
# treeview
|
||||||
# (track, disc, title, artist, album, duration, date, genre, file, weight)
|
# (track, disc, title, artist, album, human duration, date, genre, file, weight, duration)
|
||||||
self._store=Gtk.ListStore(str, str, str, str, str, str, str, str, str, Pango.Weight)
|
self._store=Gtk.ListStore(str, str, str, str, str, str, str, str, str, Pango.Weight, float)
|
||||||
self._treeview=Gtk.TreeView(model=self._store,activate_on_single_click=True,reorderable=True,search_column=2,fixed_height_mode=True)
|
self._treeview=Gtk.TreeView(model=self._store,activate_on_single_click=True,reorderable=True,search_column=2,fixed_height_mode=True)
|
||||||
self._selection=self._treeview.get_selection()
|
self._selection=self._treeview.get_selection()
|
||||||
|
|
||||||
@ -2974,20 +2973,28 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
def _clear(self, *args):
|
def _clear(self, *args):
|
||||||
self._playlist_info.set_text("")
|
self._playlist_info.set_text("")
|
||||||
self._playlist_version=None
|
self._playlist_version=None
|
||||||
|
self._selected_path=None
|
||||||
self._store.handler_block(self._row_inserted)
|
self._store.handler_block(self._row_inserted)
|
||||||
self._store.handler_block(self._row_deleted)
|
self._store.handler_block(self._row_deleted)
|
||||||
self._store.clear()
|
self._store.clear()
|
||||||
self._store.handler_unblock(self._row_inserted)
|
self._store.handler_unblock(self._row_inserted)
|
||||||
self._store.handler_unblock(self._row_deleted)
|
self._store.handler_unblock(self._row_deleted)
|
||||||
|
|
||||||
def _refresh_playlist_info(self):
|
def _select(self, path):
|
||||||
songs=self._client.playlistinfo()
|
self._unselect()
|
||||||
if songs == []:
|
try:
|
||||||
self._playlist_info.set_text("")
|
self._store[path][9]=Pango.Weight.BOLD
|
||||||
else:
|
self._selected_path=path
|
||||||
length_human_readable=ClientHelper.calc_display_length(songs)
|
except IndexError: # invalid path
|
||||||
titles=ngettext("{titles} title", "{titles} titles", len(songs)).format(titles=len(songs))
|
pass
|
||||||
self._playlist_info.set_text(" ".join((titles, "({length})".format(length=length_human_readable))))
|
|
||||||
|
def _unselect(self):
|
||||||
|
if self._selected_path is not None:
|
||||||
|
try:
|
||||||
|
self._store[self._selected_path][9]=Pango.Weight.BOOK
|
||||||
|
self._selected_path=None
|
||||||
|
except IndexError: # invalid path
|
||||||
|
self._selected_path=None
|
||||||
|
|
||||||
def _scroll_to_selected_title(self, *args):
|
def _scroll_to_selected_title(self, *args):
|
||||||
treeview, treeiter=self._selection.get_selected()
|
treeview, treeiter=self._selection.get_selected()
|
||||||
@ -2997,15 +3004,14 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
|
|
||||||
def _refresh_selection(self): # Gtk.TreePath(len(self._store) is used to generate an invalid TreePath (needed to unset cursor)
|
def _refresh_selection(self): # Gtk.TreePath(len(self._store) is used to generate an invalid TreePath (needed to unset cursor)
|
||||||
self._treeview.set_cursor(Gtk.TreePath(len(self._store)), None, False)
|
self._treeview.set_cursor(Gtk.TreePath(len(self._store)), None, False)
|
||||||
for row in self._store: # reset bold text
|
song=self._client.status().get("song")
|
||||||
row[9]=Pango.Weight.BOOK
|
if song is None:
|
||||||
try:
|
self._selection.unselect_all()
|
||||||
song=self._client.status()["song"]
|
self._unselect()
|
||||||
|
else:
|
||||||
path=Gtk.TreePath(int(song))
|
path=Gtk.TreePath(int(song))
|
||||||
self._selection.select_path(path)
|
self._selection.select_path(path)
|
||||||
self._store[path][9]=Pango.Weight.BOLD
|
self._select(path)
|
||||||
except:
|
|
||||||
self._selection.unselect_all()
|
|
||||||
|
|
||||||
def _on_button_press_event(self, widget, event):
|
def _on_button_press_event(self, widget, event):
|
||||||
path_re=widget.get_path_at_pos(int(event.x), int(event.y))
|
path_re=widget.get_path_at_pos(int(event.x), int(event.y))
|
||||||
@ -3052,12 +3058,14 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
def _on_playlist_changed(self, emitter, version):
|
def _on_playlist_changed(self, emitter, version):
|
||||||
self._store.handler_block(self._row_inserted)
|
self._store.handler_block(self._row_inserted)
|
||||||
self._store.handler_block(self._row_deleted)
|
self._store.handler_block(self._row_deleted)
|
||||||
|
self._unselect()
|
||||||
songs=[]
|
songs=[]
|
||||||
if self._playlist_version is not None:
|
if self._playlist_version is not None:
|
||||||
songs=self._client.plchanges(self._playlist_version)
|
songs=self._client.plchanges(self._playlist_version)
|
||||||
else:
|
else:
|
||||||
songs=self._client.playlistinfo()
|
songs=self._client.playlistinfo()
|
||||||
if songs != []:
|
if songs != []:
|
||||||
|
self._treeview.freeze_child_notify()
|
||||||
self._playlist_info.set_text("")
|
self._playlist_info.set_text("")
|
||||||
for s in songs:
|
for s in songs:
|
||||||
song=ClientHelper.song_to_str_dict(ClientHelper.pepare_song_for_display(s))
|
song=ClientHelper.song_to_str_dict(ClientHelper.pepare_song_for_display(s))
|
||||||
@ -3073,7 +3081,8 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
6, song["date"],
|
6, song["date"],
|
||||||
7, song["genre"],
|
7, song["genre"],
|
||||||
8, song["file"],
|
8, song["file"],
|
||||||
9, Pango.Weight.BOOK
|
9, Pango.Weight.BOOK,
|
||||||
|
10, float(song["duration"])
|
||||||
)
|
)
|
||||||
except:
|
except:
|
||||||
self._store.append([
|
self._store.append([
|
||||||
@ -3081,14 +3090,22 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
song["title"], song["artist"],
|
song["title"], song["artist"],
|
||||||
song["album"], song["human_duration"],
|
song["album"], song["human_duration"],
|
||||||
song["date"], song["genre"],
|
song["date"], song["genre"],
|
||||||
song["file"], Pango.Weight.BOOK
|
song["file"], Pango.Weight.BOOK,
|
||||||
|
float(song["duration"])
|
||||||
])
|
])
|
||||||
|
self._treeview.thaw_child_notify()
|
||||||
for i in reversed(range(int(self._client.status()["playlistlength"]), len(self._store))):
|
for i in reversed(range(int(self._client.status()["playlistlength"]), len(self._store))):
|
||||||
treeiter=self._store.get_iter(i)
|
treeiter=self._store.get_iter(i)
|
||||||
self._store.remove(treeiter)
|
self._store.remove(treeiter)
|
||||||
self._refresh_playlist_info()
|
playlist_length=len(self._store)
|
||||||
if self._playlist_version is None or songs != []:
|
if playlist_length == 0:
|
||||||
self._refresh_selection()
|
self._playlist_info.set_text("")
|
||||||
|
else:
|
||||||
|
length_human_readable=ClientHelper.seconds_to_display_time(int(sum([row[10] for row in self._store])))
|
||||||
|
titles=ngettext("{titles} title", "{titles} titles", playlist_length).format(titles=playlist_length)
|
||||||
|
self._playlist_info.set_text(" ".join((titles, "({length})".format(length=length_human_readable))))
|
||||||
|
self._refresh_selection()
|
||||||
|
if self._playlist_version != version:
|
||||||
self._scroll_to_selected_title()
|
self._scroll_to_selected_title()
|
||||||
self._playlist_version=version
|
self._playlist_version=version
|
||||||
self._store.handler_unblock(self._row_inserted)
|
self._store.handler_unblock(self._row_inserted)
|
||||||
@ -3101,10 +3118,8 @@ class PlaylistWindow(Gtk.Box):
|
|||||||
|
|
||||||
def _on_back_to_current_song_button_clicked(self, *args):
|
def _on_back_to_current_song_button_clicked(self, *args):
|
||||||
self._treeview.set_cursor(Gtk.TreePath(len(self._store)), None, False) # set to invalid TreePath (needed to unset cursor)
|
self._treeview.set_cursor(Gtk.TreePath(len(self._store)), None, False) # set to invalid TreePath (needed to unset cursor)
|
||||||
for path, row in enumerate(self._store):
|
if self._selected_path is not None:
|
||||||
if row[9] == Pango.Weight.BOLD:
|
self._selection.select_path(self._selected_path)
|
||||||
self._selection.select_path(path)
|
|
||||||
break
|
|
||||||
self._scroll_to_selected_title()
|
self._scroll_to_selected_title()
|
||||||
|
|
||||||
def _on_disconnected(self, *args):
|
def _on_disconnected(self, *args):
|
||||||
@ -3250,18 +3265,19 @@ class PlaybackControl(Gtk.ButtonBox):
|
|||||||
self.pack_start(self._next_button, True, True, 0)
|
self.pack_start(self._next_button, True, True, 0)
|
||||||
|
|
||||||
def _refresh_tooltips(self, *args):
|
def _refresh_tooltips(self, *args):
|
||||||
try:
|
status=self._client.status()
|
||||||
songs=self._client.playlistinfo()
|
song=status.get("song")
|
||||||
song=int(self._client.status()["song"])
|
length=status.get("playlistlength")
|
||||||
elapsed=ClientHelper.calc_display_length(songs[:song])
|
if song is None or length is None:
|
||||||
rest=ClientHelper.calc_display_length(songs[song+1:])
|
|
||||||
elapsed_titles=ngettext("{titles} title", "{titles} titles", song).format(titles=song)
|
|
||||||
rest_titles=ngettext("{titles} title", "{titles} titles", (len(songs)-(song+1))).format(titles=(len(songs)-(song+1)))
|
|
||||||
self._prev_button.set_tooltip_text(" ".join((elapsed_titles, "({length})".format(length=elapsed))))
|
|
||||||
self._next_button.set_tooltip_text(" ".join((rest_titles, "({length})".format(length=rest))))
|
|
||||||
except:
|
|
||||||
self._prev_button.set_tooltip_text("")
|
self._prev_button.set_tooltip_text("")
|
||||||
self._next_button.set_tooltip_text("")
|
self._next_button.set_tooltip_text("")
|
||||||
|
else:
|
||||||
|
elapsed=int(song)
|
||||||
|
rest=int(length)-elapsed-1
|
||||||
|
elapsed_titles=ngettext("{titles} title", "{titles} titles", elapsed).format(titles=elapsed)
|
||||||
|
rest_titles=ngettext("{titles} title", "{titles} titles", rest).format(titles=rest)
|
||||||
|
self._prev_button.set_tooltip_text(elapsed_titles)
|
||||||
|
self._next_button.set_tooltip_text(rest_titles)
|
||||||
|
|
||||||
def _on_state(self, emitter, state):
|
def _on_state(self, emitter, state):
|
||||||
if state == "play":
|
if state == "play":
|
||||||
|
Loading…
Reference in New Issue
Block a user