| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 #!/usr/bin/env python | 1 #!/usr/bin/env python |
| 2 | 2 |
| 3 import json | 3 import json |
| 4 import os | 4 import os |
| 5 import re | 5 import re |
| 6 import subprocess | 6 import subprocess |
| 7 import warnings | 7 import warnings |
| 8 | 8 |
| 9 EMSCRIPTEN_PATH = '../emscripten' | 9 EMSCRIPTEN_PATH = '../emscripten' |
| 10 SOURCE_DIR = './compiled' | 10 SOURCE_DIR = './compiled' |
| (...skipping 28 matching lines...) Expand all Loading... | |
| 39 env = {} | 39 env = {} |
| 40 output = subprocess.check_output([ | 40 output = subprocess.check_output([ |
| 41 '/bin/bash', '-c', os.path.join(EMSCRIPTEN_PATH, 'emsdk_env.sh')]) | 41 '/bin/bash', '-c', os.path.join(EMSCRIPTEN_PATH, 'emsdk_env.sh')]) |
| 42 for line in output.splitlines(): | 42 for line in output.splitlines(): |
| 43 match = re.search(r'^\s*PATH\s*\+=\s*(.*)', line) | 43 match = re.search(r'^\s*PATH\s*\+=\s*(.*)', line) |
| 44 if match: | 44 if match: |
| 45 path.append(match.group(1)) | 45 path.append(match.group(1)) |
| 46 match = re.search(r'^\s*(\w+)\s*=\s*(.*)', line) | 46 match = re.search(r'^\s*(\w+)\s*=\s*(.*)', line) |
| 47 if match: | 47 if match: |
| 48 env[match.group(1)] = match.group(2) | 48 env[match.group(1)] = match.group(2) |
| 49 env['PATH'] = ':'.join([os.environ['PATH']] + path) | 49 env['PATH'] = os.pathsep.join([os.environ['PATH']] + path) |
|
sergei
2017/01/10 15:57:27
Should not we use os.pathsep instead of ':' here?
Wladimir Palant
2017/03/13 17:41:49
Done.
| |
| 50 return env | 50 return env |
| 51 | 51 |
| 52 def generate_bindings(env): | 52 def generate_bindings(env): |
| 53 params = [os.path.join(env['EMSCRIPTEN'], 'emcc'), BINDINGS_FILE, | 53 params = [os.path.join(env['EMSCRIPTEN'], 'emcc'), BINDINGS_FILE, |
| 54 '-o', BINDINGS_GENERATOR, '-std=gnu++14', '-DPRINT_BINDINGS', | 54 '-o', BINDINGS_GENERATOR, '-std=gnu++14', '-DPRINT_BINDINGS', |
| 55 '-s', 'WARN_ON_UNDEFINED_SYMBOLS=0', | 55 '-s', 'WARN_ON_UNDEFINED_SYMBOLS=0', |
| 56 ] | 56 ] |
| 57 subprocess.check_call(params, env=env) | 57 subprocess.check_call(params, env=env) |
| 58 | 58 |
| 59 node = subprocess.check_output('which node', env=env, shell=True).strip(); | 59 node = subprocess.check_output('which node', env=env, shell=True).strip(); |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 70 params.extend('-D' + flag for flag in DEFINES) | 70 params.extend('-D' + flag for flag in DEFINES) |
| 71 for key, value in GENERATION_PARAMS.iteritems(): | 71 for key, value in GENERATION_PARAMS.iteritems(): |
| 72 params.extend(['-s', '%s=%s' % (key, str(value))]) | 72 params.extend(['-s', '%s=%s' % (key, str(value))]) |
| 73 params.extend(ADDITIONAL_PARAMS) | 73 params.extend(ADDITIONAL_PARAMS) |
| 74 subprocess.check_call(params, env=env) | 74 subprocess.check_call(params, env=env) |
| 75 | 75 |
| 76 if __name__ == '__main__': | 76 if __name__ == '__main__': |
| 77 env = getenv() | 77 env = getenv() |
| 78 generate_bindings(env) | 78 generate_bindings(env) |
| 79 run_compiler(env) | 79 run_compiler(env) |
| LEFT | RIGHT |