summaryrefslogtreecommitdiffstats
path: root/module/thread_list.py
diff options
context:
space:
mode:
Diffstat (limited to 'module/thread_list.py')
-rw-r--r--module/thread_list.py55
1 files changed, 30 insertions, 25 deletions
diff --git a/module/thread_list.py b/module/thread_list.py
index 1f967540b..979a98c60 100644
--- a/module/thread_list.py
+++ b/module/thread_list.py
@@ -32,9 +32,9 @@ class Thread_List(object):
self.download_queue = Queue()
#self.status_queue = Queue()
self.f_relation = [0,0]
- self.lock = Lock()
- self.py_downloading = [] # files downloading
- self.occ_plugins = [] #occupied plugins
+ self.lock = Lock()
+ self.py_downloading = [] # files downloading
+ self.occ_plugins = [] #occupied plugins
def create_thread(self):
""" creates thread for Py_Load_File and append thread to self.threads
@@ -61,32 +61,37 @@ class Thread_List(object):
def get_job(self):
# return job if suitable, otherwise send thread idle
- self.lock.acquire()
-
- pyfile = None
-
- for i in range(len(self.py_load_files)):
- if not self.py_load_files[i].modul.__name__ in self.occ_plugins:
- pyfile = self.py_load_files.pop(i)
-
- if pyfile:
- self.py_downloading.append(pyfile)
- if not pyfile.plugin.multi_dl:
- self.occ_plugins.append(pyfile.modul.__name__)
-
- self.lock.release()
+ self.lock.acquire()
+
+ pyfile = None
+ for i in range(len(self.py_load_files)):
+ if not self.py_load_files[i].modul.__name__ in self.occ_plugins:
+ pyfile = self.py_load_files.pop(i)
+ break
+
+ if pyfile:
+ self.py_downloading.append(pyfile)
+ if not pyfile.plugin.multi_dl:
+ self.occ_plugins.append(pyfile.modul.__name__)
+
+ self.lock.release()
return pyfile
-
+
+
def job_finished(self, pyfile):
- self.lock.acquire()
-
- self.occ_plugins.remove(pyfile.modul.__name__)
- self.py_downloading.remove(pyfile)
+ self.lock.acquire()
+
+ if not pyfile.plugin.multi_dl:
+ self.occ_plugins.remove(pyfile.modul.__name__)
+
+ self.py_downloading.remove(pyfile)
+
+ if pyfile.plugin.plugin_type == "container":
+ self.parent.extend_links(pyfile.plugin.links)
#remove from list, logging etc
-
- self.lock.release()
- return True
+ self.lock.release()
+ return True
def extend_py_load_files(self):
pass