summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
authorGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2010-08-27 22:44:01 +0200
committerGravatar RaNaN <Mast3rRaNaN@hotmail.de> 2010-08-27 22:44:01 +0200
commitf31082dfaf52c80b3f7ee96ef4390af2d1e9331c (patch)
treed391670f160b5733c218581a0311587710b201a9 /module
parentreadded speedmanager (diff)
downloadpyload-f31082dfaf52c80b3f7ee96ef4390af2d1e9331c.tar.xz
implemented speedmanager
Diffstat (limited to 'module')
-rw-r--r--module/HookManager.py2
-rw-r--r--module/PluginThread.py1
-rw-r--r--module/SpeedManager.py71
-rw-r--r--module/config/default.conf1
4 files changed, 39 insertions, 36 deletions
diff --git a/module/HookManager.py b/module/HookManager.py
index 8a6193d87..8bb8d1d5b 100644
--- a/module/HookManager.py
+++ b/module/HookManager.py
@@ -48,6 +48,7 @@ class HookManager():
return func(*args)
except Exception, e:
args[0].log.error(_("Error executing hooks: %s") % str(e))
+ traceback.print_exc()
return new
def createIndex(self):
@@ -58,7 +59,6 @@ class HookManager():
#hookClass = getattr(plugin, plugin.__name__)
if self.core.config.getPlugin(pluginClass.__name__, "load"):
- #@TODO handle in pluginmanager
plugin = pluginClass(self.core)
plugins.append(plugin)
self.log.info(_("%(name)s loaded, activated %(value)s") % {"name": pluginClass.__name__, "value": plugin.isActivated() })
diff --git a/module/PluginThread.py b/module/PluginThread.py
index 9d16155ef..32426766a 100644
--- a/module/PluginThread.py
+++ b/module/PluginThread.py
@@ -147,7 +147,6 @@ class DownloadThread(PluginThread):
except Reconnect:
self.queue.put(pyfile)
- #@TODO
#pyfile.req.clearCookies()
while self.m.reconnecting.isSet():
diff --git a/module/SpeedManager.py b/module/SpeedManager.py
index e69c641fc..e0ce05586 100644
--- a/module/SpeedManager.py
+++ b/module/SpeedManager.py
@@ -23,44 +23,49 @@ from threading import Thread
from time import sleep, time
class SpeedManager(Thread):
- def __init__(self, parent):
+ def __init__(self, core, hook):
Thread.__init__(self)
- self.parent = parent
+ self.setDaemon(True)
+
+ self.hook = hook
+ self.core = core
self.running = True
self.lastSlowCheck = 0.0
-
+
stat = {}
stat["slow_downloads"] = None
stat["each_speed"] = None
stat["each_speed_optimized"] = None
self.stat = stat
-
+
self.slowCheckInterval = 60
self.slowCheckTestTime = 25
-
- self.logger = self.parent.parent.logger
+
+ self.log = self.core.log
self.start()
-
+
def run(self):
while self.running:
sleep(1)
self.manageSpeed()
-
+
def getMaxSpeed(self):
- return self.parent.parent.getMaxSpeed()
-
+ return int(self.hook.getConfig("speed"))
+
def manageSpeed(self):
maxSpeed = self.getMaxSpeed()
- if maxSpeed <= 0:
- for thread in self.parent.py_downloading:
- thread.plugin.req.speedLimitActive = False
+ if maxSpeed <= 0 or self.core.compare_time(self.hook.getConfig("start").split(":"),
+ self.hook.getConfig("end").split(":")):
+ for pyfile in [x.active for x in self.core.threadManager.threads if x.active and x.active != "quit"]:
+ pyfile.plugin.req.speedLimitActive = False
return
- threads = self.parent.py_downloading
+
+ threads = [x.active for x in self.core.threadManager.threads if x.active and x.active != "quit"]
threadCount = len(threads)
- if threadCount <= 0:
+ if not threads:
return
- eachSpeed = maxSpeed/threadCount
-
+ eachSpeed = maxSpeed / threadCount
+
currentOverallSpeed = 0
restSpeed = maxSpeed - currentOverallSpeed
speeds = []
@@ -68,39 +73,39 @@ class SpeedManager(Thread):
currentOverallSpeed += thread.plugin.req.dl_speed
speeds.append((thread.plugin.req.dl_speed, thread.plugin.req.averageSpeed, thread))
thread.plugin.req.speedLimitActive = True
-
- if currentOverallSpeed+50 < maxSpeed:
- for thread in self.parent.py_downloading:
+
+ if currentOverallSpeed + 50 < maxSpeed:
+ for thread in threads:
thread.plugin.req.speedLimitActive = False
return
-
+
slowCount = 0
slowSpeed = 0
- if self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime < time.time():
- self.lastSlowCheck = time.time()
- if self.lastSlowCheck + self.slowCheckInterval < time.time() < self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime:
+ if self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime < time():
+ self.lastSlowCheck = time()
+ if self.lastSlowCheck + self.slowCheckInterval < time(
+ ) < self.lastSlowCheck + self.slowCheckInterval + self.slowCheckTestTime:
for speed in speeds:
speed[2].plugin.req.isSlow = False
else:
for speed in speeds:
- if speed[0] <= eachSpeed-7:
- if speed[1] < eachSpeed-15:
- if speed[2].plugin.req.dl_time > 0 and speed[2].plugin.req.dl_time+30 < time.time():
+ if speed[0] <= eachSpeed - 7:
+ if speed[1] < eachSpeed - 15:
+ if speed[2].plugin.req.dl_time > 0 and speed[2].plugin.req.dl_time + 30 < time():
speed[2].plugin.req.isSlow = True
- if not speed[1]-5 < speed[2].plugin.req.maxSpeed/1024 < speed[1]+5:
- speed[2].plugin.req.maxSpeed = (speed[1]+10)*1024
+ if not speed[1] - 5 < speed[2].plugin.req.maxSpeed / 1024 < speed[1] + 5:
+ speed[2].plugin.req.maxSpeed = (speed[1] + 10) * 1024
if speed[2].plugin.req.isSlow:
slowCount += 1
- slowSpeed += speed[2].plugin.req.maxSpeed/1024
+ slowSpeed += speed[2].plugin.req.maxSpeed / 1024
stat = {}
stat["slow_downloads"] = slowCount
stat["each_speed"] = eachSpeed
eachSpeed = (maxSpeed - slowSpeed) / (threadCount - slowCount)
stat["each_speed_optimized"] = eachSpeed
self.stat = stat
-
+
for speed in speeds:
if speed[2].plugin.req.isSlow:
continue
- speed[2].plugin.req.maxSpeed = eachSpeed*1024
- print "max", speed[2].plugin.req.maxSpeed, "current", speed[2].plugin.req.dl_speed
+ speed[2].plugin.req.maxSpeed = eachSpeed * 1024
diff --git a/module/config/default.conf b/module/config/default.conf
index df8682804..915604084 100644
--- a/module/config/default.conf
+++ b/module/config/default.conf
@@ -26,7 +26,6 @@ general - "General":
int max_downloads : "Max Parallel Downloads" = 3
bool debug_mode : "Debug Mode" = False
int max_download_time : "Max Download Time" = 5
- int download_speed_limit : "Download Speed Limit" = 0
bool checksum : "Use Checksum" = False
int min_free_space : "Min Free Space (MB)" = 200
bool folder_per_package : "Create folder for each package" = True