From 48645d0e29b14a12280817b1d70e3a540faf1ed1 Mon Sep 17 00:00:00 2001 From: Reinhold Gschweicher Date: Sat, 15 Oct 2022 22:26:52 +0200 Subject: [PATCH] Document the Unification of tools/target build type configuration Introduced in https://github.com/godotengine/godot/pull/66242 the `tools=yes/no` option was removed and merged into the `target` preset. Replace the `tools=yes/no` calls in the documentation to the new template target presets `editor`, `template_release` and `template_debug`. --- .../compiling/compiling_for_android.rst | 24 ++++---- development/compiling/compiling_for_ios.rst | 4 +- .../compiling/compiling_for_linuxbsd.rst | 16 +++--- development/compiling/compiling_for_macos.rst | 20 +++---- development/compiling/compiling_for_uwp.rst | 4 +- development/compiling/compiling_for_web.rst | 16 +++--- .../compiling/compiling_for_windows.rst | 10 ++-- development/compiling/compiling_with_mono.rst | 30 +++++----- .../cross-compiling_for_ios_on_linux.rst | 2 +- .../introduction_to_the_buildsystem.rst | 56 +++++++++---------- development/compiling/optimizing_for_size.rst | 10 ++-- development/cpp/using_cpp_profilers.rst | 8 +-- 12 files changed, 97 insertions(+), 103 deletions(-) diff --git a/development/compiling/compiling_for_android.rst b/development/compiling/compiling_for_android.rst index 0ce721048060..48387decbcd1 100644 --- a/development/compiling/compiling_for_android.rst +++ b/development/compiling/compiling_for_android.rst @@ -94,8 +94,8 @@ root directory with the following arguments: :: - scons platform=android target=release android_arch=armv7 - scons platform=android target=release android_arch=arm64v8 + scons platform=android target=template_release android_arch=armv7 + scons platform=android target=template_release android_arch=arm64v8 cd platform/android/java # On Windows .\gradlew generateGodotTemplates @@ -109,8 +109,8 @@ The resulting APK will be located at ``bin/android_release.apk``. :: - scons platform=android target=release_debug android_arch=armv7 - scons platform=android target=release_debug android_arch=arm64v8 + scons platform=android target=template_debug android_arch=armv7 + scons platform=android target=template_debug android_arch=arm64v8 cd platform/android/java # On Windows .\gradlew generateGodotTemplates @@ -136,10 +136,10 @@ example, for the release template: :: - scons platform=android target=release android_arch=armv7 - scons platform=android target=release android_arch=arm64v8 - scons platform=android target=release android_arch=x86 - scons platform=android target=release android_arch=x86_64 + scons platform=android target=template_release android_arch=armv7 + scons platform=android target=template_release android_arch=arm64v8 + scons platform=android target=template_release android_arch=x86 + scons platform=android target=template_release android_arch=x86_64 cd platform/android/java # On Windows .\gradlew generateGodotTemplates @@ -214,10 +214,10 @@ root directory with the following arguments: :: - scons platform=android android_arch=armv7 production=yes tools=yes target=release_debug - scons platform=android android_arch=arm64v8 production=yes tools=yes target=release_debug - scons platform=android android_arch=x86 production=yes tools=yes target=release_debug - scons platform=android android_arch=x86_64 production=yes tools=yes target=release_debug + scons platform=android android_arch=armv7 production=yes target=editor + scons platform=android android_arch=arm64v8 production=yes target=editor + scons platform=android android_arch=x86 production=yes target=editor + scons platform=android android_arch=x86_64 production=yes target=editor cd platform/android/java # On Windows .\gradlew generateGodotEditor diff --git a/development/compiling/compiling_for_ios.rst b/development/compiling/compiling_for_ios.rst index a156885a8129..21db6e94f28d 100644 --- a/development/compiling/compiling_for_ios.rst +++ b/development/compiling/compiling_for_ios.rst @@ -36,13 +36,13 @@ Open a Terminal, go to the root dir of the engine source code and type: :: - $ scons p=ios target=debug + $ scons p=ios target=template_debug for a debug build, or: :: - $ scons p=ios target=release + $ scons p=ios target=template_release for a release build (check ``platform/ios/detect.py`` for the compiler flags used for each configuration). diff --git a/development/compiling/compiling_for_linuxbsd.rst b/development/compiling/compiling_for_linuxbsd.rst index 95cbf5ba5dd9..b0dc9b24c9e8 100644 --- a/development/compiling/compiling_for_linuxbsd.rst +++ b/development/compiling/compiling_for_linuxbsd.rst @@ -149,7 +149,7 @@ manager. .. note:: If you are compiling Godot for production use, then you can make the final executable smaller and faster by adding the - SCons option ``target=release_debug``. + SCons option ``target=template_release``. If you are compiling Godot with GCC, you can make the binary even smaller and faster by adding the SCons option ``use_lto=yes``. @@ -167,17 +167,17 @@ Compiling a headless/server build To compile a *headless* build which provides editor functionality to export projects in an automated manner, use:: - scons -j8 platform=server tools=yes target=release_debug + scons -j8 platform=server target=editor To compile a debug *server* build which can be used with :ref:`remote debugging tools `, use:: - scons -j8 platform=server tools=no target=release_debug + scons -j8 platform=server target=template_debug To compile a *server* build which is optimized to run dedicated game servers, use:: - scons -j8 platform=server tools=no target=release + scons -j8 platform=server target=template_release Building export templates ------------------------- @@ -197,15 +197,15 @@ following parameters: :: - scons platform=linuxbsd tools=no target=release bits=32 - scons platform=linuxbsd tools=no target=release_debug bits=32 + scons platform=linuxbsd target=template_release bits=32 + scons platform=linuxbsd target=template_debug bits=32 - (64 bits) :: - scons platform=linuxbsd tools=no target=release bits=64 - scons platform=linuxbsd tools=no target=release_debug bits=64 + scons platform=linuxbsd target=template_release bits=64 + scons platform=linuxbsd target=template_debug bits=64 Note that cross-compiling for the opposite bits (64/32) as your host platform is not always straight-forward and might need a chroot environment. diff --git a/development/compiling/compiling_for_macos.rst b/development/compiling/compiling_for_macos.rst index f55c6fbd1af4..096b62aff48e 100644 --- a/development/compiling/compiling_for_macos.rst +++ b/development/compiling/compiling_for_macos.rst @@ -100,24 +100,24 @@ Compiling a headless/server build To compile a *headless* build which provides editor functionality to export projects in an automated manner, use:: - scons platform=server tools=yes target=release_debug --jobs=$(sysctl -n hw.logicalcpu) + scons platform=server target=editor --jobs=$(sysctl -n hw.logicalcpu) To compile a debug *server* build which can be used with :ref:`remote debugging tools `, use:: - scons platform=server tools=no target=release_debug --jobs=$(sysctl -n hw.logicalcpu) + scons platform=server target=template_debug --jobs=$(sysctl -n hw.logicalcpu) To compile a release *server* build which is optimized to run dedicated game servers, use:: - scons platform=server tools=no target=release --jobs=$(sysctl -n hw.logicalcpu) + scons platform=server target=template_release --jobs=$(sysctl -n hw.logicalcpu) Building export templates ------------------------- -To build macOS export templates, you have to compile with ``tools=no`` (no -editor) and respectively for ``target=release`` (release template) and -``target=release_debug``. +To build macOS export templates, you have to compile with the no +editor targets ``target=template_release`` (release template) and +``target=template_debug``. Official templates are universal binaries which support both Intel x86_64 and ARM64 architectures. You can also create export templates that support only one @@ -125,13 +125,13 @@ of those two architectures by leaving out the ``lipo`` step below. - For Intel x86_64:: - scons platform=macos tools=no target=release arch=x86_64 --jobs=$(sysctl -n hw.logicalcpu) - scons platform=macos tools=no target=release_debug arch=x86_64 --jobs=$(sysctl -n hw.logicalcpu) + scons platform=macos target=template_release arch=x86_64 --jobs=$(sysctl -n hw.logicalcpu) + scons platform=macos target=template_debug arch=x86_64 --jobs=$(sysctl -n hw.logicalcpu) - For ARM64 (Apple M1):: - scons platform=macos tools=no target=release arch=arm64 --jobs=$(sysctl -n hw.logicalcpu) - scons platform=macos tools=no target=release_debug arch=arm64 --jobs=$(sysctl -n hw.logicalcpu) + scons platform=macos target=template_release arch=arm64 --jobs=$(sysctl -n hw.logicalcpu) + scons platform=macos target=template_debug arch=arm64 --jobs=$(sysctl -n hw.logicalcpu) To support both architectures in a single "Universal 2" binary, run the above two commands blocks and then use ``lipo`` to bundle them together:: diff --git a/development/compiling/compiling_for_uwp.rst b/development/compiling/compiling_for_uwp.rst index 32e2e09e842c..df091abcc270 100644 --- a/development/compiling/compiling_for_uwp.rst +++ b/development/compiling/compiling_for_uwp.rst @@ -66,8 +66,8 @@ be able to export. Open the command prompt for one architecture and run SCons twice (once for each target):: - C:\godot>scons platform=uwp target=release_debug - C:\godot>scons platform=uwp target=release + C:\godot>scons platform=uwp target=template_debug + C:\godot>scons platform=uwp target=template_release Repeat for the other architectures. diff --git a/development/compiling/compiling_for_web.rst b/development/compiling/compiling_for_web.rst index a206aeca9c0e..ded57214776c 100644 --- a/development/compiling/compiling_for_web.rst +++ b/development/compiling/compiling_for_web.rst @@ -34,18 +34,18 @@ and ``source ./emsdk_env.sh``/``emsdk_env.bat``. Open a terminal and navigate to the root directory of the engine source code. Then instruct SCons to build the Web platform. Specify ``target`` as -either ``release`` for a release build or ``release_debug`` for a debug build:: +either ``template_release`` for a release build or ``template_debug`` for a debug build:: - scons platform=web tools=no target=release - scons platform=web tools=no target=release_debug + scons platform=web target=template_release + scons platform=web target=template_debug By default, the :ref:`JavaScript singleton ` will be built into the engine. Official export templates also have the JavaScript singleton enabled. Since ``eval()`` calls can be a security concern, the ``javascript_eval`` option can be used to build without the singleton:: - scons platform=web tools=no target=release javascript_eval=no - scons platform=web tools=no target=release_debug javascript_eval=no + scons platform=web target=template_release javascript_eval=no + scons platform=web target=template_debug javascript_eval=no The engine will now be compiled to WebAssembly by Emscripten. Once finished, the resulting file will be placed in the ``bin`` subdirectory. Its name is @@ -71,8 +71,8 @@ performance and compatibility reasons. See the You can build the export templates using the option ``dlink_enabled=yes`` to enable GDExtension support:: - scons platform=web tools=no dlink_enabled=yes target=release - scons platform=web tools=no dlink_enabled=yes target=release_debug + scons platform=web dlink_enabled=yes target=template_release + scons platform=web dlink_enabled=yes target=template_debug Once finished, the resulting file will be placed in the ``bin`` subdirectory. Its name will have ``_dlink`` added. @@ -90,7 +90,7 @@ It is also possible to build a version of the Godot editor that can run in the browser. The editor version is not recommended over the native build. You can build the editor with:: - scons platform=web tools=yes target=release_debug + scons platform=web target=editor Once finished, the resulting file will be placed in the ``bin`` subdirectory. Its name will be ``godot.web.opt.tools.wasm32.zip``. You can upload the diff --git a/development/compiling/compiling_for_windows.rst b/development/compiling/compiling_for_windows.rst index c63b320b79bf..5821c6d5d809 100644 --- a/development/compiling/compiling_for_windows.rst +++ b/development/compiling/compiling_for_windows.rst @@ -157,7 +157,7 @@ dependencies. Running it will bring up the Project Manager. .. note:: If you are compiling Godot for production use, then you can make the final executable smaller and faster by adding the - SCons option ``target=release_debug``. + SCons option ``target=template_release``. If you are compiling Godot with MinGW, you can make the binary even smaller and faster by adding the SCons option ``use_lto=yes``. @@ -269,10 +269,10 @@ Creating Windows export templates Windows export templates are created by compiling Godot without the editor, with the following flags:: - C:\godot> scons platform=windows tools=no target=release_debug bits=32 - C:\godot> scons platform=windows tools=no target=release bits=32 - C:\godot> scons platform=windows tools=no target=release_debug bits=64 - C:\godot> scons platform=windows tools=no target=release bits=64 + C:\godot> scons platform=windows target=template_debug bits=32 + C:\godot> scons platform=windows target=template_release bits=32 + C:\godot> scons platform=windows target=template_debug bits=64 + C:\godot> scons platform=windows target=template_release bits=64 If you plan on replacing the standard export templates, copy these to the following location, replacing ```` with the version identifier diff --git a/development/compiling/compiling_with_mono.rst b/development/compiling/compiling_with_mono.rst index 9db5ce01e0a7..01255fa6206b 100644 --- a/development/compiling/compiling_with_mono.rst +++ b/development/compiling/compiling_with_mono.rst @@ -58,9 +58,9 @@ Generate the glue Glue sources are the wrapper functions that will be called by managed methods. These source files must be generated before building your final binaries. In order to generate them, first, you must build a temporary Godot binary with the -options ``tools=yes`` and ``mono_glue=no``:: +options ``target=editor`` and ``mono_glue=no``:: - scons p= tools=yes module_mono_enabled=yes mono_glue=no + scons p= target=editor module_mono_enabled=yes mono_glue=no After the build finishes, you need to run the compiled executable with the parameter ``--generate-mono-glue`` followed by the path to an output directory. @@ -77,8 +77,8 @@ without having to repeat this process. ```` refers to the tools binary you compiled above with the Mono module enabled. Its exact name will differ based on your system and configuration, but should be of the form -``bin/godot..tools..mono``, e.g. ``bin/godot.linuxbsd.tools.64.mono`` -or ``bin/godot.windows.tools.64.mono.exe``. Be especially aware of the **.mono** +``bin/godot..editor..mono``, e.g. ``bin/godot.linuxbsd.editor.64.mono`` +or ``bin/godot.windows.editor.64.mono.exe``. Be especially aware of the **.mono** suffix! If you've previously compiled Godot without Mono support, you might have similarly named binaries without this suffix. These binaries can't be used to generate the Mono glue. @@ -104,11 +104,11 @@ Once you have generated the Mono glue, you can build the final binary with ``mono_glue=yes``. This is the default value for ``mono_glue``, so you can also omit it. To build a Mono-enabled editor:: - scons p= tools=yes module_mono_enabled=yes mono_glue=yes + scons p= target=editor module_mono_enabled=yes mono_glue=yes And Mono-enabled export templates:: - scons p= tools=no module_mono_enabled=yes mono_glue=yes + scons p= target=template_release module_mono_enabled=yes mono_glue=yes If everything went well, apart from the normal output, SCons should have created the following files in the ``bin`` directory: @@ -136,16 +136,16 @@ Example (Windows) :: # Build temporary binary - scons p=windows tools=yes module_mono_enabled=yes mono_glue=no + scons p=windows target=editor module_mono_enabled=yes mono_glue=no # Generate glue sources bin\godot.windows.tools.64.mono --generate-mono-glue modules/mono/glue ### Build binaries normally # Editor - scons p=windows target=release_debug tools=yes module_mono_enabled=yes + scons p=windows target=editor module_mono_enabled=yes # Export templates - scons p=windows target=release_debug tools=no module_mono_enabled=yes - scons p=windows target=release tools=no module_mono_enabled=yes + scons p=windows target=template_debug module_mono_enabled=yes + scons p=windows target=template_release module_mono_enabled=yes Example (Linux, \*BSD) ^^^^^^^^^^^^^^^^^^^^^^ @@ -153,16 +153,16 @@ Example (Linux, \*BSD) :: # Build temporary binary - scons p=linuxbsd tools=yes module_mono_enabled=yes mono_glue=no + scons p=linuxbsd target=editor module_mono_enabled=yes mono_glue=no # Generate glue sources - bin/godot.linuxbsd.tools.64.mono --generate-mono-glue modules/mono/glue + bin/godot.linuxbsd.editor.64.mono --generate-mono-glue modules/mono/glue ### Build binaries normally # Editor - scons p=linuxbsd target=release_debug tools=yes module_mono_enabled=yes + scons p=linuxbsd target=editor module_mono_enabled=yes # Export templates - scons p=linuxbsd target=release_debug tools=no module_mono_enabled=yes - scons p=linuxbsd target=release tools=no module_mono_enabled=yes + scons p=linuxbsd target=template_debug module_mono_enabled=yes + scons p=linuxbsd target=template_release module_mono_enabled=yes .. _compiling_with_mono_data_directory: diff --git a/development/compiling/cross-compiling_for_ios_on_linux.rst b/development/compiling/cross-compiling_for_ios_on_linux.rst index 72edb4fb9c76..08003e8fb61a 100644 --- a/development/compiling/cross-compiling_for_ios_on_linux.rst +++ b/development/compiling/cross-compiling_for_ios_on_linux.rst @@ -141,4 +141,4 @@ way, with some additional arguments to provide the correct paths: :: - $ scons -j 4 platform=ios arch=arm64 target=release_debug IOS_SDK_PATH="/path/to/iPhoneSDK" IOS_TOOLCHAIN_PATH="/path/to/iostoolchain" ios_triple="arm-apple-darwin11-" + $ scons -j 4 platform=ios arch=arm64 target=template_release IOS_SDK_PATH="/path/to/iPhoneSDK" IOS_TOOLCHAIN_PATH="/path/to/iostoolchain" ios_triple="arm-apple-darwin11-" diff --git a/development/compiling/introduction_to_the_buildsystem.rst b/development/compiling/introduction_to_the_buildsystem.rst index fc1ec12a8e30..21cae9452793 100644 --- a/development/compiling/introduction_to_the_buildsystem.rst +++ b/development/compiling/introduction_to_the_buildsystem.rst @@ -98,22 +98,22 @@ Resulting binary The resulting binaries will be placed in the ``bin/`` subdirectory, generally with this naming convention:: - godot..[opt].[tools/debug].[extension] + godot..[editor/template_release/template_debug].[dev_build].[extension] For the previous build attempt, the result would look like this:: ls bin - bin/godot.linuxbsd.tools.64 + bin/godot.linuxbsd.editor.x86_64 -This means that the binary is for Linux *or* \*BSD (*not* both), is not optimized, has tools (the -whole editor) compiled in, and is meant for 64 bits. +This means that the binary is for Linux *or* \*BSD (*not* both), is not optimized, has the +whole editor compiled in, and is meant for 64 bits. A Windows binary with the same configuration will look like this: .. code-block:: console C:\godot> dir bin/ - godot.windows.tools.64.exe + godot.windows.editor.64.exe 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 @@ -124,44 +124,38 @@ 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. -.. _doc_introduction_to_the_buildsystem_tools: +.. _doc_introduction_to_the_buildsystem_target: -Tools ------ +Target +------ -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. +Target controls if the editor is contained and used debug flags. +All builds are optimized. Each mode means: -:: +- **editor**: Build with editor, optimized, with debugging code +- **template_debug**: Build with C++ debugging symbols +- **template_release**: Build without symbols - scons platform= tools=yes/no +The editor is enabled by default in all PC targets (Linux, Windows, macOS), +disabled for everything else. Disabling the editor produces a binary that can +run projects but that does not include the editor or the project manager. -.. _doc_introduction_to_the_buildsystem_target: +:: -Target ------- + scons platform= target=editor/template_debug/template_release -Target controls optimization and debug flags. Each mode means: +Dev build +--------- -- **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 - ``tools=yes``, as the editor requires some debug functionality and run-time - checks to run. +When doing enigine development the ``dev_build`` option can be used together +with ``target`` to enable dev-specific code. :: - scons platform= target=debug/release_debug/release + scons platform= dev_build=yes -This flag appends the ``.debug`` suffix (for debug), or ``.tools`` (for debug -with tools enabled). When optimization is enabled (release), it appends -the ``.opt`` suffix. +This flag appends the ``.dev`` suffix (for development) to the generated +binary name. Bits ---- diff --git a/development/compiling/optimizing_for_size.rst b/development/compiling/optimizing_for_size.rst index 112e047c045e..322dc592e5b2 100644 --- a/development/compiling/optimizing_for_size.rst +++ b/development/compiling/optimizing_for_size.rst @@ -61,7 +61,7 @@ To enable this, set the ``optimize`` flag to ``size``: :: - scons p=windows target=release tools=no optimize=size + scons p=windows target=template_release optimize=size Some platforms such as WebAssembly already use this mode by default. @@ -79,7 +79,7 @@ and MSVC compilers: :: - scons p=windows target=release tools=no use_lto=yes + scons p=windows target=template_release use_lto=yes Linking becomes much slower and more RAM-consuming with this option, so it should be used only for release builds: @@ -100,7 +100,7 @@ For 2D games, having the whole 3D engine available usually makes no sense. Becau :: - scons p=windows target=release tools=no disable_3d=yes + scons p=windows target=template_release disable_3d=yes Tools must be disabled in order to use this flag, as the editor is not designed to operate without 3D support. Without it, the binary size can be reduced @@ -118,7 +118,7 @@ TextEdit or GraphEdit. They can be disabled using a build flag: :: - scons p=windows target=release tools=no disable_advanced_gui=yes + scons p=windows target=template_release disable_advanced_gui=yes This is everything that will be disabled: @@ -167,7 +167,7 @@ a lot of them: :: - scons p=windows target=release tools=no module_arkit_enabled=no module_assimp_enabled=no module_bmp_enabled=no module_bullet_enabled=no module_camera_enabled=no module_csg_enabled=no module_dds_enabled=no module_enet_enabled=no module_etc_enabled=no module_gdnative_enabled=no module_gridmap_enabled=no module_hdr_enabled=no module_jsonrpc_enabled=no module_mbedtls_enabled=no module_mobile_vr_enabled=no module_opensimplex_enabled=no module_pvr_enabled=no module_recast_enabled=no module_regex_enabled=no module_squish_enabled=no module_svg_enabled=no module_tga_enabled=no module_theora_enabled=no module_tinyexr_enabled=no module_upnp_enabled=no module_vhacd_enabled=no module_vorbis_enabled=no module_webrtc_enabled=no module_websocket_enabled=no module_xatlas_unwrap_enabled=no + scons p=windows target=template_release module_arkit_enabled=no module_assimp_enabled=no module_bmp_enabled=no module_bullet_enabled=no module_camera_enabled=no module_csg_enabled=no module_dds_enabled=no module_enet_enabled=no module_etc_enabled=no module_gdnative_enabled=no module_gridmap_enabled=no module_hdr_enabled=no module_jsonrpc_enabled=no module_mbedtls_enabled=no module_mobile_vr_enabled=no module_opensimplex_enabled=no module_pvr_enabled=no module_recast_enabled=no module_regex_enabled=no module_squish_enabled=no module_svg_enabled=no module_tga_enabled=no module_theora_enabled=no module_tinyexr_enabled=no module_upnp_enabled=no module_vhacd_enabled=no module_vorbis_enabled=no module_webrtc_enabled=no module_websocket_enabled=no module_xatlas_unwrap_enabled=no If this proves not to work for your use case, you should review the list of modules and see which ones you actually still need for your game (e.g. you diff --git a/development/cpp/using_cpp_profilers.rst b/development/cpp/using_cpp_profilers.rst index 7145ea730565..718c29c6dfde 100644 --- a/development/cpp/using_cpp_profilers.rst +++ b/development/cpp/using_cpp_profilers.rst @@ -32,13 +32,13 @@ symbols, since these would make the download size significantly larger. To get profiling data that best matches the production environment, you should compile binaries with the following SCons options: -- For editor binaries: ``target=release_debug use_lto=yes`` -- For debug export templates: ``target=release_debug use_lto=yes`` -- For release export templates: ``tools=no target=release debug_symbols=yes`` +- For editor binaries: ``target=editor use_lto=yes`` +- For debug export templates: ``target=template_debug use_lto=yes`` +- For release export templates: ``target=template_release debug_symbols=yes`` - ``debug_symbols=yes`` is required as export templates are stripped from debugging symbols by default. -It is possible to run a profiler on less optimized builds (e.g. ``target=debug`` without LTO), +It is possible to run a profiler on less optimized builds (e.g. ``target=template_debug`` without LTO), but results will naturally be less representative of real world conditions. .. warning::