summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
Diffstat (limited to 'module')
-rw-r--r--module/plugins/hooks/UnRar.py5
-rw-r--r--module/pyunrar.py17
2 files changed, 13 insertions, 9 deletions
diff --git a/module/plugins/hooks/UnRar.py b/module/plugins/hooks/UnRar.py
index 48e69ead9..88da0b64d 100644
--- a/module/plugins/hooks/UnRar.py
+++ b/module/plugins/hooks/UnRar.py
@@ -37,7 +37,8 @@ class UnRar(Hook):
("overwrite", "bool", "overwrite files", True),
("passwordfile", "str", "unrar passoword file", "unrar_passwords.txt"),
("deletearchive", "bool", "delete archives when done", False),
- ("ramwarning", "bool", "warn about low ram", True)]
+ ("ramwarning", "bool", "warn about low ram", True),
+ ("renice", "int", "Cpu Priority", 10)]
__threaded__ = ["packageFinished"]
__author_name__ = ("mkaay")
__author_mail__ = ("mkaay@mkaay.de")
@@ -127,7 +128,7 @@ class UnRar(Hook):
else:
folder = download_folder
- u = Unrar(join(folder, fname), tmpdir=join(folder, "tmp"), ramSize=(self.ram if self.getConfig("ramwarning") else 0))
+ u = Unrar(join(folder, fname), tmpdir=join(folder, "tmp"), ramSize=(self.ram if self.getConfig("ramwarning") else 0), cpu=self.getConfig("renice"))
try:
success = u.crackPassword(passwords=self.passwords, statusFunction=s, overwrite=True, destination=folder, fullPath=self.getConfig("fullpath"))
except WrongPasswordError:
diff --git a/module/pyunrar.py b/module/pyunrar.py
index 11b19330b..8b9892f8e 100644
--- a/module/pyunrar.py
+++ b/module/pyunrar.py
@@ -76,7 +76,7 @@ class CommandError(Exception):
return EXITMAP[self.ret]
class Unrar():
- def __init__(self, archive, tmpdir=None, ramSize=0):
+ def __init__(self, archive, tmpdir=None, ramSize=0, cpu=0):
"""
archive should be be first or only part
"""
@@ -88,9 +88,12 @@ class Unrar():
else: #old style
self.pattern = "%s.r*" % archive.replace(".rar", "")
if os.name == "nt":
- self.cmd = join(pypath, "UnRAR.exe")
+ self.cmd = [join(pypath, "UnRAR.exe")]
else:
- self.cmd = "unrar"
+ if cpu:
+ self.cmd = ["nice", "-%s" % cpu,"unrar"]
+ else:
+ self.cmd = ["unrar"]
self.encrypted = None
self.headerEncrypted = None
self.smallestFiles = None
@@ -112,7 +115,7 @@ class Unrar():
f = self.archive
if self.pattern:
f = self.pattern
- args = [self.cmd, "v"]
+ args = self.cmd + ["v"]
if password:
args.append("-p%s" % password)
else:
@@ -213,7 +216,7 @@ class Unrar():
f = self.archive
if self.pattern:
f = self.pattern
- args = [self.cmd, "t", "-p%s" % password, f]
+ args = self.cmd + ["t", "-p%s" % password, f]
try:
args.append(self.getSmallestFile(password)["name"])
except WrongPasswordError:
@@ -236,7 +239,7 @@ class Unrar():
f = self.archive
if self.pattern:
f = self.pattern
- args = [self.cmd]
+ args = self.cmd
if fullPath:
args.append("x")
else:
@@ -299,7 +302,7 @@ class Unrar():
destination = "."
if overwrite:
try:
- remove(abspath(join(destination, sf[0])))
+ remove(abspath( join(destination, sf[0])))
except OSError, e:
if not e.errno == 2:
raise e