2023-01-12 20:49:14 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
# Introduction to the buildsystem
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## SCons
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:39:50 +01:00
|
|
|
Godot uses `SCons ( https://www.scons.org/ )` to build. We love it, we are
|
2022-03-18 17:46:08 +01:00
|
|
|
not changing it for anything else. We are not even sure other build
|
|
|
|
systems are up to the task of building Godot. We constantly get requests
|
|
|
|
to move the build system to CMake, or Visual Studio, but this is not
|
|
|
|
going to happen. There are many reasons why we have chosen SCons over
|
|
|
|
other alternatives, for example:
|
|
|
|
|
|
|
|
- Godot can be compiled for a dozen different platforms: all PC
|
|
|
|
platforms, all mobile platforms, many consoles, and WebAssembly.
|
|
|
|
- Developers often need to compile for several of the platforms **at
|
|
|
|
the same time**, or even different targets of the same platform. They
|
|
|
|
can't afford reconfiguring and rebuilding the project each time.
|
|
|
|
SCons can do this with no sweat, without breaking the builds.
|
|
|
|
- SCons will *never* break a build no matter how many changes,
|
|
|
|
configurations, additions, removals etc. You have more chances to die
|
|
|
|
struck by lightning than needing to clean and rebuild in SCons.
|
|
|
|
- Godot build process is not simple. Several files are generated by
|
|
|
|
code (binders), others are parsed (shaders), and others need to offer
|
|
|
|
customization (plugins). This requires complex logic which is easier
|
|
|
|
to write in an actual programming language (like Python) rather than
|
|
|
|
using a mostly macro-based language only meant for building.
|
|
|
|
- Godot build process makes heavy use of cross-compiling tools. Each
|
|
|
|
platform has a specific detection process, and all these must be
|
|
|
|
handled as specific cases with special code written for each.
|
|
|
|
|
|
|
|
So, please try to keep an open mind and get at least a little familiar with it
|
|
|
|
if you are planning to build Godot yourself.
|
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Setup
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:29:11 +01:00
|
|
|
Please refer to the documentation for `doc_compiling_for_android`,
|
|
|
|
`doc_compiling_for_ios`, `doc_compiling_for_osx`,
|
|
|
|
`doc_compiling_for_uwp`, `doc_compiling_for_web`,
|
|
|
|
`doc_compiling_for_windows` and `doc_compiling_for_x11`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Note that for **Windows/Visual Studio**, you need to use `x86_x64 Cross Tools
|
|
|
|
Command Prompt for VS 2017` or similar, depending on your install, instead of
|
2022-03-18 17:46:08 +01:00
|
|
|
the standard Windows command prompt to enter the commands below.
|
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Platform selection
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Godot's build system will begin by detecting the platforms it can build
|
|
|
|
for. If not detected, the platform will simply not appear on the list of
|
|
|
|
available platforms. The build requirements for each platform are
|
|
|
|
described in the rest of this tutorial section.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
SCons is invoked by just calling `scons`. If no platform is specified,
|
2022-03-18 17:46:08 +01:00
|
|
|
SCons will detect the target platform automatically based on the host platform.
|
|
|
|
It will then start building for the target platform right away.
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
To list the available target platforms, use `scons platform=list`:
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons platform=list
|
|
|
|
scons: Reading SConscript files ...
|
|
|
|
The following platforms are available:
|
|
|
|
|
|
|
|
android
|
|
|
|
javascript
|
|
|
|
server
|
|
|
|
windows
|
|
|
|
x11
|
|
|
|
|
|
|
|
Please run SCons again and select a valid platform: platform=<string>
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
To build for a platform (for example, x11), run with the `platform=` (or
|
|
|
|
`p=` to make it short) argument:
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons platform=x11
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
This will start the build process, which will take a while. If you want
|
2023-01-12 20:39:50 +01:00
|
|
|
SCons to build faster, use the `-j <cores )` parameter to specify how many
|
2022-03-18 17:46:08 +01:00
|
|
|
cores will be used for the build. Or leave it using one core, so you
|
|
|
|
can use your computer for something else :)
|
|
|
|
|
|
|
|
Example for using 4 cores:
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons platform=x11 -j 4
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Resulting binary
|
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The resulting binaries will be placed in the `bin/` subdirectory,
|
2023-01-12 22:00:14 +01:00
|
|
|
generally with this naming convention:
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
godot.<platform>.[opt].[tools/debug].<architecture>[extension]
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
For the previous build attempt, the result would look like this:
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
ls bin
|
|
|
|
bin/godot.x11.tools.64
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
This means that the binary is for X11, is not optimized, has tools (the
|
|
|
|
whole editor) compiled in, and is meant for 64 bits.
|
|
|
|
|
|
|
|
A Windows binary with the same configuration will look like this:
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
C:\godot> dir bin/
|
|
|
|
godot.windows.tools.64.exe
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Copy that binary to any location you like, as it contains the project manager,
|
|
|
|
editor and all means to execute the game. However, it lacks the data to export
|
|
|
|
it to the different platforms. For that the export templates are needed (which
|
2023-01-12 20:39:50 +01:00
|
|
|
can be either downloaded from `godotengine.org ( https://godotengine.org/ )`, or
|
2022-03-18 17:46:08 +01:00
|
|
|
you can build them yourself).
|
|
|
|
|
|
|
|
Aside from that, there are a few standard options that can be set in all
|
|
|
|
build targets, and which will be explained below.
|
|
|
|
|
2023-01-12 20:49:14 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Tools
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Tools are enabled by default in all PC targets (Linux, Windows, macOS),
|
|
|
|
disabled for everything else. Disabling tools produces a binary that can
|
|
|
|
run projects but that does not include the editor or the project
|
|
|
|
manager.
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons platform=<platform> tools=yes/no
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2023-01-12 20:49:14 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Target
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Target controls optimization and debug flags. Each mode means:
|
|
|
|
|
|
|
|
- **debug**: Build with C++ debugging symbols, runtime checks (performs
|
|
|
|
checks and reports error) and none to little optimization.
|
|
|
|
- **release_debug**: Build without C++ debugging symbols and
|
|
|
|
optimization, but keep the runtime checks (performs checks and
|
|
|
|
reports errors). Official editor binaries use this configuration.
|
|
|
|
- **release**: Build without symbols, with optimization and with little
|
|
|
|
to no runtime checks. This target can't be used together with
|
2023-01-12 19:43:03 +01:00
|
|
|
`tools=yes`, as the editor requires some debug functionality and run-time
|
2022-03-18 17:46:08 +01:00
|
|
|
checks to run.
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons platform=<platform> target=debug/release_debug/release
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
This flag appends the `.debug` suffix (for debug), or `.tools` (for debug
|
2022-03-18 17:46:08 +01:00
|
|
|
with tools enabled). When optimization is enabled (release), it appends
|
2023-01-12 19:43:03 +01:00
|
|
|
the `.opt` suffix.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Bits
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Bits is meant to control the CPU or OS version intended to run the
|
|
|
|
binaries. It is focused mostly on desktop platforms and ignored everywhere
|
|
|
|
else.
|
|
|
|
|
|
|
|
- **32**: Build binaries for 32-bit platforms.
|
|
|
|
- **64**: Build binaries for 64-bit platforms.
|
|
|
|
- **default**: Build for the architecture that matches the host platform.
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons platform=<platform> bits=default/32/64
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
This flag appends `.32` or `.64` suffixes to resulting binaries when
|
|
|
|
relevant. If `bits=default` is used, the suffix will match the detected
|
2022-03-18 17:46:08 +01:00
|
|
|
architecture.
|
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Custom modules
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
It's possible to compile modules residing outside of Godot's directory
|
|
|
|
tree, along with the built-in modules.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
A `custom_modules` build option can be passed to the command line before
|
2022-03-18 17:46:08 +01:00
|
|
|
compiling. The option represents a comma-separated list of directory paths
|
|
|
|
containing a collection of independent C++ modules that can be seen as C++
|
2023-01-12 19:43:03 +01:00
|
|
|
packages, just like the built-in `modules/` directory.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
For instance, it's possible to provide both relative, absolute, and user
|
|
|
|
directory paths containing such modules:
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons custom_modules="../modules,/abs/path/to/modules,~/src/godot_modules"
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
Note:
|
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
If there's any custom module with the exact directory name as a built-in
|
|
|
|
module, the engine will only compile the custom one. This logic can be used
|
|
|
|
to override built-in module implementations.
|
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
See also:
|
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:29:11 +01:00
|
|
|
`doc_custom_modules_in_c++`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Cleaning generated files
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Sometimes, you may encounter an error due to generated files being present. You
|
2023-01-12 20:39:50 +01:00
|
|
|
can remove them by using `scons --clean <options )`, where `<options )` is the
|
2022-03-18 17:46:08 +01:00
|
|
|
list of build options you've used to build Godot previously.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Alternatively, you can use `git clean -fixd` which will clean build artifacts
|
2022-03-18 17:46:08 +01:00
|
|
|
for all platforms and configurations. Beware, as this will remove all untracked
|
|
|
|
and ignored files in the repository. Don't run this command if you have
|
|
|
|
uncommitted work!
|
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Other build options
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
There are several other build options that you can use to configure the
|
|
|
|
way Godot should be built (compiler, debug options, etc.) as well as the
|
|
|
|
features to include/disable.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Check the output of `scons --help` for details about each option for
|
2022-03-18 17:46:08 +01:00
|
|
|
the version you are willing to compile.
|
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
### Overriding the build options
|
2023-01-12 20:49:14 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
#### Using a file
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The default `custom.py` file can be created at the root of the Godot Engine
|
2022-03-18 17:46:08 +01:00
|
|
|
source to initialize any SCons build options passed via the command line:
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
# custom.py
|
|
|
|
|
|
|
|
optimize = "size"
|
|
|
|
module_mono_enabled = "yes"
|
|
|
|
use_llvm = "yes"
|
|
|
|
extra_suffix = "game_title"
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
You can also disable some of the builtin modules before compiling, saving some
|
2023-01-12 19:29:11 +01:00
|
|
|
time it takes to build the engine. See `doc_optimizing_for_size` page for more details.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
See also:
|
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
You can use the online `Godot build options generator ( https://godot-build-options-generator.github.io/ )`
|
|
|
|
to generate a `custom.py` file containing SCons options. You can then save this file and place it at the root
|
|
|
|
of your Godot source directory.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
Another custom file can be specified explicitly with the `profile` command
|
2022-03-18 17:46:08 +01:00
|
|
|
line option, both overriding the default build configuration:
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
scons profile=path/to/custom.py
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
Note: Build options set from the file can be overridden by the command line options.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
It's also possible to override the options conditionally:
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
# custom.py
|
|
|
|
|
|
|
|
import version
|
|
|
|
|
|
|
|
# Override options specific for Godot 3.x and 4.x versions.
|
|
|
|
if version.major == 3:
|
|
|
|
pass
|
|
|
|
elif version.major == 4:
|
|
|
|
pass
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
#### Using the SCONSFLAGS
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
`SCONSFLAGS` is an environment variable which is used by the SCons to set the
|
2022-03-18 17:46:08 +01:00
|
|
|
options automatically without having to supply them via the command line.
|
|
|
|
|
|
|
|
For instance, you may want to build Godot in parallel with the aforementioned
|
2023-01-12 19:43:03 +01:00
|
|
|
`-j` option for all the future builds:
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
bash Linux/macOS
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
``` export SCONSFLAGS="-j4" ```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
bat Windows (cmd)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
``` set SCONSFLAGS=-j4 ```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
powershell Windows (powershell)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 18:31:02 +01:00
|
|
|
``` $env:SCONSFLAGS="-j4" ```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-04-07 00:05:12 +02:00
|
|
|
## Export templates
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Official export templates are downloaded from the Godot Engine site:
|
2023-01-12 20:39:50 +01:00
|
|
|
`godotengine.org ( https://godotengine.org/ )`. However, you might want
|
2022-03-18 17:46:08 +01:00
|
|
|
to build them yourself (in case you want newer ones, you are using custom
|
|
|
|
modules, or simply don't trust your own shadow).
|
|
|
|
|
|
|
|
If you download the official export templates package and unzip it, you
|
|
|
|
will notice that most files are optimized binaries or packages for each
|
|
|
|
platform:
|
|
|
|
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
android_debug.apk
|
|
|
|
android_release.apk
|
|
|
|
webassembly_debug.zip
|
|
|
|
webassembly_release.zip
|
|
|
|
linux_server_32
|
|
|
|
linux_server_64
|
|
|
|
linux_x11_32_debug
|
|
|
|
linux_x11_32_release
|
|
|
|
linux_x11_64_debug
|
|
|
|
linux_x11_64_release
|
|
|
|
osx.zip
|
|
|
|
version.txt
|
|
|
|
windows_32_debug.exe
|
|
|
|
windows_32_release.exe
|
|
|
|
windows_64_debug.exe
|
|
|
|
windows_64_release.exe
|
2023-01-12 22:00:14 +01:00
|
|
|
```
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
To create those yourself, follow the instructions detailed for each
|
|
|
|
platform in this same tutorial section. Each platform explains how to
|
|
|
|
create its own template.
|
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
The `version.txt` file should contain the corresponding Godot version
|
2022-03-18 17:46:08 +01:00
|
|
|
identifier. This file is used to install export templates in a version-specific
|
|
|
|
directory to avoid conflicts. For instance, if you are building export templates
|
2023-01-12 19:43:03 +01:00
|
|
|
for Godot 3.1.1, `version.txt` should contain `3.1.1.stable` on the first
|
|
|
|
line (and nothing else). This version identifier is based on the `major`,
|
|
|
|
`minor`, `patch` (if present) and `status` lines of the
|
2023-01-12 20:39:50 +01:00
|
|
|
`version.py file in the Godot Git repository ( https://github.com/godotengine/godot/blob/master/version.py )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
If you are developing for multiple platforms, macOS is definitely the most
|
|
|
|
convenient host platform for cross-compilation, since you can cross-compile for
|
|
|
|
almost every target (except for UWP). Linux and Windows come in second place,
|
|
|
|
but Linux has the advantage of being the easier platform to set this up.
|