diff options
| -rw-r--r-- | module/plugins/hooks/ClickAndLoad.py | 17 | 
1 files changed, 10 insertions, 7 deletions
| diff --git a/module/plugins/hooks/ClickAndLoad.py b/module/plugins/hooks/ClickAndLoad.py index fcbb27c21..f0372dbf8 100644 --- a/module/plugins/hooks/ClickAndLoad.py +++ b/module/plugins/hooks/ClickAndLoad.py @@ -41,18 +41,18 @@ class ClickAndLoad(Hook):  		else:  		    ip = "127.0.0.1" -                thread.start_new_thread(proxy, (ip, self.port, 9666)) +                thread.start_new_thread(proxy, (self, ip, self.port, 9666))              except:                  self.log.error("ClickAndLoad port already in use.") -def proxy(*settings): -    thread.start_new_thread(server, settings) +def proxy(self, *settings): +    thread.start_new_thread(server, (self,)+settings)      lock = thread.allocate_lock()      lock.acquire()      lock.acquire() -def server(*settings): +def server(self, *settings):      try:          dock_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)          dock_socket.bind((settings[0], settings[2])) @@ -63,10 +63,13 @@ def server(*settings):              server_socket.connect(("127.0.0.1", settings[1]))              thread.start_new_thread(forward, (client_socket, server_socket))              thread.start_new_thread(forward, (server_socket, client_socket)) +    except socket.error, e: +        if e.errno == 98: +            self.core.log.warning(_("Click'N'Load: Port 9666 already in use")) +            return +        thread.start_new_thread(server, (self,)+settings)      except: -        pass -    finally: -        thread.start_new_thread(server, settings) +        thread.start_new_thread(server, (self,)+settings)  def forward(source, destination):      string = ' ' | 
