use "window" feature of search command

This commit is contained in:
Martin Wagner 2021-07-23 17:29:35 +02:00
parent 9d7b618a1c
commit c520e43bd4

View File

@ -1626,9 +1626,6 @@ class SongsView(Gtk.TreeView):
self._song_popover.popdown()
self._store.clear()
def count(self):
return len(self._store)
def get_files(self):
return_list=[]
for row in self._store:
@ -1970,18 +1967,23 @@ class SearchWindow(Gtk.Box):
self._songs_view.clear()
self._hits_label.set_text("")
self._action_bar.set_sensitive(False)
if len(self.search_entry.get_text()) > 0:
try: # client cloud meanwhile disconnect
hits=0
if self.search_entry.get_text():
if self._tag_combo_box.get_active() == 0:
songs=self._client.search("any", self.search_entry.get_text())
search_tag="any"
else:
songs=self._client.search(self._tag_combo_box.get_active_text(), self.search_entry.get_text())
search_tag=self._tag_combo_box.get_active_text()
search_text=self.search_entry.get_text()
stripe_size=100
try: # client cloud meanwhile disconnect
songs=self._client.search(search_tag, search_text, "window", f"0:{stripe_size}")
except MPDBase.ConnectionError:
self._done_callback()
return
hits=len(songs)
self._hits_label.set_text(ngettext("{hits} hit", "{hits} hits", hits).format(hits=hits))
for i, s in enumerate(songs):
stripe_start=stripe_size
while songs:
hits+=len(songs)
for s in songs:
if self._stop_flag:
self._done_callback()
return
@ -1996,11 +1998,18 @@ class SearchWindow(Gtk.Box):
song["human_duration"], song["file"],
int_track
])
if i%100 == 0:
self.search_entry.set_progress_fraction((i+1)/hits)
self.search_entry.progress_pulse()
self._hits_label.set_text(ngettext("{hits} hit", "{hits} hits", hits).format(hits=hits))
while Gtk.events_pending():
Gtk.main_iteration_do(True)
if self._songs_view.count() > 0:
stripe_end=stripe_start+stripe_size
try: # client cloud meanwhile disconnect
songs=self._client.search(search_tag, search_text, "window", f"{stripe_start}:{stripe_end}")
except MPDBase.ConnectionError:
self._done_callback()
return
stripe_start+=stripe_size
if hits > 0:
self._action_bar.set_sensitive(True)
self._done_callback()
elif not self._search in self._pending: