Cleaned up 02_introduction_to_the_buildsystem.md.

This commit is contained in:
Relintai 2024-09-29 21:17:22 +02:00
parent a41e85f8e9
commit 249703402e

View File

@ -3,7 +3,7 @@
## SCons ## SCons
Pandemonium uses `SCons ( https://www.scons.org/ )` to build. We love it, we are Pandemonium uses [SCons](https://www.scons.org/) to build. We love it, we are
not changing it for anything else. We are not even sure other build not changing it for anything else. We are not even sure other build
systems are up to the task of building Pandemonium. We constantly get requests systems are up to the task of building Pandemonium. We constantly get requests
to move the build system to CMake, or Visual Studio, but this is not to move the build system to CMake, or Visual Studio, but this is not
@ -33,10 +33,7 @@ if you are planning to build Pandemonium yourself.
## Setup ## Setup
Please refer to the documentation for `doc_compiling_for_android`, Please refer to the documentation for the platform you are compiling for.
`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`.
Note that for **Windows/Visual Studio**, you need to use `x86_x64 Cross Tools 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 Command Prompt for VS 2017` or similar, depending on your install, instead of
@ -94,7 +91,7 @@ The resulting binaries will be placed in the `bin/` subdirectory,
generally with this naming convention: generally with this naming convention:
``` ```
pandemonium.&lt;platform&gt;.[opt].[tools/debug].&lt;architecture&gt;[extension] pandemonium.<platform>.[opt].[tools/debug].<architecture>[extension]
``` ```
For the previous build attempt, the result would look like this: For the previous build attempt, the result would look like this:
@ -117,7 +114,7 @@ pandemonium.windows.tools.64.exe
Copy that binary to any location you like, as it contains the project manager, 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 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 it to the different platforms. For that the export templates are needed (which
can be either downloaded from `pandemoniumengine.org ( https://pandemoniumengine.org/ )`, or can be either downloaded from [here](https://github.com/Relintai/pandemonium_engine/releases), or
you can build them yourself). you can build them yourself).
Aside from that, there are a few standard options that can be set in all Aside from that, there are a few standard options that can be set in all
@ -132,7 +129,7 @@ run projects but that does not include the editor or the project
manager. manager.
``` ```
scons platform=&lt;platform&gt; tools=yes/no scons platform=<platform> tools=yes/no
``` ```
## Target ## Target
@ -150,7 +147,7 @@ Target controls optimization and debug flags. Each mode means:
checks to run. checks to run.
``` ```
scons platform=&lt;platform&gt; target=debug/release_debug/release scons platform=<platform> target=debug/release_debug/release
``` ```
This flag appends the `.debug` suffix (for debug), or `.tools` (for debug This flag appends the `.debug` suffix (for debug), or `.tools` (for debug
@ -168,7 +165,7 @@ else.
- **default**: Build for the architecture that matches the host platform. - **default**: Build for the architecture that matches the host platform.
``` ```
scons platform=&lt;platform&gt; bits=default/32/64 scons platform=<platform> bits=default/32/64
``` ```
This flag appends `.32` or `.64` suffixes to resulting binaries when This flag appends `.32` or `.64` suffixes to resulting binaries when
@ -194,20 +191,16 @@ scons custom_modules="../modules,/abs/path/to/modules,~/src/pandemonium_modules"
Note: Note:
- 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.
If there's any custom module with the exact directory name as a built-in See also: [Custom modules in C++](../02_cpp/07_custom_modules_in_cpp.md)
module, the engine will only compile the custom one. This logic can be used
to override built-in module implementations.
See also:
`doc_custom_modules_in_c++`
## Cleaning generated files ## Cleaning generated files
Sometimes, you may encounter an error due to generated files being present. You Sometimes, you may encounter an error due to generated files being present. You
can remove them by using `scons --clean &lt;options&gt;`, where `&lt;options&gt;` is the can remove them by using `scons --clean <options>`, where `<options>` is the
list of build options you've used to build Pandemonium previously. list of build options you've used to build Pandemonium previously.
Alternatively, you can use `git clean -fixd` which will clean build artifacts Alternatively, you can use `git clean -fixd` which will clean build artifacts
@ -241,13 +234,7 @@ extra_suffix = "game_title"
``` ```
You can also disable some of the builtin modules before compiling, saving some You can also disable some of the builtin modules before compiling, saving some
time it takes to build the engine. See `doc_optimizing_for_size` page for more details. time it takes to build the engine. See [Optimizing a build for size](11_optimizing_for_size.md) page for more details.
See also:
You can use the online `Pandemonium build options generator ( https://pandemonium-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 Pandemonium source directory.
Another custom file can be specified explicitly with the `profile` command Another custom file can be specified explicitly with the `profile` command
line option, both overriding the default build configuration: line option, both overriding the default build configuration:
@ -294,9 +281,8 @@ powershell Windows (powershell)
## Export templates ## Export templates
Official export templates are downloaded from the Pandemonium Engine site: Official export templates can be downloaded from [here](https://github.com/Relintai/pandemonium_engine/releases).
`pandemoniumengine.org ( https://pandemoniumengine.org/ )`. However, you might want However, you might want to build them yourself (in case you want newer ones, you are using custom
to build them yourself (in case you want newer ones, you are using custom
modules, or simply don't trust your own shadow). modules, or simply don't trust your own shadow).
If you download the official export templates package and unzip it, you If you download the official export templates package and unzip it, you
@ -338,3 +324,4 @@ If you are developing for multiple platforms, macOS is definitely the most
convenient host platform for cross-compilation, since you can cross-compile for 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, 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. but Linux has the advantage of being the easier platform to set this up.