summaryrefslogtreecommitdiffstats
path: root/module/plugins
diff options
context:
space:
mode:
Diffstat (limited to 'module/plugins')
-rw-r--r--module/plugins/hooks/ExtractArchive.py26
-rw-r--r--module/plugins/internal/UnRar.py15
2 files changed, 26 insertions, 15 deletions
diff --git a/module/plugins/hooks/ExtractArchive.py b/module/plugins/hooks/ExtractArchive.py
index aee8674ec..47f47bcaf 100644
--- a/module/plugins/hooks/ExtractArchive.py
+++ b/module/plugins/hooks/ExtractArchive.py
@@ -1,12 +1,34 @@
#!/usr/bin/env python
# -*- coding: utf-8 -*-
+import sys
import os
from os import remove, chmod
from os.path import exists, basename, isfile, isdir
+import subprocess
from traceback import print_exc
from copy import copy
+
+# cleanup patch for older python versions
+# see http://bugs.python.org/issue6122
+# http://bugs.python.org/issue1236
+# http://bugs.python.org/issue1731717
+if sys.version_info < (2, 6):
+ def _cleanup():
+ pass
+ subprocess._cleanup = _cleanup
+
+def _old_cleanup():
+ for inst in subprocess._active[:]:
+ res = inst._internal_poll(_deadstate=sys.maxint)
+ if res is not None and res >= 0:
+ try:
+ subprocess._active.remove(inst)
+ except ValueError:
+ pass
+
+
if os.name != "nt":
from os import chown
from pwd import getpwnam
@@ -203,6 +225,10 @@ class ExtractArchive(Hook):
if self.core.debug:
print_exc()
self.logError(basename(plugin.file), _("Unknown Error"), str(e))
+ finally:
+ if sys.version_info < (2, 6):
+ # call cleanup when its seems save
+ _old_cleanup()
return []
diff --git a/module/plugins/internal/UnRar.py b/module/plugins/internal/UnRar.py
index e2a61c678..3f27c2e9e 100644
--- a/module/plugins/internal/UnRar.py
+++ b/module/plugins/internal/UnRar.py
@@ -18,25 +18,10 @@
"""
import os
-import sys
from os.path import join
from glob import glob
-import subprocess
from subprocess import Popen, PIPE
-def _cleanup():
- for inst in subprocess._active[:]:
- res = inst._internal_poll(_deadstate=sys.maxint)
- if res is not None and res >= 0:
- try:
- subprocess._active.remove(inst)
- except ValueError:
- # This can happen if two threads create a new Popen instance.
- # It's harmless that it was already removed, so ignore.
- pass
-
-# cleanup patch for older python versions
-subprocess._cleanup = _cleanup
from module.plugins.hooks.ExtractArchive import AbtractExtractor
from module.utils import save_join, decode