summaryrefslogtreecommitdiffstats
path: root/module/plugins
diff options
context:
space:
mode:
authorGravatar mkaay <mkaay@mkaay.de> 2011-02-01 00:40:36 +0100
committerGravatar mkaay <mkaay@mkaay.de> 2011-02-01 00:40:36 +0100
commitdf6598f06c7c442371f95b1036ba8997abc490de (patch)
tree671a8bc458dd6cefff826546fb5b41c0135f325e /module/plugins
parentreally fixed proxy support (diff)
downloadpyload-df6598f06c7c442371f95b1036ba8997abc490de.tar.xz
resolved #178
Diffstat (limited to 'module/plugins')
-rw-r--r--module/plugins/hooks/UnRar.py19
1 files changed, 13 insertions, 6 deletions
diff --git a/module/plugins/hooks/UnRar.py b/module/plugins/hooks/UnRar.py
index fa762a832..b1902f4ad 100644
--- a/module/plugins/hooks/UnRar.py
+++ b/module/plugins/hooks/UnRar.py
@@ -21,10 +21,10 @@ from __future__ import with_statement
import sys
from module.plugins.Hook import Hook
-from module.pyunrar import Unrar, WrongPasswordError, CommandError, UnknownError, LowRamError
+from module.lib.pyunrar import Unrar, WrongPasswordError, CommandError, UnknownError, LowRamError
from traceback import print_exc
-from os.path import exists, join
+from os.path import exists, join, isabs
from os import remove
import re
@@ -38,7 +38,8 @@ class UnRar(Hook):
("passwordfile", "str", "unrar password file", "unrar_passwords.txt"),
("deletearchive", "bool", "delete archives when done", False),
("ramwarning", "bool", "warn about low ram", True),
- ("renice", "int", "Cpu Priority", 10)]
+ ("renice", "int", "Cpu Priority", 10),
+ ("unrar_destination", "str", "Unpack files to", "")]
__threaded__ = ["packageFinished"]
__author_name__ = ("mkaay")
__author_mail__ = ("mkaay@mkaay.de")
@@ -122,17 +123,23 @@ class UnRar(Hook):
pyfile.progress.setRange(0, 100)
def s(p):
pyfile.progress.setValue(p)
-
-
+
download_folder = self.core.config['general']['download_folder']
+
if self.core.config['general']['folder_per_package']:
folder = join(download_folder, pack.folder.decode(sys.getfilesystemencoding()))
else:
folder = download_folder
+
+ destination = None
+ if self.getConfig("unrar_destination") and not self.getConfig("unrar_destination").lower() == "none":
+ destination = self.getConfig("unrar_destination")
+ if not isabs(destination):
+ destination = join(folder, destination)
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"))
+ success = u.crackPassword(passwords=self.passwords, statusFunction=s, overwrite=True, destination=folder, fullPath=self.getConfig("fullpath"), destination=destination)
except WrongPasswordError:
self.core.log.info(_("Unrar of %s failed (wrong password)") % fname)
continue