diff options
Diffstat (limited to 'platform/javascript/SCsub')
| -rw-r--r-- | platform/javascript/SCsub | 56 | 
1 files changed, 26 insertions, 30 deletions
diff --git a/platform/javascript/SCsub b/platform/javascript/SCsub index 05992ebac8..5991075e29 100644 --- a/platform/javascript/SCsub +++ b/platform/javascript/SCsub @@ -3,39 +3,35 @@  Import('env')  javascript_files = [ -    "os_javascript.cpp", -    "audio_driver_javascript.cpp", -    "javascript_main.cpp", -    "power_javascript.cpp", -    "http_client_javascript.cpp", -    "javascript_eval.cpp", +    'audio_driver_javascript.cpp', +    'http_client_javascript.cpp', +    'javascript_eval.cpp', +    'javascript_main.cpp', +    'os_javascript.cpp',  ] -env_javascript = env.Clone() -if env['target'] == "profile": -    env_javascript.Append(CPPFLAGS=['-DPROFILER_ENABLED']) +build = env.add_program(['#bin/godot${PROGSUFFIX}.js', '#bin/godot${PROGSUFFIX}.wasm'], javascript_files); +js, wasm = build -javascript_objects = [] -for x in javascript_files: -    javascript_objects.append(env_javascript.Object(x)) - -env.Append(LINKFLAGS=["-s", "EXPORTED_FUNCTIONS=\"['_main','_main_after_fs_sync','_send_notification']\""]) - -target_dir = env.Dir("#bin") -build = env.add_program(['#bin/godot', target_dir.File('godot' + env['PROGSUFFIX'] + '.wasm')], javascript_objects, PROGSUFFIX=env['PROGSUFFIX'] + '.js'); - -js_libraries = [] -js_libraries.append(env.File('http_request.js')) +js_libraries = [ +    'http_request.js', +]  for lib in js_libraries: -    env.Append(LINKFLAGS=['--js-library', lib.path]) +    env.Append(LINKFLAGS=['--js-library', env.File(lib).path])  env.Depends(build, js_libraries) -prejs = env.File('pre.js') -postjs = env.File('engine.js') -env.Append(LINKFLAGS=['--pre-js', prejs.path]) -env.Append(LINKFLAGS=['--post-js', postjs.path]) -env.Depends(build, [prejs, postjs]) - -zip_dir = target_dir.Dir('.javascript_zip') -zip_files = env.InstallAs([zip_dir.File('godot.js'), zip_dir.File('godot.wasm'), zip_dir.File('godot.html')], build + ['#misc/dist/html/default.html']) -Zip('#bin/godot', zip_files, ZIPSUFFIX=env['PROGSUFFIX'] + env['ZIPSUFFIX'], ZIPROOT=zip_dir, ZIPCOMSTR="Archving $SOURCES as $TARGET") +wrapper_start = env.File('pre.js') +wrapper_end = env.File('engine.js') +js_wrapped = env.Textfile('#bin/godot', [wrapper_start, js, wrapper_end], TEXTFILESUFFIX='${PROGSUFFIX}.wrapped.js') + +zip_dir = env.Dir('#bin/.javascript_zip') +zip_files = env.InstallAs([ +    zip_dir.File('godot.js'), +    zip_dir.File('godot.wasm'), +    zip_dir.File('godot.html') +], [ +	js_wrapped, +	wasm, +	'#misc/dist/html/default.html' +]) +env.Zip('#bin/godot', zip_files, ZIPROOT=zip_dir, ZIPSUFFIX='${PROGSUFFIX}${ZIPSUFFIX}', ZIPCOMSTR='Archving $SOURCES as $TARGET')  |