diff --git a/deluge.py b/deluge.py index cd3d6a667..5f49a5dcd 100644 --- a/deluge.py +++ b/deluge.py @@ -75,6 +75,15 @@ PREF_FUNCTIONS = { "max_download_rate" : deluge_core.set_download_rate_limit, "max_upload_rate" : deluge_core.set_upload_rate_limit } +STATE_MESSAGES = ( "Queued", + "Checking", + "Connecting", + "Downloading Metadata", + "Downloading", + "Finished", + "Seeding", + "Allocating" + ) # Exceptions @@ -143,7 +152,7 @@ class persistent_state: # The manager for the torrent system -class manager: +class Manager: # blank_slate mode ignores the two pickle files and DHT state file, i.e. you start # completely fresh. When quitting, the old files will be overwritten def __init__(self, client_ID, version, user_agent, base_dir, blank_slate=False): diff --git a/delugegtk.py b/delugegtk.py index 010731be4..bd4ec3233 100755 --- a/delugegtk.py +++ b/delugegtk.py @@ -29,10 +29,18 @@ import pygtk pygtk.require('2.0') import gtk import gtk.glade +import gobject + +import xdg, xdg.BaseDirectory class DelugeGTK: def __init__(self): + #Start the Deluge Manager: + self.manager = deluge.Manager("DL", "0500", "Deluge 0.5.0", + os.path.expanduser("~") + "/Temp") + #xdg.BaseDirectory.save_config_path("deluge-svn")) + #Set up the interface: self.gladefile = dcommon.get_glade_file("delugegtk.glade") self.wtree = gtk.glade.XML(self.gladefile) self.window = self.wtree.get_widget("main_window") @@ -109,50 +117,57 @@ class DelugeGTK: self.peer_complete_column = dgtk.add_text_column(self.peer_view, "Percent Complete", 2) self.peer_download_column = dgtk.add_text_column(self.peer_view, "Download Rate", 3) self.peer_upload_column = dgtk.add_text_column(self.peer_view, "Upload Rate", 4) - - - - - - ## Interface created + ## Interface created + + ## add torrents in manager to interface + for uid in self.manager.get_unique_IDs(): + self.store.append(self.get_list_from_uid(uid)) + + + ## Start the timer that updates the interface def start(self): - pass + gobject.timeout_add(1000, self.update) + + ## Call via a timer to update the interface + def update(self): + itr = self.store.get_iter_first() + + while itr is not None: + uid = self.store.get_value(itr, 0) + tlist = self.get_list_from_uid(uid) + for i in range(12): + self.store.set_value(itr, i, tlist[i]) + itr = self.store.iter_next(itr) + return True + + # UID, Q#, Name, Size, Progress, Message, Seeders, Peers, DL, UL, ETA, Share + def get_list_from_uid(self, unique_id): + state = self.manager.get_torrent_state(unique_id) + return [unique_id, state['queue_pos'], state['name'], state['total_size'], + int(state['progress'] * 100), deluge.STATE_MESSAGES[state['state']], state['total_seeds'], + state['total_peers'], state['download_rate'], state['upload_rate'], + "NULL", "NULL"] def new_torrent(self, obj=None): pass def add_torrent(self, obj=None): - pass + torrent = dgtk.show_file_open_dialog() + if torrent is not None: + uid = self.manager.add_torrent(torrent, ".", True) + self.store.append(self.get_list_from_uid(uid)) def quit(self, obj=None): + self.manager.quit() self.window.destroy() - ## Call via a timer to update the interface - def update(self): - pass + ## For testing purposes, create a copy of the interface if __name__ == "__main__": - deluge = DelugeGTK() - - ## Test the interface by adding a few fake torrents - deluge.store.append([0,1,"Deluge Torrent","700MB",50,"Downloading","10 (50)", "15 (30)", "50 KB/s", "10 KB/s", "2 h", "100%"]) - deluge.store.append([1,2,"Sample Torrent","350MB",75,"Queued","10 (20)","20 (20)","0 KB/s", "0 KB/s", "und", "0%"]) - deluge.store.append([2,3,"Deluge Torrent","700MB",55,"Downloading","10 (50)", "15 (30)", "50 KB/s", "10 KB/s", "2 h", "300%"]) - deluge.store.append([3,4,"Sample Torrent","350MB",65,"Queued","10 (20)","20 (20)","0 KB/s", "0 KB/s", "und", "10%"]) - deluge.store.append([4,5,"Deluge Torrent","700MB",50,"Downloading","10 (50)", "15 (30)", "50 KB/s", "10 KB/s", "2 h", "120%"]) - deluge.store.append([5,6,"Sample Torrent","350MB",95,"Queued","10 (20)","20 (20)","0 KB/s", "0 KB/s", "und", "110%"]) - - deluge.file_store.append(["Sample_Filename.ext", True]) - deluge.file_store.append(["Second_Filename.ext", True]) - - deluge.peer_store.append(["192.168.0.1", "Deluge 0.3.1", "100%", "30 KB/s", "0 KB/s"]) - deluge.peer_store.append(["192.168.0.2", "Deluge 0.4.0", "76%", "13 KB/s", "0 KB/s"]) - deluge.peer_store.append(["192.168.0.3", "Deluge 0.3.0", "74%", "12 KB/s", "3 KB/s"]) - deluge.peer_store.append(["192.168.0.4", "Deluge 0.3.99.2", "50%", "9 KB/s", "0 KB/s"]) - deluge.peer_store.append(["192.168.0.5", "Deluge 0.4.0", "90%", "0 KB/s", "20 KB/s"]) - ## Done with sample lines + interface = DelugeGTK() + interface.start() gtk.main() \ No newline at end of file diff --git a/dgtk.py b/dgtk.py index 43a9f6bb5..d7284c4c7 100644 --- a/dgtk.py +++ b/dgtk.py @@ -130,7 +130,23 @@ class PreferencesDialog: self.notebook.set_current_page(2) self.prf.run() self.prf.hide_all() + + +## A simple file open dialog. I'm going to improve it later, +## this is a quick implementation for testing. +def show_file_open_dialog(): + chooser = gtk.FileChooserDialog("Open", None, gtk.FILE_CHOOSER_ACTION_OPEN, + buttons=(gtk.STOCK_CANCEL,gtk.RESPONSE_CANCEL,gtk.STOCK_OPEN,gtk.RESPONSE_OK)) + response = chooser.run() + if response == gtk.RESPONSE_OK: + result = chooser.get_filename() + else: + result = None + chooser.destroy() + return result + + ## Functions to create columns def add_text_column(view, header, cid): diff --git a/test.py b/test.py index 0defc33fd..4ce23f329 100644 --- a/test.py +++ b/test.py @@ -13,14 +13,14 @@ import deluge from time import sleep import os -manager = deluge.manager("DL", "0500", "deluge - testing only", +manager = deluge.Manager("DL", "0500", "deluge - testing only", os.path.expanduser("~") + "/Temp")# blank_slate=True) #manager.set_pref('max_upload_rate', 6*1024) -my_torrent = manager.add_torrent("ubuntu.iso.torrent", ".", True) +##my_torrent = manager.add_torrent("ubuntu.iso.torrent", ".", True) -print "Unique ID:", my_torrent +##print "Unique ID:", my_torrent print "PREFS:", manager.prefs @@ -29,7 +29,9 @@ try: print "STATE:", manager.get_state() print "# torrents:", manager.get_num_torrents() for unique_ID in manager.get_unique_IDs(): - print unique_ID, manager.get_torrent_state(unique_ID) + state = manager.get_torrent_state(unique_ID) + for key in state.keys(): + print key, state[key] manager.handle_events() print "" sleep(2)