| 
									
										
										
										
											2016-10-17 08:50:25 +02:00
										 |  |  | #!/usr/bin/env python | 
					
						
							| 
									
										
										
										
											2024-06-11 15:19:07 -05:00
										 |  |  | from misc.utility.scons_hints import * | 
					
						
							| 
									
										
										
										
											2016-10-17 08:50:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  | Import("env") | 
					
						
							|  |  |  | Import("env_modules") | 
					
						
							| 
									
										
										
										
											2014-02-24 09:53:33 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 15:45:37 +01:00
										 |  |  | env_gdscript = env_modules.Clone() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | env_gdscript.add_source_files(env.modules_sources, "*.cpp") | 
					
						
							| 
									
										
										
										
											2014-02-24 09:53:33 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												SCons: Unify tools/target build type configuration
Implements https://github.com/godotengine/godot-proposals/issues/3371.
New `target` presets
====================
The `tools` option is removed and `target` changes to use three new presets,
which match the builds users are familiar with. These targets control the
default optimization level and enable editor-specific and debugging code:
- `editor`: Replaces `tools=yes target=release_debug`.
  * Defines: `TOOLS_ENABLED`, `DEBUG_ENABLED`, `-O2`/`/O2`
- `template_debug`: Replaces `tools=no target=release_debug`.
  * Defines: `DEBUG_ENABLED`, `-O2`/`/O2`
- `template_release`: Replaces `tools=no target=release`.
  * Defines: `-O3`/`/O2`
New `dev_build` option
======================
The previous `target=debug` is now replaced by a separate `dev_build=yes`
option, which can be used in combination with either of the three targets,
and changes the following:
- `dev_build`: Defines `DEV_ENABLED`, disables optimization (`-O0`/`/0d`),
  enables generating debug symbols, does not define `NDEBUG` so `assert()`
  works in thirdparty libraries, adds a `.dev` suffix to the binary name.
Note: Unlike previously, `dev_build` defaults to off so that users who
compile Godot from source get an optimized and small build by default.
Engine contributors should now set `dev_build=yes` in their build scripts or
IDE configuration manually.
Changed binary names
====================
The name of generated binaries and object files are changed too, to follow
this format:
`godot.<platform>.<target>[.dev][.double].<arch>[.<extra_suffix>][.<ext>]`
For example:
- `godot.linuxbsd.editor.dev.arm64`
- `godot.windows.template_release.double.x86_64.mono.exe`
Be sure to update your links/scripts/IDE config accordingly.
More flexible `optimize` and `debug_symbols` options
====================================================
The optimization level and whether to generate debug symbols can be further
specified with the `optimize` and `debug_symbols` options. So the default
values listed above for the various `target` and `dev_build` combinations
are indicative and can be replaced when compiling, e.g.:
`scons p=linuxbsd target=template_debug dev_build=yes optimize=debug`
will make a "debug" export template with dev-only code enabled, `-Og`
optimization level for GCC/Clang, and debug symbols. Perfect for debugging
complex crashes at runtime in an exported project.
											
										 
											2022-09-22 08:28:55 +02:00
										 |  |  | if env.editor_build: | 
					
						
							| 
									
										
										
										
											2019-08-28 13:10:32 +02:00
										 |  |  |     env_gdscript.add_source_files(env.modules_sources, "./editor/*.cpp") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-28 15:48:38 +02:00
										 |  |  |     SConscript("editor/script_templates/SCsub") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-28 13:10:32 +02:00
										 |  |  |     # Those two modules are required for the language server protocol | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |     if env["module_jsonrpc_enabled"] and env["module_websocket_enabled"]: | 
					
						
							| 
									
										
										
										
											2019-08-28 13:10:32 +02:00
										 |  |  |         env_gdscript.add_source_files(env.modules_sources, "./language_server/*.cpp") | 
					
						
							|  |  |  |     else: | 
					
						
							|  |  |  |         # Using a define in the disabled case, to avoid having an extra define | 
					
						
							|  |  |  |         # in regular builds where all modules are enabled. | 
					
						
							| 
									
										
										
										
											2020-03-30 08:28:32 +02:00
										 |  |  |         env_gdscript.Append(CPPDEFINES=["GDSCRIPT_NO_LSP"]) | 
					
						
							| 
									
										
										
										
											2023-10-30 15:28:34 +01:00
										 |  |  |         # Also needed in main env to unexpose --lsp-port option. | 
					
						
							|  |  |  |         env.Append(CPPDEFINES=["GDSCRIPT_NO_LSP"]) | 
					
						
							| 
									
										
										
										
											2020-08-18 17:24:45 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-28 15:48:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-18 17:24:45 +03:00
										 |  |  | if env["tests"]: | 
					
						
							|  |  |  |     env_gdscript.Append(CPPDEFINES=["TESTS_ENABLED"]) | 
					
						
							|  |  |  |     env_gdscript.add_source_files(env.modules_sources, "./tests/*.cpp") |