summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
Diffstat (limited to 'module')
-rw-r--r--module/download_thread.py10
-rw-r--r--module/thread_list.py1
2 files changed, 9 insertions, 2 deletions
diff --git a/module/download_thread.py b/module/download_thread.py
index ce353d6f6..202ebcafb 100644
--- a/module/download_thread.py
+++ b/module/download_thread.py
@@ -50,6 +50,10 @@ class Status(object):
return ((self.size()-self.kB_left()) * 100) / self.size()
return 0
+class Reconnect(Exception):
+ pass
+
+
class Download_Thread(threading.Thread):
def __init__(self, parent):
threading.Thread.__init__(self)
@@ -66,10 +70,12 @@ class Download_Thread(threading.Thread):
if self.loadedPyFile:
try:
self.download(self.loadedPyFile)
+ except Reconnect:
+ pass
except Exception, e:
traceback.print_exc()
self.loadedPyFile.status.type = "failed"
- self.loadedPyFile.status.error = e.message
+ self.loadedPyFile.status.error = str(e)
finally:
self.parent.job_finished(self.loadedPyFile)
sleep(0.5)
@@ -103,7 +109,7 @@ class Download_Thread(threading.Thread):
if self.parent.init_reconnect() or self.parent.reconnecting:
pyfile.status.type = "reconnected"
pyfile.status.want_reconnect = False
- return False
+ raise Reconnect
sleep(1)
pyfile.status.want_reconnect = False
return True
diff --git a/module/thread_list.py b/module/thread_list.py
index 63f20c6f5..1dadb91d3 100644
--- a/module/thread_list.py
+++ b/module/thread_list.py
@@ -159,6 +159,7 @@ class Thread_List(object):
def reconnect(self):
reconn = subprocess.Popen(self.parent.config['reconnect_method'])
reconn.wait()
+ time.sleep(1)
ip = re.match(".*Current IP Address: (.*)</body>.*", urllib2.urlopen("http://checkip.dyndns.org/").read()).group(1) #versuchen neue ip aus zu lesen
while ip == "": #solange versuch bis neue ip ausgelesen
ip = re.match(".*Current IP Address: (.*)</body>.*", urllib2.urlopen("http://checkip.dyndns.org/").read()).group(1)