diff options
author | RaNaN <Mast3rRaNaN@hotmail.de> | 2011-05-13 19:53:37 +0200 |
---|---|---|
committer | RaNaN <Mast3rRaNaN@hotmail.de> | 2011-05-13 19:53:37 +0200 |
commit | 04a8860b22f5ac5bd6bd89be999c6fdba789daab (patch) | |
tree | 0150c6ec0e7963d64a2f72f28d633e6d09320bb9 /module/JsEngine.py | |
parent | some fixes, closed #306 (diff) | |
download | pyload-04a8860b22f5ac5bd6bd89be999c6fdba789daab.tar.xz |
rhino js engine
Diffstat (limited to 'module/JsEngine.py')
-rw-r--r-- | module/JsEngine.py | 55 |
1 files changed, 50 insertions, 5 deletions
diff --git a/module/JsEngine.py b/module/JsEngine.py index 2f34d54c0..3549595f7 100644 --- a/module/JsEngine.py +++ b/module/JsEngine.py @@ -18,6 +18,8 @@ """ from imp import find_module +from os.path import join, exists + ENGINE = "" try: @@ -36,8 +38,38 @@ if not ENGINE: if not ENGINE: try: import subprocess - subprocess.Popen(["js", "-v"], bufsize=-1,stdout=subprocess.PIPE, stderr=subprocess.PIPE) - ENGINE = "js" + + subprocess.Popen(["js", "-v"], bufsize=-1, stdout=subprocess.PIPE, stderr=subprocess.PIPE).communicate() + p = subprocess.Popen(["js", "-e", "print(23+19)"], stdout=subprocess.PIPE, stderr=subprocess.PIPE) + out, err = p.communicate() + #integrity check + if out.strip() == "42": + ENGINE = "js" + except: + pass + + +if not ENGINE or ENGINE: + try: + path = "" #path where to find rhino + + if exists("/usr/share/java/js.jar"): + path = "/usr/share/java/js.jar" + elif exists("js.jar"): + path = "js.jar" + elif exists(join(pypath, "js.jar")): #may raises an exception, but js.jar wasnt found anyway + path = join(pypath, "js.jar") + + if not path: + raise Exception + + import subprocess + + p = subprocess.Popen(["java", "-cp", path, "org.mozilla.javascript.tools.shell.Main", "-e", "print(23+19)"], stdout=subprocess.PIPE, stderr=subprocess.PIPE) + out, err = p.communicate() + #integrity check + if out.strip() == "42": + ENGINE = "rhino" except: pass @@ -54,9 +86,11 @@ class JsEngine(): if ENGINE == "spidermonkey": import spidermonkey global spidermonkey + elif ENGINE == "pyv8": import PyV8 global PyV8 + self.init = True if not ENGINE: @@ -67,6 +101,8 @@ class JsEngine(): return self.eval_pyv8(script) elif ENGINE == "js": return self.eval_js(script) + elif ENGINE == "rhino": + return self.eval_rhino(script) def eval_spidermonkey(self, script): @@ -80,9 +116,17 @@ class JsEngine(): return rt.eval(script) def eval_js(self, script): - script = "print(eval('%s'))" % script.replace("'",'"') + script = "print(eval('%s'))" % script.replace("'", '"') p = subprocess.Popen(["js", "-e", script], stdout=subprocess.PIPE, stderr=subprocess.STDOUT, bufsize=-1) - res = p.stdout.read().strip() + out, err = p.communicate() + res = out.strip() + return res + + def eval_rhino(self, script): + script = "print(eval('%s'))" % script.replace("'", '"') + p = subprocess.Popen(["java", "-cp", path, "org.mozilla.javascript.tools.shell.Main", "-e", script], stdout=subprocess.PIPE, stderr=subprocess.STDOUT, bufsize=-1) + out, err = p.communicate() + res = out.strip() return res def error(self): @@ -92,10 +136,11 @@ if __name__ == "__main__": js = JsEngine() import subprocess import spidermonkey - import PyV8 + #import PyV8 test = '"a"+"b"' print js.eval_js(test) print js.eval_spidermonkey(test) + print js.eval_rhino(test) print js.eval_pyv8(test)
\ No newline at end of file |