emscripten/emscripten.py

49 строки
1.7 KiB
Python
Executable File

#!/usr/bin/python
import os, sys, subprocess
COMPILER_ENGINE = None
abspath = os.path.abspath(os.path.dirname(__file__))
def path_from_root(*pathelems):
return os.path.join(os.path.sep, *(abspath.split(os.sep) + list(pathelems)))
exec(open(path_from_root('tools', 'shared.py'), 'r').read())
COMPILER = path_from_root('src', 'compiler.js')
def emscripten(filename, settings, outfile):
data = open(filename, 'r').read()
try:
cwd = os.getcwd()
except:
cwd = None
os.chdir(os.path.dirname(COMPILER))
subprocess.Popen(COMPILER_ENGINE + [COMPILER], stdin=subprocess.PIPE, stdout=outfile, stderr=subprocess.STDOUT).communicate(settings+'\n'+data)
if outfile: outfile.close()
if cwd is not None:
os.chdir(cwd)
if __name__ == '__main__':
if sys.argv.__len__() not in range(2,6):
print '''
Emscripten usage: emscripten.py INFILE [PATH-TO-JS-ENGINE] [SETTINGS] [OUTPUT_FILE]
INFILE must be in human-readable LLVM disassembly form (i.e., as text,
not binary).
PATH-TO-JS-ENGINE should be a path to the JavaScript engine used to
run the compiler (which is in JavaScript itself). You can later use
the same engine to run the code, or another one, that is a separate
issue. If you do not provide this parameter, you should define
COMPILER_ENGINE = ... in a file at ~/.emscripten.
SETTINGS is an optional set of compiler settings, overriding the defaults.
OUTPUT_FILE is the file to create with the output. If not given, we write
to stdout
'''
else:
if len(sys.argv) >= 3:
COMPILER_ENGINE = [sys.argv[2]]
settings = sys.argv[3] if len(sys.argv) >= 4 else "{}"
outfile = open(sys.argv[4], 'w') if len(sys.argv) >= 5 else None
emscripten(sys.argv[1], settings, outfile)