| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | import os | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-03 15:46:52 +02:00
										 |  |  | from emscripten_helpers import run_closure_compiler, create_engine_file | 
					
						
							|  |  |  | from SCons.Util import WhereIs | 
					
						
							| 
									
										
										
										
											2016-10-30 19:05:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-08 16:55:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | def is_active(): | 
					
						
							| 
									
										
										
										
											2016-10-30 18:44:57 +01:00
										 |  |  |     return True | 
					
						
							| 
									
										
										
										
											2016-04-02 20:26:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 19:05:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | def get_name(): | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     return "JavaScript" | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 19:05:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | def can_build(): | 
					
						
							| 
									
										
										
										
											2020-10-03 15:46:52 +02:00
										 |  |  |     return WhereIs("emcc") is not None | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 19:05:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | def get_opts(): | 
					
						
							| 
									
										
										
										
											2017-09-25 00:37:17 -04:00
										 |  |  |     from SCons.Variables import BoolVariable | 
					
						
							| 
									
										
										
										
											2020-05-08 16:55:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 18:44:57 +01:00
										 |  |  |     return [ | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  |         # eval() can be a security concern, so it can be disabled. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         BoolVariable("javascript_eval", "Enable JavaScript eval interface", True), | 
					
						
							|  |  |  |         BoolVariable("threads_enabled", "Enable WebAssembly Threads support (limited browser support)", False), | 
					
						
							| 
									
										
										
										
											2020-05-01 14:45:45 +02:00
										 |  |  |         BoolVariable("use_closure_compiler", "Use closure compiler to minimize JavaScript code", False), | 
					
						
							| 
									
										
										
										
											2016-10-30 18:44:57 +01:00
										 |  |  |     ] | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-30 19:05:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | def get_flags(): | 
					
						
							| 
									
										
										
										
											2016-10-30 18:44:57 +01:00
										 |  |  |     return [ | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         ("tools", False), | 
					
						
							|  |  |  |         ("builtin_pcre2_with_jit", False), | 
					
						
							| 
									
										
										
										
											2018-02-08 22:00:55 +01:00
										 |  |  |         # Disabling the mbedtls module reduces file size. | 
					
						
							| 
									
										
										
										
											2018-01-25 09:07:07 +01:00
										 |  |  |         # The module has little use due to the limited networking functionality | 
					
						
							|  |  |  |         # in this platform. For the available networking methods, the browser | 
					
						
							|  |  |  |         # manages TLS. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         ("module_mbedtls_enabled", False), | 
					
						
							| 
									
										
										
										
											2016-10-30 18:44:57 +01:00
										 |  |  |     ] | 
					
						
							| 
									
										
										
										
											2014-02-09 22:10:30 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def configure(env): | 
					
						
							| 
									
										
										
										
											2016-06-14 11:27:16 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-30 19:21:38 +02:00
										 |  |  |     ## Build type | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     if env["target"] == "release": | 
					
						
							| 
									
										
										
										
											2018-01-07 00:13:04 +01:00
										 |  |  |         # Use -Os to prioritize optimizing for reduced file size. This is | 
					
						
							|  |  |  |         # particularly valuable for the web platform because it directly | 
					
						
							|  |  |  |         # decreases download time. | 
					
						
							|  |  |  |         # -Os reduces file size by around 5 MiB over -O3. -Oz only saves about | 
					
						
							|  |  |  |         # 100 KiB over -Os, which does not justify the negative impact on | 
					
						
							|  |  |  |         # run-time performance. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(CCFLAGS=["-Os"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-Os"]) | 
					
						
							|  |  |  |     elif env["target"] == "release_debug": | 
					
						
							|  |  |  |         env.Append(CCFLAGS=["-Os"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-Os"]) | 
					
						
							|  |  |  |         env.Append(CPPDEFINES=["DEBUG_ENABLED"]) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |         # Retain function names for backtraces at the cost of file size. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(LINKFLAGS=["--profiling-funcs"]) | 
					
						
							| 
									
										
										
										
											2020-05-08 16:55:01 +02:00
										 |  |  |     else:  # "debug" | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(CPPDEFINES=["DEBUG_ENABLED"]) | 
					
						
							|  |  |  |         env.Append(CCFLAGS=["-O1", "-g"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-O1", "-g"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-s", "ASSERTIONS=1"]) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if env["tools"]: | 
					
						
							|  |  |  |         if not env["threads_enabled"]: | 
					
						
							|  |  |  |             raise RuntimeError( | 
					
						
							|  |  |  |                 "Threads must be enabled to build the editor. Please add the 'threads_enabled=yes' option" | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |         # Tools need more memory. Initial stack memory in bytes. See `src/settings.js` in emscripten repository (will be renamed to INITIAL_MEMORY). | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(LINKFLAGS=["-s", "TOTAL_MEMORY=33554432"]) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |     else: | 
					
						
							|  |  |  |         # Disable exceptions and rtti on non-tools (template) builds | 
					
						
							|  |  |  |         # These flags help keep the file size down. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(CCFLAGS=["-fno-exceptions", "-fno-rtti"]) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |         # Don't use dynamic_cast, necessary with no-rtti. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(CPPDEFINES=["NO_SAFE_CAST"]) | 
					
						
							| 
									
										
										
										
											2017-06-30 19:21:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |     ## Copy env variables. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env["ENV"] = os.environ | 
					
						
							| 
									
										
										
										
											2018-03-28 06:10:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |     # LTO | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     if env["use_lto"]: | 
					
						
							|  |  |  |         env.Append(CCFLAGS=["-s", "WASM_OBJECT_FILES=0"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-s", "WASM_OBJECT_FILES=0"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["--llvm-lto", "1"]) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Closure compiler | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     if env["use_closure_compiler"]: | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |         # For emscripten support code. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(LINKFLAGS=["--closure", "1"]) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |         # Register builder for our Engine files | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         jscc = env.Builder(generator=run_closure_compiler, suffix=".cc.js", src_suffix=".js") | 
					
						
							|  |  |  |         env.Append(BUILDERS={"BuildJS": jscc}) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Add method that joins/compiles our Engine files. | 
					
						
							|  |  |  |     env.AddMethod(create_engine_file, "CreateEngineFile") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     # Closure compiler extern and support for ecmascript specs (const, let, etc). | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env["ENV"]["EMCC_CLOSURE_ARGS"] = "--language_in ECMASCRIPT6" | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env["CC"] = "emcc" | 
					
						
							|  |  |  |     env["CXX"] = "em++" | 
					
						
							|  |  |  |     env["LINK"] = "emcc" | 
					
						
							| 
									
										
										
										
											2015-03-20 07:47:06 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env["AR"] = "emar" | 
					
						
							|  |  |  |     env["RANLIB"] = "emranlib" | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Use TempFileMunge since some AR invocations are too long for cmd.exe. | 
					
						
							|  |  |  |     # Use POSIX-style paths, required with TempFileMunge. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env["ARCOM_POSIX"] = env["ARCOM"].replace("$TARGET", "$TARGET.posix").replace("$SOURCES", "$SOURCES.posix") | 
					
						
							|  |  |  |     env["ARCOM"] = "${TEMPFILE(ARCOM_POSIX)}" | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # All intermediate files are just LLVM bitcode. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env["OBJPREFIX"] = "" | 
					
						
							|  |  |  |     env["OBJSUFFIX"] = ".bc" | 
					
						
							|  |  |  |     env["PROGPREFIX"] = "" | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  |     # Program() output consists of multiple files, so specify suffixes manually at builder. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env["PROGSUFFIX"] = "" | 
					
						
							|  |  |  |     env["LIBPREFIX"] = "lib" | 
					
						
							|  |  |  |     env["LIBSUFFIX"] = ".bc" | 
					
						
							|  |  |  |     env["LIBPREFIXES"] = ["$LIBPREFIX"] | 
					
						
							|  |  |  |     env["LIBSUFFIXES"] = ["$LIBSUFFIX"] | 
					
						
							| 
									
										
										
										
											2015-03-20 07:47:06 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env.Prepend(CPPPATH=["#platform/javascript"]) | 
					
						
							|  |  |  |     env.Append(CPPDEFINES=["JAVASCRIPT_ENABLED", "UNIX_ENABLED"]) | 
					
						
							| 
									
										
										
										
											2016-10-30 18:44:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     if env["javascript_eval"]: | 
					
						
							|  |  |  |         env.Append(CPPDEFINES=["JAVASCRIPT_EVAL_ENABLED"]) | 
					
						
							| 
									
										
										
										
											2017-06-30 19:21:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |     # Thread support (via SharedArrayBuffer). | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     if env["threads_enabled"]: | 
					
						
							|  |  |  |         env.Append(CPPDEFINES=["PTHREAD_NO_RENAME"]) | 
					
						
							|  |  |  |         env.Append(CCFLAGS=["-s", "USE_PTHREADS=1"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-s", "USE_PTHREADS=1"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-s", "PTHREAD_POOL_SIZE=4"]) | 
					
						
							|  |  |  |         env.Append(LINKFLAGS=["-s", "WASM_MEM_MAX=2048MB"]) | 
					
						
							| 
									
										
										
										
											2020-09-30 19:13:59 +02:00
										 |  |  |         env.extra_suffix = ".threads" + env.extra_suffix | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  |     else: | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env.Append(CPPDEFINES=["NO_THREADS"]) | 
					
						
							| 
									
										
										
										
											2020-03-11 11:55:28 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # Reduce code size by generating less support code (e.g. skip NodeJS support). | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "ENVIRONMENT=web,worker"]) | 
					
						
							| 
									
										
										
										
											2017-06-30 19:21:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-19 09:44:04 +01:00
										 |  |  |     # We use IDBFS in javascript_main.cpp. Since Emscripten 1.39.1 it needs to | 
					
						
							|  |  |  |     # be linked explicitly. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env.Append(LIBS=["idbfs.js"]) | 
					
						
							| 
									
										
										
										
											2019-11-19 09:44:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "BINARYEN=1"]) | 
					
						
							| 
									
										
										
										
											2020-05-01 14:45:45 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "MODULARIZE=1", "-s", "EXPORT_NAME='Godot'"]) | 
					
						
							| 
									
										
										
										
											2019-12-02 14:10:46 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  |     # Allow increasing memory buffer size during runtime. This is efficient | 
					
						
							|  |  |  |     # when using WebAssembly (in comparison to asm.js) and works well for | 
					
						
							|  |  |  |     # us since we don't know requirements at compile-time. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "ALLOW_MEMORY_GROWTH=1"]) | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     # This setting just makes WebGL 2 APIs available, it does NOT disable WebGL 1. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "USE_WEBGL2=1"]) | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "INVOKE_RUN=0"]) | 
					
						
							| 
									
										
										
										
											2018-03-21 15:51:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-01 14:45:45 +02:00
										 |  |  |     # Allow use to take control of swapping WebGL buffers. | 
					
						
							|  |  |  |     env.Append(LINKFLAGS=["-s", "OFFSCREEN_FRAMEBUFFER=1"]) | 
					
						
							| 
									
										
										
										
											2020-05-01 14:36:41 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-01 14:45:45 +02:00
										 |  |  |     # callMain for manual start, FS for preloading, PATH and ERRNO_CODES for BrowserFS. | 
					
						
							| 
									
										
										
										
											2020-05-08 16:55:01 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "EXTRA_EXPORTED_RUNTIME_METHODS=['callMain', 'FS', 'PATH']"]) | 
					
						
							| 
									
										
										
										
											2020-05-01 14:36:41 +02:00
										 |  |  |     # Add code that allow exiting runtime. | 
					
						
							| 
									
										
										
										
											2020-05-01 14:45:45 +02:00
										 |  |  |     env.Append(LINKFLAGS=["-s", "EXIT_RUNTIME=1"]) |