mirror of
https://git.deluge-torrent.org/deluge
synced 2025-08-06 16:38:43 +00:00
Wait on the session state before requesting torrent status updates
This commit is contained in:
parent
25afa04ba3
commit
8fc4caa2f1
1 changed files with 15 additions and 9 deletions
|
@ -159,6 +159,9 @@ class TorrentView(listview.ListView, component.Component):
|
||||||
"torrentview.state")
|
"torrentview.state")
|
||||||
log.debug("TorrentView Init..")
|
log.debug("TorrentView Init..")
|
||||||
|
|
||||||
|
# If we have gotten the state yet
|
||||||
|
self.got_state = False
|
||||||
|
|
||||||
# This is where status updates are put
|
# This is where status updates are put
|
||||||
self.status = {}
|
self.status = {}
|
||||||
|
|
||||||
|
@ -265,6 +268,7 @@ class TorrentView(listview.ListView, component.Component):
|
||||||
self.mark_dirty(torrent_id)
|
self.mark_dirty(torrent_id)
|
||||||
self.treeview.set_model(model)
|
self.treeview.set_model(model)
|
||||||
self.treeview.thaw_child_notify()
|
self.treeview.thaw_child_notify()
|
||||||
|
self.got_state = True
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
def stop(self):
|
def stop(self):
|
||||||
|
@ -328,8 +332,9 @@ class TorrentView(listview.ListView, component.Component):
|
||||||
self.filter, status_keys, True).addCallback(self._on_get_torrents_status)
|
self.filter, status_keys, True).addCallback(self._on_get_torrents_status)
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
# Send a status request
|
if self.got_state:
|
||||||
gobject.idle_add(self.send_status_request)
|
# Send a status request
|
||||||
|
gobject.idle_add(self.send_status_request)
|
||||||
|
|
||||||
def update_view(self, columns=None):
|
def update_view(self, columns=None):
|
||||||
"""Update the view. If columns is not None, it will attempt to only
|
"""Update the view. If columns is not None, it will attempt to only
|
||||||
|
@ -354,13 +359,14 @@ class TorrentView(listview.ListView, component.Component):
|
||||||
for column in self.columns_to_update:
|
for column in self.columns_to_update:
|
||||||
column_index = self.get_column_index(column)
|
column_index = self.get_column_index(column)
|
||||||
for i, status_field in enumerate(self.columns[column].status_field):
|
for i, status_field in enumerate(self.columns[column].status_field):
|
||||||
try:
|
if status_field in status[torrent_id]:
|
||||||
# Only update if different
|
try:
|
||||||
row_value = status[torrent_id][status_field]
|
# Only update if different
|
||||||
if row[column_index[i]] != row_value:
|
row_value = status[torrent_id][status_field]
|
||||||
row[column_index[i]] = row_value
|
if row[column_index[i]] != row_value:
|
||||||
except Exception, e:
|
row[column_index[i]] = row_value
|
||||||
log.debug("%s", e)
|
except Exception, e:
|
||||||
|
log.debug("%s", e)
|
||||||
|
|
||||||
component.get("MenuBar").update_menu()
|
component.get("MenuBar").update_menu()
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue