diff options
-rw-r--r-- | module/file_list.py | 9 | ||||
-rw-r--r-- | module/remote/SocketServer.py | 8 | ||||
-rw-r--r-- | pyLoadCore.py | 18 | ||||
-rwxr-xr-x | pyLoadGui.py | 2 |
4 files changed, 26 insertions, 11 deletions
diff --git a/module/file_list.py b/module/file_list.py index fe4080807..3a1c866dc 100644 --- a/module/file_list.py +++ b/module/file_list.py @@ -22,6 +22,7 @@ LIST_VERSION = 1 import cPickle from Py_Load_File import PyLoadFile +from module.remote.RequestObject import RequestObject class File_List(object): def __init__(self, core): @@ -67,6 +68,8 @@ class File_List(object): output = open('links.pkl', 'wb') cPickle.dump(self.data, output, -1) + self.inform_client() + def load(self): try: pkl_file = open('links.pkl', 'rb') @@ -83,6 +86,12 @@ class File_List(object): self.core.logger.info("Links loaded: "+ str(int(len(obj) - 1))) + def inform_client(self): + obj = RequestObject() + obj.command = "file_list" + obj.data = self.data + + self.core.server.push_all(obj) class Data(): def __init__(self, url): diff --git a/module/remote/SocketServer.py b/module/remote/SocketServer.py index 676cb5556..297a9a422 100644 --- a/module/remote/SocketServer.py +++ b/module/remote/SocketServer.py @@ -42,15 +42,15 @@ class ServerThread(threading.Thread): class MainServerSocket(asyncore.dispatcher): def __init__(self, port, pycore): - print 'initing MSS' asyncore.dispatcher.__init__(self) + pycore.logger.info('initing Remote-Server') self.pycore = pycore self.create_socket(socket.AF_INET, socket.SOCK_STREAM) self.bind(('localhost', port)) self.listen(5) def handle_accept(self): newSocket, address = self.accept() - print "Connected from", address + self.pycore.logger.info("Connected from " + str(address)) SecondaryServerSocket(newSocket, self.pycore) def handle_close(self): print "going to close" @@ -59,7 +59,6 @@ class MainServerSocket(asyncore.dispatcher): class SecondaryServerSocket(asynchat.async_chat): def __init__(self, socket, pycore): - print 'initing SSS' asynchat.async_chat.__init__(self, socket) self.pycore = pycore self.handler = RequestHandler(pycore) @@ -70,11 +69,10 @@ class SecondaryServerSocket(asynchat.async_chat): def found_terminator(self): rep = self.handler.proceed(self.data) self.push(rep) - print "data arrived" self.data = "" #having fun with the data def handle_close(self): - print "Disconnected from", self.getpeername() + self.pycore.logger.info("Disconnected from "+ str(self.getpeername())) self.close() def push_obj(self, obj): obj = self.handler.encrypt(obj) diff --git a/pyLoadCore.py b/pyLoadCore.py index 667cc3473..2f89b9af6 100644 --- a/pyLoadCore.py +++ b/pyLoadCore.py @@ -67,10 +67,10 @@ class Core(object): path.append(self.config['plugin_folder']) self.create_plugin_index() + self.init_server() + self.file_list = File_List(self) self.thread_list = Thread_List(self) - - self.init_server() def read_config(self): """ read config and sets preferences @@ -216,8 +216,6 @@ class Core(object): self._test_print_status() self.server_test() sleep(2) - if len(self.thread_list.threads) == 0: - pass #break def server_test(self): obj = RequestObject() @@ -227,10 +225,20 @@ class Core(object): self.server.push_all(obj) def init_server(self): - print _("Server Mode") self.server = ServerThread(self) self.server.start() + def kill(self): + exit() + + def shutdown(self): + + self.thread_list.pause = True + + while self.thread_list.py_downloading: + sleep(1) + + exit() if __name__ == "__main__": testLoader = Core() diff --git a/pyLoadGui.py b/pyLoadGui.py index 0f256686f..535c60022 100755 --- a/pyLoadGui.py +++ b/pyLoadGui.py @@ -137,7 +137,7 @@ class Pyload_Main_Gui(wx.Frame): #self.core = _Core_Thread() #self.core.start() cmd = ['python', 'pyLoadCore.py'] - subprocess.call(cmd) + subprocess.Popen(cmd) sleep(1) self.thread = SocketThread(socket_host.host.GetValue(), int(socket_host.port.GetValue()), socket_host.password.GetValue(), self) |