Properly update the Details tab of paused torrents.
This commit is contained in:
parent
2e035967d0
commit
9fac711ff7
|
@ -857,11 +857,11 @@ class Manager:
|
||||||
up = float((torrent_state['total_payload_upload'] / 1024) + (self.unique_IDs[unique_ID].uploaded_memory / 1024))
|
up = float((torrent_state['total_payload_upload'] / 1024) + (self.unique_IDs[unique_ID].uploaded_memory / 1024))
|
||||||
down = float(torrent_state["total_done"] / 1024)
|
down = float(torrent_state["total_done"] / 1024)
|
||||||
try:
|
try:
|
||||||
ret = float(up/down)
|
ret = up/down
|
||||||
except:
|
except:
|
||||||
ret = 0
|
ret = 0.0
|
||||||
return ret
|
|
||||||
|
|
||||||
|
return ret
|
||||||
|
|
||||||
def create_torrent(self, filename, source_directory, trackers, comments=None,
|
def create_torrent(self, filename, source_directory, trackers, comments=None,
|
||||||
piece_size=32, author="Deluge"):
|
piece_size=32, author="Deluge"):
|
||||||
|
|
121
src/interface.py
121
src/interface.py
|
@ -48,6 +48,7 @@ import dgtk
|
||||||
import ipc_manager
|
import ipc_manager
|
||||||
import files
|
import files
|
||||||
import plugins
|
import plugins
|
||||||
|
import tab_details
|
||||||
|
|
||||||
class DelugeGTK:
|
class DelugeGTK:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
|
@ -64,7 +65,6 @@ class DelugeGTK:
|
||||||
#Start the Deluge Manager:
|
#Start the Deluge Manager:
|
||||||
self.manager = core.Manager(common.CLIENT_CODE, common.CLIENT_VERSION,
|
self.manager = core.Manager(common.CLIENT_CODE, common.CLIENT_VERSION,
|
||||||
'%s %s'%(common.PROGRAM_NAME, common.PROGRAM_VERSION), common.CONFIG_DIR)
|
'%s %s'%(common.PROGRAM_NAME, common.PROGRAM_VERSION), common.CONFIG_DIR)
|
||||||
self.files_tab = files.FilesTabManager(self.manager)
|
|
||||||
self.plugins = plugins.PluginManager(self.manager, self)
|
self.plugins = plugins.PluginManager(self.manager, self)
|
||||||
self.plugins.add_plugin_dir(common.PLUGIN_DIR)
|
self.plugins.add_plugin_dir(common.PLUGIN_DIR)
|
||||||
if os.path.isdir(os.path.join(common.CONFIG_DIR , 'plugins')):
|
if os.path.isdir(os.path.join(common.CONFIG_DIR , 'plugins')):
|
||||||
|
@ -87,6 +87,13 @@ class DelugeGTK:
|
||||||
self.notebook = self.wtree.get_widget("torrent_info")
|
self.notebook = self.wtree.get_widget("torrent_info")
|
||||||
self.notebook.connect("switch-page", self.notebook_switch_page)
|
self.notebook.connect("switch-page", self.notebook_switch_page)
|
||||||
|
|
||||||
|
# Tabs
|
||||||
|
self.tab_details = tab_details.DetailsManager(self.wtree,
|
||||||
|
self.manager)
|
||||||
|
self.tab_details.build()
|
||||||
|
self.tab_files = files.FilesTabManager(self.manager)
|
||||||
|
self.tab_files.build_file_view(self.wtree.get_widget("file_view"))
|
||||||
|
|
||||||
self.statusbar = self.wtree.get_widget("statusbar")
|
self.statusbar = self.wtree.get_widget("statusbar")
|
||||||
|
|
||||||
## Construct the Interface
|
## Construct the Interface
|
||||||
|
@ -100,8 +107,6 @@ class DelugeGTK:
|
||||||
self.has_tray = True
|
self.has_tray = True
|
||||||
|
|
||||||
self.build_torrent_table()
|
self.build_torrent_table()
|
||||||
self.build_summary_tab()
|
|
||||||
self.build_file_tab()
|
|
||||||
self.build_peer_tab()
|
self.build_peer_tab()
|
||||||
self.load_status_icons()
|
self.load_status_icons()
|
||||||
|
|
||||||
|
@ -549,7 +554,7 @@ class DelugeGTK:
|
||||||
return True
|
return True
|
||||||
|
|
||||||
self.clear_peer_store()
|
self.clear_peer_store()
|
||||||
self.clear_file_store()
|
self.tab_files.clear_file_store()
|
||||||
|
|
||||||
unique_id = model.get_value(model.get_iter(path), 0)
|
unique_id = model.get_value(model.get_iter(path), 0)
|
||||||
self.update_torrent_info_widget(unique_id)
|
self.update_torrent_info_widget(unique_id)
|
||||||
|
@ -618,28 +623,6 @@ class DelugeGTK:
|
||||||
menuitem.set_image(gtk.image_new_from_stock(gtk.STOCK_MEDIA_PAUSE, gtk.ICON_SIZE_MENU))
|
menuitem.set_image(gtk.image_new_from_stock(gtk.STOCK_MEDIA_PAUSE, gtk.ICON_SIZE_MENU))
|
||||||
menuitem.get_children()[0].set_text(_("Pause"))
|
menuitem.get_children()[0].set_text(_("Pause"))
|
||||||
|
|
||||||
def build_summary_tab(self):
|
|
||||||
#Torrent Summary tab
|
|
||||||
# Look into glade's widget prefix function
|
|
||||||
self.text_summary_name = self.wtree.get_widget("summary_name")
|
|
||||||
self.text_summary_total_size = self.wtree.get_widget("summary_total_size")
|
|
||||||
self.text_summary_pieces = self.wtree.get_widget("summary_pieces")
|
|
||||||
self.text_summary_availability = self.wtree.get_widget("summary_availability")
|
|
||||||
self.text_summary_total_downloaded = self.wtree.get_widget("summary_total_downloaded")
|
|
||||||
self.text_summary_total_uploaded = self.wtree.get_widget("summary_total_uploaded")
|
|
||||||
self.text_summary_download_speed = self.wtree.get_widget("summary_download_speed")
|
|
||||||
self.text_summary_upload_speed = self.wtree.get_widget("summary_upload_speed")
|
|
||||||
self.text_summary_seeders = self.wtree.get_widget("summary_seeders")
|
|
||||||
self.text_summary_peers = self.wtree.get_widget("summary_peers")
|
|
||||||
self.text_summary_percentage_done = self.wtree.get_widget("summary_percentage_done")
|
|
||||||
self.text_summary_share_ratio = self.wtree.get_widget("summary_share_ratio")
|
|
||||||
self.text_summary_downloaded_this_session = self.wtree.get_widget("summary_downloaded_this_session")
|
|
||||||
self.text_summary_uploaded_this_session = self.wtree.get_widget("summary_uploaded_this_session")
|
|
||||||
self.text_summary_tracker = self.wtree.get_widget("summary_tracker")
|
|
||||||
self.text_summary_tracker_status = self.wtree.get_widget("summary_tracker_status")
|
|
||||||
self.text_summary_next_announce = self.wtree.get_widget("summary_next_announce")
|
|
||||||
self.text_summary_eta = self.wtree.get_widget("summary_eta")
|
|
||||||
|
|
||||||
def build_peer_tab(self):
|
def build_peer_tab(self):
|
||||||
self.peer_view = self.wtree.get_widget("peer_view")
|
self.peer_view = self.wtree.get_widget("peer_view")
|
||||||
# IP int, IP string, Client, Percent Complete, Down Speed, Up Speed
|
# IP int, IP string, Client, Percent Complete, Down Speed, Up Speed
|
||||||
|
@ -668,12 +651,6 @@ class DelugeGTK:
|
||||||
self.peer_store.clear()
|
self.peer_store.clear()
|
||||||
self.peer_store_dict = {}
|
self.peer_store_dict = {}
|
||||||
|
|
||||||
def build_file_tab(self):
|
|
||||||
self.files_tab.build_file_view(self.wtree.get_widget("file_view"))
|
|
||||||
|
|
||||||
def clear_file_store(self):
|
|
||||||
self.files_tab.clear_file_store()
|
|
||||||
|
|
||||||
def show_about_dialog(self, arg=None):
|
def show_about_dialog(self, arg=None):
|
||||||
dialogs.show_about_dialog()
|
dialogs.show_about_dialog()
|
||||||
|
|
||||||
|
@ -765,7 +742,7 @@ class DelugeGTK:
|
||||||
progress = float(state['progress'] * 100)
|
progress = float(state['progress'] * 100)
|
||||||
message = self.get_message_from_state(state)
|
message = self.get_message_from_state(state)
|
||||||
availability = state['distributed_copies']
|
availability = state['distributed_copies']
|
||||||
share = float(self.calc_share_ratio(unique_id, state))
|
share = self.manager.calc_ratio(unique_id, state)
|
||||||
|
|
||||||
# setting after initial paused state ensures first change gets updated
|
# setting after initial paused state ensures first change gets updated
|
||||||
if state["is_paused"]:
|
if state["is_paused"]:
|
||||||
|
@ -1020,53 +997,7 @@ class DelugeGTK:
|
||||||
page_num = self.wtree.get_widget("torrent_info").get_current_page()
|
page_num = self.wtree.get_widget("torrent_info").get_current_page()
|
||||||
|
|
||||||
if page_num == 0: # Details
|
if page_num == 0: # Details
|
||||||
state = self.manager.get_torrent_state(unique_id)
|
self.tab_details.update(unique_id)
|
||||||
|
|
||||||
# Update selected files size, tracker, tracker status and next
|
|
||||||
# announce no matter what status of the torrent is
|
|
||||||
self.text_summary_total_size.set_text(common.fsize(state["total_wanted"]))
|
|
||||||
self.text_summary_tracker.set_text(str(state["tracker"]))
|
|
||||||
# At this time we still may not receive EVENT_TRACKER so there
|
|
||||||
# could be no tracker_status yet.
|
|
||||||
if "tracker_status" in state:
|
|
||||||
self.text_summary_tracker_status.set_text(state["tracker_status"])
|
|
||||||
self.text_summary_next_announce.set_text(str(state["next_announce"]))
|
|
||||||
|
|
||||||
just_paused = False
|
|
||||||
if state['is_paused']:
|
|
||||||
# Take a notice about " " space on the end, it's like a sign
|
|
||||||
# to decide was this torrent already paused before we get here
|
|
||||||
# or not. It's to don't add any instance variable for just
|
|
||||||
# this specific check and to keep instance clearer.
|
|
||||||
if self.text_summary_seeders.get_text() != "0 (0) ":
|
|
||||||
# Selected torrent just paused, zero data now and don't
|
|
||||||
# update it anymore on each update()
|
|
||||||
state['num_seeds'] = state['total_seeds'] = \
|
|
||||||
state['num_peers'] = state['total_peers'] = \
|
|
||||||
state['download_rate'] = state['upload_rate'] = 0
|
|
||||||
just_paused = True
|
|
||||||
else:
|
|
||||||
# If we already updated paused torrent - do nothing more
|
|
||||||
return
|
|
||||||
|
|
||||||
self.wtree.get_widget("summary_name").set_text(state['name'])
|
|
||||||
self.text_summary_pieces.set_text('%s x %s' % \
|
|
||||||
(state["num_pieces"], common.fsize(state["piece_length"])))
|
|
||||||
self.text_summary_availability.set_text('%.3f' % state["distributed_copies"])
|
|
||||||
self.text_summary_total_downloaded.set_text(common.fsize(state["total_done"]) \
|
|
||||||
+ " (" + common.fsize(state["total_download"]) + ")")
|
|
||||||
self.text_summary_total_uploaded.set_text(common.fsize(self.manager.unique_IDs\
|
|
||||||
[unique_id].uploaded_memory + state["total_payload_upload"]) + \
|
|
||||||
" (" + common.fsize(state["total_upload"]) + ")")
|
|
||||||
self.text_summary_download_speed.set_text(common.fspeed(state["download_rate"]))
|
|
||||||
self.text_summary_upload_speed.set_text(common.fspeed(state["upload_rate"]))
|
|
||||||
self.text_summary_seeders.set_text(common.fseed(state) +
|
|
||||||
(just_paused and " " or ""))
|
|
||||||
self.text_summary_peers.set_text(common.fpeer(state))
|
|
||||||
self.wtree.get_widget("progressbar").set_fraction(float(state['progress']))
|
|
||||||
self.wtree.get_widget("progressbar").set_text(common.fpcnt(state["progress"]))
|
|
||||||
self.text_summary_eta.set_text(common.estimate_eta(state))
|
|
||||||
self.text_summary_share_ratio.set_text('%.3f'%(self.calc_share_ratio(unique_id, state)))
|
|
||||||
elif page_num == 1: # Peers
|
elif page_num == 1: # Peers
|
||||||
new_peer_info = self.manager.get_torrent_peer_info(unique_id)
|
new_peer_info = self.manager.get_torrent_peer_info(unique_id)
|
||||||
new_ips = set()
|
new_ips = set()
|
||||||
|
@ -1107,13 +1038,9 @@ class DelugeGTK:
|
||||||
elif page_num == 2: # Files
|
elif page_num == 2: # Files
|
||||||
# Fill self.file_store with files only once and only when we click to
|
# Fill self.file_store with files only once and only when we click to
|
||||||
# Files tab or it's already open
|
# Files tab or it's already open
|
||||||
self.files_tab.set_unique_id(unique_id)
|
self.tab_files.set_unique_id(unique_id)
|
||||||
self.files_tab.prepare_file_store()
|
self.tab_files.prepare_file_store()
|
||||||
self.files_tab.update_file_store()
|
self.tab_files.update_file_store()
|
||||||
|
|
||||||
def calc_share_ratio(self, unique_id, torrent_state):
|
|
||||||
r = float(self.manager.calc_ratio(unique_id, torrent_state))
|
|
||||||
return r
|
|
||||||
|
|
||||||
# Return the id of the last single selected torrent
|
# Return the id of the last single selected torrent
|
||||||
def get_selected_torrent(self):
|
def get_selected_torrent(self):
|
||||||
|
@ -1274,25 +1201,9 @@ class DelugeGTK:
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
def clear_details_pane(self):
|
def clear_details_pane(self):
|
||||||
self.wtree.get_widget("progressbar").set_text("")
|
self.tab_details.clear()
|
||||||
self.wtree.get_widget("summary_name").set_text("")
|
|
||||||
self.text_summary_total_size.set_text("")
|
|
||||||
self.text_summary_pieces.set_text("")
|
|
||||||
self.text_summary_availability.set_text("")
|
|
||||||
self.text_summary_total_downloaded.set_text("")
|
|
||||||
self.text_summary_total_uploaded.set_text("")
|
|
||||||
self.text_summary_download_speed.set_text("")
|
|
||||||
self.text_summary_upload_speed.set_text("")
|
|
||||||
self.text_summary_seeders.set_text("")
|
|
||||||
self.text_summary_peers.set_text("")
|
|
||||||
self.wtree.get_widget("progressbar").set_fraction(0.0)
|
|
||||||
self.text_summary_share_ratio.set_text("")
|
|
||||||
self.text_summary_tracker.set_text("")
|
|
||||||
self.text_summary_tracker_status.set_text("")
|
|
||||||
self.text_summary_next_announce.set_text("")
|
|
||||||
self.text_summary_eta.set_text("")
|
|
||||||
self.clear_peer_store()
|
self.clear_peer_store()
|
||||||
self.clear_file_store()
|
self.tab_files.clear_file_store()
|
||||||
|
|
||||||
def remove_toggle_warning(self, args, warning):
|
def remove_toggle_warning(self, args, warning):
|
||||||
if not args.get_active():
|
if not args.get_active():
|
||||||
|
|
|
@ -0,0 +1,110 @@
|
||||||
|
#!/usr/bin/env python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# tab_details.py
|
||||||
|
|
||||||
|
import common
|
||||||
|
|
||||||
|
class DetailsManager(object):
|
||||||
|
def __init__(self, glade, manager):
|
||||||
|
self.glade = glade
|
||||||
|
self.manager = manager
|
||||||
|
|
||||||
|
self.paused_unique_id = None
|
||||||
|
|
||||||
|
def build(self):
|
||||||
|
#Torrent Summary tab
|
||||||
|
# Look into glade's widget prefix function
|
||||||
|
self.progress_bar = self.glade.get_widget("progressbar")
|
||||||
|
self.name = self.glade.get_widget("summary_name")
|
||||||
|
self.total_size = self.glade.get_widget("summary_total_size")
|
||||||
|
self.pieces = self.glade.get_widget("summary_pieces")
|
||||||
|
self.availability = self.glade.get_widget("summary_availability")
|
||||||
|
self.total_downloaded = self.glade.get_widget("summary_total_downloaded")
|
||||||
|
self.total_uploaded = self.glade.get_widget("summary_total_uploaded")
|
||||||
|
self.download_speed = self.glade.get_widget("summary_download_speed")
|
||||||
|
self.upload_speed = self.glade.get_widget("summary_upload_speed")
|
||||||
|
self.seeders = self.glade.get_widget("summary_seeders")
|
||||||
|
self.peers = self.glade.get_widget("summary_peers")
|
||||||
|
self.percentage_done = self.glade.get_widget("summary_percentage_done")
|
||||||
|
self.share_ratio = self.glade.get_widget("summary_share_ratio")
|
||||||
|
self.downloaded_this_session = self.glade.get_widget("summary_downloaded_this_session")
|
||||||
|
self.uploaded_this_session = self.glade.get_widget("summary_uploaded_this_session")
|
||||||
|
self.tracker = self.glade.get_widget("summary_tracker")
|
||||||
|
self.tracker_status = self.glade.get_widget("summary_tracker_status")
|
||||||
|
self.next_announce = self.glade.get_widget("summary_next_announce")
|
||||||
|
self.eta = self.glade.get_widget("summary_eta")
|
||||||
|
|
||||||
|
def update(self, unique_id):
|
||||||
|
state = self.manager.get_torrent_state(unique_id)
|
||||||
|
|
||||||
|
# Update selected files size, tracker, tracker status and next
|
||||||
|
# announce no matter what status of the torrent is
|
||||||
|
self.total_size.set_text(common.fsize(state["total_wanted"]))
|
||||||
|
self.tracker.set_text(str(state["tracker"]))
|
||||||
|
# At this time we still may not receive EVENT_TRACKER so there
|
||||||
|
# could be no tracker_status yet.
|
||||||
|
if "tracker_status" in state:
|
||||||
|
self.tracker_status.set_text(state["tracker_status"])
|
||||||
|
self.next_announce.set_text(str(state["next_announce"]))
|
||||||
|
|
||||||
|
if state['is_paused']:
|
||||||
|
if not self.paused_unique_id:
|
||||||
|
# Selected torrent just paused, zero data now and don't
|
||||||
|
# update it anymore on each update()
|
||||||
|
state['num_seeds'] = state['total_seeds'] = \
|
||||||
|
state['num_peers'] = state['total_peers'] = \
|
||||||
|
state['download_rate'] = state['upload_rate'] = 0
|
||||||
|
|
||||||
|
self.paused_unique_id = unique_id
|
||||||
|
elif self.paused_unique_id != unique_id:
|
||||||
|
# User selected another paused torrent with unique_id after
|
||||||
|
# paused torrent with self.paused_unique_id, so update
|
||||||
|
# currently selected unique_id and do full update of details
|
||||||
|
self.paused_unique_id = unique_id
|
||||||
|
else:
|
||||||
|
# If we already updated paused torrent - do nothing more
|
||||||
|
return
|
||||||
|
else:
|
||||||
|
self.paused_unique_id = None
|
||||||
|
|
||||||
|
self.name.set_text(state['name'])
|
||||||
|
self.pieces.set_text('%s x %s' % (state["num_pieces"],
|
||||||
|
common.fsize(state["piece_length"])))
|
||||||
|
self.availability.set_text('%.3f' % state["distributed_copies"])
|
||||||
|
self.total_downloaded.set_text('%s (%s)' % \
|
||||||
|
(common.fsize(state["total_done"]),
|
||||||
|
common.fsize(state["total_download"])))
|
||||||
|
self.total_uploaded.set_text('%s (%s)' % \
|
||||||
|
(common.fsize(self.manager.unique_IDs[unique_id].uploaded_memory+\
|
||||||
|
state["total_payload_upload"]),
|
||||||
|
common.fsize(state["total_upload"])))
|
||||||
|
self.download_speed.set_text(common.fspeed(state["download_rate"]))
|
||||||
|
self.upload_speed.set_text(common.fspeed(state["upload_rate"]))
|
||||||
|
self.seeders.set_text(common.fseed(state))
|
||||||
|
self.peers.set_text(common.fpeer(state))
|
||||||
|
self.progress_bar.set_fraction(float(state['progress']))
|
||||||
|
self.progress_bar.set_text(common.fpcnt(state["progress"]))
|
||||||
|
self.eta.set_text(common.estimate_eta(state))
|
||||||
|
self.share_ratio.set_text( '%.3f' % self.manager.calc_ratio(unique_id,
|
||||||
|
state))
|
||||||
|
|
||||||
|
def clear(self):
|
||||||
|
self.name.set_text("")
|
||||||
|
self.total_size.set_text("")
|
||||||
|
self.pieces.set_text("")
|
||||||
|
self.availability.set_text("")
|
||||||
|
self.total_downloaded.set_text("")
|
||||||
|
self.total_uploaded.set_text("")
|
||||||
|
self.download_speed.set_text("")
|
||||||
|
self.upload_speed.set_text("")
|
||||||
|
self.seeders.set_text("")
|
||||||
|
self.peers.set_text("")
|
||||||
|
self.progress_bar.set_fraction(0.0)
|
||||||
|
self.progress_bar.set_text("")
|
||||||
|
self.share_ratio.set_text("")
|
||||||
|
self.tracker.set_text("")
|
||||||
|
self.tracker_status.set_text("")
|
||||||
|
self.next_announce.set_text("")
|
||||||
|
self.eta.set_text("")
|
||||||
|
|
Loading…
Reference in New Issue