UnrealBuildTool
Helper class for directory mapping
Creating cache
Root of the project
Given a file, return the artifact structure for it. This routine tests to see if the
file is under any of the well known directories.
Action requesting the artifact
File in question
Hash value used to populate artifact
Created artifact
Create an artifact with the given settings
Directory tree
Path to artifact
Hash of the artifact
The artifact
Generic handler for artifacts
Logging device
Cache of dependency files.
Cache for file hashes
Directory mapper to be used for targets without projects
Artifact mappers for all targets
Construct a new artifact handler object
Artifact cache instance
Previously created dependency cache
Logging device
Create a new action artifact cache using horde file based storage
Directory for the cache
Previously created dependency cache
Cache for memory mapped files
Logging device
Action artifact cache object
Create a new action artifact cache using horde memory based storage
Previously created dependency cache
Logging device
Action artifact cache object
Create a new artifact action that represents the input and output of the action
Source action
Cancellation token
Artifact action
Get the key has for the action
Directory mapping object
Source action
Inputs used to construct the key
Task returning the key
Generate the key and action key hashes for the action
Directory mapping object
Source action
Inputs used to construct the key
Dependencies used to construct the key
Task object with the key and action key
Generate the lookup key. This key is generated from the action's inputs.
Destination builder
Directory mapping object
Source action
Inputs used to construct the key
Task object
Generate the full action key. This contains the hashes for the action's inputs and the dependent files.
Destination builder
Directory mapping object
Source action
Dependencies used to construct the key
Task object
Append the file information for a given list of files
Destination builder
Directory mapping object
Source action
Collection of files
Task object
Given an action, collect the list of inputs and dependencies. This includes any processing required
for disabled actions that propagate their inputs to dependent actions.
Action in question
If true, collect the dependencies too
Collection of inputs and dependencies
Add a list of file items to the collection
Hash set used to detect already included file items
Substitutions when a given input is found
Destination list
Source inputs
Return the tree name of the artifact
Artifact in question
Tree name
Return an artifact mapper for the given action
Action in question
Artifact mapper specific to the target's project directory
Artifacts can exist in different directory roots.
Absolute path
Input/Output exists in the engine directory tree
Input/Outputs exists in the project directory tree
Represents a single artifact file
Directory tree containing the artifact
Name of the artifact
Hash of the artifact contents
Represents a single artifact file
Directory tree containing the artifact
Name of the artifact
Hash of the artifact contents
Directory tree containing the artifact
Name of the artifact
Hash of the artifact contents
The full path of the artifact
Mapping object to use instead of embedded object
Full path of the artifact
Collection of inputs and outputs for an action
The hash of the primary input and the environment
The unique hash for all inputs and the environment
Information about all inputs
Information about all outputs
Collection of inputs and outputs for an action
The hash of the primary input and the environment
The unique hash for all inputs and the environment
Information about all inputs
Information about all outputs
The hash of the primary input and the environment
The unique hash for all inputs and the environment
Information about all inputs
Information about all outputs
Directory mapping object
Collection of helper extension methods for working with IMemoryReader/Writer
Read an artifact structure
Source reader
Read artifact structure
Write an artifact structure
Destination writer
Artifact to be written
Read an artifact action structure
Source reader
Read artifact action structure
Write an artifact action structure
Destination writer
Artifact action to be written
Represents the state of the cache. It is expect that after construction, the cache
can be in pending state, but this is optional. From the pending state, the cache
becomes available or unavailable.
The cache is still initializing
There has been some form of cache failure and it is unavailable
The cache is functional and ready to process requests
Interface used to map a directory tree to an actual directory
Return the directory root for the given tree
Tree in question
Directory root
Interface for querying and adding artifacts
Return true if the cache is ready to process requests
Return task that waits for the cache to be ready
State of the artifact cache
Given a collection of partial keys return all matching artifacts
Source file key
Token to be used to cancel operations
Collection of all known artifacts
Query the actual contents of a group of artifacts
Actions to be read
Token to be used to cancel operations
Dictionary of the artifacts
Save new artifact to the cache
Collection of artifacts to be saved
Token to be used to cancel operations
Asynchronous task objects
Flush all updates in the cache asynchronously.
Token to be used to cancel operations
Asynchronous task objects
Struct containing results from artifact fetch
Is set to true if succeeded in fetching artifacts
Contains log lines if any
Struct containing results from artifact fetch
Is set to true if succeeded in fetching artifacts
Contains log lines if any
Is set to true if succeeded in fetching artifacts
Contains log lines if any
Interface for action specific support of artifacts.
Underlying artifact cache
If true, reads will be serviced
If true, writes will be propagated to storage
If true, log all cache misses. Defaults to false.
Root location of the engine
Array of extra directory roots when handling relative directories.
The array MUST be consistent between runs since only the index is saved.
Complete an action from existing cached data
Action to be completed
Token to be used to cancel operations
True if it has been completed, false if not
Save the output for a completed action
Completed action
Token to be used to cancel operations
Asynchronous task object
Flush all updates in the cache asynchronously.
Token to be used to cancel operations
Asynchronous task object
Horde specific artifact action structure that also contains the file nodes for the outputs
Artifact action
Collection of output file references. There should be exactly the same number
of file references as outputs in the action
Construct a new horde artifact number
Artifact action
Construct a new artifact action from the reader
Source reader
Serialize the artifact action
Destination writer
Write all the files to disk
Destination writer
Cancellation token
Task
Series of helper methods for serialization
Read a horde artifact action
Source reader
Created artifact action
Write a horde artifact action
Destination writer
Artifact action to write
Horde node that represents a collection of action nodes
Collection of actions
Construct a new collection
Class for managing artifacts using horde storage
Defines the theoretical max number of pending actions to write
Underlying storage object
Task used to wait on ready state
Ready state
Collection of actions waiting to be written
Task for any pending flush
Controls access to shared data structures
Test to see if the cache is ready
Create a memory only cache
Create a file based cache
Destination directory
Cache for memory mapped files
Logging object
If true, clean the directory
Constructor
Storage object to use
Optionally flush all pending writes
If true, force a flush
Cancellation token
Add a group of artifact actions to a new or existing source
New artifact actions to add
Token to be used to cancel operations
List of tasks
Initialize a file based cache
Destination directory
Cache for memory mapped files
Logger
If true, clean the directory
Cache state
Return the ref name for horde storage given a artitfact action collection key
Artifact action collection key
The reference name
Global settings for building. Should not contain any target-specific settings.
Whether to ignore import library files that are out of date when building targets. Set this to true to improve iteration time.
By default, we do not bother re-linking targets if only a dependent .lib has changed, as chances are that
the import library was not actually different unless a dependent header file of this target was also changed,
in which case the target would automatically be rebuilt.
Use existing static libraries for all engine modules in this target.
Whether debug info should be written to the console.
Whether the hybrid executor will be used (a remote executor and local executor). No longer supported.
Priority order for remote executors (XGE, SNDBS, FASTBuild, UBA)
Whether the UnrealBuildAccelerator executor will be used.
Whether the UnrealBuildAccelerator (local only) executor will be used.
Whether XGE may be used if available, default is true.
Whether FASTBuild may be used if available, default is true.
Whether SN-DBS may be used if available, default is true.
Enables support for very fast iterative builds by caching target data. Turning this on causes Unreal Build Tool to emit
'UBT Makefiles' for targets when they are built the first time. Subsequent builds will load these Makefiles and begin
outdatedness checking and build invocation very quickly. The caveat is that if source files are added or removed to
the project, UBT will need to gather information about those in order for your build to complete successfully. Currently,
you must run the project file generator after adding/removing source files to tell UBT to re-gather this information.
Events that can invalidate the 'UBT Makefile':
- Adding/removing .cpp files
- Adding/removing .h files with UObjects
- Adding new UObject types to a file that did not previously have any
- Changing global build settings (most settings in this file qualify)
- Changed code that affects how Unreal Header Tool works
You can force regeneration of the 'UBT Makefile' by passing the '-gather' argument, or simply regenerating project files.
This also enables the fast include file dependency scanning and caching system that allows Unreal Build Tool to detect out
of date dependencies very quickly. When enabled, a deep C++ include graph does not have to be generated, and instead,
we only scan and cache indirect includes for after a dependent build product was already found to be out of date. During the
next build, we will load those cached indirect includes and check for outdatedness.
Number of actions that can be executed in parallel. If 0 then code will pick a default based
on the number of cores and memory available. Applies to the ParallelExecutor, HybridExecutor, and LocalExecutor
Consider logical cores when determining how many total cpu cores are available.
If true, force header regeneration. Intended for the build machine.
If true, do not build UHT, assume it is already built.
If true, fail if any of the generated header files is out of date.
True if hot-reload from IDE is allowed.
If true, the Debug version of UnrealHeaderTool will be built and run instead of the Development version.
If true, use C# UHT internal to UBT
If true, generate warnings when C++ UHT is used
Whether to skip compiling rules assemblies and just assume they are valid
Whether to force compiling rules assemblies, regardless of whether they are valid
Maximum recommended root path length.
Maximum length of a path relative to the root directory. Used on Windows to ensure paths are portable between machines.
When single file targets are specified, via -File=, -SingleFile=, or -FileList=
If this option is set, no error will be produced if the source file is not included in the target.
Additionally, if any file or file list is specified, the target will not be built if none of the specified files are part of that target,
including the case where a file specified via -FileList= is empty.
Instruct the executor to write compact output e.g. only errors, if supported by the executor.
This field is used to hold the value when specified from the command line or XML
If set, artifacts will be read
If set, artifacts will be written
If true, log all artifact cache misses as informational messages
Location to store the artifacts.
Instruct the executor to write compact output e.g. only errors, if supported by the executor,
and only if output is not being redirected e.g. during a build from within Visual Studio
Whether to unify C++ code into larger files for faster compilation.
Whether to force C++ source files to be combined into larger files for faster compilation.
Intermediate environment. Determines if the intermediates end up in a different folder than normal.
Controls how a particular warning is treated
Use the default behavior
Do not display diagnostics
Output warnings normally
Output warnings as errors
Describes the origin and visibility of Verse code
Created by Epic and only public definitions will be visible to public users
Created by Epic and is entirely hidden from public users
Created by a public user
Created by an Epic internal user
To what extent a module supports include-what-you-use
None means code does not even compile. IWYU needs to skip this module entirely
Module could be modified with iwyu but we want it to stay the way it is and handle changes manually
Module is parsed and processed. This means that from the outside it is stripped for includes
even though the files are not modified. This can be used to defer iwyu work on a module.
When it comes to transitive includes this module is seen as modified from the outside.
Same as KeepAsIsForNow but will allow iwyu to update private headers and cpp files.
Full iwyu support. When running with -Mode=IWYU this module will be modified if needed
ModuleRules is a data structure that contains the rules for defining a module
Type of module
C++
External (third-party)
Override the settings of the UHTModuleType to have a different set of
PKG_ flags. Cannot set on a plugin because that value already set in
the '.uplugin' file
Do not override the package type on this module
Set the PKG_EditorOnly flag on this module
Set the PKG_Developer on this module
Set the PKG_Developer on this module
Set the PKG_UncookedOnly flag on this module
Set the PKG_UncookedOnly flag on this module as a game
Code optimization settings
Code should never be optimized if possible.
Code should only be optimized in non-debug builds (not in Debug).
Code should only be optimized in shipping builds (not in Debug, DebugGame, Development)
Code should always be optimized if possible.
Default: 'InNonDebugBuilds' for game modules, 'Always' otherwise.
What type of PCH to use for this module.
Default: Engine modules use shared PCHs, game modules do not
Never use any PCHs.
Never use shared PCHs. Always generate a unique PCH for this module if appropriate
Shared PCHs are OK!
Shared PCHs may be used if an explicit private PCH is not set through PrivatePCHHeaderFile. In either case, none of the source files manually include a module PCH, and should include a matching header instead.
Which type of targets this module should be precompiled for
Never precompile this module.
Inferred from the module's directory. Engine modules under Engine/Source/Runtime will be compiled for games, those under Engine/Source/Editor will be compiled for the editor, etc...
Any game targets.
Any editor targets.
Any targets.
Control visibility of symbols in this module for special cases
Standard visibility rules
Make sure symbols in this module are visible in Dll builds
Information about a file which is required by the target at runtime, and must be moved around with it.
The file that should be staged. Should use $(EngineDir) and $(ProjectDir) variables as a root, so that the target can be relocated to different machines.
The initial location for this file. It will be copied to Path at build time, ready for staging.
How to stage this file.
Constructor
Path to the runtime dependency
How to stage the given path
Constructor
Path to the runtime dependency
Source path for the file in the working tree
How to stage the given path
List of runtime dependencies, with convenience methods for adding new items
Inner list of runtime dependencies
Readonly access of inner list of runtime dependencies
Default constructor
Add a runtime dependency to the list
Path to the runtime dependency. May include wildcards.
Add a runtime dependency to the list
Path to the runtime dependency. May include wildcards.
How to stage this file
Add a runtime dependency to the list
Path to the runtime dependency. May include wildcards.
Source path for the file to be added as a dependency. May include wildcards.
How to stage this file
List of runtime dependencies, with convenience methods for adding new items
Inner list of runtime dependencies
Readonly access of inner list of runtime dependencies
Default constructor
Add a receipt property to the list
Name of the property
Value for the property
Remove recepit properties from the list
the maatcher predicate
the number of items removed
Stores information about a framework on IOS or MacOS
Name of the framework
Specifies the path to a zip file that contains it or where the framework is located on disk
How to handle linking and copying the framework
Pass this framework to the linker
Copy this framework into the final .app
Both link into executable and copy into .app
How to treat the framework during linking and creating the .app
Constructor
Name of the framework
Path to a zip file containing the framework or a framework on disk
Copy the framework to the target's Framework directory
Constructor
Name of the framework
Path to a zip file containing the framework or a framework on disk
How to treat the framework during linking and creating the .app
Specifies if the file is a zip file
Constructor
Information about a Windows type library (TLB/OLB file) which requires a generated header.
Name of the type library
Additional attributes for the #import directive
Name of the output header
Name of the output include
Constructor
Name of the type library. Follows the same conventions as the filename parameter in the MSVC #import directive.
Additional attributes for the import directive
Name of the output header
Name of the output include
Name of this module
File containing this module
Directory containing this module
The Directory that contains either the Build.cs file, or the platform extension's SubClass directory
Returns true if the rules are a platform extension subclass
Additional directories that contribute to this module (likely in UnrealBuildTool.EnginePlatformExtensionsDirectory).
The dictionary tracks module subclasses
Additional directories that contribute to this module but are not based on a subclass (NotForLicensees, etc)
The rules assembly to use when searching for modules
Plugin containing this module
True if a Plugin contains this module
The rules context for this instance
Rules for the target that this module belongs to
Type of module
Accessor for the target logger
Overridden type of module that will set different package flags.
Cannot be used for modules that are a part of a plugin because that is
set in the `.uplugin` file already.
Returns true if there has been an override type specified on this module
Subfolder of Binaries/PLATFORM folder to put this module in when building DLLs. This should only be used by modules that are found via searching like the
TargetPlatform or ShaderFormat modules. If FindModules is not used to track them down, the modules will not be found.
When this module's code should be optimized.
Allows fine tuning optimization level for speed and\or code size. This requires a private PCH (or NoPCHs, which is not recommended)
Allows overriding the FP semantics for this module. This requires a private PCH (or NoPCHs, which is not recommended)
Header files that should be force included for every source file in this module.
Explicit private PCH for this module. Implies that this module will not use a shared PCH.
Header file name for a shared PCH provided by this module. Must be a valid relative path to a public C++ header file.
This should only be set for header files that are included by a significant number of other C++ modules.
Specifies an alternate name for intermediate directories and files for intermediates of this module. Useful when hitting path length limitations.
Precompiled header usage for this module
Whether this module should be treated as an engine module (eg. using engine definitions, PCHs, compiled with optimizations enabled in DebugGame configurations, etc...).
Initialized to a default based on the rules assembly it was created from.
If this contains a platform and the project has had it's SDK version overriden from default, this module will be compiled as a project module, instead of shared engine module
Emits compilation errors for incorrect UE_LOG format strings.
Emits deprecated warnings\errors for internal API usage for non-engine modules
Which engine version's build settings to use by default.
What version of include order to use when compiling this module. Can be overridden via -ForceIncludeOrder on the command line or in a module's rules.
Use run time type information
Whether to direct MSVC to remove unreferenced COMDAT functions and data.
zc-inline-remove-unreferenced-comdat
Enable code coverage compilation/linking support.
Obsolete: Direct the compiler to generate AVX instructions wherever SSE or AVX intrinsics are used, on the platforms that support it.
Note that by enabling this you are changing the minspec for the PC platform, and the resultant executable will crash on machines without AVX support.
Direct the compiler to generate AVX instructions wherever SSE or AVX intrinsics are used, on the x64 platforms that support it.
Note that by enabling this you are changing the minspec for the PC platform, and the resultant executable will crash on machines without AVX support.
Enable buffer security checks. This should usually be enabled as it prevents severe security risks.
Enable exception handling
Enable objective C exception handling
Enable objective C automatic reference counting (ARC)
If you set this to true you should not use shared PCHs for this module. The engine won't be extensively using ARC in the short term
Not doing this will result in a compile errors because shared PCHs were compiled with different flags than consumer
How to treat deterministic warnings (experimental).
How to treat shadow variable warnings
Whether to enable all warnings as errors. UE enables most warnings as errors already, but disables a few (such as deprecation warnings).
`
How to treat unsafe implicit type cast warnings (e.g., double->float or int64->int32)
Indicates what warning/error level to treat undefined identifiers in conditional expressions.
Enable warnings for using undefined identifiers in #if expressions
How to treat general module include path validation messages
How to treat private module include path validation messages, where a module is adding an include path that exposes private headers
How to treat unnecessary module sub-directory include path validation messages
Disable all static analysis - clang, msvc, pvs-studio.
Enable additional analyzer extension warnings using the EspXEngine plugin. This is only supported for MSVC.
See https://learn.microsoft.com/en-us/cpp/code-quality/using-the-cpp-core-guidelines-checkers
This will add a large number of warnings by default. It's recommended to use StaticAnalyzerRulesets if this is enabled.
The static analyzer rulesets that should be used to filter warnings. This is only supported for MSVC.
See https://learn.microsoft.com/en-us/cpp/code-quality/using-rule-sets-to-specify-the-cpp-rules-to-run
The static analyzer checkers that should be enabled rather than the defaults. This is only supported for Clang.
See https://clang.llvm.org/docs/analyzer/checkers.html for a full list. Or run:
'clang -Xclang -analyzer-checker-help'
or:
'clang -Xclang -analyzer-checker-help-alpha'
for the list of experimental checkers.
The static analyzer default checkers that should be disabled. Unused if StaticAnalyzerCheckers is populated. This is only supported for Clang.
See https://clang.llvm.org/docs/analyzer/checkers.html for a full list. Or run:
'clang -Xclang -analyzer-checker-help'
or:
'clang -Xclang -analyzer-checker-help-alpha'
for the list of experimental checkers.
The static analyzer non-default checkers that should be enabled. Unused if StaticAnalyzerCheckers is populated. This is only supported for Clang.
See https://clang.llvm.org/docs/analyzer/checkers.html for a full list. Or run:
'clang -Xclang -analyzer-checker-help'
or:
'clang -Xclang -analyzer-checker-help-alpha'
for the list of experimental checkers.
The PVS Studio analysis errors that should be disabled.
If unity builds are enabled this can be used to override if this specific module will build using Unity.
This is set using the per module configurations in BuildConfiguration.
Whether to merge module and generated unity files for faster compilation.
The number of source files in this module before unity build will be activated for that module. If set to
anything besides -1, will override the default setting which is controlled by MinGameModuleSourceFilesForUnityBuild
Overrides BuildConfiguration.MinFilesUsingPrecompiledHeader if non-zero.
Overrides Target.NumIncludedBytesPerUnityCPP if non-zero.
Helper function to get the number of byes per unity cpp file
Module uses a #import so must be built locally when compiling with SN-DBS
Enable warnings for when there are .gen.cpp files that could be inlined in a matching handwritten cpp file
Redistribution override flag for this module.
Whether the output from this module can be publicly distributed, even if it has code/
dependencies on modules that are not (i.e. CarefullyRedist, NotForLicensees, NoRedist).
This should be used when you plan to release binaries but not source.
List of folders which are allowed to be referenced when compiling this binary, without propagating restricted folder names
Set of aliased restricted folder references
Enforce "include what you use" rules when PCHUsage is set to ExplicitOrSharedPCH; warns when monolithic headers (Engine.h, UnrealEd.h, etc...)
are used, and checks that source files include their matching header first.
Allows "include what you use" to modify the source code when run. bEnforceIWYU must be true for this variable to matter.
Whether to add all the default include paths to the module (eg. the Source/Classes folder, subfolders under Source/Public).
Whether to ignore dangling (i.e. unresolved external) symbols in modules
Whether this module should be precompiled. Defaults to the bPrecompile flag from the target. Clear this flag to prevent a module being precompiled.
Whether this module should use precompiled data. Always true for modules created from installed assemblies.
Whether this module can use PLATFORM_XXXX style defines, where XXXX is a confidential platform name. This is used to ensure engine or other
shared code does not reveal confidential information inside an #if PLATFORM_XXXX block. Licensee game code may want to allow for them, however.
Disables AutoRTFM instrumentation to this module only when AutoRTFMCompiler is enabled
List of modules names (no path needed) with header files that our module's public headers needs access to, but we don't need to "import" or link against.
List of public dependency module names (no path needed) (automatically does the private/public include). These are modules that are required by our public source files.
List of modules name (no path needed) with header files that our module's private code files needs access to, but we don't need to "import" or link against.
List of private dependency module names. These are modules that our private code depends on but nothing in our public
include files depend on.
Only for legacy reason, should not be used in new code. List of module dependencies that should be treated as circular references. This modules must have already been added to
either the public or private dependent module list.
List of system/library include paths - typically used for External (third party) modules. These are public stable header file directories that are not checked when resolving header dependencies.
(This setting is currently not need as we discover all files from the 'Public' folder) List of all paths to include files that are exposed to other modules
(This setting is currently not need as we discover all files from the 'Internal' folder) List of all paths to include files that are exposed to other internal modules
List of all paths to this module's internal include files, not exposed to other modules (at least one include to the 'Private' path, more if we want to avoid relative paths)
List of system library paths (directory of .lib files) - for External (third party) modules please use the PublicAdditionalLibaries instead
List of search paths for libraries at runtime (eg. .so files)
List of search paths for libraries at runtime (eg. .so files)
List of additional libraries (names of the .lib files including extension) - typically used for External (third party) modules
List of additional debug visualizers (.natvis and .natstepfilter) exposed to other modules - typically used for External (third party) modules
Per-architecture lists of dependencies for linking to ignore (useful when building for multiple architectures, and a lib only is needed for one architecture), it's up to the Toolchain to use this
Returns the directory of where the passed in module name lives.
Name of the module
Directory where the module lives
List of additional pre-build libraries (names of the .lib files including extension) - typically used for additional targets which are still built, but using either TargetRules.PreBuildSteps or TargetRules.PreBuildTargets.
List of system libraries to use - these are typically referenced via name and then found via the system paths. If you need to reference a .lib file use the PublicAdditionalLibraries instead
List of XCode frameworks (iOS and MacOS)
List of weak frameworks (for OS version transitions)
List of addition frameworks - typically used for External (third party) modules on Mac and iOS
List of addition resources that should be copied to the app bundle for Mac or iOS
List of type libraries that we need to generate headers for (Windows only)
List of delay load DLLs - typically used for External (third party) modules
Private compiler definitions for this module
Public compiler definitions for this module
Append (or create)
Addition modules this module may require at run-time
List of files which this module depends on at runtime. These files will be staged along with the target.
List of additional properties to be added to the build receipt
Which targets this module should be precompiled for
External files which invalidate the makefile if modified. Relative paths are resolved relative to the .build.cs file.
Subclass rules files which invalidate the makefile if modified.
Whether this module requires the IMPLEMENT_MODULE macro to be implemented. Most UE modules require this, since we use the IMPLEMENT_MODULE macro
to do other global overloads (eg. operator new/delete forwarding to GMalloc).
If this module has associated Verse code, this is the Verse root path of it
Visibility of Verse code in this module's Source/Verse folder
Whether this module qualifies included headers from other modules relative to the root of their 'Public' folder. This reduces the number
of search paths that have to be passed to the compiler, improving performance and reducing the length of the compiler command line.
Whether this module qualifies included headers from other modules relative to the parent directory. This reduces the number
of search paths that have to be passed to the compiler, improving performance and reducing the length of the compiler command line.
Whether circular dependencies will be validated against the allow list
Circular module dependencies result in slower builds. Disabling this option is strongly discouraged.
This option is ignored for Engine modules which will always be validated against the allow list.
Which stanard to use for compiling this module
Which standard to use for compiling this module
A list of subdirectory names and functions that are invoked to generate header files.
The subdirectory name is appended to the generated code directory to form a new directory
that headers are generated inside.
Control visibility of symbols
The AutoSDK directory for the active host platform
The current engine directory
Property for the directory containing this plugin. Useful for adding paths to third party dependencies.
Property for the directory containing this module. Useful for adding paths to third party dependencies.
Property for the directory containing this module or the platform extension's subclass. Useful for adding paths to third party dependencies.
Name of a platform under the PlatformModuleDirectory - for a PlatfomrExtension, we don't use platform subdirectories since it's already in a platform dir, so this returns '.'
Returns module's low level tests directory "Tests".
Constructor. For backwards compatibility while the parameterless constructor is being phased out, initialization which would happen here is done by
RulesAssembly.CreateModulRules instead.
Rules for building this target
Add the given Engine ThirdParty modules as static private dependencies
Statically linked to this module, meaning they utilize exports from the other module
Private, meaning the include paths for the included modules will not be exposed when giving this modules include paths
NOTE: There is no AddThirdPartyPublicStaticDependencies function.
The target this module belongs to
The names of the modules to add
Add the given Engine ThirdParty modules as dynamic private dependencies
Dynamically linked to this module, meaning they do not utilize exports from the other module
Private, meaning the include paths for the included modules will not be exposed when giving this modules include paths
NOTE: There is no AddThirdPartyPublicDynamicDependencies function.
Rules for the target being built
The names of the modules to add
Setup this module for Mesh Editor support (based on the settings in UEBuildConfiguration)
Setup this module for GameplayDebugger support
Setup this module for Iris support (based on the settings in UEBuildConfiguration)
Setup this module for Chaos Visual Debugger support (Required for recording debug data that will be visualized in the Chaos Visual Debugger tool)
Setup this module for physics support (based on the settings in UEBuildConfiguration)
Determines if a module type is valid for a target, based on custom attributes
The type of the module to check
The target to check against
Out, reason this module was invalid
True if the module is valid, false otherwise
Determines if this module can be precompiled for the current target.
Path to the module rules file
True if the module can be precompiled, false otherwise
Determines whether a given platform is available in the context of the current Target
The platform to check for
True if it's available, false otherwise
Returns all the modules that are in the given module group
The name of the module group, as defined by a [ModuleGroup("Name")] attribute
Only include modules that are valid for the current Target
Prepares a module for building a low level tests executable.
If we're building a module as part of a test module chain, then they require the LowLevelTestsRunner dependency.
Whether this is a low level tests module.
Returns the module directory for a given subclass of the module (platform extensions add subclasses of ModuleRules to add in platform-specific settings)
typeof the subclass
Directory where the subclass's .Build.cs lives, or null if not found
Returns the directories for all subclasses of this module, as well as any additional directories specified by the rules
List of directories, or null if none were added
Adds an additional module directory, if it exists (useful for NotForLicensees/NoRedist)
true if the directory exists
Returns if VcPkg is supported for the build configuration.
True if supported
Returns the VcPkg root directory for the build configuration
The name of the third-party package
Adds libraries compiled with vcpkg to the current module
The name of the third-party package
Should the include directory be added to PublicIncludePaths
The names of the libaries to add to PublicAdditionalLibraries/
Replace an expected value in a list of definitions with a new value
List of definitions e.g. PublicDefinitions
Name of the define to change
Expected value
New value
Replace an expected value in a list of module names with a new value
List of module names e.g. PublicDependencyModuleNames
Expected value
New value
Stores information about where a module rules object came from, and how it can be used.
The scope for this module. Used to validate references to other modules.
The default directory for output files
The plugin that this module belongs to
Whether this module should be included in the default hot reload set
Whether this module should be compiled with optimization disabled in DebugGame configurations (ie. whether it's a game module).
Whether this module can be used for generating shared PCHs
Whether to treat this module as a game module for UHT ordering
The default module type for UnrealHeaderTool. Do not use this for inferring other things about the module.
Constructor
Copy constructor
The context to copy from
Read-only wrapper around an existing TargetRules instance. This exposes target settings to modules without letting them to modify the global environment.
The writeable TargetRules instance
Constructor
The TargetRules instance to wrap around
Accessors for fields on the inner TargetRules instance
Provide access to the RelativeEnginePath property for code referencing ModuleRules.BuildConfiguration.
Provide access to the UEThirdPartySourceDirectory property for code referencing ModuleRules.UEBuildConfiguration.
Provide access to the UEThirdPartyBinariesDirectory property for code referencing ModuleRules.UEBuildConfiguration.
Whether this is a low level tests target.
Whether this is a test target explicitly defined.
Explicitley defined test targets always inherit from TestTargetRules and define their own tests.
Implicit test targets are created from existing targets when building with -Mode=Test and they include tests from all dependencies.
Controls the value of WITH_LOW_LEVEL_TESTS that dictates whether module-specific low level tests are compiled in or not.
Get the platforms this target supports
Get the configurations this target supports
Checks if current platform is part of a given platform group
The platform group to check
True if current platform is part of a platform group
Gets diagnostic messages about default settings which have changed in newer versions of the engine
List of messages to be appended to
Checks if a plugin should be programmatically allowed in the build
true if the plugin is allowed
Determines if the automation tests should be compiled based on the current configuration and optional forced settings.
If either the development tests or performance tests are compiled (unless explicitly disabled), this property returns true.
PS4-specific target settings
PS5-specific target settings
Switch-specific target settings
Singleton accessor for WinGDKPlatform
Singleton accessor for XB1Platform
XboxCommon-specific target settings - directs to the platform-specific rules
Singleton accessor for XSXPlatform
Describes all of the information needed to initialize a UEBuildTarget object
Foreign plugin to compile against this target
Whether we should treat the ForeignPlugin argument as a local plugin for building purposes
When building a foreign plugin, whether to build plugins it depends on as well.
Set of module names to compile.
Lists of files to compile
Individual file(s) to compile
Relative path to file(s) to compile
Working directory when compiling with RelativePathsToSpecificFilesToCompile
Will build all files that directly include any of the files provided in -SingleFile
Whether to perform hot reload for this target
Map of module name to suffix for hot reloading from the editor
Path to a file containing a list of modules that may be modified for live coding.
Path to the manifest for passing info about the output to live coding
If a non-zero value, a live coding request will be terminated if more than the given number of actions are required.
Suppress messages about building this target
Clean the target before trying to build it
Whether to unify C++ code into larger files for faster compilation.
Whether to force C++ source files to be combined into larger files for faster compilation.
Enables "include what you use" mode.
Intermediate environment. Determines if the intermediates end up in a different folder than normal.
Constructor
Path to the project file
Name of the target to build
Platform to build for
Configuration to build
Architectures to build for
Other command-line arguments for the target
Parse a list of target descriptors from the command line
Command-line arguments
Build configuration to get common flags from
Logger for output
List of target descriptors
Parse a list of target descriptors from the command line
Command-line arguments
Logger for output
List of target descriptors
Parse a list of target descriptors from the command line
Command-line arguments
Whether to use a precompiled engine distribution
Whether to skip compiling rules assemblies
Whether to always compile all rules assemblies
Logger for output
List of target descriptors
Parse a list of target descriptors from the command line
Command-line arguments
Whether to use a precompiled engine distribution
Whether to skip compiling rules assemblies
Whether to always compile rules assemblies
Receives the list of parsed target descriptors
Logger for output
Parse a list of target descriptors from the command line
Command-line arguments
Whether to use a precompiled engine distribution
Whether to skip compiling rules assemblies
Whether to always compile all rules assemblies
List of target descriptors
Logger for output
Try to parse the project file from the command line
The command line arguments
The project file that was parsed
True if the project file was parsed, false otherwise
Format this object for the debugger
String representation of this target descriptor
Information about a target, passed along when creating a module descriptor
Name of the target
The platform that the target is being built for
The configuration being built
Architecture that the target is being built for
Intermediate environment. Determines if the intermediates end up in a different folder than normal.
The project containing the target
The current build version
Additional command line arguments for this target
Constructs a TargetInfo for passing to the TargetRules constructor.
Name of the target being built
The platform that the target is being built for
The configuration being built
The architectures being built for
Path to the project file containing the target
Additional command line arguments for this target
Intermediate environment to use
Construct a TargetInfo from an archive on disk
Archive to read from
Write a TargetInfo to an archive on disk
Archive to write to
The type of target
Cooked monolithic game executable (GameName.exe). Also used for a game-agnostic engine executable (UnrealGame.exe or RocketGame.exe)
Uncooked modular editor executable and DLLs (UnrealEditor.exe, UnrealEditor*.dll, GameName*.dll)
Cooked monolithic game client executable (GameNameClient.exe, but no server code)
Cooked monolithic game server executable (GameNameServer.exe, but no client code)
Program (standalone program, e.g. ShaderCompileWorker.exe, can be modular or monolithic depending on the program)
Specifies how to link all the modules in this target
Use the default link type based on the current target type
Link all modules into a single binary
Link modules into individual dynamic libraries
Specifies whether to share engine binaries and intermediates with other projects, or to create project-specific versions. By default,
editor builds always use the shared build environment (and engine binaries are written to Engine/Binaries/Platform), but monolithic builds
and programs do not (except in installed builds). Using the shared build environment prevents target-specific modifications to the build
environment.
Engine binaries and intermediates are output to the engine folder. Target-specific modifications to the engine build environment will be ignored.
Engine binaries and intermediates are specific to this target
Will switch to Unique if needed - per-project sdk is enabled, or a property that requires unique is set away from default
Specifies how UnrealHeaderTool should enforce member pointer declarations in UCLASSes and USTRUCTs. This should match (by name, not value) the
EPointerMemberBehavior enum in BaseParser.h so that it can be interpreted correctly by UnrealHeaderTool.
Pointer members of the associated type will be disallowed and result in an error emitted from UnrealHeaderTool.
Pointer members of the associated type will be allowed and not emit any messages to log or screen.
Pointer members of the associated type will be allowed but will emit messages to log.
Determines which version of the engine to take default build settings from. This allows for backwards compatibility as new options are enabled by default.
Legacy default build settings for 4.23 and earlier.
New defaults for 4.24:
* ModuleRules.PCHUsage = PCHUsageMode.UseExplicitOrSharedPCHs
* ModuleRules.bLegacyPublicIncludePaths = false
New defaults for 5.2:
* ModuleRules.bLegacyParentIncludePaths = false
New defaults for 5.3:
* TargetRules.CppStandard = CppStandard.Default has changed from Cpp17 to Cpp20
* TargetRules.WindowsPlatform.bStrictConformanceMode = true
New defaults for 5.4:
* TargetRules.bValidateFormatStrings = true
Always use the defaults for the current engine version. Note that this may cause compatibility issues when upgrading.
What version of include order to use when compiling. This controls which UE_ENABLE_INCLUDE_ORDER_DEPRECATED_IN_5_X defines are enabled when compiling the target.
The UE_ENABLE_INCLUDE_ORDER_DEPRECATED_IN_5_X defines are used when removing implicit includes from Unreal Public headers.
Specific versions can be used by licensees to avoid compile errors when integrating new versions of Unreal.
Using Latest comes with a high risk of introducing compile errors in your code on newer Unreal versions.
Include order used in Unreal 5.1
Include order used in Unreal 5.2
Include order used in Unreal 5.3
Include order used in Unreal 5.4
Include order used in Unreal 5.5
Always use the latest version of include order. This value is updated every Unreal release, use with caution if you intend to integrate newer Unreal releases.
Contains the oldest version of include order that the engine supports.
Do not delete old enum entries to prevent breaking project generation
Which static analyzer to use
Do not perform static analysis
Use the default static analyzer for the selected compiler, if it has one. For
Visual Studio and Clang, this means using their built-in static analysis tools.
Any compiler that doesn't support static analysis will ignore this option.
Use the built-in Visual C++ static analyzer
Use PVS-Studio for static analysis
Use clang for static analysis. This forces the compiler to clang.
Output type for the static analyzer. This currently only works for the Clang static analyzer.
The Clang static analyzer can do either Text, which prints the analysis to stdout, or
html, where it writes out a navigable HTML page for each issue that it finds, per file.
The HTML is output in the same directory as the object file that would otherwise have
been generated.
All other analyzers default automatically to Text.
Output the analysis to stdout.
Output the analysis to an HTML file in the object folder.
Output type for the static analyzer. This currently only works for the Clang static analyzer.
The Clang static analyzer can do a shallow quick analysis. However the default deep is recommended.
Default deep analysis.
Quick analysis. Not recommended.
Optimization mode for compiler settings
Favor speed
Favor minimal code size
Somewhere between Speed and Size
Debug info mode for compiler settings to determine how much debug info is available
Disable all debugging info.
MSVC: object files will be compiled without /Z7 or /Zi but pdbs will still be created
callstacks should be available in this mode but there have been reports with them being incorrect
Enable debug info for engine modules
Enable debug info for engine plugins
Enable debug info for project modules
Enable debug info for project plugins
Only include debug info for engine modules and plugins
Only include debug info for project modules and project plugins
Include full debugging information for all modules
Floating point math semantics
Use the default semantics for the platform.
FP math is IEEE-754 compliant, assuming that FP exceptions are disabled and the rounding
mode is round-to-nearest-even.
FP math isn't IEEE-754 compliant: the compiler is allowed to transform math expressions
in a ways that might result in differently rounded results from what IEEE-754 requires.
Determines how the Gameplay Debugger plugin will be activated.
Default => Not overriden, default usage behavior.
Core => WITH_GAMEPLAY_DEBUGGER = 0 and WITH_GAMEPLAY_DEBUGGER_CORE = 1
Full => WITH_GAMEPLAY_DEBUGGER = 1 and WITH_GAMEPLAY_DEBUGGER_CORE = 1
Utility class for EngineIncludeOrderVersion defines
Returns a list of every deprecation define available.
Get a list of every deprecation define and their value for the specified engine include order.
Returns the latest deprecation define.
Attribute used to mark fields which must match between targets in the shared build environment
Attribute used to mark configurable sub-objects
TargetRules is a data structure that contains the rules for defining a target (application/executable)
Static class wrapping constants aliasing the global TargetType enum.
Alias for TargetType.Game
Alias for TargetType.Editor
Alias for TargetType.Client
Alias for TargetType.Server
Alias for TargetType.Program
The name of this target
If the Name of this target has been overriden
Return the original target name without overrides or adornments
Override the name used for this target
Whether this is a low level tests target.
Override this boolean flag in inheriting classes for low level test targets.
Whether this is a test target explicitly defined.
Explicitley defined test targets always inherit from TestTargetRules and define their own tests.
Implicit test targets are created from existing targets when building with -Mode=Test and they include tests from all dependencies.
Controls the value of WITH_LOW_LEVEL_TESTS that dictates whether module-specific low level tests are compiled in or not.
Override the value of WithLowLevelTests by setting this to true in inherited classes.
File containing the general type for this target (not including platform/group)
File containing the platform/group-specific type for this target
All target files that could be referenced by this target and will require updating the Makefile if changed
Logger for output relating to this target. Set before the constructor is run from
Generic nullable object so a user can set additional data in a project's TargetRule and access in a project's ModuleRule without needing to add new properties post-release.
For example:
* in .Target.cs: AdditionalData = "data";
* in .Build.cs: if ((Target.AdditionalData as string) == "data") { ... }
Platform that this target is being built for.
The configuration being built.
Architecture that the target is being built for (or an empty string for the default).
Gets the Architecture in the normal case where there is a single Architecture in Architectures
(this will throw an exception if there is more than one architecture specified)
Intermediate environment. Determines if the intermediates end up in a different folder than normal.
Path to the project file for the project containing this target.
The current build version
The type of target.
Specifies the engine version to maintain backwards-compatible default build settings with (eg. DefaultSettingsVersion.Release_4_23, DefaultSettingsVersion.Release_4_24). Specify DefaultSettingsVersion.Latest to always
use defaults for the current engine version, at the risk of introducing build errors while upgrading.
Force the include order to a specific version. Overrides any Target and Module rules.
What version of include order to use when compiling this target. Can be overridden via -ForceIncludeOrder on the command line. ModuleRules.IncludeOrderVersion takes precedence.
Path to the output file for the main executable, relative to the Engine or project directory.
This setting is only typically useful for non-UE programs, since the engine uses paths relative to the executable to find other known folders (eg. Content).
Tracks a list of config values read while constructing this target
Whether the target uses Steam.
Whether the target uses CEF3.
Whether the project uses visual Slate UI (as opposed to the low level windowing/messaging, which is always available).
Forces linking against the static CRT. This is not fully supported across the engine due to the need for allocator implementations to be shared (for example), and TPS
libraries to be consistent with each other, but can be used for utility programs.
Enables the debug C++ runtime (CRT) for debug builds. By default we always use the release runtime, since the debug
version isn't particularly useful when debugging Unreal Engine projects, and linking against the debug CRT libraries forces
our third party library dependencies to also be compiled using the debug CRT (and often perform more slowly). Often
it can be inconvenient to require a separate copy of the debug versions of third party static libraries simply
so that you can debug your program's code.
Whether the output from this target can be publicly distributed, even if it has dependencies on modules that are in folders
with special restrictions (eg. CarefullyRedist, NotForLicensees, NoRedist).
Specifies the configuration whose binaries do not require a "-Platform-Configuration" suffix.
Specifies the separator charcter for binary filenames.
Whether this target supports hot reload
Build all the modules that are valid for this target type. Used for CIS and making installed engine builds.
Set this to reference a VSTest run settings file from generated projects.
Additional plugins that are built for this target type but not enabled.
If this is true, then the BuildPlugins list will be used to populate RuntimeDependencies, rather than EnablePlugins
A list of additional plugins which need to be included in this target. This allows referencing non-optional plugin modules
which cannot be disabled, and allows building against specific modules in program targets which do not fit the categories
in ModuleHostType.
Additional plugins that should be included for this target.
List of plugins to be disabled for this target. Note that the project file may still reference them, so they should be marked
as optional to avoid failing to find them at runtime.
Additional plugins that should be included for this target if they are found.
If false, suppress loading "enabled by default" engine plugins not explicitly enabled by the project or target files.
How to treat conflicts when a disabled plugin is being enabled by another plugin referencing it
A list of Plugin names that are allowed to exist as dependencies without being defined in the uplugin descriptor
Path to the set of pak signing keys to embed in the executable.
Allows a Program Target to specify it's own solution folder path.
Force a Target to be treated as a Program for the purposes of project file generation.
If true, GetTargetNameByType will not consider this target, thereby disambiguating -TargetType=X.
Whether the target should be included in the default solution build configuration
Setting this to false will skip building when running in the IDE
Whether this target should be compiled as a DLL. Requires LinkType to be set to TargetLinkType.Monolithic.
Extra subdirectory to load config files out of, for making multiple types of builds with the same platform
This will get baked into the game executable as CUSTOM_CONFIG and used when staging to filter files and settings
Subfolder to place executables in, relative to the default location.
Allow target module to override UHT code generation version.
Whether to enable the mesh editor.
Whether to use the BPVM to run Verse.
Whether to use the AutoRTFM Clang compiler.
Whether to use force AutoRTFM Clang compiler off.
Whether to enable emitting AutoRTFM verification metadata
Whether to compile the Chaos physics plugin.
Whether to use the Chaos physics interface. This overrides the physx flags to disable APEX and NvCloth
Whether to compile in checked chaos features for debugging
Whether to compile in chaos memory tracking features
Whether to compile in Chaos Visual Debugger (CVD) support features to record the state of the physics simulation
Whether scene query acceleration is done by UE. The physx scene query structure is still created, but we do not use it.
Whether to include PhysX support.
Whether to include PhysX APEX support.
Whether to include NvCloth.
Whether to include ICU unicode/i18n support in Core.
Whether to compile CEF3 support.
Whether to compile using ISPC.
Whether to compile IntelMetricsDiscovery.
Whether to compile in python support
Whether to compile with WITH_GAMEPLAY_DEBUGGER enabled with all Engine's default gameplay debugger categories.
Set to true when bUseGameplayDebugger is false but GameplayDebugger's core parts are required.
Whether to use I/O store on-demand
Whether to use Iris.
Whether to track owner (asset name) of RHI resource for Test configuration.
Useful for ListShaderMaps and ListShaderLibraries commands.
Whether we are compiling editor code or not. Prefer the more explicit bCompileAgainstEditor instead.
Whether to compile code related to building assets. Consoles generally cannot build assets. Desktop platforms generally can.
Whether to compile WITH_EDITORONLY_DATA disabled. Only Windows will use this, other platforms force this to false.
Manually specified value for bBuildDeveloperTools.
Whether to compile the developer tools.
Manually specified value for bBuildTargetDeveloperTools.
Whether to compile the developer tools that are for target platforms or connected devices (defaults to bBuildDeveloperTools)
Whether to force compiling the target platform modules, even if they wouldn't normally be built.
Whether to force compiling shader format modules, even if they wouldn't normally be built.
Override for including extra shader formats
Whether we should include any extra shader formats. By default this is only enabled for Program and Editor targets.
Checks the above flags to see if target SDKs are likely to be compiled in
Whether we should compile SQLite using the custom "Unreal" platform (true), or using the native platform (false).
Whether to utilize cache freed OS allocs with MallocBinned
Enabled for all builds that include the engine project. Disabled only when building standalone apps that only link with Core.
Enabled for all builds that include the CoreUObject project. Disabled only when building standalone apps that only link with Core.
Enabled for builds that need to initialize the ApplicationCore module. Command line utilities do not normally need this.
Enabled for builds that want to use against the Trace module for profiling and diagnostics.
Force enable tracing - used to allow testing programs to verify tracing works as intended.
Manually specified value for bCompileAgainstEditor.
Enabled for editor builds (TargetType.Editor). Can be overridden for programs (TargetType.Program) that would need to compile against editor code. Not available for other target types.
Mainly drives the value of WITH_EDITOR.
Whether to compile Recast navmesh generation.
Whether to compile with navmesh segment links.
Whether to compile with navmesh cluster links.
Whether to compile SpeedTree support.
Whether we should compile in support for SpeedTree or not.
Enable exceptions for all modules.
Enable inlining for all modules.
Enable exceptions for all modules.
Enable RTTI for all modules.
Enable BuildSettings to contain private information about build. Such as machine name, user name and user domain name (exposed in BuildSettings.h)
Enable Position Independent Executable (PIE). Has an overhead cost
Enable Stack Protection. Has an overhead cost
Compile client-only code.
Compile server-only code.
Compile with FName storing the number part in the name table.
Saves memory when most names are not numbered and those that are are referenced multiple times.
The game and engine must ensure they reuse numbered names similarly to name strings to avoid leaking memory.
When enabled, Push Model Networking support will be compiled in.
This can help reduce CPU overhead of networking, at the cost of more memory.
Always enabled in editor builds.
Whether to include stats support even without the engine.
Whether to include plugin support.
Whether to allow plugins which support all target platforms.
Whether to allow accessibility code in both Slate and the OS layer.
Whether to include PerfCounters support.
Whether to enable support for live coding
Whether to enable support for live coding
Whether to enable support for DirectX Math
LWC_TODO: No longer supported. Needs removing.
Whether to enable the support for FixedTimeStep in the engine
Whether to turn on logging for test/shipping builds.
Whether to turn on console for shipping builds.
Whether to turn on logging to memory for test/shipping builds.
Whether to check that the process was launched through an external launcher.
Whether to turn on checks (asserts) for test/shipping builds.
Whether to turn on GPU markers for Test builds.
Whether to turn on GPU markers for Shipping builds.
Whether to turn on UTF-8 mode, mapping TCHAR to UTF8CHAR.
Whether to use the EstimatedUtcNow or PlatformUtcNow. EstimatedUtcNow is appropriate in
cases where PlatformUtcNow can be slow.
True if we need FreeType support.
Whether to turn allow exec commands for shipping builds.
True if we want to favor optimizing size over speed.
Allows to fine tune optimizations level for speed and\or code size
Allows setting the FP semantics.
Whether to compile development automation tests.
Whether to compile performance automation tests.
Whether to override the defaults for automation tests (Debug/Development configs)
If true, event driven loader will be used in cooked builds. @todoio This needs to be replaced by a runtime solution after async loading refactor.
Used to override the behavior controlling whether UCLASSes and USTRUCTs are allowed to have native pointer members, if disallowed they will be a UHT error and should be substituted with TObjectPtr members instead.
Whether the XGE controller worker and modules should be included in the engine build.
These are required for distributed shader compilation using the XGE interception interface.
Enables "include what you use" by default for modules in this target. Changes the default PCH mode for any module in this project to PCHUsageMode.UseExplicitOrSharedPCHs.
Adds header files in included modules to the build.
When used with -IncludeHeaders, only header files will be compiled.
Enforce "include what you use" rules; warns if monolithic headers (Engine.h, UnrealEd.h, etc...) are used, and checks that source files include their matching header first.
Emit a warning when an old-style monolithic header is included while compiling this target.
Whether the final executable should export symbols.
Make static libraries for all engine modules as intermediates for this target.
Whether we should compile with support for OS X 10.9 Mavericks. Used for some tools that we need to be compatible with this version of OS X.
True if this is a console application that's being built.
If true, creates an additional console application. Hack for Windows, where it's not possible to conditionally inherit a parent's console Window depending on how
the application is invoked; you have to link the same executable with a different subsystem setting.
If true, only creates an additional console application. Overrides bBuildAdditionalConsoleApp.
True if debug symbols that are cached for some platforms should not be created.
Whether to unify C++ code into larger files for faster compilation.
Whether to unify C++ code into larger files for faster compilation.
Whether to force C++ source files to be combined into larger files for faster compilation.
Whether to merge module and generated unity files for faster compilation.
List of modules that disables merging module and generated cpp files in the same unity files.
Use a heuristic to determine which files are currently being iterated on and exclude them from unity blobs, result in faster
incremental compile times. The current implementation uses the read-only flag to distinguish the working set, assuming that files will
be made writable by the source control system if they are being modified. This is true for Perforce, but not for Git.
Disable optimization for files that are in the adaptive non-unity working set.
Disables force-included PCHs for files that are in the adaptive non-unity working set.
Backing storage for bAdaptiveUnityDisablesProjectPCH.
Whether to disable force-included PCHs for project source files in the adaptive non-unity working set. Defaults to bAdaptiveUnityDisablesPCH;
Creates a dedicated PCH for each source file in the working set, allowing faster iteration on cpp-only changes.
Creates a dedicated PCH for each source file in the working set, allowing faster iteration on cpp-only changes.
Creates a dedicated source file for each header file in the working set to detect missing includes in headers.
The number of source files in a game module before unity build will be activated for that module. This
allows small game modules to have faster iterative compile times for single files, at the expense of slower full
rebuild times. This setting can be overridden by the bFasterWithoutUnity option in a module's Build.cs file.
Default treatment of uncategorized warnings
Require TObjectPtr for FReferenceCollector API's. (Needed for compatibility with incremental GC.)
Emits compilation errors for incorrect UE_LOG format strings.
Level to report deprecation warnings as errors
Forces shadow variable warnings to be treated as errors on platforms that support it.
Whether to enable all warnings as errors. UE enables most warnings as errors already, but disables a few (such as deprecation warnings).
Indicates what warning/error level to treat unsafe type casts as on platforms that support it (e.g., double->float or int64->int32)
Forces the use of undefined identifiers in conditional expressions to be treated as errors.
Indicates what warning/error level to treat undefined identifiers in conditional expressions.
Indicates what warning/error level to treat potential PCH performance issues.
How to treat general module include path validation messages
How to treat private module include path validation messages, where a module is adding an include path that exposes private headers
How to treat unnecessary module sub-directory include path validation messages
Print out files that are included by each source file
Forces frame pointers to be retained this is usually required when you want reliable callstacks e.g. mallocframeprofiler
Forces frame pointers to be retained this is usually required when you want reliable callstacks e.g. mallocframeprofiler
New Monolithic Graphics drivers have optional "fast calls" replacing various D3d functions
An approximate number of bytes of C++ code to target for inclusion in a single unified C++ file.
Disables overrides that are set by the module
Whether to stress test the C++ unity build robustness by including all C++ files files in a project from a single unified file.
Whether to add additional information to the unity files, such as '_of_X' in the file name. Not recommended.
Whether to force debug info to be generated.
Whether to globally disable debug info generation; Obsolete, please use TargetRules.DebugInfoMode instead
How much debug info should be generated. See DebugInfoMode enum for more details
Modules that should have debug info disabled
Plugins that should have debug info disabled
True if only debug line number tables should be emitted in debug information for compilers that support doing so. Overrides TargetRules.DebugInfo
See https://clang.llvm.org/docs/UsersManual.html#cmdoption-gline-tables-only for more information
Modules that should emit line number tables instead of full debug information for compilers that support doing so. Overrides DisableDebugInfoModules
Plugins that should emit line number tables instead of full debug information for compilers that support doing so. Overrides DisableDebugInfoPlugins
Whether to disable debug info generation for generated files. This improves link times and reduces pdb size for modules that have a lot of generated glue code.
Whether to disable debug info on PC/Mac in development builds (for faster developer iteration, as link times are extremely fast with debug info disabled).
Whether PDB files should be used for Visual C++ builds.
Whether PCH files should be used.
Set flags require for deterministic compiling and linking.
Enabling deterministic mode for msvc disables codegen multithreading so compiling will be slower
Whether PCHs should be chained when compiling with clang.
Whether PCH headers should be force included for gen.cpp files when PCH is disabled.
Whether to just preprocess source files for this target, and skip compilation
Generate dependency files by preprocessing. This is only recommended when distributing builds as it adds additional overhead.
Whether to generate assembly data while compiling this target. Works exclusively on MSVC for now.
Experimental: Store object (.obj) compressed on disk. Requires UBA to link, currently MSVC only. Toggling this flag will invalidate MSVC actions.
Warning, this option is not currently compatitable with PGO or the the cl-clang linker as those are not detoured and linking will fail.
Whether static code analysis should be enabled.
The output type to use for the static analyzer. This is only supported for Clang.
The mode to use for the static analyzer. This is only supported for Clang.
Shallow mode completes quicker but is generally not recommended.
The level of warnings to print when analyzing using PVS-Studio
Only run static analysis against project modules, skipping engine modules
When enabled, generated source files will be analyzed
The minimum number of files that must use a pre-compiled header before it will be created and used.
When enabled, a precompiled header is always generated for game modules, even if there are only a few source files
in the module. This greatly improves compile times for iterative changes on a few files in the project, at the expense of slower
full rebuild times for small game projects. This can be overridden by setting MinFilesUsingPrecompiledHeaderOverride in
a module's Build.cs file.
Whether to use incremental linking or not. Incremental linking can yield faster iteration times when making small changes.
Currently disabled by default because it tends to behave a bit buggy on some computers (PDB-related compile errors).
Whether to allow the use of link time code generation (LTCG).
When Link Time Code Generation (LTCG) is enabled, whether to
prefer using the lighter weight version on supported platforms.
Directory where to put the ThinLTO cache on supported platforms.
Arguments that will be applied to prune the ThinLTO cache on supported platforms.
Arguments will only be applied if ThinLTOCacheDirectory is set.
Whether to enable Profile Guided Optimization (PGO) instrumentation in this build.
Whether to optimize this build with Profile Guided Optimization (PGO).
Whether the target requires code coverage compilation and linking.
Whether to support edit and continue.
Whether to omit frame pointers or not. Disabling is useful for e.g. memory profiling on the PC.
If we want to compress the debug files
Whether to enable support for C++20 modules
Whether to enable support for C++20 coroutines
This option is provided to facilitate evaluation of the feature.
Expect the name of the option to change. Use of coroutines in with UE is untested and unsupported.
Whether to enable engine's ability to set process priority on runtime.
This option requires some environment setup on Linux, that's why it's disabled by default.
Project has to opt-in this feature as it has to guarantee correct setup.
If true, then enable memory profiling in the build (defines USE_MALLOC_PROFILER=1 and forces bOmitFramePointers=false).
If true, then enable Unreal Insights (utrace) profiling in the build for the Shader Compiler Worker (defines USE_SHADER_COMPILER_WORKER_TRACE=1).
Enables "Shared PCHs", a feature which significantly speeds up compile times by attempting to
share certain PCH files between modules that UBT detects is including those PCH's header files.
True if Development and Release builds should use the release configuration of PhysX/APEX.
True if Development and Release builds should use the checked configuration of PhysX/APEX. if bUseShippingPhysXLibraries is true this is ignored.
Tells the UBT to check if module currently being built is violating EULA.
Tells the UBT to break build if module currently being built is violating EULA.
Whether to use the :FASTLINK option when building with /DEBUG to create local PDBs on Windows. Fast, but currently seems to have problems finding symbols in the debugger.
Outputs a map file as part of the build.
True if runtime symbols files should be generated as a post build step for some platforms.
These files are used by the engine to resolve symbol names of callstack backtraces in logs.
Package full path (directory + filename) where to store input files used at link time
Normally used to debug a linker crash for platforms that support it
Directory where to put crash report files for platforms that support it
Bundle version for Mac apps.
Whether to deploy the executable after compilation on platforms that require deployment.
Whether to force skipping deployment for platforms that require deployment by default.
When enabled, allows XGE to compile pre-compiled header files on remote machines. Otherwise, PCHs are always generated locally.
Will replace pch with ifc and use header units instead. This is an experimental and msvc-only feature
Whether headers in system paths should be checked for modification when determining outdated actions.
Whether to disable linking for this target.
Whether to ignore tracking build outputs for this target.
Whether to disable UE_DEPRECATED_FORENGINE deprecation warnings in non-engine modules.
This should only be used in the short-term as these deprecations will get removed.
Indicates that this is a formal build, intended for distribution. This flag is automatically set to true when Build.version has a changelist set and is a promoted build.
The only behavior currently bound to this flag is to compile the default resource file separately for each binary so that the OriginalFilename field is set correctly.
By default, we only compile the resource once to reduce build times.
Whether to clean Builds directory on a remote Mac before building.
Whether to write detailed timing info from the compiler and linker.
Whether to parse timing data into a tracing file compatible with chrome://tracing.
Whether to expose all symbols as public by default on POSIX platforms
Disable supports for inlining gen.cpps
Allows overriding the toolchain to be created for this target. This must match the name of a class declared in the UnrealBuildTool assembly.
The weight(cpu/memory utilization) of a MSVC compile action
The weight(cpu/memory utilization) of a clang compile action
Whether to allow engine configuration to determine if we can load unverified certificates.
Whether to load generated ini files in cooked build, (GameUserSettings.ini loaded either way)
Whether to load non-ufs ini files in cooked build, (GameUserSettings.ini loaded either way)
Add all the public folders as include paths for the compile environment.
Add all the parent folders as include paths for the compile environment.
Which C++ standard to use for compiling this target (for engine modules)
Which C++ standard to use for compiling this target (for non-engine modules)
Which C standard to use for compiling this target
Direct the compiler to generate AVX instructions wherever SSE or AVX intrinsics are used, on the x64 platforms that support it. Ignored for arm64.
Note that by enabling this you are changing the minspec for the target platform, and the resultant executable will crash on machines without AVX support.
Do not allow manifest changes when building this target. Used to cause earlier errors when building multiple targets with a shared build environment.
The build version string
Specifies how to link modules in this target (monolithic or modular). This is currently protected for backwards compatibility. Call the GetLinkType() accessor
until support for the deprecated ShouldCompileMonolithic() override has been removed.
Experimental: Strip unused exports from libraries. Only applies when LinkType is Modular
Experimental: Merge modular modules into combined libraries. Sets LinkType to Modular and enables bStripExports
Experimental: List of plugins (and their dependencies) to each merge into separate libraries. Requires bMergeModules to be enabled
Experimental: List of merged plugins to move common dependencies to a shared library, requires MergePlugins. Can be chained
Experimental: List of merged plugins to move to the main executable, requires MergePlugins. "Engine" for all shared engine modules and "Common" for shared project modules.
Backing storage for the LinkType property.
Macros to define globally across the whole target.
Macros to define across all macros in the project.
Specifies the name of the launch module. For modular builds, this is the module that is compiled into the target's executable.
Backing storage for the LaunchModuleName property.
Specifies the path to write a header containing public definitions for this target. Useful when building a DLL to be consumed by external build processes.
List of additional modules to be compiled into the target.
Path to a manifest to output for this target
Path to a list of dependencies for this target, when precompiling
Backing storage for the BuildEnvironment property
Specifies the build environment for this target. See TargetBuildEnvironment for more information on the available options.
If this true, a Shared build environment target will allow for any modules that are SDK version sensitive to have
a project side module when an SDK is overridden. For instance, if IOSTargetPlatform, which is marked as IOS SDK
version relevant, is compiled for a Target with this set to true, and that target overrides the IOS SDK, then
this would compile to e.g. MyProject/Binaries/Win64/IOS/MyProject-IOSTargetPlatform.dll
Whether to ignore violations to the shared build environment (eg. editor targets modifying definitions)
Specifies a list of targets which should be built before this target is built.
Specifies a list of steps which should be executed before this target is built, in the context of the host platform's shell.
The following variables will be expanded before execution:
$(EngineDir), $(ProjectDir), $(TargetName), $(TargetPlatform), $(TargetConfiguration), $(TargetType), $(ProjectFile).
Specifies a list of steps which should be executed after this target is built, in the context of the host platform's shell.
The following variables will be expanded before execution:
$(EngineDir), $(ProjectDir), $(TargetName), $(TargetPlatform), $(TargetConfiguration), $(TargetType), $(ProjectFile).
Specifies additional build products produced as part of this target.
Additional arguments to pass to the compiler
Additional arguments to pass to the linker
Max amount of memory that each compile action may require. Used by ParallelExecutor to decide the maximum
number of parallel actions to start at one time.
List of modules to disable unity builds for
List of modules to enable optimizations for
List of modules to disable optimizations for
List of modules to optimize for size. This allows the target to override module optimization level
Note that this may disable PCH usage if a private PCH is not provided
List of modules to optimize for size and speed. This allows the target to override module optimization level
Note that this may disable PCH usage if a private PCH is not provided
When generating project files, specifies the name of the project file to use when there are multiple targets of the same type.
If this is non-null, then any platforms NOT listed will not be allowed to have modules in their directories be created
Android-specific target settings.
IOS-specific target settings.
Linux-specific target settings.
Mac-specific target settings.
Windows-specific target settings.
Checks if the target needs to care about sdk version - if not, we can share the target between projects that are on differnet sdk versions.
For instance, ShaderCompileWorker is very tied to, say, console sdk versions, but UnrealPak doesn't have sdk things compiled in
Allow a target to override whether or not AreSDKVersionsRelevant uses default logic
Checks if the target can use non-standard sdk versions. For instance, the editor is usually compiled as a modular build shared between projects,
so if one projet uses sdk version 1, and another uses 2, then the generated engine modules will use the most recently built sdk, which could break
Checks if a plugin should be programmatically allowed in the build
true if the plugin is allowed
Checks if a property has been set with the RequiresUniqueBuildEnvironmentAttribute, and is different from it's base
Assembly containing the target
Commandline options that may affect the target creation
If the target requires a unique build environment, this will contain the names of the field/property that require unique, mapped to a pair of base and current value
If the target requires a unique build environment, this will contain the name of the target this was based on (UnrealGame, UnrealEditor, etc)/property
true if a property was set such that it requires a unique build environment
For any target that has set BuildEnvironment = TargetBuildEnvironment.Unique, this will change the Environment to either Shared or Unique accordingly
Assembly containing the target
Commandline options that may affect the target creation
Logger
Create a TargetRules instance
Type to create
Target info
Path to the file for the rules assembly
Path to the platform specific rules file
Path to all possible rules file
Logger for the new target rules
Target instance
Constructor.
Information about the target being built
Formats an array of bytes as a sequence of values
The data to convert into a string
List of hexadecimal bytes
Override any settings required for the selected target type
Override settings that all cooked editor targets will want
Gets a list of platforms that this target supports
Array of platforms that the target supports
Gets a list of configurations that this target supports
Array of configurations that the target supports
Finds all the subobjects which can be configured by command line options and config files
Sequence of objects
Gets the host platform being built on
Expose the bGenerateProjectFiles flag to targets, so we can modify behavior as appropriate for better intellisense
Indicates whether target rules should be used to explicitly enable or disable plugins. Usually not needed for project generation unless project files indicate whether referenced plugins should be built or not.
Expose a setting for whether or not the engine is installed
Flag for whether the engine is installed
Gets diagnostic messages about default settings which have changed in newer versions of the engine
List of diagnostic messages
Prints diagnostic messages about default settings which have changed in newer versions of the engine
PS4-specific target settings.
PS5-specific target settings.
Switch-specific target settings.
WinGDK-specific target settings.
XB1-specific target settings.
XboxCommon-specific target settings - directs to the platform-specific rules
XSX-specific target settings.
ModuleRules extension for low level tests.
Check if running in test mode.
Associated tested module of this test module.
Test metadata, used with BuildGraph only.
Constructs a TestModuleRules object as its own test module.
Constructs a TestModuleRules object as its own test module.
Sets value of bUsesCatch2.
Constructs a TestModuleRules object with an associated tested module.
Set test-specific resources folder relative to module directory.
This will be copied to the binaries path during deployment.
Deprecated, test metadata now generated explicitly using -Mode-Test with -GenerateMetadata.
Generates or updates metadata file for LowLevelTests.xml containing test flags: name, short name, target name, relative binaries path, supported platforms etc.
Called by RunUBT.bat -Mode=Test -GenerateMetadata
Test metadata class.
Test long name.
Test short name used for display in build system.
Type of Catch2 report, defaults to console.
Does this test use project files for staging additional files
and cause the build to use BuildCookRun instead of a Compile step
Is this test deactivated?
Depercated, use GauntletArgs or ExtraArgs instead to help indicate arguments to launch the test under.
Any initial Gauntlet args to be passed to the test executable
Any extra args to be passed to the test executable as --extra-args
Whether there's a step that gets executed after the tests have finished.
Typically used for cleanup of resources.
Test built with a frakework other than Catch2
Set of supported platforms.
Per-platform tags.
Per-platform gauntlet args.
Per-platform extra compilation arguments.
List of platforms that cannot run tests.
Whether or not the test is run inside a Docker container for a given platform.
TargetRules extension for low level tests.
Configuration mapping to control build graph test metadata generation during project files generation.
Keeps track if low level tests executable must build with the Editor.
Keeps track if low level tests executable must build with the Engine.
Keeps track if low level tests executable must build with the ApplicationCore.
Keeps track if low level tests executable must build with the CoreUObject.
Associated tested target of this test target, if defined.
Test target override for bCompileAgainstApplicationCore.
It is set to true if there is any reference to ApplicationCore in the dependency graph.
If set to true, it will not compile against ApplicationCore even if "ApplicationCore" is in the dependency graph.
Test target override for bCompileAgainstCoreUObject.
It is set to true if there is any reference to CoreUObject in the dependency graph.
If set to true, it will not compile against CoreUObject even if "CoreUObject" is in the dependency graph.
Test target override for bCompileAgainstEngine.
It is set to true if there is any reference to Engine in the dependency graph.
If set to true, it will not compile against engine even if "Engine" is in the dependency graph.
Test target override for bCompileAgainstEditor.
It is set to true if there is any reference to UnrealEd in the dependency graph.
If set to true, it will not compile against editor even if "UnrealEd" is in the dependency graph.
Whether to stub the platform file.
Whether to mock engine default instances for materials, AI controller etc.
Constructor that explicit targets can inherit from.
Constructs a valid TestTargetRules instance from an existent TargetRules instance.
Constructor for TestTargetRules based on existing target a.k.a Implicit test target.
TestTargetRules is setup as a program and is linked monolithically.
It removes a lot of default compilation behavior in order to produce a minimal test environment.
All binary types generated by UBT
An executable
A dynamic library (.dll, .dylib, or .so)
A static library (.lib or .a)
Object files
Precompiled header
A binary built by UBT.
The type of binary to build
Output directory for this binary
The output file path. This must be set before a binary can be built using it.
Returns the OutputFilePath if there is only one entry in OutputFilePaths
The intermediate directory for this binary. Modules should create separate intermediate directories below this. Must be set before a binary can be built using it.
If true, build exports lib
If true, create a separate import library
If true, creates an additional console application. Hack for Windows, where it's not possible to conditionally inherit a parent's console Window depending on how
the application is invoked; you have to link the same executable with a different subsystem setting.
If true, replaces the executable with a console application. Hack for Windows, where it's not possible to conditionally inherit a parent's console Window depending on how
the application is invoked
The primary module that this binary was constructed for. For executables, this is typically the launch module.
List of modules to link together into this executable
Cached list of dependent link libraries.
Expanded list of runtime dependencies generated by calling PrepareRuntimeDependencies.
If compiled objects will have unused exports stripped, only affects objects compiled into modular libraries.
List of all objects that would be linked.
Create an instance of the class with the given configuration data
Creates all the modules referenced by this target.
Expands all of the runtime dependencies.
Output directory for the executable
Builds the binary.
Rules for the target being built
The toolchain which to use for building
The environment to compile the binary in
The environment to link the binary in
The working set of source files
Directory containing the output executable
The graph being built
Logger for output
Set of built products
Gets all the runtime dependencies Copies all the runtime dependencies from any modules in
The output list of runtime dependencies, mapping target file to type
Map of target files to source files that need to be copied
Called to allow the binary to modify the link environment of a different binary containing
a module that depends on a module in this binary.
The link environment of the dependency
Called to allow the binary to find game modules.
The OnlyModule if found, null if not
Generates a list of all modules referenced by this binary
True if dynamically loaded modules (and all of their dependent modules) should be included.
True if circular dependencies should be process
List of all referenced modules
Generates a list of all modules referenced by this binary
Map of module to the module that referenced it
List of all referenced modules
Sets whether to create a separate import library to resolve circular dependencies for this binary
True to create a separate import library
Adds a module to the binary.
The module to add
Gets all build products produced by this binary
The target being built
The platform toolchain
Mapping of produced build product to type
Whether debug info is enabled for this binary
Adds a build product and its associated debug file to a receipt.
Build product to add
The type of built product
Extensions for the matching debug file (may be null).
Map of build products to their type
The toolchain used to build these binaries
Whether creating debug info is enabled
Enumerates resources which the toolchain may need may produced additional build products from. Some platforms (eg. Mac, Linux) can link directly
against .so/.dylibs, but they are also copied to the output folder by the toolchain.
List to which libraries required by this module are added
List of bundle resources required by this module
Helper function to get the console app BinaryName-Cmd.exe filename based on the binary filename.
Full path to the binary exe.
Checks whether the binary output paths are appropriate for the distribution
level of its direct module dependencies
Write information about this binary to a JSON file
Writer for this binary's data
ToString implementation
Returns the OutputFilePath for this binary
Base class to handle deploy of a target for a given platform
Prepare the target for deployment
Receipt for the target being deployed
True if successful, false if not
Represents a Mac/IOS framework
The name of this framework
Path to a zip file containing the framework. May be null.
Path where the zip should be extracted. May be null.
Base path to the framework on disk.
Link the framework libraries into the executable
Copy the framework to the target's Framework directory
File created after the framework has been extracted. Used to add dependencies into the action graph, used by Modern Xcode as well
For legacy xcode projects, we unzip in UBT (isntead of xcode), so we track if we've made an action for this framework yet (if two
modules use the same framework, we only want to unzip it once. Other than time waste, there could be conflicts
List of variants contained in this XCFramework. Only non null for XCFrameworks
Constructor
The framework name
Constructor
The framework name
Path to the zip file for this framework/xcframework
Path for the extracted zip file
Link the framework into the executable
Copy the framework to the target's Framework directory
Logger for diagnostic output
Constructor
The framework name
Path for the framework/xcframework on disk
Link the framework into the executable
Copy the framework to the target's Framework directory
Logger for diagnostic output
Gets the framework directory for given build settings
Logger for diagnostic output
Loads XCFramework variants description from Info.plist file inside XCFramework structure
Logger for diagnostic output
Loads XCFramework variants description from Info.plist file inside the zipped XCFramework structure
Logger for diagnostic output
Loads XCFramework variants description from Info.plist inside XCFramework structure loaded in a XmlDocument
XmlDocument containing Info.plist that defines the xcframework settings
Logger for diagnostic output
Represents a XCFramework variant description
Identifier of this framework variant. Is in the form platform-architectures-platformvariant.
Some examples would be ios-arm64, ios-arm64_x86_64-simulator
It also represents the relative path inside the XCFramefork where the Framework for this variant resides
Relative path where framework lives after applying LibraryIdentifier path
List of supported architectures for this Framework variants
Platform this Framework variant is intended for. Possible values are ios, macos, watchos, tvos
Platform variant for this Framework variant. It can be empty or any other value representing a platform variane, like maccatalyst or simulator
Constructor
Returns wether this variant is a match for given platform and architecture
Creates a XCFrameworkVariantEntry by parsing the content from the XCFramework Info.plist file
XmlNode loaded form Info.plist containing the representation of a <dict> that contains the variant description
Logger for diagnostic output
Parses the content from a string value node in a plist file
XmlNode we expect to contain a <string> value
Logger for diagnostic output
Parses the content from an array value node in a plist file that has several string entries
XmlNode we expect to contain a <array> value with several <string> entries
Logger for diagnostic output
A unit of code compilation and linking.
The rules for this module
The directory for this module's object files
The directory for this module's generated files that are architecture independent
The name that uniquely identifies the module.
Path to the module directory
Paths to all potential module source directories (with platform extension directories added in)
The name of the .Build.cs file this module was created from, if any
The binary the module will be linked into for the current target. Only set after UEBuildBinary.BindModules is called.
The name of the _API define for this module
Set of all the public definitions
Set of all public include paths
Set of all internal include paths
Nested public include paths which used to be added automatically, but are now only added for modules with bNestedPublicIncludePaths set.
Parent include paths which used to be added automatically, but are now only added for modules with bLegacyParentIncludePaths set.
Set of all private include paths
Set of all system include paths
Set of all additional libraries
Set of all system libraries
Set of all public system library paths
Set of additional frameworks
Names of modules with header files that this module's public interface needs access to.
Names of modules that this module's public interface depends on.
Names of DLLs that this module should delay load
Names of modules with header files that this module's private implementation needs access to.
Names of modules that this module's private implementation depends on.
Extra modules this module may require at run time
Set of modules that have referenced this module
Set of all allowed restricted folder references
Set of aliased restricted folder references
Per-architecture lists of dependencies for linking to ignore (useful when building for multiple architectures, and a lib only is needed for one architecture), it's up to the Toolchain to use this
The Verse source code directory associated with this module if any
If this module has Verse code associated with it (convenience function)
If this module or any of its dependencies has Verse code associated with it
Set of debug visualizer paths
Constructor
Rules for this module
Intermediate directory for this module
Intermediate directory for this module for files that are architecture independent
Logger for output
Log a warning or throw an error message
Determines if a file is part of the given module
Path to the file
True if the file is part of this module
Returns a list of this module's dependencies.
An enumerable containing the dependencies of the module.
Returns a list of this module's frameworks.
A List containing the frameworks this module requires.
Returns a list of this module's immediate dependencies.
An enumerable containing the dependencies of the module.
Converts an optional string list parameter to a well-defined hash set.
Converts an optional string list parameter to a well-defined hash set.
Determines whether this module has a circular dependency on the given module
Enumerates additional build products which may be produced by this module. Some platforms (eg. Mac, Linux) can link directly against .so/.dylibs, but they
are also copied to the output folder by the toolchain.
List to which libraries required by this module are added
List of bundle resources required by this module
Determines the distribution level of a module based on its directory and includes.
The set of additional paths to check, if available
Map of the restricted folder types to the first found instance
Finds all the directories that this folder references when building
Set of directories to add to
Find all the modules which affect the private compile environment.
Find all the modules which affect the public compile environment.
Find all the modules which affect the public compile environment. Searches through
Add definitions from source to target. This code also reformats defines to match strict rules which does not allow space before and after '='
Sets up the environment for compiling any module that includes the public interface of this module.
Sets up the environment for compiling this module.
Expand path variables within the context of this module
Path to expand variables within
Directory containing the binary that links this module. May be mull.
Directory containing the output executable. May be null.
The path with variables expanded
Match a variable name within a path
The path variable
Start index of the substring to match
End index of the substring to match
Variable name to compare against
True if the variable name matches
Expand path variables within the context of this module
Path to expand variables within
Directory containing the binary that links this module. May be mull.
Directory containing the output executable. May be null.
The path with variables expanded
Sets up the environment for linking any module that includes the public interface of this module.
Sets up the environment for linking this module.
Compiles the module, and returns a list of files output by the compiler.
Finds the modules referenced by this module which have not yet been bound to a binary
List of unbound modules
Gets all of the modules referenced by this module
Hash of all referenced modules with their addition index.
Hashset used to ignore modules which are already added to the list
True if dynamically loaded modules (and all of their dependent modules) should be included.
True if circular dependencies should be processed
True to return only this module's direct dependencies
Gathers all the module dependencies a PCH would have
Whether to include private modules.
True if circular dependencies should be processed
Internal function that gathers all the module dependencies a PCH would have
Hash of all referenced modules with their addition index.
Hashset used to ignore modules which are already added to the list
Whether to include private modules.
True if circular dependencies should be processed
Public entry point to recursively create a module and all its dependencies
Creates all the modules required for this target
Delegate to create a module with a given name
Chain of references before reaching this module
Stack of module dependencies that led to this module
Logger for output
Public entry point to validate a module
Recursively check a module for circular dependencies
Chain of references before reaching this module
Stack of module dependencies that led to this module
Logger for output
Returns valueless API defines (like MODULE_API)
Write information about this binary to a JSON file
The output directory for the binary containing this module
The output directory for the target executable
Writer for this binary's data
Write an array of module names to a JSON writer
Writer for the array data
Name of the array property
Sequence of modules to write. May be null.
Write an array of strings to a JSON writer
Writer for the array data
Name of the array property
Sequence of strings to write. May be null.
Returns a copy of Nodes sorted by dependency. Independent or circularly-dependent nodes should
remain in their same relative order within the original Nodes sequence.
The list of nodes to sort.
A module that is compiled from C++ code.
Stores a list of all source files, of different types
Instance where a CPP file doesn't include the expected header as the first include.
If UHT found any associated UObjects in this module's source files
The directory for this module's generated code
The directory for this module's generated UHT code
The directory for this module's generated VNI code
Global override to force all include paths to be always added
Paths containing *.gen.cpp files for this module. If this is null then this module doesn't have any generated code.
List of invalid include directives. These are buffered up and output before we start compiling.
Set of source directories referenced during a build
Verse source code directory associated with this module
The Verse source code directory associated with this module if any
List of allowed circular dependencies. Please do NOT add new modules here; refactor to allow the modules to be decoupled instead.
Determines if a file is part of the given module
Path to the file
True if the file is part of this module
Add the default include paths for this module to its settings
Enumerates legacy include paths under a given base directory
The directory to start from. This directory is not added to the output list.
Set of folder names to exclude from the search.
List populated with the discovered directories
Path to the precompiled manifest location
Sets up the environment for compiling any module that includes the public interface of this module.
Gets the list of module dependencies that this module declares and then tries to optimize the list to what is actually used by the header.
Compile environment for this PCH
PCH header file
Logger for output
Returns an optimized list of modules this module's shared PCH uses
Create a shared PCH template for this module, which allows constructing shared PCH instances in the future
The target which owns this module
Base compile environment for this target
Logger for output
Template for shared PCHs
Creates a precompiled header action to generate a new pch file
The toolchain to generate the PCH
List of actions to be executed. Additional actions will be added to this list.
The created PCH instance.
Generates a precompiled header instance from the given template, or returns an existing one if it already exists
The toolchain being used to build this module
The PCH template
Compile environment for the current module
List of actions to be executed. Additional actions will be added to this list.
Instance of a PCH
Determines if a module compile environment is compatible with the given shared PCH compile environment
The module compile environment
The shared PCH compile environment
True if the two compile enviroments are compatible
Gets the unique suffix for a shared PCH
The shared PCH compile environment
The base compile environment
The unique suffix for the shared PCH
Copy settings from the module's compile environment into the environment for the shared PCH
The module compile environment
The shared PCH compile environment
Compiles the provided CPP unity files. Will
Configure precompiled headers for this module
The target being built
The toolchain to build with
The current compile environment
List of files that will be linked for the target
List of build actions
Logger for output
Creates a header file containing all the preprocessor definitions for a compile environment, and force-include it. We allow a more flexible syntax for preprocessor definitions than
is typically allowed on the command line (allowing function macros or double-quote characters, for example). Ensuring all definitions are specified in a header files ensures consistent
behavior.
The compile environment
Directory to create the intermediate file
Suffix for the included file
The action graph being built
Creates header files from ISPC for inclusion and adds them as dependencies.
The toolchain to generate the PCH
Compile environment
List of ISPC source files
Directory to create the intermediate file
List of actions to be executed. Additional actions will be added to this list.
Create a header file containing the module definitions, which also includes the PCH itself. Including through another file is necessary on
Clang, since we get warnings about #pragma once otherwise, but it also allows us to consistently define the preprocessor state on all
platforms.
The output file to create
File containing definitions required by the PCH
The PCH file to include
The action graph builder
FileItem for the created file
Write a list of macro definitions to an output file
Additional context to add to generated comment
List of includes
List of definitions
List of definitions to undefine
Writer to receive output
Checks that the first header included by the source files in this module all include the same header
The target being compiled
Compile environment for the module
All header files for this module
List of C++ source files
Determine whether optimization should be enabled for a given target
The optimization setting from the rules file
The active target configuration
Whether the current module is an engine module
Whether the current module should be compiled with code coverage support
True if optimization should be enabled
Creates a compile environment from a base environment based on the module settings.
Rules for the target being built
An existing environment to base the module compile environment on.
Logger for output
The new module compile environment.
Creates a compile environment for a shared PCH from a base environment based on the module settings.
The target being built
An existing environment to base the module compile environment on.
The new shared PCH compile environment.
Finds all the source files that should be built for this module
The platform the module is being built for
Map of directory to source files inside it
Logger for output
Set of source files that should be built
Finds all the source files that should be built for this module
Directory to search from
Set of excluded directory names (eg. other platforms)
Set of all non-empty source directories.
Map from directory to source files inside it
Collection of source files, categorized by type
Logger for output
Finds the input files that should be built for this module, from a given directory
Logger for output
Array of source files
Gets a set of source files for the given directory. Used to detect when the makefile is out of date.
Logger for output
Array of source files
Gets a set of source files and headers for the given directory. Used to detect when the makefile is out of date due to a new directory
Logger for output
Array of source files and headers
Checks a given directory path whether it exists and if it contains any Verse source files
A module that is never compiled by us, and is only used to group include paths and libraries into a dependency unit.
Enum for the different ways a platform can support multiple architectures within UnrealBuildTool
This platform only supports a single architecture (consoles, etc)
This platform needs separate targets per architecture (compiling for multiple will compile two entirely separate set of source/exectuable/intermediates)
This will create a single target, but compile each source file separately
This will create a single target, but compile each source file and link the executable separately - but then packaged together into one final output
Full architecture configuation information for a platform. Can be found by platform with UnrealArchitectureConfig.ForPlatform(), or UEBuildPlatform.ArchitectureConfig
Get the architecture configuration object for a given platform
Get all known ArchitectureConfig objects
The multi-architecture mode for this platform (potentially single-architecture)
The set of all architecture this platform supports. Any platform specified on the UBT commandline not in this list will be an error
This determines what architecture(s) to compile/package when no architeecture is specified on the commandline
Like ProjectSupportedArchitectures, except when building in distribution mode. Defaults to ActiveArchitectures
Returns the set all architectures potentially supported by this project. Can be used by project file gnenerators to restrict IDE architecture options
Defaults to AllSupportedArchitectures
Returns if architecture name should be used when making intermediate directories, per-architecture filenames, etc
It is virtual, so a platform can choose to skip architecture name for one platform, but not another
Convert user specified architecture strings to what the platform wants
Get name for architecture-specific directories (can be shorter than architecture name itself)
Get name for architecture-specific directories (can be shorter than architecture name itself)
Returns the architecture of the currently running OS (only used for desktop platforms, so will throw an exception in the general case)
Simple constructor for platforms with a single architecture
Full constructor for platforms that support multiple architectures
The corresponding target platform enum
The configuration about the architecture(s) this platform supports
Logger for this platform
All the platform folder names
Cached copy of the list of folders to include for this platform
Cached copy of the list of folders to exclude for this platform
Constructor.
The enum value for this platform
The SDK management object for this platform
THe architecture configuraton for this platform. This is returned by UnrealArchitectureConfig.ForPlatform()
Logger for output
Finds all the UEBuildPlatformFactory types in this assembly and uses them to register all the available platforms, and uses a UBT commandline to check for per-project SDKs
Whether to register platforms that are not installed
Only register the host platform
Commandline args to look through for finding uprojects, to look up per-project SDK versions
The UBT mode (usually Build, but
Logger for output
Finds all the UEBuildPlatformFactory types in this assembly and uses them to register all the available platforms, and uses a UAT commandline to check for per-project SDKs
Whether to register platforms that are not installed
Only register the host platform
Commandline args to look through for finding uprojects, to look up per-project SDK versions
Logger for output
Gets an array of all platform folder names
Array of platform folders
Finds a list of folder names to include when building for this platform
Finds a list of folder names to exclude when building for this platform
Whether the required external SDKs are installed for this platform. Could be either a manual install or an AutoSDK.
Whether this platform requires specific Visual Studio version.
The version required to support Visual Studio
Gets all the registered platforms
Sequence of registered platforms
Searches a directory tree for build products to be cleaned.
The directory to search
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
List to receive a list of files to be cleaned
List to receive a list of directories to be cleaned
Enumerates any additional directories needed to clean this target
The target to clean
Receives a list of files to be removed
Receives a list of directories to be removed
Determines if a filename is a default UBT build product
The name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the substring matches the name of a build product, false otherwise
Determines if the given name is a build product for a target.
The name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the string matches the name of a build product, false otherwise
Determines if a string is in the canonical name of a UE build product, with a specific extension (eg. "UnrealEditor-Win64-Debug.exe" or "UnrealEditor-ModuleName-Win64-Debug.dll").
The file name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
The extension to check for
True if the string matches the name of a build product, false otherwise
Determines if a substring is in the canonical name of a UE build product, with a specific extension (eg. "UnrealEditor-Win64-Debug.exe" or "UnrealEditor-ModuleName-Win64-Debug.dll").
The name to check
Index of the first character to be checked
Number of characters of the substring to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
The extension to check for
True if the substring matches the name of a build product, false otherwise
Determines if a substring is in the canonical name of a UE build product, excluding extension or other decoration (eg. "UnrealEditor-Win64-Debug" or "UnrealEditor-ModuleName-Win64-Debug").
The name to check
Index of the first character to be checked
Number of characters of the substring to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the substring matches the name of a build product, false otherwise
Get the bundle directory for the shared link environment
The target rules
List of executable output files
Path to the bundle directory
Determines whether a given platform is available
The platform to check for
Ignore the sdks presence when checking for platform availablity (many platforms can be cooked as a target platform without requiring sdk)
True if it's available, false otherwise
Determines whether a given platform is available in the context of a particular Taget
The platform to check for
A Target object that may further restrict available platforms
Ignore the sdks presence when checking for platform availablity (many platforms can be cooked as a target platform without requiring sdk)
True if it's available, false otherwise
Register the given platforms UEBuildPlatform instance
The UEBuildPlatform instance to use for the InPlatform
Logger for output
Assign a platform as a member of the given group
Retrieve the list of platforms in this group (if any)
Enumerates all the platform groups for a given platform
The platform to look for
List of platform groups that this platform is a member of
Retrieve the IUEBuildPlatform instance for the given TargetPlatform
The UnrealTargetPlatform being built
UEBuildPlatform The instance of the build platform
Retrieve the IUEBuildPlatform instance for the given TargetPlatform
The UnrealTargetPlatform being built
UEBuildPlatform The instance of the build platform
Allow all registered build platforms to modify the newly created module
passed in for the given platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Returns the delimiter used to separate paths in the PATH environment variable for the platform we are executing on.
Gets the platform name that should be used.
If this platform can be compiled with XGE
If this platform can be compiled with FASTBuild
If this platform can be compiled with SN-DBS
Set all the platform-specific defaults for a new target
Validate a target's settings
Validate a plugin's settings
Validate a UEBuildModule before it's processed
The UEBuildModule that needs to be validated
Options for the target being built
Validate a UEBuildModule's include paths before it's processed
The UEBuildModule that needs to be validated
Options for the target being built
Other modules to validate against, if needed
Return whether the given platform requires a monolithic build
The platform of interest
The configuration of interest
Get the extension to use for the given binary type
The binary type being built
string The binary extension (i.e. 'exe' or 'dll')
Get the extensions to use for debug info for the given binary type
Options for the target being built
The binary type being built
string[] The debug info extensions (i.e. 'pdb')
Whether this platform should build a monolithic binary
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
For platforms that need to output multiple files per binary (ie Android "fat" binaries)
this will emit multiple paths. By default, it simply makes an array from the input
Return all valid configurations for this platform
Typically, this is always Debug, Development, and Shipping - but Test is a likely future addition for some platforms
Check for the default configuration
return true if the project uses the default build config
Check for whether we require a build for platform reasons
return true if the project requires a build
Get a list of extra modules the platform requires.
This is to allow undisclosed platforms to add modules they need without exposing information about the platform.
The target being build
List of extra modules the platform needs to add to the target
Modify the rules for a newly created module, in a target that's being built for this platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Setup the configuration environment for building
The target being built
The global compile environment
The global link environment
Allows the platform to return various build metadata that is not tracked by other means. If the returned string changes, the makefile will be invalidated.
The project file being built
String describing the current build metadata
Allows the platform to return various build metadata that is not tracked by other means. If the returned string changes, the makefile will be invalidated.
The project file being built
String builder to contain build metadata
Allows the platform to modify the binary link environment before the binary is built
The binary link environment being created
The binary compile environment being used
The target rules in use
The toolchain being used
Action graph that is used to build the binary
Indicates whether this platform requires a .loadorder file to be generated for the build.
.loadorder files contain a list of dynamic modules and the exact order in which they should be loaded
to ensure that all dependencies are satisfied i.e. we don't attempt to load a module without loading
all its dependencies first.
As such, this file is only needed in modular builds on some platforms (depending on the way they implement dynamic modules such as DLLs).
The target rules in use
True if .loadorder file should be generated
Checks if platform is part of a given platform group
The platform to check
The platform group to check
True if platform is part of a platform group
Gets the SDK object that was passed in to the constructor
The SDK object
Gets the SDK object that was passed in to the constructor to the UEBuildPlatform constructor for this platform
The SDK object
Whether this platform should create debug information or not
The target being built
bool true if debug info should be generated, false if not
Creates a toolchain instance for this platform. There should be a single toolchain instance per-target, as their may be
state data and configuration cached between calls.
The target being built
New toolchain instance.
Deploys the given target
Receipt for the target being deployed
Factory class for registering platforms at startup
Gets the target platform for an individual factory
Register the platform with the UEBuildPlatform class
Stores information about a plugin that is being built for a target
Information about the plugin
Modules that this plugin belongs to
Recursive
Whether the descriptor for this plugin is needed at runtime; because it has modules or content which is used, or because it references another module that does.
Whether this descriptor is referenced non-optionally by something else; a project file or other plugin. This is recursively applied to the plugin's references.
Chain of references to this plugin
Constructor
The static plugin information
Chain of references to this plugin
Accessor for the name of this plugin
Accessor for the file for this plugin
Accessor for the child files for this plugin
Accessor for the type of the plugin
Accessor for this plugin's root directory
Accessor for this plugin's descriptor
Returns the name of this plugin for debugging
Name of the plugin
Public entry point to validate a module
true if there are any fatal errors
The platform we're building for
Return the single instance of the Group with this name
Return the single instance of the Group with this name
///
Return the string representation
Helper that just calls UEBuildPlatform.IsPlatformInGroup
Helper that just calls UEBuildPlatform.IsPlatformInGroup
64-bit Windows
Mac
iOS
Android
Linux
LinuxArm64
TVOS
VisionOS
Playstation 4
Playstation 5
Nintendo Switch
Adds WinGDK as a target platform identifier
Adds XB1 as a target platform identifier
legacy XboxOneGDK platform - for stale build graph parsing only
Adds XSX as a target platform identifier
Extension methods used for serializing UnrealTargetPlatform instances
Read an UnrealTargetPlatform instance from a binary archive
Archive to read from
New UnrealTargetPlatform instance
Write an UnrealTargetPlatform instance to a binary archive
The archive to write to
The platform to write
Platform groups
Return the single instance of the Group with this name
Return the string representation
this group is just to lump Win32 and Win64 into Windows directories, removing the special Windows logic in MakeListOfUnsupportedPlatforms
Microsoft platforms
Apple platforms
making IOS a group allows TVOS to compile IOS code
Unix platforms
Linux platforms
Android platforms
Desktop group - used by UnrealPlatformClass.Desktop
SDLPlatform is for platforms that use SDL for windows, cursors, etc
30Hz is for platforms that typically run at 30Hz (Android, Switch) vs. the baseline 60Hz
POSIX-compliant platforms
Add GDK to the known platform groups
Nintendo group
Sony platforms
XboxCommon group
The architecture we're building for
Return the single instance of the Group with this name
True if X64, false if not, or null if it's Default and will ask the platform later
Returns true if the architecure is X64 based
Return the string representation
64-bit x86/intel
64-bit arm
Used in place when needing to handle deprecated architectures that a licensee may still have. Do not use in normal logic
Maps to the currently running architecture on the host platform (lazy because this needs other classes to be intialized)
IOS Simulator
TVOS Simulator
Apple-specific low level name for the generic platforms
Returns the low-architecture specific string for the generic architectures
Version of Arm64 that can interop with X64 (Emulation Compatible)
Windows-specific tool chain to compile with
Windows-specific lib directory for this architecture
Windows-specific system lib directory for this architecture
Windows-specific low level name for the generic platforms
A collection of one or more architecetures
Construct a UnrealArchitectures object from a list of Architectures
Construct a UnrealArchitectures object from a list of string Architectures
Construct a UnrealArchitectures object from a single Architecture
Construct a UnrealArchitectures object from a single string Architecture
Construct a UnrealArchitectures object from another one
Creates an UnrealArchitectures from a string (created via ToString() or similar)
The list of architecture names in this set, sorted by architecture name
Gets the Architecture in the normal case where there is a single Architecture in Architectures, or throw an Exception if not single
True if there is is more than one architecture specified
Gets the Architectures list as a + delimited string
Convenience function to check if the given architecture is in this set
The class of platform. See Utils.GetPlatformsInClass().
All platforms
All desktop platforms (Win32, Win64, Mac, Linux)
All platforms which support the editor (Win64, Mac, Linux)
Platforms which support running servers (Win32, Win64, Mac, Linux)
The type of configuration a target can be built for. Roughly order by optimization level.
Unknown
Debug configuration
DebugGame configuration; equivalent to development, but with optimization disabled for game modules
Development configuration
Test configuration
Shipping configuration
Intermediate environment. Determines if the intermediates end up in a different folder than normal.
Default environment
Generate clang database environment is non unity and needs it own environment
Include what you use
Nonunity
Static code analysis
Query
Generate project files
Extension methods for UnrealIntermediateEnvironment enum
Returns if this environment should default to a unity build
The environment to check
true if shold build unity by default
A container for a binary files (dll, exe) with its associated debug info.
A target that can be built
Creates a target object for the specified target name.
Information about the target
Build configuration
Logger for output
Creates a target object for the specified target name.
Information about the target
Logger for output
Creates a target object for the specified target name.
Information about the target
Logger for output
Creates a target object for the specified target name.
Information about the target
Whether to skip compiling any rules assemblies
Whether to always compile all rules assemblies
Whether to use a precompiled engine build
Intermediate environment to use
Logger for output
The build target object for the specified build rules source file
Validates that the build environment matches the shared build environment, by comparing the TargetRules instance to the vanilla target rules for the current target type.
Validate all plugins
true if there are any fatal errors
Validates a plugin
true if there are any fatal errors
Validates all plugins
true if there are any fatal errors
Validates a module
true if there are any fatal errors
The target rules
The rules assembly to use when searching for modules
Cache of source file metadata for this target
The project file for this target
The project descriptor for this target
Type of target
The name of the application the target is part of. For targets with bUseSharedBuildEnvironment = true, this is typically the name of the base application, eg. UnrealEditor for any game editor.
The name of the target
Whether the target uses the shared build environment. If false, AppName==TargetName and all binaries should be written to the project directory.
Platform as defined by the VCProject and passed via the command line. Not the same as internal config names.
Target as defined by the VCProject and passed via the command line. Not necessarily the same as internal name.
The architecture this target is being built for
Intermediate environment. Determines if the intermediates end up in a different folder than normal.
Relative path for platform-specific intermediates (eg. Intermediate/Build/Win64/x64)
Relative path for platform-specific intermediates that explicitly do not need an architeecture (eg. Intermediate/Build/Win64)
Root directory for the active project. Typically contains the .uproject file, or the engine root.
Default directory for intermediate files. Typically underneath ProjectDirectory.
Default directory for intermediate files. Typically underneath ProjectDirectory.
Directory for engine intermediates. For an agnostic editor/game executable, this will be under the engine directory. For monolithic executables this will be the same as the project intermediate directory.
All plugins which are built for this target
All plugin dependencies for this target. This differs from the list of plugins that is built for Launcher, where we build everything, but link in only the enabled plugins.
Specifies the path to a specific plugin to compile.
When building a foreign plugin, whether to build plugins it depends on as well.
Collection of all UBT plugins (project files)
Collection of all enabled UBT plugins (project files)
Collection of all enabled UHT plugin assemblies
All application binaries; may include binaries not built by this target.
Kept to determine the correct module parsing order when filtering modules.
true if target should be compiled in monolithic mode, false if not
Used to keep track of all modules by name.
Filename for the receipt for this target.
The name of the .Target.cs file, if the target was created with one
Whether to deploy this target after compilation
Whether this target should be compiled in monolithic mode
true if it should, false if it shouldn't
Whether this target was compiled with an overridden sdk (usually from a platform .ini specifying an alternate SDK version)
Constructor.
Target descriptor
The target rules, as created by RulesCompiler.
The chain of rules assemblies that this target was created with
Logger for output
Gets the intermediate directory for a given platform
Platform to get the folder for
Architectures to get the folder for
Insert External after Intermediate - for out-of-tree plugins
The output directory for intermediates
Adjusts a target name to be a usable intermediate folder name.
Base target name
Intermediate environment to use
Gets the app name for a given target type
The target type
The app name for this target type
Writes a list of all the externally referenced files required to use the precompiled data for this target
Path to the dependency list
List of all the runtime dependencies for this target
Map of runtime dependencies to their location in the source tree, before they are staged
Logger for output
Generates a public manifest file for writing out
Prepare all the module manifests for this target
Dictionary mapping from filename to module manifest
Prepare all the receipts this target (all the .target and .modules files). See the VersionManifest class for an explanation of what these files are.
The toolchain used to build the target
Artifacts from the build
Output runtime dependencies
Gathers dependency modules for given binaries list.
Binaries list.
Dependency modules set.
Creates a global compile environment suitable for generating project files.
New compile environment
Builds the target, appending list of output files and returns building result.
Gets the output directory for the main executable
The executable directory
Check that copying a file from one location to another does not violate rules regarding restricted folders
The destination location for the file
The source location of the file
Logger for output
True if the copy is permitted, false otherwise
Gets the restricted folders that the given file is in
The file to test
List of restricted folders for the file
Creates a toolchain for the current target. May be overridden by the target rules.
New toolchain instance
Cleans any stale modules that have changed moved output folder.
On Windows, the loader reads imported DLLs from the first location it finds them. If modules are moved from one place to another, we have to be sure to clean up the old versions
so that they're not loaded accidentally causing unintuitive import errors.
Check whether a reference from an engine module to a plugin module is allowed. 'Temporary' hack until these can be fixed up properly.
Name of the engine module.
Name of the plugin module.
True if the reference is allowed.
Export the definition of this target to a JSON file
File to write to
List of actions to export
Writes a header for the given binary that allows including headers from it in an external application
Binary to write a header for
Path to the header to output
The global compile environment for this target
Check for EULA violation dependency issues.
Tells if this module can be redistributed.
Dynamically merge modules into libraries based on target settings
Setup target before build. This method finds dependencies, sets up global environment etc.
Creates scripts for executing the pre-build scripts
Creates scripts for executing post-build steps
Array of post-build scripts
Adds custom build steps from the given JSON object to the list of command batches
The custom build steps
The plugin to associate with these commands
List to receive the command batches
Gets a list of variables that can be expanded in paths referenced by this target
The current plugin
Map of variable names to values
Write scripts containing the custom build steps for the given host platform
The current host platform
The output directory for the scripts
Bare prefix for all the created script files
List of custom build steps, and their matching PluginInfo (if appropriate)
List of created script files
Finds a list of module names which can be hot-reloaded
Set of module names
Determines which modules can be used to create shared PCHs
The list of binaries
The compile environment. The shared PCHs will be added to the SharedPCHs list in this.
Logger for output
Creates all the shared PCH instances before processing the modules
The target being built
The toolchain to build with
The list of binaries
The compile environment. The shared PCHs will be added to the SharedPCHs list in this.
Logger for output
List of build actions
When building a target, this is called to add any additional modules that should be compiled along
with the main target. If you override this in a derived class, remember to call the base implementation!
Adds all the precompiled modules into the target. Precompiled modules are compiled alongside the target, but not linked into it unless directly referenced.
Gets the output directory for a target
The base directory for output files
Path to the target file
The output directory for this target
Finds the base output directory for build products of the given module
The rules object created for this module
The base output directory for compiled object files for this module
Finds the base output directory for a module
The rules object created for this module
The architectures (or none) to insert into the directory structure
The output directory for compiled object files for this module
Adds a dynamic library for the given module. Does not check whether a binary already exists, or whether a binary should be created for this build configuration.
The module to create a binary for
The new binary. This has not been added to the target.
Adds a dynamic library for the given set of modules. Does not check whether a binary already exists, or whether a binary should be created for this build configuration.
The name of the merged binary
The modules to create a binary for
The new binary. This has not been added to the target.
Makes a filename (without path) for a compiled binary (e.g. "Core-Win64-Debug.lib") */
The name of this binary
The separator for a decorated filename
The platform being built for
The configuration being built
The target architectures being built
The target configuration which doesn't require a platform and configuration suffix. Development by default.
Type of binary
Name of the binary
Determine the output path for a target's executable
The base directory for the executable; typically either the engine directory or project directory.
Name of the binary
Target platform to build for
Target configuration being built
Architectures being built
The type of binary we're compiling
The configuration which doesn't have a "-{Platform}-{Configuration}" suffix added to the binary
Whether this executable contains game modules
Subfolder for executables. May be null.
The project file containing the target being built
Rules for the target being built
List of executable paths for this target
Sets up the uproject modules for this target
Sets up the plugins for this target
Modify a module rules based on the current target, be very careful not to violate the shared environment!
name of the module
the module's rules
Creates a plugin instance from a reference to it
Reference to the plugin
Textual representation of the chain of references, for error reporting
Array of folder names to be excluded
Map from plugin name to instance of it
Map from plugin name to information
Logger for diagnostic output
Instance of the plugin, or null if it should not be used
Checks whether a plugin path contains a platform directory fragment
Scan for UBT plugins. This also detects if the current target has a C++ style UHT that don't have
an associated UBT/UHT plugin. When this happens, the old UHT must be used.
Sets up the binaries for the target.
Sets up the global compile and link environment for the target.
Create a rules object for the given module, and set any default values for this target
Utility function to remove trailing slashes from a list of paths
List of paths to process
Determines the relative base directory path from the specified Binary directory to the Engine base directory if possible.
Directory that contains the platform subdirectoies for each UBT built binary
Platform that the binary is for
A string specifying the relative path from the binary directory to the engine base dir, or null if this isn't contained within the engine hierarhcy
Finds a module given its name. Throws an exception if the module couldn't be found.
Name of the module
Chain of references causing this module to be instantiated, for display in error messages
Logger for output
Constructs a new C++ module
Name of the module
Chain of references causing this module to be instantiated, for display in error messages
Logger for output
New C++ module
Normalize an include path to be relative to the engine source directory
Finds a module given its name. Throws an exception if the module couldn't be found.
Combines a list of paths with a base path.
Base path to combine with. May be null or empty.
List of input paths to combine with. May be null.
List of paths relative The build module object for the specified build rules source file
This replaces the VCToolPath64 readonly property that was available in 4.19 . Note that GetVCToolPath64
is still used internally, but the property for it is no longer exposed.
This replaces the InstallDir readonly property that was available in 4.19.
Executor to use for local actions
Used to specify the location of fbuild.exe if the distributed binary isn't being used
Controls network build distribution
Used to specify the location of the brokerage. If null, FASTBuild will fall back to checking FASTBUILD_BROKERAGE_PATH
Used to specify the FASTBuild coordinator IP or network name. If null, FASTBuild will fall back to checking FASTBUILD_COORDINATOR
Controls whether to use caching at all. CachePath and FASTCacheMode are only relevant if this is enabled.
Cache access mode - only relevant if bEnableCaching is true;
Used to specify the location of the cache. If null, FASTBuild will fall back to checking FASTBUILD_CACHE_PATH
Whether to force remote
Whether to stop on error
Which MSVC CRT Redist version to use
Which MSVC Compiler version to use
Constructor
Results from a run action
Console log lines
Process return code. Zero is assumed to be success and all other values an error.
Wall time
CPU time
Additional description of action
Results from a run action
Console log lines
Process return code. Zero is assumed to be success and all other values an error.
Wall time
CPU time
Additional description of action
Console log lines
Process return code. Zero is assumed to be success and all other values an error.
Wall time
CPU time
Additional description of action
Defines the phase of execution
Check for already existing artifacts for the inputs
Compile the action
Defines the type of the runner.
Will be used to queue jobs as part of general requests
Will only be used for manual requests to queue jobs
Actions are assigned a runner when they need executing
Type of the runner
The action phase that this step supports
Function to be run queue running a task
If true, use the action weight as a secondary limit
Maximum number of action actions
Maximum weight of actions
Actions are assigned a runner when they need executing
Type of the runner
The action phase that this step supports
Function to be run queue running a task
If true, use the action weight as a secondary limit
Maximum number of action actions
Maximum weight of actions
Type of the runner
The action phase that this step supports
Function to be run queue running a task
If true, use the action weight as a secondary limit
Maximum number of action actions
Maximum weight of actions
Current number of active actions
Current weight of actions
Used to track if the runner has already scanned the action list
for a given change count but found nothing to run.
True if the current limits have not been reached.
Helper class to manage the action queue
Running the queue can be done with a mixture of automatic and manual runners. Runners are responsible for performing
the work associated with an action. Automatic runners will have actions automatically queued to them up to the point
that any runtime limits aren't exceeded (such as maximum number of concurrent processes). Manual runners must have
jobs queued to them by calling TryStartOneAction or StartManyActions with the runner specified.
For example:
ParallelExecutor uses an automatic runner exclusively.
UBAExecutor uses an automatic runner to run jobs locally and a manual runner to run jobs remotely as processes
become available.
Number of second of no completed actions to trigger an action stall report.
If zero, stall reports will not be enabled.
Number of second of no completed actions to trigger to terminate the queue.
If zero, force termination not be enabled.
Running status of the action
Queued waiting for execution
Action is running
Action has successfully finished
Action has finished with an error
Used to track the state of each action
Action to be executed
Phase of the action
Current status of the execution
Runner assigned to the action
Optional execution results
Indices to prereq actions
State information about each action
Output logging
Total number of actions
Process group
Source for the cancellation token
Cancellation token
Progress writer
Overall success of the action queue
Whether to show compilation times along with worst offenders or not.
Whether to show CPU utilization after the work is complete.
Add target names for each action executed
Whether to log command lines for actions being executed
Whether to show compilation times for each executed action
Collapse non-error output lines
When enabled, will stop compiling targets after a compile error occurs.
Return true if the queue is done
Action that can be to notify when artifacts have been read for an action
Action that can be to notify when artifacts have been missed
Collection of available runners
First action to start scanning for actions to run
Action to invoke when writing tool output
Flush the tool output after logging has completed
Timer used to collect CPU utilization
Per-second logging of cpu utilization
Collection of all actions remaining to be logged
Task waiting to process logging
Used only by the logger to track the [x,total] output
Tracks the number of completed actions.
Tracks the number of completed actions from cache hits.
Tracks the number of unsuccessful actions from cache misses.
Flags used to track how StartManyActions should run
Number of changes to the action list
If true, an action stall has been reported for the current change count
If true, the queue has been cancelled due to an action stall
Time of the last change to the action count. This is updated by the timer.
Copy of _lastActionChange used to detect updates by the time.
Used to terminate the run with status
The last action group printed in multi-target builds
If set, artifact cache used to retrieve previously compiled results and save new results
Construct a new instance of the action queue
Collection of actions
If true, the artifact cache is being used
Max number of concurrent artifact cache tasks
Text to be displayed with the progress writer
Action to invoke when writing tool output
Action to invoke when flushing tool output
Logging interface
Event handler for the Console.CancelKeyPress event
Create a new automatic runner
Action to be run queue running a task
If true, use the action weight as a secondary limit
Maximum number of action actions
Maximum weight of actions
Created runner
Create a manual runner
Action to be run queue running a task
If true, use the action weight as a secondary limit
Maximum number of action actions
Maximum weight of actions
Created runner
Start the process of running all the actions
Run the actions until complete
True if completed successfully
Get the number of actions that were run, and how many succeeded or failed
Out parameter, the total number of actions
Out parameter, the number of successful actions
Out parameter, the number of failed actions
Out parameter, the number of cache hit actions
Out parameter, the number of cache miss actions
Return an enumeration of ready compile tasks. This is not executed under a lock and
does not modify the state of any actions.
Enumerations of all ready to compile actions.
Try to start one action
If specified, tasks will only be queued to this runner. Otherwise all manual runners will be used.
True if an action was run, false if not
Handle an exception running a task
Action that has been run
Thrown exception
Try to start one action.
If specified, tasks will only be queued to this runner. Otherwise all manual runners will be used.
Action to be run if something was queued and the number of completed actions
Start as many actions as possible.
If specified, all actions will be limited to the runner
Dispose the object
Reset the status of the given action to the queued state.
Action being re-queued
Notify the system that an action has been completed.
Action being completed
If true, the action succeeded or false if it failed.
Optional execution results
Set the new state of an action. Can only set state to Queued, Finished, or Error
Action being set
Status to set
Optional results
Add the number of completed actions and signal done if all actions complete.
Number of completed actions to add. If int.MaxValue, then the number is immediately set to total actions
Returns the number of queued actions left (including queued actions that will do artifact check first)
Note, this method is lockless and will not always return accurate count
Optional function to filter out actions. Return false if action should not be included
Purge the pending logging actions
Log an action that has completed
Action that has completed
Results of the action
Generate the final summary display
Get the ready state of an action
Action in question
Action ready state
This executor uses async Tasks to process the action graph
Maximum processor count for local execution.
Processor count multiplier for local execution. Can be below 1 to reserve CPU for other tasks.
When using the local executor (not XGE), run a single action on each CPU core. Note that you can set this to a larger value
to get slightly faster build times in many cases, but your computer's responsiveness during compiling may be much worse.
This value is ignored if the CPU does not support hyper-threading.
Free memory per action in bytes, used to limit the number of parallel actions if the machine is memory starved.
Set to 0 to disable free memory checking.
The priority to set for spawned processes.
Valid Settings: Idle, BelowNormal, Normal, AboveNormal, High
Default: BelowNormal or Normal for an Asymmetrical processor as BelowNormal can cause scheduling issues.
When enabled, will stop compiling targets after a compile error occurs.
Whether to show compilation times along with worst offenders or not.
Whether to show compilation times for each executed action
Whether to log command lines for actions being executed
Add target names for each action executed
Whether to take into account the Action's weight when determining to do more work or not.
Whether to show CPU utilization after the work is complete.
Collapse non-error output lines
How many processes that will be executed in parallel
Constructor
How many actions to execute in parallel
Consider logical cores when determining how many total cpu cores are available
Should output be written in a compact fashion
Logger for output
Returns the name of this executor
Checks whether the task executor can be used
True if the task executor can be used
Telemetry event for this executor
Create an action queue
Actions to be executed
Artifact cache
Max artifact tasks that can execute in parallel
Logging interface
Action queue
Publicly visible static class that allows external access to the parallel executor config
Maximum number of processes that should be used for execution
Maximum number of processes that should be used for execution
When enabled, SN-DBS will stop compiling targets after a compile error occurs. Recommended, as it saves computing resources for others.
When set to false, SNDBS will not be enabled when running connected to the coordinator over VPN. Configure VPN-assigned subnets via the VpnSubnets parameter.
List of subnets containing IP addresses assigned by VPN
Executes the process, parsing progress markup as part of the output.
SN-DBS templates that are automatically included in the build.
ID for this Horde session
Executes the provided actions
True if all the tasks successfully executed, or false if any of them failed.
Determine if an action must be run locally and with no detouring
The action to check
If this action must be local, non-detoured
Determine if an action is able to be run remotely
The action to check
If this action can be run remotely
UBAExecutor, but force local only compiles regardless of other settings
Configuration for Unreal Build Accelerator
When set to true, UBA will not use any remote help
When set to true, UBA will force all actions that can be built remotely to be built remotely. This will hang if there are no remote agents available
When set to true, actions that fail locally with UBA will be retried without UBA.
When set to true, actions that fail remotely with UBA will be retried locally with UBA.
When set to true, all errors and warnings from UBA will be output at the appropriate severity level to the log (rather than being output as 'information' and attempting to continue regardless).
If UBA should store cas compressed or raw
If UBA should distribute linking to remote workers. This needs bandwidth but can be an optimization
The amount of gigabytes UBA is allowed to use to store workset and cached data. It is a good idea to have this >10gb
Max number of worker threads that can handle messages from remotes.
Max size of each message sent from server to client
Which ip UBA server should listen to for connections
Which port UBA server should listen to for connections.
Which directory to store files for UBA.
Use Quic protocol instead of Tcp (experimental)
Enable logging of UBA processes
Prints summary of UBA stats at end of build
Launch visualizer application which shows build progress
Resets the cas cache
Provide custom path for trace output file
Add verbose details to the UBA trace
Disable UBA waiting on available memory before spawning new processes
Let UBA kill running processes when close to out of memory
Store object (.obj) compressed on disk. Requires uba to do link step where it will decompress obj files again
Threshold for when executor should output logging for the process. Defaults to never
Skip writing intermediate and output files to disk. Useful for validation builds where we don't need the output
Set to true to disable mimalloc and detouring of memory allocations.
The zone to use for UBA.
Set to true to enable encryption when transferring files over the network.
Set to true to provide known inputs to processes that are run remote. This is an experimental feature to speed up build times when ping is higher
Write yaml file with all actions that are queued for build. This can be used to replay using "UbaCli.exe local file.yaml"
Set to true to see more info about what is happening inside uba and also log output from agents
Address of the uba cache service. Will automatically use cache if connected
Set cache to write instead of fetch
Max number of cache download tasks that can execute in parallel
Report reason a cache miss happened. Useful when searching for determinism/portability issues
Configuration for Unreal Build Accelerator Horde session
Uri of the Horde server
Auth token for the Horde server
OIDC id for the login to use
Pool for the Horde agent to assign, calculated based on platform and overrides
Pool for the Horde agent to assign if no override current platform doesn't have it set
Pool for the Horde agent to assign, only used for commandline override
Pool for the Horde agent to assign when on Linux
Pool for the Horde agent to assign when on Mac
Pool for the Horde agent to assign when on Windows
Requirements for the Horde agent to assign
Default compute cluster ID if nothing is set
Compute cluster ID for automatically resolving the most suitable cluster
Compute cluster ID to use in Horde. Set to "_auto" to let Horde server resolve a suitable cluster.
In multi-region setups this is can simplify configuration of UBT/UBA a lot.
Which ip UBA server should give to agents. This will invert so host listens and agents connect
Max cores allowed to be used by build session
How long UBT should wait to ask for help. Useful in build configs where machine can delay remote work and still get same wall time results (pch dependencies etc)
Allow use of Wine. Only applicable to Horde agents running Linux. Can still be ignored if Wine executable is not set on agent.
Connection mode for agent/compute communication
for valid modes.
Encryption to use for agent/compute communication. Note that UBA agent uses its own encryption.
for valid modes.
Sentry URL to send box data to. Optional.
Disable horde all together
Enabled parameter for use by INI config, expects one of [True, False, BuildMachineOnly]
Whether to use the no_watchdog_thread option to prevent VS2015 toolchain stalls.
Whether to display the XGE build monitor.
When enabled, XGE will stop compiling targets after a compile error occurs. Recommended, as it saves computing resources for others.
When set to false, XGE will not be enabled when running connected to the coordinator over VPN. Configure VPN-assigned subnets via the VpnSubnets parameter.
List of subnets containing IP addresses assigned by VPN
Whether to allow remote linking
Whether to enable the VCCompiler=true setting. This requires an additional license for VC tools.
Minimum number of actions to use XGE execution.
Check for a concurrent XGE build and treat the XGE executor as unavailable if it's in use.
This will allow UBT to fall back to another executor such as the parallel executor.
Writes a XGE task file containing the specified actions to the specified file path.
The possible result of executing tasks with XGE.
Executes the tasks in the specified file.
- The path to the file containing the tasks to execute in XGE XML format.
Indicates whether the tasks were successfully executed.
Executes the tasks in the specified file, parsing progress markup as part of the output.
Matches compile errors and annotates with the source file path and revision
Matcher for linker errors
Matcher for generic Microsoft errors (see https://docs.microsoft.com/en-us/cpp/build/formatting-the-output-of-a-custom-build-step-or-build-event?view=msvc-160)
Aggregates clang timing information files together into one monolithic breakdown file.
Aggregates parsed Visual C++ timing information files together into one monolithic breakdown file.
Outputs information about the given target, including a module dependecy graph (in .gefx format and list of module references)
Execute the command
Command line arguments
Exit code
Identifies plugins with python requirements and attempts to install all dependencies using pip.
Full path to python interpreter engine was built with (if unspecified use value in PythonSDKRoot.txt)
The action the pip install tool should implement (GenRequirements, Setup, Parse, Install, ViewLicenses, default: Install)
Disable requiring hashes in pip install requirements (NOTE: this is insecure and may simplify supply-chain attacks)
Allow overriding the index url (this will also disable extra-urls)
Run pip installer on all plugins in project and engine
Execute the command
Command line arguments
Exit code
PipEnv helper class for setting up a self-contained pip environment and running pip commands (particularly pip install) within that env.
Simple interface for logging command stdout/stderr with progress tags if supported
Simple factory types so that users don't need to implement the factory
Basic command logger which just echos output/errors to Logger (indent stdout data by 2 spaces)
Pyuthon command wraps python logging facility outputs to appropriate log channel
Basic command writer that redirects stdout to file, and writes stderr normally (used to output pip freeze to file)
Simple interface for logging command stdout/stderr with progress tags if supported
Implement the UHT configuration interface. Due to the configuration system being fairly embedded into
UBT, the implementation must be part of UBT.
Types that have been renamed, treat the old deprecated name as the new name for code generation
Meta data that have been renamed, treat the old deprecated name as the new name for code generation
Supported units in the game
Special parsed struct names that do not require a prefix
Special parsed struct names that have a 'T' prefix
Mapping from 'human-readable' macro substring to # of parameters for delegate declarations
Index 0 is 1 parameter, Index 1 is 2, etc...
Default version of generated code. Defaults to oldest possible, unless specified otherwise in config.
Internal version of pointer warning for native pointers in the engine
Internal version of pointer warning for object pointers in the engine
Internal version of pointer warning for native pointers in engine plugins
Internal version of pointer warning for object pointers in engine plugins
Internal version of pointer warning for native pointers outside the engine
Internal version of pointer warning for object pointers outside the engine
If true, deprecation warnings should be shown
If true, UObject properties are enabled in RigVM
If true, UInterface properties are enabled in RigVM
Internal version of behavior when there is a missing generated header include in the engine code.
Internal version of behavior when there is a missing generated header include in non engine code.
Internal version of the behavior set when the underlying type of a regular and namespaced enum isn't set in the engine code.
Internal version of the behavior set when the underlying type of a regular and namespaced enum isn't set in the non engine code.
Collection of known documentation policies
Default documentation policy (usually empty)
If true, UObject properties are enabled in RigVM
If true, UInterface properties are enabled in RigVM
If true, deprecation warnings should be shown
Read the UHT configuration
Extra command line arguments
Global options for UBT (any modes)
User asked for help
The amount of detail to write to the log
Specifies the path to a log file to write. Note that the default mode (eg. building, generating project files) will create a log file by default if this not specified.
Whether to include timestamps in the log
Whether to format messages in MsBuild format
Disables all logging including the default log location
Initialize the options with the given command line arguments
File manager for the test harness
Collection of test fragments that can be read
All output segments generated by code gen
Construct a new instance of the test file manager
Root directory of the UE
Add a source file fragment to the session. When requests are made to read sources, the
fragment list will be searched first.
Source file
The relative path to add
Starting line number
The data associated with the path
Testing harness to run the test scripts
Invoke UHT
Directory for saved application settings (typically Engine/Programs)
The engine programs directory
Print (incomplete) usage information
Defined exporters
Configuration
Execute the command
Command line arguments
Exit code
Options controlling how a target is built
Default options
Don't build anything, just do target setup and terminate
Just output a list of XGE actions; don't build anything
Fail if any engine files would be modified by the build
Builds a target
Specifies the file to use for logging.
Whether to skip checking for files identified by the junk manifest.
Skip building; just do setup and terminate.
Skip pre build targets; just do the main target.
Whether we should just export the XGE XML and pretend it succeeded
Do not allow any engine files to be output (used by compile on startup functionality)
Whether we should just export the outdated actions list
An optional directory to copy crash dump files into
If specified, then only this type of action will execute
Main entry point
Command-line arguments
One of the values of ECompilationResult
Creates scripts for executing the init scripts (only supported on project descriptors)
The current target
List of created script files
Write scripts containing the custom build steps for the given host platform
The current target
The current host platform
The output directory for the scripts
Bare prefix for all the created script files
List of custom build steps
List of created script files
Gets a list of variables that can be expanded in paths referenced by this target
The current target
Map of variable names to values
Build a list of targets
Target descriptors
Current build configuration
The source file working set
Additional options for the build
Files to write the list of outdated actions to (rather than building them)
Logger for output
If true then only the current target descriptors will be built.
If specified, only actions of this type will be run
Result from the compilation
Build a list of targets with a given set of makefiles.
Makefiles created with CreateMakefiles
Target descriptors
Current build configuration
Additional options for the build
Files to write the list of outdated actions to (rather than building them)
Logger for output
If specified, only actions of this type will be run
Result from the compilation
If there are headers in the specific list, this function will exand the list to include all files that include those headers
List of files to compile
Project file if there is one
Actions to filter out expansion of files
Logger for output
Outputs the toolchain used to build each target
List of targets being built
Matching array of makefiles for each target
Logger for output
Returns true if File is header
File to check
Creates the makefile for a target. If an existing, valid makefile already exists on disk, loads that instead.
The build configuration
Target being built
Set of source files which are part of the working set
Logger for output
Makefile for the given target
Determines all the actions that should be executed for a target (filtering for single module/file, etc..)
The target being built
Makefile for the target
Set of all output items
List of actions that need to be executed
Merge action graphs for multiple targets into a single set of actions. Sets group names on merged actions to indicate which target they belong to.
List of target descriptors
Array of actions for each target
List of merged actions
Cleans build products and intermediates for the target. This deletes files which are named consistently with the target being built
(e.g. UnrealEditor-Foo-Win64-Debug.dll) rather than an actual record of previous build products.
Whether to avoid cleaning targets
Skip pre build targets; just do the main target.
Main entry point
Command-line arguments
One of the values of ECompilationResult
Invokes the deployment handler for a target.
If we are just running the deployment step, specifies the path to the given deployment settings
Execute the tool mode
Command line arguments
Exit code
Builds a target
Whether we should just export the outdated actions list
Main entry point
Command-line arguments
One of the values of ECompilationResult
Fixes the include paths found in a header and source file
Regex that matches #include statements.
Execute the command
Command line arguments
Exit code
Generate a clang compile_commands file for a target
Optional set of source files to include in the compile database. If this is empty, all files will be included by default and -Exclude can be used to exclude some.
Relative to the root directory, or to the project file.
Optional set of source files to exclude from the compile database.
Relative to the root directory, or to the project file.
Execute any actions which result in code generation (eg. ISPC compilation)
Optionally override the output filename for handling multiple targets
Optionally overrite the output directory for the compile_commands file.
Execute the command
Command line arguments
Exit code
Generates project files for one or more projects
Types of project files to generate
Disable native project file generators for platforms. Platforms with native project file generators typically require IDE extensions to be installed.
Whether this command is being run in an automated mode
Execute the tool mode
Command line arguments
Exit code
Try to parse the project file from the command line
The command line arguments
Logger for output
The project file that was parsed
True if the project file was parsed, false otherwise
Generate a clang compile_commands file for a target
Regex that matches #include statements.
Regex that matches #include generated header statements.
Regex that matches inline macro.
Execute the command
Command line arguments
Exit code
Representing an #include inside a code file.
Full path using forward paths, eg: d:/dev/folder/file.h
Printable path for actual include. Does not include quotes or angle brackets. eg: folder/file.h
Reference to file info. Not populated with .iwyu file
Decides if printable should be #include quote or angle bracket
If true #include was found inside a declaration such as a namespace or class/struct/function
Comparer for include entries using printable to compare
Representing a forward declaration inside a code file. eg: class MyClass;
The string to add to the file
True if forward declaration has already been seen in the file
Representing an include that the code file needs that is missing in the include list
Note, in cpp files it is listing the includes that are in the matching h file
Full path using forward paths, eg: d:/dev/folder/file.h
Representing a file (header or source). Each .iwyu file has a list of these (most of the time only one)
Full path of file using forward paths, eg: d:/dev/folder/file.h
Includes that this file needs. This is what iwyu have decided is used.
Forward declarations that this file needs. This is what iwyu have decided is used.
Includes seen in the file. This is how it looked like on disk.
Includes that didnt end up in the Includes list but is needed by the code file
Transitive includes. This is all the includes that someone gets for free when including this file
Note, this is based on what iwyu believes should be in all includes. So it will not look at "seen includes"
and only use its generated list.
Transitive forward declarations. Same as transitive includes
Which .iwyu file that produced this info. Note, it might be null for some special cases (like .generated.h files)
Module that this file belongs to
Is true if this file was included inside a declaration such as a namespace or class/struct/function
Is true if this file ends with .cpp
This is what include-what-you-use.exe produces for each build. a .iwyu file that is parsed into these instances
The different headers and source files that was covered by this execution of iwyu.
Name of .iwyu file
Profiles different unity sizes and prints out the different size and its timings
Specifies the file to use for logging.
Will check out files from p4 and write to disk
Update only includes in cpp files and don't touch headers
Which module to run IWYU on. Will also include all modules depending on this module
Which directory to run IWYU on. Will search for modules that has module directory matching this string
If no module is found in -PathToUpdate it handles this for individual files instead.
Note this can be combined with -ModuleToUpdate to double filter
PathToUpdate supports multiple paths using semi colon separation
Same as PathToUpdate but provide the list of paths in a text file instead.
Add all the desired paths on a separate line
Also update modules that are depending on the module we are updating
Will check out files from p4 and write to disk
Allow files to not add includes if they are transitively included by other includes
Will remove headers that are needed but redundant because they are included through other needed includes
Will skip compiling before updating. Handle with care, this is dangerous since files might not match .iwyu files
Will ignore update check that .iwyu is newer than source files.
If set, this will keep removed includes in #if/#endif scope at the end of updated file.
Applied to non-private headers that are part of the Engine folder.
Compare current include structure with how it would look like if iwyu was applied on all files
For Development only - Will write a toc referencing all .iwyu files. Toc can be used by -ReadToc
For Development only - Will read a toc to find all .iwyu files instead of building the code.
Execute the command
Command line arguments
Exit code
Calculate all indirect transitive includes for a file. This list contains does not contain itself and will handle circular dependencies
Exports a target as a JSON file
Execute any actions which result in code generation (eg. ISPC compilation)
Execute this command
Command line arguments
Exit code (always zero)
Parses an MSVC timing info file generated from cl-filter to turn it into a form that can be used by other tooling.
This is implemented as a separate mode to allow it to be done as part of the action graph.
Generate a clang compile_commands file for a target
Execute the command
Command line arguments
Exit code
Profiles different unity sizes and prints out the different size and its timings
Set of filters for files to include in the database. Relative to the root directory, or to the project file.
Execute the command
Command line arguments
Exit code
Compile the module multiple times looking for the best unity size
Print the timing data
Returns best compile timings after building the module times
Compiles the module and returns the timing information
Queries information about the targets supported by a project
Path to the project file to query
Path to the output file to receive information about the targets
Write out all targets, even if a default is specified in the BuildSettings section of the Default*.ini files.
Execute the mode
Command line arguments
Gets the path to the target info output file
Project file being queried
Path to the output file
Writes information about the targets in an assembly to a file
The project file for the targets being built
The rules assembly for this target
Output file to write to
Logger for output
Include all targets even if a default target is specified for a given target type.
Include all targets from parent assemblies (useful for EngineRules which can be chained)
Register all platforms (and in the process, configure all autosdks)
Execute the tool mode
Command line arguments
Exit code
Builds low level tests on one or more targets.
Whether we're building implicit tests (default is explicit)
Whether we're cleaning tests instead of just building
Whether we're rebuilding tests instead of just building
Updates tests' build graph metadata files for explicit tests
Specific project file to run tests on or update test metadata
Main entry point
Command-line arguments
Validates the various platforms to determine if they are ready for building
Platforms to validate
Whether to validate all platforms
Whether to output SDK versions.
Executes the tool with the given arguments
Command line arguments
Exit code
Generates documentation from reflection data
Enum for the type of documentation to generate
Type of documentation to generate
The HTML file to write to
Entry point for this command
Parameters for the WriteMetadata mode
The project file
Output location for the version file
The new version to write. This should only be set on the engine step.
Output location for the target file
The new receipt to write. This should only be set on the target step.
Map of module manifest filenames to their location on disk.
Map of load order manifest filenames to their locations on disk (generally, at most one load oder manifest is expected).
Constructor
Writes all metadata files at the end of a build (receipts, version files, etc...). This is implemented as a separate mode to allow it to be done as part of the action graph.
Version number for output files. This is not used directly, but can be appended to command-line invocations of the tool to ensure that actions to generate metadata are updated if the output format changes.
The action graph is regenerated whenever UBT is rebuilt, so this should always match.
Execute the command
Command line arguments
Exit code
Execute the command, having obtained the appropriate mutex
Command line arguments
Logger for output
Exit code
Checks if this
Attempts to read a manifest from the given location
Path to the manifest
If successful, receives the manifest that was read
True if the manifest was read correctly, false otherwise
Merge a manifest into another manifest
The source manifest
The target manifest to merge into
Handler for AAR and JAR dependency determination and staging
Add a new respository path to search for AAR and JAR files
Directory containing the repository
Logger for output
Add new respository paths to search for AAR and JAR files (recursive)
Root directory containing the repository
Search pattern to match
Logger for output
Adds a new required JAR file and resolves dependencies
Name of the package the JAR belongs to in repository
Directory in repository containing the JAR
Version of the AAR to use
Logger instance
Adds a new required AAR file and resolves dependencies
Name of the package the AAR belongs to in repository
Directory in repository containing the AAR
Version of the AAR to use
Logger for output
Optionally process POM file for dependencies (default)
Copies the required JAR files to the provided directory
Destination path for JAR files
Logger for output
Extracts the required AAR files to the provided directory
Destination path for AAR files
Name of the package these AARs are being used with
Logger for output
Extracts the contents of a zip file
Name of the zip file
Output directory
Logger for output
List of files written
Interface to allow exposing public methods from the toolchain to other assemblies
Returns the Android NDK Level
The NDK Level
Returns the Current NDK Version
The NDK Version
Interface to allow exposing public methods from the Android deployment context to other assemblies
Public Android functions exposed to UAT
Logger for output
checks if the sdk is installed or has been synced
Base class for platform-specific project generators
Whether Android Game Development Extension is installed in the system. See https://developer.android.com/games/agde for more details.
May be disabled by using -noagde on commandline
Enumerate all the platforms that this generator supports
Android-specific target settings
Enables address sanitizer (ASan)
Enables HW address sanitizer (HWASan)
Enables thread sanitizer (TSan)
Enables undefined behavior sanitizer (UBSan)
Enables minimal undefined behavior sanitizer (UBSan)
Enables runtime ray tracing support.
Enables the desktop renderer.
Enables ASIS plugin and STANDALONE support.
Read-only wrapper for Android-specific target settings
The private mutable settings object
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Modify the rules for a newly created module, in a target that's being built for this platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Internal usage for GetApiLevel
Determines whether we package data inside the APK. Based on and OR of "-ForcePackageData" being
false and bPackageDataInsideApk in /Script/AndroidRuntimeSettings.AndroidRuntimeSettings being true
Ignore AppBundle (AAB) generation setting if "-ForceAPKGeneration" specified
Do not use Gradle if previous APK exists and only libUnreal.so changed
Whether UBT is invoked from MSBuild.
If false will, disable bDontBundleLibrariesInAPK, unless forced .
Forcing bDontBundleLibrariesInAPK to "true" or "false" ignoring any other option.
Adds LD_PRELOAD'ed .so to capture all malloc/free/etc calls to libc.so and route them to our memory tracing.
Simple function to pipe output asynchronously
Reads the bPackageDataInsideApk from AndroidRuntimeSettings
Public Apple functions exposed to UAT
Is the current project using modern xcode?
Get the given project's Swift settings
This is a FilePath from UE settings, like /Game/Foo/Bar.txt
Directory to use for /Game paths
Convert UnrealTargetPlatform to the platform that Xcode uses for -destination
The architecture we are targeting (really, this is for Simulators)
Different ways that xcodebuild is run, so the scripts can behave appropriately
This is when hitting Build from in Xcode
This runs after building when building on commandline directly with UBT
This runs when making a fully made .app in the Staged directory
This runs when packaging a full made .app into Project/Binaries
This runs when packaging a .xcarchive for distribution
Gets the AppStoreConnect auth options for a given project. Will return empty string if the project isn't set up to use ASC
Generates a stub xcode project for the given project/platform/target combo, then builds or archives it
Project to build
Platform to build
The architecture we are targeting (really, this is for Simulator to pass in the -destination field)
Configuration to build
Target to build
Sets an envvar used inside the xcode project to control certain features
Any extra options to pass to xcodebuild
If true, force signing with the - identity
xcode's exit code
Genearate an run-only Xcode project, that is not meant to be used for anything else besides code-signing/running/etc of the native .app bundle
Location of .uproject file (or null for the engine project
The platform to generate a project for
The name of the target being built, so we can generate a more minimal project
True if this is making a bild for uploading to app store
Logging object
Returns the .xcworkspace that was made
Version of FinalizeAppWithXcode that is meant for modern xcode mode, where we assume all codesigning is setup already in the project, so nothing else is needed
The .xcworkspace file to build
THe platform to make the .app for
The architecture we are targeting (really, this is for Simulator to pass in the -destination field)
The name of the scheme (basically the target on the .xcworkspace)
Which configuration to make (Debug, etc)
Action (build, archive, etc)
Extra options to pass to xcodebuild
Logging object
xcode's exit code
Pass along the call to UEBuildTarget.MakeBinaryFileName, but taking an extension instead of a binary type, since the type is hidden
FInds the latest .xcarchive for a given Target name (the .xcarchive will start with this name then have a data appended)
Name of the target to look for, this will be the prefix for the .xcarchive to search for
If null, look in Xcode Archives library, otherwiwse, look here
Base class for Apple-based project generators
Utilities related to code sign for Apple Platforms
A logger
Constructor
The shared provision library directory (on PC)
Get the name from the Certificate
Get the friendly name from the Certificate
When receiving the cert tool process call
Finds all valid installed certificates
Finds all valid installed provisions
Tries to find a matching certificate on this machine from the the serial number of one of the
certificates in the mobile provision (the one in the mobileprovision is missing the public/private key pair)
Makes sure the required files for code signing exist and can be found
Find the certs and provision
The XML doc
Helper for info plist
Set read only
constructor
Create plist from file
save the plist to file
Constructor
Convert value to plist format
Add key value pair
Add key value pair
Clones a dictionary from an existing .plist into a new one. Root should point to the dict key in the source plist.
Get String
Get date
Get bool
Process one node event
Process the value for the key
Merge two plists together. Whenever both have the same key, the value in the dominant source list wins.
Returns each of the entries in the value tag of type array for a given key
If the key is missing, an empty array is returned.
Only entries of a given type within the array are returned.
Returns true if the key exists (and has a value) and false otherwise
Remove the key value
Set the value for the key
Set the string
Save the string
Find a prefixable file (checks first with the prefix and then without it)
The path that the file should be in
The filename to check for (with and without SigningPrefix prepended to it)
The path to the most desirable file (may still not exist)
Finds the first file in the directory with a given extension (if it exists). This method is to provide some
idiot-proofing (for example, .mobileprovision files, which will be expected to be saved from the website as
GameName.mobileprovision or Distro_GameName.mobileprovision, but falling back to using the first one we find
if the correctly named one is not found helps the user if they mess up during the process.
Find a prefixable file or directory (checks first with the prefix and then without it)
The path that the file should be in
The name to check for (with and without SigningPrefix prepended to it)
Is the desired name a directory?
The path to the most desirable file (may still not exist)
The constructor
Get the string from the plist
Get the precompile source plist filename
Handle grabbing the initial plist
The mobile provision
Tag
ApplicationIdentifierPrefix
ApplicationIdentifier
DeveloperCertificates
ProvisionedDeviceIDs
ProvisionName
bDebugn
Data
CreationDate
ExpirationDate
FileName
UUID
The Platform
The logger
The constructor
Cache the mobile provisions
Clean the mobile provisions
Fond compatible provision
Extracts the dict values for the Entitlements key and creates a new full .plist file
from them (with outer plist and dict keys as well as doctype, etc...)
Constructs a MobileProvision from an xml blob extracted from the real ASN.1 file
Does this provision contain the specified UDID?
This class understands how to get the embedded plist in a .mobileprovision file. It doesn't
understand the full format and is not capable of writing a new one out or anything similar.
The mobile provision parser
Parse the file
Parse the file
Parse the file
The code signing config class
The display name in title bars, popups, etc ...
The game directory
The binaries directory
Optional Prefix to append to .xcent and .mobileprovision files, for handling multiple certificates on same source game
PCStagingRootDir
The local staging directory for files needed by Xcode on the Mac (on PC)
The staging directory from UAT that is passed into IPP (for repackaging, etc...)
The delta manifest for deploying files for iterative deploy
The files to be retrieved from the device
The project file that is passed into IPP from UAT
The device to deploy or launch on
Determine whether to use RPC Util or not
Optional override for the dev root on the target mac for remote builds.
Optional value specifying that we are working with tvOS
The local build directory (on PC)
The shared provision library directory (on PC)
The shared (Engine) build directory (on PC)
The local build intermediate directory (on PC)
The local directory cooked files are placed (on PC)
The local directory config files are placed (on PC)
The engine config files are placed (on PC)
The engine directory
The local directory that a payload (GameName.app) is assembled into before being copied to the Mac (on PC)
Program_Architecture
Program_GameName
Returns the name of the file containing user overrides that will be applied when packaging on PC
GetPlistOverrideFilename
Whether or not to output extra information (like every file copy and date/time stamp)
Whether or not to output extra information in code signing
Whether or not non-critical files will be packaged (critical == required for signing or .app validation, the app may still fail to
run with only 'critical' files present). Also affects the name and location of the IPA back on the PC
Is this a distribution packaging build? Controls a number of aspects of packing (which signing prefix and provisioning profile to use, etc...)
Is this a c++ code based project? So far used on repackagefromstage to properly choose the .ipa name
Is this going to try automatic signing?
Whether or not to strip symbols (they will always be stripped when packaging for distribution)
Do a code signing update when repackaging?
Whether the cooked data will be cooked on the fly or was already cooked by the books.
Whether the install should be performed on a provision
provision to be installed
provision to be installed
provision to extract certificate for
target name specificied by the command line, if not set GameName + optional Client will be used
IOS Team ID to be used for automatic signing
Whether the install should be performed on a certificate
Certificate to be installed
Certificate to be output
An override server Mac name
A name to use for the bundle indentifier and display name when resigning
Whether to use None or Best for the compression setting when repackaging IPAs (int version of Ionic.Zlib.CompressionLevel)
By making this an int, we are able to delay load the Ionic assembly from a different path (which is required)
If the requirements blob is present in the existing executable when code signing, should it be carried forward
(true) or should a dummy requirements blob be created with no actual requirements (false)
The code signing identity to use when signing via RPC
The minimum OS version
Create an iterative IPA (i.e. a stub only with Icons and Splash images)
Returns a path to the place to back up documents from a device
The init
Public IOS functions exposed to UAT
Logger for output
Logger for output
Set a secondary remote Mac to retrieve built data on a remote Mac.
Prepare the build and project on a Remote Mac to be able to debug an iOS or tvOS package built remotely
TargetPlatform, iOS or tvOS
Location of .uproject file
A logger
Base class for platform-specific project generators
Constructor
Command line arguments passed to the project generator
Logger for output
Enumerate all the platforms that this generator supports
If this is set, then we do not do any post-compile steps -- except moving the executable into the proper spot on Mac.
Which compiler\linker frontend to use
Which library archiver to use
Adds a build product and its associated debug file to a receipt.
Build product to add
Type of build product
Generates debug info for a given executable
FileItem describing the executable to generate debug info for
Was this build made with LTO enabled?
List of actions to be executed. Additional actions will be added to this list.
Logger for output
Generates pseudo pdb info for a given executable
FileItem describing the executable to generate debug info for
List of actions to be executed. Additional actions will be added to this list.
Substrings that indicate a line contains an error
Helper function to sync source files to and from the local system and a remote Mac
Allows interrogating the contents of a .mobileprovision
The contents of the provision
Map of key names to XML elements holding their values
Constructor
XML file to create the mobile provision from. Call Read() to read from a signed file on disk.
Gets the unique id for this mobileprovision
UUID for the provision
Gets the bundle id for this mobileprovision
Bundle Identifier for the provision
Gets the team unique id for this mobileprovision
Receives the team unique id
True if the team unique ID was found, false otherwise
Reads a mobileprovision from a file on disk
Path to the file
New mobile provision instance
Reads the plist file inside a mobileprovision
Path to the file
XML plist extracted from the mobile provision
IOS-specific target settings
Whether to strip iOS symbols or not (implied by Shipping config).
If true, then a stub IPA will be generated when compiling is done (minimal files needed for a valid IPA).
Whether to generate a native Xcode project as a wrapper for the framework.
Don't generate crashlytics data
Don't generate crashlytics data
Disables clang build verification checks on static libraries
Mark the build for distribution
Manual override for the provision to use. Should be a full path.
Imports the given certificate (inc private key) into a temporary keychain before signing.
Password for the imported certificate
Cached project settings for the target (set in ResetTarget)
Enables address sanitizer (ASan)
Enables thread sanitizer (TSan)
Enables undefined behavior sanitizer (UBSan)
Read-only wrapper for IOS-specific target settings
The private mutable settings object
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
Stores project-specific IOS settings. Instances of this object are cached by IOSPlatform.
The cached project file location
Whether to build the iOS project as a framework.
Whether to generate a native Xcode project as a wrapper for the framework.
Whether to generate a dSYM file or not.
Whether to generate a dSYM bundle (as opposed to single file dSYM)
Whether to generate a dSYM file or not.
The minimum supported version
Whether to support iPhone
Whether to support iPad
additional linker flags for shipping
additional linker flags for non-shipping
mobile provision to use for code signing
signing certificate to use for code signing
true if notifications are enabled
true if notifications are enabled
true if notifications are enabled
true if iTunes file sharing support is enabled
The bundle identifier
true if using Xcode managed provisioning, else false
The IOS Team ID
true to change FORCEINLINE to a regular INLINE.
true if IDFA are enabled
true when building for distribution
override for the app's display name if different from the project name
longer display name than BundleName if needed
Which version of the iOS to allow at run time
which devices the game is allowed to run on
Constructor
The project file to read settings for
Bundle identifier needed when project file is empty
Protected constructor. Used by TVOSProjectSettings.
The project file to read settings for
The platform to read settings for
Bundle identifier needed when project file is empty
IOS provisioning data
Determines if the given name is a build product for a target.
The name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the string matches the name of a build product, false otherwise
Get the extension to use for the given binary type
The binary type being built
string The binary extenstion (ie 'exe' or 'dll')
Check for the default configuration
return true if the project uses the default build config
Check for the build requirement due to platform requirements
return true if the project requires a build
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Whether this platform should create debug information or not
The target being built
bool true if debug info should be generated, false if not
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Setup the binaries for this specific platform.
The target being built
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Register the platform with the UEBuildPlatform class
Reads the GameName.PackageVersionCounter from disk and bumps the minor version number in it
Pulls apart a version string of one of the two following formats:
"7301.15 11-01 10:28" (Major.Minor Date Time)
"7486.0" (Major.Minor)
Parses the version string (expected to be of the form major.minor or major)
Also parses the major.minor from the running version file and increments it's minor by 1.
If the running version major matches and the running version minor is newer, then the bundle version is updated.
In either case, the running version is set to the current bundle version number and written back out.
The (possibly updated) bundle version
Updates the minor version in the CFBundleVersion key of the specified PList if this is a new package.
Also updates the key EpicAppVersion with the bundle version and the current date/time (no year)
Public Linux functions exposed to UAT
Logger for output
Platform name (embeds architecture for now)
Force using system compiler and error out if not possible
Whether to compile with the verbose flag
Whether to link with the verbose flag
Whether platform supports switching SDKs during runtime
true if supports
Returns a path to the internal SDK
Valid path to the internal SDK, null otherwise
Returns the in-tree root for the Linux Toolchain for this host platform.
Whether a host can use its system sdk for this platform
Returns the root SDK path for all architectures
WARNING: Do not cache this value - it may be changed after sourcing OutputEnvVars.txt
Valid SDK string
Returns the SDK path for a specific architecture
WARNING: Do not cache this value - it may be changed after sourcing OutputEnvVars.txt
Valid SDK DirectoryReference
Whether the path contains a valid clang version
Whether the required external SDKs are installed for this platform
Base class for platform-specific project generators
Constructor
Command line arguments passed to the project generator
Logger for output
Enumerate all the platforms that this generator supports
Get clang toolchain version from full version string
v17_clang-10.0.1-centos7 -> 10.0.1
v17_clang-16.0.1-centos7 -> 16
Full clang toolchain version string. Example: "v17_clang-10.0.1-centos7"
Clang toolchain version. Example: 10.0.1 or 16
Starting with clang 16.x the directory naming changed to include major version only
Flavor of the current build (will map to target triplet)
Pass --gdb-index option to linker to generate .gdb_index section.
Allows you to override the maximum binary size allowed to be passed to objcopy.exe when cross building on Windows.
Max value is 2GB, due to bat file limitation
Platform SDK to use
Architecture-specific compiler switches
Whether to use old, slower way to relink circularly dependent libraries.
It makes sense to use it when cross-compiling on Windows due to race conditions between actions reading and modifying the libs.
Track which scripts need to be deleted before appending to
Holds all the binaries for a particular target (except maybe the executable itself).
Tracks that information about used C++ library is only printed once
Creates an action to archive all the .o files into single .a file
Linux-specific target settings
Constructor
Enables address sanitizer (ASan)
Enables LibFuzzer
Enables thread sanitizer (TSan)
Enables undefined behavior sanitizer (UBSan)
Enables memory sanitizer (MSan)
Whether or not to preserve the portable symbol file produced by dump_syms
Turns on tuning of debug info for LLDB
Whether to globally disable calling dump_syms
Enables runtime ray tracing support.
Read-only wrapper for Linux-specific target settings
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
Linux host architecture (compiler target triplet)
@todo Remove this and get the actual Host architecture?
SDK in use by the platform
Constructor
Determines if the given name is a build product for a target.
The name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the string matches the name of a build product, false otherwise
Get the extension to use for the given binary type
The binary type being built
string The binary extension (i.e. 'exe' or 'dll')
Get the extensions to use for debug info for the given binary type
Rules for the target being built
The binary type being built
string[] The debug info extensions (i.e. 'pdb')
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Modify the rules for a newly created module, in a target that's being built for this platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Whether this platform should create debug information or not
The target being built
bool true if debug info should be generated, false if not
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Register the platform with the UEBuildPlatform class
Get the default deployment target version for the given target type. This will be put into the .plist file for runtime check
Will be in the format A.B.C
Get the default build target version for the given target type. This will be passed to clang when compiling/linking
Will be in the format AA.BB
Public Mac functions exposed to UAT
Describes the architecture of the host. Note - this ignores translation.
IsRunningUnderRosetta can be used to detect that we're running under translation
Cached result for AppleArch check
Cached result for Rosetta check
Returns true if we're running under Rosetta
Returns true if we're running on Apple architecture (either natively which dotnet will do, or under Rosetta)
Strips symbols from a file
The input file
The output file
Base class for platform-specific project generators
Constructor
Command line arguments passed to the project generator
Logger for output
Register the platform with the UEPlatformProjectGenerator class
Which version of the Mac OS X to allow at run time
Minimum version of Mac OS X to actually run on, running on earlier versions will display the system minimum version error dialog and exit.
Constructor
Whether to output verbose logging
Logger for output
Mac toolchain wrapper
Which compiler\linker frontend to use
Which archiver to use
Generates debug info for a given executable
FileItem describing the executable or dylib to generate debug info for
List of actions to be executed. Additional actions will be added to this list.
Logger for output
Creates app bundle for a given executable
FileItem describing the executable to generate app bundle for
List of actions to be executed. Additional actions will be added to this list.
Mac-specific target settings
Enables address sanitizer (ASan).
Enables LibFuzzer.
Enables thread sanitizer (TSan).
Enables undefined behavior sanitizer (UBSan).
Enables the generation of .dsym files. This can be disabled to enable faster iteration times during development.
Disables clang build verification checks on static libraries
Enables runtime ray tracing support.
Read-only wrapper for Mac-specific target settings
The private mutable settings object
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
Determines if the given name is a build product for a target.
The name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the string matches the name of a build product, false otherwise
Get the extension to use for the given binary type
The binrary type being built
string The binary extenstion (ie 'exe' or 'dll')
Get the extensions to use for debug info for the given binary type
Rules for the target being built
The binary type being built
string[] The debug info extensions (i.e. 'pdb')
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
For platforms that need to output multiple files per binary (ie Android "fat" binaries)
this will emit multiple paths. By default, it simply makes an array from the input
Modify the rules for a newly created module, in a target that's being built for this platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Whether this platform should create debug information or not
The target being built
true if debug info should be generated, false if not
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Register the platform with the UEBuildPlatform class
Public TVOS functions exposed to UAT
Constructor
Command line arguments passed to the project generator
Logger for output
Enumerate all the platforms that this generator supports
which devices the game is allowed to run on
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Register the platform with the UEBuildPlatform class
Base class for VC appx manifest generation
config section for platform-specific target settings
config section for platform-specific general target settings (i.e. settings with are unrelated to manifest generation)
config section for general target settings
default subdirectory for build resources
default subdirectory for engine resources
Manifest compliance values
cached engine ini
cached game ini
AppX package resource generator
the default culture to use
lookup table for UE's CultureToStage StageId to AppX CultureId
the platform to generate the manifest for
project file to use
target name to use
Logger for output
Whether we have logged the deprecation warning for PerCultureResources CultureId being replaced by StageIdOverrides
CustomConfig to use when reading the ini files
Create a manifest generator for the given platform variant.
Returns a valid version of the given package version string
Returns a valid version of the given application id
Reads an integer from the cached ini files
Reads a string from the cached ini files
Reads a bool from the cached ini files
Reads a color from the cached ini files
Create all the localization data. Returns whether there is any per-culture data set up
Register the locations where resource binary files can be found
Get the resources element
Get the package identity name string
Get the publisher name string
Get the package version string
Get the package identity element
Updates the given package version to include the engine build version, if requested
Get the path to the makepri.exe tool
Get any additional platform-specific parameters for makepri.exe
Return the entire manifest element
Perform any platform-specific processing on the manifest before it is saved
Perform any additional initialization once all parameters and configuration are ready
Create a manifest and return the list of modified files
Cache of Visual C++ installation directories
Cache of Windows SDK installation directories
Cache of Universal CRT installation directories
Cache of Visual Studio installation directories
Cache of DIA SDK installation directories
Finds all the installed Windows SDK versions
Logger for output
Map of version number to Windows SDK directories
List all the installed Windows SDK versions
Logger for output
Finds all the installed Universal CRT versions
Logger for output
Map of version number to universal CRT directories
Determines the directory containing the Windows SDK toolchain
The desired Windows SDK version. This may be "Latest", a specific version number, or null. If null, the function will look for DefaultWindowsSdkVersion. Failing that, it will return the latest version.
Logger for output
Receives the version number of the selected Windows SDK
Receives the root directory for the selected SDK
Optional minimum required version. Ignored if DesiredVesrion is specified
Optional maximum required version. Ignored if DesiredVesrion is specified
True if the toolchain directory was found correctly
Updates the CachedWindowsSdkDirs and CachedUniversalCrtDirs variables
Enumerates all the Windows 10 SDK root directories
Receives all the Windows 10 sdk root directories
Logger for output
Gets the installation directory for the NETFXSDK
Receives the installation directory on success
True if the directory was found, false otherwise
Reads an install directory for a 32-bit program from a registry key. This checks for per-user and machine wide settings, and under the Wow64 virtual keys (HKCU\SOFTWARE, HKLM\SOFTWARE, HKCU\SOFTWARE\Wow6432Node, HKLM\SOFTWARE\Wow6432Node).
Path to the key to read, under one of the roots listed above.
Value to be read.
On success, the directory corresponding to the value read.
True if the key was read, false otherwise.
For each root location relevant to install dirs, look for the given key and add its subkeys to the set of subkeys to return.
This checks for per-user and machine wide settings, and under the Wow64 virtual keys (HKCU\SOFTWARE, HKLM\SOFTWARE, HKCU\SOFTWARE\Wow6432Node, HKLM\SOFTWARE\Wow6432Node).
The subkey to look for under each root location
A list of unique subkeys found under any of the existing subkeys
Attempts to reads a directory name stored in a registry key
Key to read from
Value within the key to read
The directory read from the registry key
True if the key was read, false if it was missing or empty
Gets the MSBuild path, and throws an exception on failure.
Path to MSBuild
Determines if a given compiler is installed
Compiler to check for
Architecture the compiler must support
Logger for output
True if the given compiler is installed
Determines if a given compiler is installed and valid
Compiler to check for
Architecture the compiler must support
Logger for output
True if the given compiler is installed and valid
Determines the directory containing the MSVC toolchain
Major version of the compiler to use
The minimum compiler version to use
Architecture that is required
Logger for output
Receives the chosen toolchain version
Receives the directory containing the toolchain
Receives the optional directory containing redistributable components
True if the toolchain directory was found correctly
Returns the human-readable name of the given compiler
The compiler value
Name of the compiler
Select which toolchain to use, combining a custom preference with a default sort order
Ordering function
Architecture that must be supported
Dump all available toolchain info, combining a custom preference with a default sort order
Ordering function
Architecture that must be supported
The ILogger interface to write to
Dump all available toolchain info for a compiler
The compiler to filter by
Architecture that must be supported
The ILogger interface to write to
Read the Visual Studio install directory for the given compiler version. Note that it is possible for the compiler toolchain to be installed without
Visual Studio, and vice versa.
List of directories containing Visual Studio installations
Read the Visual Studio install directory for the given compiler version. Note that it is possible for the compiler toolchain to be installed without
Visual Studio, and vice versa.
List of directories containing Visual Studio installations
Finds all the valid Visual Studio toolchains under the given base directory
Base directory to search
Optional directory for redistributable components (DLLs etc)
The release channel of this installation
Map of tool chain version to installation info
Whether this folder contains AutoSDK entries
Logger for output
Finds the most appropriate redist directory for the given toolchain version
Adds a Visual C++ toolchain to a list of installations
Add a Clang toolchain
Add an Intel OneAPI toolchain
Finds all the valid Intel oneAPI toolchains under the given base directory
Base directory to search
Map of tool chain version to installation info
Logger for output
Test whether an executable is 64-bit
Executable to test
The compiler host directory name for the running process architecture.
Determines if the given path is a valid Visual C++ version number
The toolchain directory
The version number for the toolchain
True if the path is a valid version
Checks if the given directory contains a 64-bit toolchain. Used to prefer regular Visual Studio versions over express editions.
Directory to check
True if the given directory contains a 64-bit toolchain
Checks if the given directory contains an arm64 toolchain. Used to require arm64, which is an optional install item, when that is our target architecture.
Directory to check
True if the given directory contains the arm64 toolchain
Checks if the given directory contains a arm64ec toolchain. Used to require arm64, which is an optional install item, when that is our target architecture.
Directory to check
True if the given directory contains the arm64ec toolchain
Determines if an IDE for the given compiler is installed.
Compiler to check for
Logger for output
True if the given compiler is installed
Gets the path to MSBuild. This mirrors the logic in GetMSBuildPath.bat.
Logger for output
On success, receives the path to the MSBuild executable.
True on success.
Function to query the registry under HKCU/HKLM Win32/Wow64 software registry keys for a certain install directory.
This mirrors the logic in GetMSBuildPath.bat.
Determines the directory containing the MSVC toolchain
Major version of the compiler to use
Map of version number to directories
Determines if a directory contains a valid DIA SDK
The directory to check
True if it contains a valid DIA SDK
The default compiler version to be used, if installed.
The minimum supported Clang compiler
Ranges of tested compiler toolchains to be used, in order of preference. If multiple toolchains in a range are present, the latest version will be preferred.
Note that the numbers here correspond to the installation *folders* rather than precise executable versions.
Minimum Clang version required for MSVC toolchain versions
Tested compiler toolchains that should not be allowed.
The minimum supported MSVC compiler
The default compiler version to be used, if installed.
https://www.intel.com/content/www/us/en/developer/articles/tool/oneapi-standalone-components.html#dpcpp-cpp
The minimum supported Intel compiler
If a toolchain version is a preferred version
The toolchain type
The version number
If the version is preferred
Get the latest preferred toolchain version
The toolchain type
The version number
The minimum supported Clang version for a given MSVC toolchain
The base Clang version for a given Intel toolchain
Whether toolchain errors should be ignored. Enable to ignore banned toolchains when generating projects,
as components such as the recommended toolchain can be installed by opening the generated solution via the .vsconfig file.
If enabled the error will be downgraded to a warning.
The default set of components that should be suggested to be installed for Visual Studio
This or the 2022 specific components should be updated if the preferred visual cpp version changes
Additional set of components that should be suggested to be installed for Visual Studio
to support the Linux platform.
Additional set of components that should be suggested to be installed for Visual Studio 2022.
The minimum supported Visual Studio IDE version
Returns the list of suggested of components that should be suggested to be installed for Visual Studio.
Used to generate a .vsconfig file which will prompt Visual Studio to ask the user to install these components.
Information about a particular toolchain installation
The version "family" (ie. the nominal version number of the directory this toolchain is installed to)
Index into the preferred version range
The actual version number of this toolchain
Whether this is a 64-bit toolchain
The release channel of this toolchain
The architecture of this ToolChainInstallation (multiple ToolChainInstallation instances may be created, one per architecture).
Reason for this toolchain not being compatible
Base directory for the toolchain
Base directory for the redistributable components
Whether this toolchain comes from AutoSDK.
Constructor
The release channel of this toolchain
Base directory for the toolchain
Optional directory for redistributable components (DLLs etc)
Whether this toolchain comes from AutoSDK
Flags for the PVS analyzer mode
Check for 64-bit portability issues
Enable general analysis
Check for optimizations
Enable customer-specific rules
Enable MISRA analysis
Flags for the PVS analyzer timeout
Analisys timeout for file 10 minutes (600 seconds)
Analisys timeout for file 30 minutes (1800 seconds)
Analisys timeout for file 60 minutes (3600 seconds)
Analisys timeout when not set (a lot of seconds)
Partial representation of PVS-Studio main settings file
Masks for paths excluded for analysis
Registered username
Registered serial number
Disable the 64-bit Analysis
Disable the General Analysis
Disable the Optimization Analysis
Disable the Customer's Specific diagnostic rules
Disable the MISRA Analysis
File analysis timeout
Disable analyzer Level 3 (Low) messages
Enable the display of analyzer rules exceptions which can be specified by comments and .pvsconfig files.
Gets the analysis mode flags from the settings
Mode flags
Attempts to read the application settings from the default location
Application settings instance, or null if no file was present
Settings for the PVS Studio analyzer
Returns the application settings
Whether to use application settings to determine the analysis mode
Override for the analysis mode to use
Private storage for the mode flags
Override for the analysis timeoutFlag to use
Private storage for the analysis timeout
Override for the disable Level 3 (Low) analyzer messages
Private storage for the NoNoise analyzer setting
Override for the enable the display of analyzer rules exceptions which can be specified by comments and .pvsconfig files.
Private storage for the ReportDisabledRules analyzer setting
Read-only version of the PVS toolchain settings
Inner settings
Constructor
The inner object
Accessor for the Application settings
Whether to use the application settings for the mode
Override for the analysis mode to use
Override for the analysis timeout to use
Override NoNoise analysis setting to use
Override EnableReportDisabledRules analysis setting to use
Special mode for gathering all the messages into a single output file
Path to the input file list
Output file to generate
Path to file list of paths to ignore
The maximum level of warnings to print
Version of the analyzers
If all ThirdParty code should be ignored
Execute the command
List of command line arguments
Always zero, or throws an exception
AppX Package Resource Index generator
Folders where binary resource files are located, in decreasing priority order
Folders where fallback binary resource files are located, in decreasing priority order
Target OS version
Create a new instance
Adds a reference to the given culture
Adds a reference to all of the given cultures
Returns a collection of all registered cultures
Add the given string to the default culture
Adds all of the given strings to the default culture
Add the given string to the given culture
Adds all of the given strings to the given culture
Returns whether the given string is known
Clear all stored strings for all cultures
Attempts to locate the given resource binary file in the previously-specified resource folders
Determines whether the given resource binary file can be found in one of the known folder locations for the given culture
Determines whether the given default resource binary file can be found in one of the known folder locations
Adds the given resource binary file(s) to the manifest files
Adds the given file to the manifest files
Copies all of the generated files to the output folder
Adds the given string to the culture string writers
Generate the package resource index and copies all resources files to the output
Intentionally unimplemented, but declared so that it's type can be included in generated resx files
Resource writer for VC app manifest generator
Create a new resource writer at the given path
Closes the writer
Add the given resource reference
Available compiler toolchains on Windows platform
Use the default compiler. A specific value will always be used outside of configuration classes.
Use Clang for Windows, using the clang-cl driver.
Use the RTFM (Rollback Transactions on Failure Memory) Clang variant for Verse on Windows, using the verse-clang-cl driver.
Use the Intel oneAPI C++ compiler
Visual Studio 2022 (Visual C++ 17.0)
Unsupported Visual Studio
Must be the last entry in WindowsCompiler enum and should only be used in limited circumstances
Enum describing the release channel of a compiler
Extension methods for WindowsCompiler enum
Returns if this compiler toolchain based on Clang
The compiler to check
true if Clang based
Returns if this compiler toolchain based on Intel
The compiler to check
true if Intel based
Returns if this compiler toolchain based on MSVC
The compiler to check
true if MSVC based
Windows-specific target settings
The target rules which owns this object. Used to resolve some properties.
If enabled will set the ProductVersion embeded in windows executables and dlls to contain BUILT_FROM_CHANGELIST and BuildVersion
Enabled by default for all precompiled and Shipping configurations. Regardless of this setting, the versions from Build.version will be available via the BuildSettings module
Note: Embedding these versions will cause resource files to be recompiled whenever changelist is updated which will cause binaries to relink
If -PGOOptimize is specified but the linker flags have changed since the last -PGOProfile, this will emit a warning and build without PGO instead of failing during link with LNK1268.
If specified along with -PGOProfile, then /FASTGENPROFILE will be used instead of /GENPROFILE. This usually means that the PGO data is generated faster, but the resulting data may not yield as efficient optimizations during -PGOOptimize
If specified along with -PGOOptimize, will use the specified per-merged pgd file instead of the usual pgd file with loose pgc files.
If specified along with -PGOProfile, prevent the usage of extra counters. Please note that by default /FASTGENPROFILE doesnt use extra counters
genprofile-fastgenprofile-generate-profiling-instrumented-build
If specified along with -PGOProfile, use sample-based PGO instead of instrumented. Currently Intel oneAPI 2024.0+ only.
Which level to use for Inline Function Expansion when TargetRules.bUseInlining is enabled
ob-inline-function-expansion
Version of the compiler toolchain to use on Windows platform. A value of "default" will be changed to a specific version at UBT start up.
Version of the toolchain to use on Windows platform when a non-msvc Compiler is in use, to locate include paths etc.
Architecture of Target.
Warning level when reporting toolchains that are not in the preferred version list
The specific compiler version to use. This may be a specific version number (for example, "14.13.26128"), the string "Latest" to select the newest available version, or
the string "Preview" to select the newest available preview version. By default, and if it is available, we use the toolchain version indicated by
WindowsPlatform.DefaultToolChainVersion (otherwise, we use the latest version).
The specific msvc toolchain version to use if the compiler is not msvc. This may be a specific version number (for example, "14.13.26128"), the string "Latest" to select the newest available version, or
the string "Preview" to select the newest available preview version. By default, and if it is available, we use the toolchain version indicated by
WindowsPlatform.DefaultToolChainVersion (otherwise, we use the latest version).
True if /fastfail should be passed to the msvc compiler and linker
True if /d2ExtendedWarningInfo should be passed to the compiler and /d2:-ExtendedWarningInfo to the linker
True if optimizations to reduce the size of debug information should be disabled
See https://clang.llvm.org/docs/UsersManual.html#cmdoption-fstandalone-debug for more information
True if we should use the Clang linker (LLD) when we are compiling with Clang or Intel oneAPI, otherwise we use the MSVC linker.
The specific Windows SDK version to use. This may be a specific version number (for example, "8.1", "10.0" or "10.0.10150.0"), or the string "Latest", to select the newest available version.
By default, and if it is available, we use the Windows SDK version indicated by WindowsPlatform.DefaultWindowsSdkVersion (otherwise, we use the latest version).
Value for the WINVER macro, defining the minimum supported Windows version.
Value for the NTDDI_VERSION macro, defining the minimum supported Windows version.
https://learn.microsoft.com/en-us/windows/win32/winprog/using-the-windows-headers?redirectedfrom=MSDN#macros-for-conditional-declarations
Enable PIX debugging (automatically disabled in Shipping and Test configs)
Enable building with the Win10 SDK instead of the older Win8.1 SDK
Enable building with the C++/WinRT language projection
Enables runtime ray tracing support.
The name of the company (author, provider) that created the project.
The project's copyright and/or trademark notices.
The product name.
Enables address sanitizer (ASan). Only supported for Visual Studio 2019 16.7.0 and up.
Enables LibFuzzer. Only supported for Visual Studio 2022 17.0.0 and up.
Whether .sarif files containing errors and warnings are written alongside each .obj, if supported
Whether we should export a file containing .obj to source file mappings.
Whether to have the linker or library tool to generate a link repro in the specified directory
See https://learn.microsoft.com/en-us/cpp/build/reference/linkrepro for more information
Provides a Module Definition File (.def) to the linker to describe various attributes of a DLL.
Necessary when exporting functions by ordinal values instead of by name.
Specifies the path to a manifest file for the linker to embed. Defaults to the manifest in Engine/Build/Windows/Resources. Can be assigned to null
if the target wants to specify its own manifest.
Specifies the path to an .ico file to use as the appliction icon. Can be assigned to null and will default to Engine/Build/Windows/Resources/Default.ico for engine targets or Build/Windows/Application.ico for projects.
Enables strict standard conformance mode (/permissive-).
Enables updated __cplusplus macro (/Zc:__cplusplus).
Enables inline conformance (Remove unreferenced COMDAT) (/Zc:inline).
Enables new preprocessor conformance (/Zc:preprocessor). This is always enabled for C++20 modules.
Enables enum types conformance (/Zc:enumTypes) in VS2022 17.4 Preview 4.0+.
Enables enforcing standard C++ ODR violations (/Zc:checkGwOdr) in VS2022 17.5 Preview 2.0+
Volatile Metadata is enabled by default and improves x64 emulation on arm64, but may come at a small perfomance cost (/volatileMetadata-).
Whether to request the linker create a stripped pdb file as part of the build.
If enabled the full debug pdb will have the extension .full.pdb
If you supply -NoDebugInfo, windows platforms still create debug info while linking. Set this to true to not create debug info while linking in this circumstance
Set page size to allow for larger than 4GB PDBs to be generated by the msvc linker.
Will default to 16384 for monolithic editor builds.
Values should be a power of two such as 4096, 8192, 16384, or 32768
Specify an alternate location for the PDB file. This option does not change the location of the generated PDB file,
it changes the name that is embedded into the executable. Path can contain %_PDB% which will be expanded to the original
PDB file name of the target, without the directory.
See https://learn.microsoft.com/en-us/cpp/build/reference/pdbaltpath-use-alternate-pdb-path
VS2015 updated some of the CRT definitions but not all of the Windows SDK has been updated to match.
Microsoft provides legacy_stdio_definitions library to enable building with VS2015 until they fix everything up.
The stack size when linking
The stack size to commit when linking
Max number of slots FWindowsPlatformTLS::AllocTlsSlot can allocate.
Max number threads that can use FWindowsPlatformTLS at one time.
Determines the amount of memory that the compiler allocates to construct precompiled headers (/Zm).
Allow the target to specify extra options for linking that aren't otherwise noted here
Create an image that can be hot patched (/FUNCTIONPADMIN)
Strip unreferenced symbols (/OPT:REF)
Merge identical COMDAT sections together (/OPT:ICF)
Whether to put global symbols in their own sections (/Gw), allowing the linker to discard any that are unused.
Whether to reduce optimizations for huge functions over an instruction threshold to improve compile time
https://devblogs.microsoft.com/cppblog/msvc-backend-updates-in-visual-studio-2019-versions-16-3-and-16-4/
The instruction threshold to use when reducing optimizations for huge functions, default 20000.
(Experimental) Appends the -ftime-trace argument to the command line for Clang to output a JSON file containing a timeline for the compile.
See http://aras-p.info/blog/2019/01/16/time-trace-timeline-flame-chart-profiler-for-Clang/ for more info.
Outputs compile timing information so that it can be analyzed.
Print out files that are included by each source file
Bundle a working version of dbghelp.dll with the application, and use this to generate minidumps. This works around a bug with the Windows 10 Fall Creators Update (1709)
where rich PE headers larger than a certain size would result in corrupt minidumps.
Whether this build will use Microsoft's custom XCurl instead of libcurl
Note that XCurl is not part of the normal Windows SDK and will require additional downloads
Settings for PVS studio
The Visual C++ environment to use for this target. Only initialized after all the target settings are finalized, in ValidateTarget().
Directory containing the NETFXSDK
Directory containing the DIA SDK
Directory containing the IDE package (Professional, Community, etc...)
Directory containing ThirdParty DirectX
Directory containing ThirdParty DirectX libs
Directory containing ThirdParty DirectX dlls
When using a Visual Studio compiler, returns the version name as a string
The Visual Studio compiler version name (e.g. "2022")
Determines if a given compiler is installed and valid
Compiler to check for
Architecture the compiler must support
Logger for output
True if the given compiler is installed and valid
Constructor
The target rules which owns this object
Read-only wrapper for Windows-specific target settings
The private mutable settings object
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
Information about a particular Visual Studio installation
Compiler type
Version number for this installation
Base directory for the installation
Whether it's a community edition of Visual Studio.
The release channel of this installation
Constructor
Constructor
Creates a windows platform with the given enum value
The installed Windows SDK
Logger instance
Constructor that takes an archConfig (for use by subclasses)
Creates a windows platform with the given enum value
The installed Windows SDK
Achitecture configuration
Logger instance
Reset a target's settings to the default
Creates the VCEnvironment object used to control compiling and other tools. Virtual to allow other platforms to override behavior
Stanard target object
Validate a target's settings
Gets the default compiler which should be used, if it's not set explicitly by the target, command line, or config file.
The default compiler version
Returns the human-readable name of the given compiler
The compiler value
Name of the compiler
Get the first Visual Studio install directory for the given compiler version. Note that it is possible for the compiler toolchain to be installed without
Visual Studio.
Version of the toolchain to look for.
Logger for output
True if the directory was found, false otherwise.
Determines if a given compiler is installed and valid
Compiler to check for
Architecture the compiler must support
Logger for output
True if the given compiler is installed and valid
Determines the directory containing the MSVC toolchain
Major version of the compiler to use
The minimum compiler version to use
Architecture that is required
Logger for output
Receives the chosen toolchain version
Receives the directory containing the toolchain
Receives the optional directory containing redistributable components
True if the toolchain directory was found correctly
Determines if a directory contains a valid DIA SDK
The directory to check
True if it contains a valid DIA SDK
Gets the platform name that should be used.
If this platform can be compiled with SN-DBS
If this platform can be compiled with FASTBuild
Determines if the given name is a build product for a target.
The name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the string matches the name of a build product, false otherwise
Get the extension to use for the given binary type
The binrary type being built
string The binary extenstion (ie 'exe' or 'dll')
Get the extensions to use for debug info for the given binary type
The target being built
The binary type being built
string[] The debug info extensions (i.e. 'pdb')
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Gets the application icon for a given project
The project file
The icon to use for this project
Gets the application icon for a given project
The project file
The icon to use for this project
Modify the rules for a newly created module, in a target that's being built for this platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Setup the configuration environment for building
The target being built
The global compile environment
The global link environment
Whether this platform should create debug information or not
The target being built
bool true if debug info should be generated, false if not
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Allows the platform to return various build metadata that is not tracked by other means. If the returned string changes, the makefile will be invalidated.
The project file being built
String builder to contain build metadata
Deploys the given target
Receipt for the target being deployed
Allows the platform header name to be overridden to differ from the platform name.
Register the platform with the UEBuildPlatform class
Interface for an action that compiles C++ source code
Path to the compiled module interface file
Serializer which creates a portable object file and allows caching it
The action type
Artifact support for this step
Path to the compiler
The type of compiler being used
The version of the compiler being used
Source file to compile
The object file to output
The assembly file to output
The output preprocessed file
The output analyze warning and error log file
The output experimental warning and error log file
The dependency list file
Compiled module interface
For C++ source files, specifies a timing file used to track timing information.
Response file for the compiler
The precompiled header file
The precompiled header file
The header which matches the PCH
List of include paths
List of system include paths
List of macro definitions
List of force included files
Every file this action depends on. These files need to exist and be up to date in order for this action to even be considered
The files that this action produces after completing
Arguments to pass to the compiler
Whether to show included files to the console
Whether to override the normal logic for UsingClFilter and force it on.
Architecture this is compiling for (used for display)
Whether this compile is static code analysis (used for display)
Items that should be deleted before running this action
Root paths for this action (generally engine root project root, toolchain root, sdk root)
Whether to use cl-filter
Constructor
Compiler executable
Copy constructor
Action to copy from
Serialize a cache handler from an archive
Reader to serialize from
Writes the response file with the action's arguments
The graph builder
Logger for output
Serializer for instances
Stores information about a Visual C++ installation and compile environment
The compiler version
The compiler directory
The compiler version
The compiler Architecture
The underlying toolchain to use. Using Clang/ICL will piggy-back on a Visual Studio toolchain for the CRT, linker, etc...
Root directory containing the toolchain
The toolchain version number
Root directory containing the Windows Sdk
Version number of the Windows Sdk
Use the CPP/WinRT language projection
Allow use of Clang linker
The path to the compiler for compiling code
The path to the linker for linking executables
The path to the linker for linking libraries
Path to the resource compiler from the Windows SDK
The path to the toolchain compiler for compiling code
Optional directory containing redistributable items (DLLs etc)
The default system include paths
The default system library paths
Constructor
Main constructor parameters
Logger for output
Updates environment variables needed for running with this toolchain
Gets the path to the tool binaries.
Base directory for the VC toolchain
Target Architecture
Directory containing the 64-bit toolchain binaries
Gets the path to the compiler.
Gets the path to the linker.
Gets the path to the library linker.
Gets the path to the resource compiler.
Return the standard Visual C++ library path.
Sets up the standard compile environment for the toolchain
Creates an environment with the given settings
The compiler version to use
The toolchain version to use, when a non-msvc compiler is used
The platform to target
The Architecture to target
The specific compiler version to use
The specific toolchain version to use (if the compiler isn't msvc)
Version of the Windows SDK to use
If specified, this is the SDK directory to use, otherwise, attempt to look up via registry. If specified, the WindowsSdkVersion is used directly
Include the CPP/WinRT language projection
Allow use of Clang linker
Logger for output
New environment object with paths for the given settings
Creates an environment with the given parameters
Parameter structure for constructing VCEnvironment
The platform to find the compiler for
The compiler to use
The compiler directory
The compiler version number
The compiler Architecture
The base toolchain version
Directory containing the toolchain
Version of the toolchain
Root directory containing the Windows Sdk
Version of the Windows Sdk
Optional directory for redistributable items (DLLs etc)
Include the CPP/WinRT language projection
Allow use of Clang linker
Creates VC environment construction parameters with the given settings
The compiler version to use
The toolchain version to use, when a non-msvc compiler is used
The platform to target
The Architecture to target
The specific compiler version to use
The specific toolchain version to use (if the compiler isn't msvc)
Version of the Windows SDK to use
If specified, this is the SDK directory to use, otherwise, attempt to look up via registry. If specified, the WindowsSdkVersion is used directly
Include the CPP/WinRT language projection
Allow use of Clang linker
Logger for output
Creation parameters for VC environment
Caches predefined state ("prelude") for compiler versions and options
Set of options which can influence the prelude state. Any options matching entries in this set will be used to generate a separate prelude file.
Object used for ensuring only one thread can create items in the cache at once
File containing a list of macros to be used to generate a prelude file
Base directory for the cache
The parsed list of macros
Path to the file used to generate prelude headers
Cached mapping from compiler filename to its version string
Get the prelude file (or create it) for the given compiler executable and set of options
Path to the compiler executable
Command line arguments for generating the prelude file
Path to the prelude file
Creates a prelude header
Path to the file to create
Path to the compiler
Version number of the compiler
Command line arguments used to generate the header
The target being built
The Visual C++ environment
Prepares the environment for building
Returns the version info for the toolchain. This will be output before building.
String describing the current toolchain
Macros passed via the command line have their quotes stripped, and are tokenized before being re-stringized by the compiler. This conversion
back and forth is normally ok, but certain characters such as single quotes must always be paired. Remove any such characters here.
The macro value
The sanitized value
Gets the default include paths for the given platform.
Public Linux functions exposed to UAT
Tries to get the directory for an installed Visual Studio version
The compiler version
True if successful
Gets the path to MSBuild.exe
Path to MSBuild.exe
Returns the architecture name of the current architecture.
The architecture enum
String with the name
Tries to get the directory for an installed Windows SDK
Receives the desired version on success
Version of SDK
Path to SDK root folder
String with the name
Gets a list of Windows Sdk installation directories, ordered by preference
String with the name
Enumerates all the Windows 10 SDK root directories
Receives all the Windows 10 sdk root directories
Logger for output
Base class for platform-specific project generators
Constructor
Command line arguments passed to the project generator
Logger for output
Contains the name of an identifier. Individual objects are unique.
The name of this identifier
Global map of name to identifier instance
Constructor
Name of this identifier
Finds or adds an identifier with the given name
Name of the identifier
New Identifier instance
Compares this identifier to another identifier
Identifier to compare to
Value indicating which identifier should sort first
Formats this identifier as a string for debugging
Name of this identifier
Well known predefined identifiers
Helper functions for serialization
Read an identifier from a binary archive
Reader to serialize data from
Instance of the serialized identifier
Write an identifier to a binary archive
Writer to serialize data to
Identifier to write
Exception class for the preprocessor, which contains the file and position of the code causing an error
The context when the error was encountered
Constructor
The current preprocesor context
Format string, to be passed to String.Format
Optional argument list for the format string
Implementation of a C++ preprocessor.
Type of an include path
Regular include path, enclosed by quotes
System include path, enclosed by angle brackets
Include paths to look in
Framework paths to look in
Set of all included files with the #pragma once directive
Set of any files that has been processed
The current state of the preprocessor
Predefined token containing the constant "0"
Predefined token containing the constant "1"
Value of the __COUNTER__ variable
List of files included by the preprocessor
Enumerable of processed files
Default constructor
Determines whether the current preprocessor branch is active
True if the current branch is active
Defines a macro. May have an optional '=Value' suffix.
Macro to define
Defines a macro
Name of the macro
String to be parsed for the macro's value
Defines a macro
The macro definition
Adds an include path to the preprocessor
The include path
Adds an include path to the preprocessor
The include path
Adds an include path to the preprocessor
The include path
Adds a framework path to the preprocessor
The framework path
Adds a framework path to the preprocessor
The framework path
Adds a framework path to the preprocessor
The framework path
Try to resolve an quoted include against the list of include directories. Uses search order described by https://msdn.microsoft.com/en-us/library/36k2cdd4.aspx.
The current preprocessor context
The path appearing in an #include directive
Specifies rules for how to resolve the include path (normal/system)
If found, receives the resolved file
True if the The resolved file
Try to resolve an quoted include against the list of include directories. Uses search order described by https://msdn.microsoft.com/en-us/library/36k2cdd4.aspx.
The base directory to search from
Fragments of the relative path to follow
The file that was found, if successful
True if the The resolved file
Parses a file recursively
File to parse
Lists of fragments that are parsed
Outer context information, for error messages
Cache for source files
Logger for output
Show all the included files, in order
Suppress exceptions if an include path can not be resolved
Parse an include directive and resolve the file it references
Markup for the include directive
Current preprocessor context
Suppress exceptions if an include path can not be resolved
Included file
Parse a source file fragment, using cached transforms if possible
The source file being parsed
Fragment to parse
Current preprocessor context
Validate and add a macro using the given parameter and token list
The current preprocessor context
Name of the macro
Parameter list for the macro
List of tokens
Set a predefined macro to a given value
Name of the macro
Type of the macro token
Value of the macro
The created macro
Parse a marked up directive from a file
The markup type
Tokens for the directive
The context that this markup is being parsed in
Read a macro definition
List of tokens in the directive
The context that this directive is being parsed in
Parse an #undef directive
List of tokens in the directive
The context that this directive is being parsed in
Parse an #if directive
List of tokens in the directive
The context that this directive is being parsed in
Parse an #ifdef directive
List of tokens in the directive
The context that this directive is being parsed in
Parse an #ifndef directive
List of tokens for this directive
The context that this directive is being parsed in
Parse an #elif directive
List of tokens for this directive
The context that this directive is being parsed in
Parse an #else directive
List of tokens in the directive
The context that this directive is being parsed in
Parse an #endif directive
List of tokens in the directive
The context that this directive is being parsed in
Parse a #pragma directive
List of tokens in the directive
The context that this directive is being parsed in
Expand macros in the given sequence.
Sequence of input tokens
List to receive the expanded tokens
Whether a conditional expression is being evaluated (and 'defined' expressions are valid)
The context that this directive is being parsed in
Expand macros in the given sequence, ignoring previously expanded macro names from a list.
Sequence of input tokens
List to receive the expanded tokens
Whether a conditional expression is being evaluated (and 'defined' expressions are valid)
List of macros to ignore
The context that this directive is being parsed in
Merges an optional leading space flag into the given token (recycling the original token if possible).
The token to merge a leading space into
The leading space flag
New token with the leading space flag set, or the existing token
Read a token from an enumerator and substitute it if it's a macro or 'defined' expression (reading more tokens as necessary to complete the expression).
The enumerator of input tokens
List to receive the expanded tokens
Whether a conditional expression is being evaluated (and 'defined' expressions are valid)
List of macros to ignore
The context that this directive is being parsed in
Result from calling the enumerator's MoveNext() method
Gets a string for the __FILE__ macro
Context to scan to find the current file
String representing the current context
Gets a string for the current file
Context to scan to find the current file
Current source file being parsed
Gets the current line number
Context to scan to find the current file
Line number in the first file encountered
Expand an object macro
The functional macro
The list to receive the output tokens
Whether the macro is being expanded in a conditional context, allowing use of the 'defined' keyword
List of macros currently being expanded, which should be ignored for recursion
The context that this directive is being parsed in
Expand a function macro
The functional macro
Identifiers for each argument token
The list to receive the output tokens
Whether the macro is being expanded in a conditional context, allowing use of the 'defined' keyword
List of macros currently being expanded, which should be ignored for recursion
The context that this macro is being expanded
Appends a list of tokens to another list, setting the leading whitespace flag to the given value
List to receive the appended tokens
List of tokens to append
Whether there is space before the first token
Copies a single token from one list of tokens to another, or if it's an opening parenthesis, the entire subexpression until the closing parenthesis.
The input token list
First token index in the input token list. Set to the last uncopied token index on return.
List to recieve the output tokens
True if a balanced expression was read, or false if the end of the list was encountered before finding a matching token
Copies a single token from one list of tokens to another, or if it's an opening parenthesis, the entire subexpression until the closing parenthesis.
The input token list
List to recieve the output tokens
The context that the parser is in
True if a balanced expression was read, or false if the end of the list was encountered before finding a matching token
Represents a context that the preprocessor is working in. Used to form error messages, and determine things like the __FILE__ and __LINE__ directives.
The outer context
Constructor
The outer context
Context for a command line argument
Constructor
Formats this context for error messages
String describing this context
Represents a context that the preprocessor is reading from
The source file being read
The directory containing this file. When searching for included files, MSVC will check this directory.
Index of the current markup object being processed
Index of the next fragment to be read
Constructor
The source file being parsed
The outer context
Format this file for the debugger, and error messages
Class to allow evaluating a preprocessor expression
Precedence table for binary operators (indexed by TokenType). Lower values indicate higher precedence.
Static constructor. Initializes the Precedence table.
Evaluate a preprocessor expression
The current preprocessor context
List of tokens in the expression
Value of the expression
Evaluates a ternary expression (a? b :c)
The current preprocessor context
List of tokens in the expression
Index into the token list of the next token to read
Value of the expression
Recursive path for evaluating a sequence of binary operators, given a known LHS. Implementation of the shunting yard algorithm.
The current preprocessor context
List of tokens in the expression
Index into the token list of the next token to read
The LHS value for the binary expression
Minimum precedence value to consume
Value of the expression
Evaluates a unary expression (+, -, !, ~)
The current preprocessor context
List of tokens in the expression
Index into the token list of the next token to read
Value of the expression
Evaluates a primary expression
The current preprocessor context
List of tokens in the expression
Index into the token list of the next token to read
Value of the expression
Parse a numeric literal from the given token
The current preprocessor context
The utf-8 literal characters
The literal value of the token
Checks whether the given literal has a valid integer suffix, starting at the given position
The literal token
Index within the literal to start reading
The literal value of the token
Stores information about a defined preprocessor macro
Name of the macro
Parameter names for the macro. The '...' placeholder is represented by the __VA_ARGS__ string.
Raw list of tokens for this macro
Construct a preprocessor macro
Name of the macro
Parameter list for the macro. Should be null for object macros. Ownership of this list is transferred.
Tokens for the macro. Ownership of this list is transferred.
Read a macro from a binary archive
Reader to serialize from
Write a macro to a binary archive
Writer to serialize to
Finds the index of a parameter in the parameter list
Parameter name to look for
Index of the parameter, or -1 if it's not found.
Checks whether this macro definition is equivalent to another macro definition
The macro definition to compare against
True if the macro definitions are equivalent
True if the macro is an object macro
True if the macro is a function macro
The number of required parameters. For variadic macros, the last parameter is optional.
True if the macro has a variable argument list
Converts this macro to a string for debugging
The tokens in this macro
Flags indicating the state of each nested conditional block in a stack.
The current conditional branch is active.
A branch within the current conditional block has been taken. Any #else/#elif blocks will not be taken.
The #else directive for this conditional block has been encountered. An #endif directive is expected next.
The first condition in this branch was an #if directive (as opposed to an #ifdef or #ifndef directive)
The first condition in this branch was an #if directive (as opposed to an #ifdef or #ifndef directive)
The first condition in this branch was an #ifndef directive (as opposed to an #ifdef or #if directive)
The branch has an #elif directive
Marshals access to the preprocessor state, ensuring that any changes are tracked within the active transform
Stack of conditional branch states
Mapping of name to macro definition
The current transform. Any queries or state modifications will be recorded in this.
Enumerates the current branches. Do not use this for decision logic; any dependencies will not be tracked.
Enumerates the current macros. Do not use this for decision logic; any dependencies will not be tracked.
Initialize an empty preprocessor state
Duplicates another preprocessor state. Throws an exception if a transform is currently being built in the other state.
The preprocessor state to copy
Create a new transform object, and assign it to be current
The new transform object
Detach the current transform
The transform object
Sets a flag indicating that a #pragma once directive was encountered
Set a macro to a specific definition
Macro definition
Checks if a macro with the given name is defined
The macro name
True if the macro is defined
Removes a macro definition
Name of the macro
Attemps to get the definition for a macro
Name of the macro
Receives the macro definition, or null if it's not defined
True if the macro is defined, otherwise false
Pushes the preprocessor branch onto the stack
The branch state
Pops a preprocessor branch from the stack
The popped branch state
Attempts to pops a preprocessor branch from the stack
On success, receives the preprocessor branch state
True if a branch was active, else false
Determines if the branch that the preprocessor is in is active
True if the branch is active, false otherwise
Determines if the given transform can apply to the current preprocessor state
The transform to test
True if the transform can be applied to the current state
Apply the given transform to the current preprocessor state
The transform to apply
True if the transform was applied to the current state
Tracks dependencies for transforming the current preprocessor state
Whether the preprocessor must be in an active state after the branches below are popped. This cannot be treated as a 'pop', because it might be the global scope.
List of branch states that will be popped from the stack
Map of macro name to their required value
List of new branches that will be pushed onto the stack
List of new macros that will be defined
This fragment contains a pragma once directive
Constructor
Reads a transform from disk
Archive to serialize from
Writes a transform to disk
Archive to serialize to
Encapsulates metadata for a C++ source file
The corresponding file item
Hash of the source file data
Last write time of this file when constructed
Markup dividing up this source file
Macro which is defined as part of the header guard. If this macro is defined, we don't need to include the header more than once.
Parsed fragments in this file. Only set for files which are being optimized.
Gets the location of this file
Construct a SourceFile from a file on disk
Location of the file
Construct a SourceFile from a raw byte array
Location of the file
Contents of the file
Read a source file from a binary reader
The reader to serialize from
Read a source file from a binary reader
The reader to serialize to
Reads the contents of a file into a buffer, with a null terminator
Location of the file
Array of bytes, with a null terminator
Converts a buffer from a given encoding to UTF8, appending a null terminator
The source data
Length of the data in the source buffer
Array of utf-8 encoded characters, with a null terminator
Converts a buffer from a given encoding to UTF8, appending a null terminator
The encoding to convert from
The source data
Length of the data in the source buffer
Array of utf-8 encoded characters, with a null terminator
Checks whether the markup matches a C-style header guard
Converts a source file to a string for debugging
The full path to the file
Represents an fragment of a source file consisting of a sequence of includes followed by some arbitrary directives or source code.
The file that this fragment is part of
Index into the file's markup array of the start of this fragment (inclusive)
Index into the file's markup array of the end of this fragment (exclusive). Set to zero for external files.
List of known transforms for this fragment
Constructor
The source file that this fragment is part of
Index into the file's markup array of the start of this fragment (inclusive)
Index into the file's markup array of the end of this fragment (exclusive)
Constructor
The source file that this fragment is part of
Reader to deserialize this object from
Write this fragment to an archive
The writer to serialize to
Summarize this fragment for the debugger
String representation of this fragment for the debugger
Possible types of source file markup
A span of tokens which are not preprocessor directives
An #include directive
A #define directive
An #undef directive
An #if directive
An #ifdef directive
An #ifndef directive
An #elif directive
An #else directive
An #endif directive
A #pragma directive
An #error directive
A #warning directive
An empty '#' on a line of its own
Some other directive
Base class for an annotated section of a source file
The directive corresponding to this markup
The one-based line number of this markup
The tokens parsed for this markup. Set for directives.
Construct the annotation with the given range
The type of this directive
The line number of this markup
List of tokens
Constructs a markup object using data read from an archive
The reader to deserialize from
Serializes this object to a binary archive
Writer to serialize to
Determines if this markup indicates a conditional preprocessor directive
True if this object is a conditional preprocessor directive
How this condition modifies the condition depth. Opening "if" statements have a value of +1, "endif" statements have a value of -1, and "else" statements have a value of 0.
Generate a string describing this annotation
String representation for debugging
Create markup for the given file
Reader for tokens in the file
Array of markup objects which split up the given text buffer
Flags for a single token
No flags
The token has space before it
Do not replace any instances of this token with the corresponding macro.
Enumeration for token types
Single lexical token
Static token names
Contains the type of the token
Properties for this token
If this token is identifier, contains the identifier name
If this token is a literal, contains the raw utf-8 representation of it.
Constructor
The token type
Flags for this token
Constructor
The token identifier
Flags for this token
Constructs a literal token
Constructs a literal token
Reads a token from a binary archive
Archive to read from
Writes a token to a binary archive
The writer to serialize to
Checks if a token is equal to another object
The object to compare against
True if the objects are equal, false otherwise
Checks if two tokens are equivalent
The object to compare against
True if the tokens are equal, false otherwise
Compares two tokens for equality
The first token to compare
The second token to compare
True if the objects are equal, false otherwise
Compares two tokens for inequality
The first token to compare
The second token to compare
True if the objects are not equal, false otherwise
Gets a hash code for this object
Hash code for the object
Text corresponding to this token
Returns a new token with different flags
Flags to add from the token
New token with updated flags
Returns a new token with different flags
Flags to remove from the token
New token with updated flags
Accessor for whether this token has leading whitespace
Checks whether two tokens match
The token to compare against
True if the tokens match, false otherwise
Determines whether the given token type is a literal
The type to test
True if the given type is a literal
Concatenate a sequence of tokens into a string
The sequence of tokens to concatenate
String containing the concatenated tokens
Concatenate a sequence of tokens into a string
The sequence of tokens to concatenate
Receives the formatted string
Concatenate two tokens together
The first token
The second token
Current preprocessor context
The combined token
Static constructor. Initializes the StaticTokens array.
Helper functions for serialization
Read a token from a binary archive
Reader to serialize data from
Token read from the archive
Write a token to a binary archive
Writer to serialize data to
Token to write
Tokenizer for C++ source files. Provides functions for navigating a source file skipping whitespace, comments, and so on when required.
Flags used to classify the first character in a token
Flags used to classify subsequent characters in a token
Map of utf-8 leading bytes to their class
Array of flags for different leading utf-8 sequences
The current buffer being read from. Encoded as UTF-8 with a null terminator.
Current offset within the buffer
The current token
Constructor
The raw byte stream to read from, encoded as UTF-8
Constructor
The text to read from
Copy constructor
Token reader to copy from
Gets a null terminated byte array from the given string
String to convert into bytes
Array of bytes
Tokenize an input string
Text to tokenize
List of tokens parsed from the text
Current line number (one-based)
Line number at the end of this token (one-based)
Returns the current token
Untyped implementation of Current for IEnumerator.
Override of IEnumerator.Dispose. Not required.
Move to the next token
True if the reader could move to the next token, false otherwise
Move to the next token, parsing a single literal token string until the end of the line (in the form used by error directives)
True if a token was parsed
Move to the next token, allowing include directives in triangle brackets in the style permitted by system include directives
True if a token was read
Creates a literal token
Type of token to create
Flags for the token
Offset of the literal within the source data stream
Length of the literal
New token for the literal
Scan ahead until we reach the next directive (a hash token after a newline). Assumes that the current line does not contain a directive.
True if we were able to find another token
Definition of IEnumerator.Reset(). Not supported.
Attempts to read a given character from the stream
Character to read
True if the character was read (and the current position was updated)
Advances the given position past any horizontal whitespace or comments
Flags for the following token
Skip past a text literal (a quoted character literal or string literal)
The terminating character to look for, ignoring escape sequences
Skips over a numeric literal after the initial digit or dot/digit pair.
Static constructor. Initializes the lookup tables used by the lexer.
Class that stores info about aliased file.
CLion project file generator which is just the CMakefileGenerator and only here for UBT to match against
Creates a new instance of the class.
CMakefile project file generator implementation
Creates a new instance of the class.
Determines whether or not we should generate code completion data whenever possible.
true if we should generate code completion data; false otherwise.
Is this a project build?
This determines if engine files are included in the source lists.
true if we should treat this as a project build; false otherwise.
The file extension for this project file.
The CMake helper file extension
The CMake file used to store the list of includes for the project.
The CMake file used to store the configuration files (INI) for the engine.
The CMake file used to store the configuration files (INI) for the project.
The CMake file used to store the additional build configuration files (CSharp) for the engine.
The CMake file used to store the additional configuration files (CSharp) for the project.
The CMake file used to store the additional shader files (usf/ush) for the engine.
The CMake file used to store the additional shader files (usf/ush) for the project.
The CMake file used to store the list of engine headers.
The CMake file used to store the list of engine headers.
The CMake file used to store the list of sources for the engine.
The CMake file used to store the list of sources for the project.
The CMake file used to store the list of definitions for the project.
Writes the primary project file (e.g. Visual Studio Solution file)
The UnrealBuildTool project
The registered platform project generators
True if successful
Adds the include directory to the list, after converting it to relative to Unreal root
This will filter out numerous targets to speed up cmake processing
Whether to include iOS targets or not
Whether to include TVOS targets or not
Allocates a generator-specific project file object
Path to the project file
The base directory for files within this project
The newly allocated project file object
Constructor
KDevelop project file generator implementation
File extension for project files we'll be generating (e.g. ".vcxproj")
Write the primare $ProjectName.kdev4 project file, the one that should be opened when loading the project
into KDevelop
File content.
Name.
Write the Command Sub section for .kdev4/$ProjectName.kdev4 file
File content.
Target name.
Conf name.
Build config index.
Type.
Write the Command section for a .kdev4/$ProjectName.kdev4 file.
File content.
Adds the include directory to the list, after converting it to an absolute path to UnrealEngine root directory.
File content.
Splits the definition text into macro name and value (if any).
Definition text
Out: The definition name
Out: The definition value or null if it has none
Pair representing macro name and value.
Write the defines section to the .kdev4/$ProjectName.kdev4 project file.
File content.
Logger for output
Excludes list in one big ugly list.
File content.
Simple Place to call all the Write*Section functions.
ProjectFileGenerator interface
ProjectFileGenerator interface
Allocates a generator-specific project file object
Path to the project file
The base directory for files within this project
The newly allocated project file object
ProjectFileGenerator interface
Makefile project file generator implementation
True if intellisense data should be generated (takes a while longer)
Now this is needed for project target generation.
Default constructor
True if we should include IntelliSense data in the generated project files when possible
File extension for project files we'll be generating (e.g. ".vcxproj")
ProjectFileGenerator interface
ProjectFileGenerator interface
Allocates a generator-specific project file object
Path to the project file
The base directory for files within this project
The newly allocated project file object
ProjectFileGenerator interface
Base class for platform-specific project generators
Constructor
Command line arguments passed to the project generator
Logger for output
Register the platform with the UEPlatformProjectGenerator class
Checks the local VS install directories to see if the platform is supported.
The ProjectFileSettings that contains the project platform/configuration/etc info being built
bool true if native VisualStudio support (or custom VSI) is available
Return the VisualStudio platform name for this build platform
The ProjectFileSettings that contains the project platform/configuration/etc info being built
string The name of the platform that VisualStudio recognizes
Return whether we need a distinct platform name - for cases where there are two targets of the same VS solution platform
The ProjectFileSettings that contains the project platform/configuration/etc info being built
bool
Return project configuration settings that must be included before the default props file for all configurations
The UnrealTargetPlatform being built
String builder for the project file
string The custom configuration section for the project file; Empty string if it doesn't require one
Return project configuration settings that must be included before the default props file
The UnrealTargetPlatform being built
The UnrealTargetConfiguration being built
String builder for the project file
string The custom configuration section for the project file; Empty string if it doesn't require one
Return the platform toolset string to write into the project configuration
The ProjectFileSettings that contains the project platform/configuration/etc info being built
String builder for the project file
string The custom configuration section for the project file; Empty string if it doesn't require one
Return any custom property group lines
The ProjectFileSettings that contains the project platform/configuration/etc info being built
String builder for the project file
string The custom property import lines for the project file; Empty string if it doesn't require one
Return any custom property group lines
The ProjectFileSettings that contains the project platform/configuration/etc info being built
string The platform configuration type. Defaults to "Makefile" unless overridden
Return any custom paths for VisualStudio this platform requires
This include ReferencePath, LibraryPath, LibraryWPath, IncludePath and ExecutablePath.
The ProjectFileSettings that contains the project platform/configuration/etc info being built
The type of target (game or program)
Path to the .target.cs file
String builder for the project file
The custom path lines for the project file; Empty string if it doesn't require one
Return any custom property settings. These will be included in the ImportGroup section
The ProjectFileSettings that contains the project platform/configuration/etc info being built
String builder for the project file
string The custom property import lines for the project file; Empty string if it doesn't require one
Return any custom property settings. These will be included right after Global properties to make values available to all other imports.
The ProjectFileSettings that contains the project platform/configuration/etc info being built
String builder for the project file
string The custom property import lines for the project file; Empty string if it doesn't require one
Return any custom target overrides. These will be included last in the project file so they have the opportunity to override any existing settings.
The ProjectFileSettings that contains the project platform/configuration/etc info being built
String builder for the project file
string The custom property import lines for the project file; Empty string if it doesn't require one
Return any custom layout directory sections
The ProjectFileSettings that contains the project platform/configuration/etc info being built
The type of target (game or program)
string The custom property import lines for the project file; Empty string if it doesn't require one
Get the output manifest section, if required
The ProjectFileSettings that contains the project platform/configuration/etc info being built
The type of the target being built
Path to the .target.cs file
Path to the project file
The output manifest section for the project file; Empty string if it doesn't require one
Get whether this platform deploys
bool true if the 'Deploy' option should be enabled
Additional configuration related to Visual Studio user file (.vcxproj.user).
Patch existing .vcxproj.user file based on the new file content and corresponding patching settings, by doing the following:
- Go over every <PropertyGroup> in the new document.
- Finds <PropertyGroup> in the current document with matching "Condition" attribute.
- If no property group is found, appends property group from new document to the end of current document.
- Otherwise, saves values of properties configured with bPreserveExistingValue == true.
- Removes all properties flagged for patching from current document property group.
- Adds all properties required for patching from new document property group as declared in new document order.
This makes possible to override some properties crucial for UE features while keeping rest of user configuration intact.
Otherwise, if .vcxproj.user doesn't exist, patching do nothing and instead creates a new file based on new file content.
Name of the property to patch.
If true, the value of the property will be taken from existing user file, but relative order will be taken from newly generated file.
Get the text to insert into the user file for the given platform/configuration/target
Configuration for user file creation/patching/etc.
The ProjectFileSettings that contains the project platform/configuration/etc info being built
The condition string
The target rules
The target rules path
The project file path
Output path for NMake
The name of the project
Path to foreign .uproject file, if any
The string to append to the user file
For Additional Project Property files that need to be written out. This is currently used only on Android.
For additional Project files (ex. *PROJECTNAME*-AndroidRun.androidproj.user) that needs to be written out. This is currently used only on Android.
Project file this will be related to
For additional Project files (ex. *PROJECTNAME*-AndroidRun.androidproj) that needs to be written out. This is currently used only on Android.
Project file this will be related to
Project file written out, Solution folder it should be put in
Gets the text to insert into the UnrealVS configuration file
Gets the text to insert into the Project files as additional build arguments for given platform/configuration
The ProjectFileSettings that contains the project platform/configuration/etc info being built
Indicates whether this generator will be emitting additional build targets.
Functionally, it's fine to return true and not return any additional text in GetVisualStudioTargetsString, but doing
so may incur additional cost of preparing data for generation.
The platform being added
True if Targets will be generate, false otherwise. If true is returned, GetVisualStudioTargetsString will be called next.
Get the text to insert into the Project files as additional build targets for the given platform.
The platform being added
List of build configurations for the platform
String builder for the project file
Get include paths to system headers (STL, SDK, ...) needed for coding assistance features in IDE
Target for which include paths shall be returned
The list of include paths
Stores all the registered platform project generators
Returns the list of platforms that have been registered in this collection
Registered platforms
Register the given platforms UEPlatformProjectGenerator instance
The UnrealTargetPlatform to register with
The UEPlatformProjectGenerator instance to use for the InPlatform
Logger for output
Retrieve the UEPlatformProjectGenerator instance for the given TargetPlatform
The UnrealTargetPlatform being built
If true, do not throw an exception and return null
UEPlatformProjectGenerator The instance of the project generator
Allow various platform project generators to generate stub projects if required
Allow various platform project generators to generate any special project properties if required
Data common to all generated Project entries
Platforms supported by the target
Extra supported build configurations. Normally the target rules determines these, but for synthetic targets we'll add them here.
Extra supported build platforms. Normally the target rules determines these, but for synthetic targets we'll add them here.
If true, forces Development configuration regardless of which configuration is set as the Solution Configuration
Whether the project requires 'Deploy' option set (VC projects)
Optional target rules for this target. If the target came from a *.Target.cs file on disk, then it will have one of these.
For targets that are synthetic (like UnrealBuildTool or other manually added project files) we won't have a rules object for those.
Never set for an untargeted project
Path to the .uproject file on disk
Never set for an untargeted project.
Description of a project build configuration provided during project generation by ProjectFile.
Name of the build configuration as displayed in the IDE e.g. Debug_Client.
Build command associated with this build configuration (as generated by classes derived from ProjectFile).
Represents a single source file (or other type of file) in a project
Constructor
Path to the source file on disk
The directory on this the path within the project will be relative to
File path to file on disk
Optional directory that overrides where files in this project are relative to when displayed in the IDE. If null, will default to the project's BaseFolder.
Define ToString() so the debugger can show the name in watch windows
Constructs a new project file object
The path to the project file, relative to the primary project file
The base directory for files within this project
Project file path
The base directory for files within this project
Returns true if this is a generated project (as opposed to an imported project)
Returns true if this is a "stub" project. Stub projects function as simple containers for source files
and are never actually "built" by the primary project. Stub projects are always "generated" projects.
Returns true if this is a foreign project, and requires UBT to be passed the path to the .uproject file
on the command line.
Returns true if this is a content only project, and will be re-using the engine targets
Returns true if this is a project without source code, but some build setting requires it to be compiled as code, which will make
a unique executable, instead of using UnrealGame, etc
@note: Currently unused by any generator, but a future generator may make use of it
Whether this project should be built for all solution targets
Whether this project should be built by default. Can still be built from the IDE through the context menu.
C++ version which is used in this project.
Information for IntelliSense: whether coroutines are enabled
All of the targets in this project. All non-stub projects must have at least one target.
Adds a list of files to this project, ignoring dupes
Files to add
The directory the path within the project will be relative to
Set of all files that have been added
Aliased (i.e. files is custom filter tree) in this project
Adds aliased file to the project.
Aliased file.
Adds a file to this project, ignoring dupes
Path to the file on disk
The directory the path within the project will be relative to
Splits the definition text into macro name and value (if any).
Definition text
Out: The definition name
Out: The definition value or null if it has none
Pair representing macro name and value.
Adds information about a module to this project file
The module to add
Compile environment for this module
Adds all of the specified preprocessor definitions to this VCProject's list of preprocessor definitions for all modules in the project
List of preprocessor definitons to add
Adds all of the specified include paths to this VCProject's list of include paths for all modules in the project
The collection to add to
List of include paths to add
Sets highest C++ version which is used in this project
Version
Sets whether coroutines should be enabled or not
Should enable them or not
Add the given project to the DepondsOn project list.
The project this project is dependent on
Writes a project file to disk
The platforms to write the project files for
The configurations to add to the project files
The registered platform project generators
Logger for output
True on success
If found writes a debug project file to disk
The platforms to write the project files for
The configurations to add to the project files
The registered platform project generators
Logger for output
List of project files written
Allocates a generator-specific source file object
Path to the source file on disk
Optional sub-folder to put the file in. If empty, this will be determined automatically from the file's path relative to the project file
The newly allocated source file object
Takes the given path and tries to rebase it relative to the project or solution directory variables.
Takes the given path and tries to rebase it relative to the project.
Takes the given path, normalizes it, and quotes it if necessary.
Visualizer for the debugger
Map of file paths to files in the project.
Files in this project
Collection of include paths
Build environment for a particular module
Merged list of include paths for the project
Merged list of include paths for the project
Map of base directory to user include paths
Legacy accessor for user search paths
Legacy accessor for system include paths
List of preprocessor definitions for the project
Set of unique preprocessor definitions
Projects that this project is dependent on
Represents a folder within the primary project (e.g. Visual Studio solution)
Constructor
Project file generator that owns this object
Name for this folder
Name of this folder
Adds a new sub-folder to this folder
Name of the new folder
The newly-added folder
Recursively searches for the specified project and returns the folder that it lives in, or null if not found
The project file to look for
The found folder that the project is in, or null
Owner project generator
Sub-folders
Child projects
Files in this folder. These are files that aren't part of any project, but display in the IDE under the project folder
and can be browsed/opened by the user easily in the user interface
The type of project files to generate
Static class containing
Default list of project file formats to generate.
Parses a list of project file formats from a string
Sequence of project file formats
Base class for all project file generators
Global static that enables generation of project files. Doesn't actually compile anything.
This is enabled only via UnrealBuildTool command-line.
Current ProjectFileGenerator that is in the middle of generating project files. Set just before GenerateProjectFiles() is called.
True if we're generating lightweight project files for a single game only, excluding most engine code, documentation, etc.
True if we're generating temporary solution/workspace that we want to put under Intermediate/ProjectFiles along with the projects to not dirty up the root dir
True will override any extra settings files like .vcxproj.user
Optional list of platforms to generate projects for
Whether to append the list of platform names after the solution
When bGeneratingGameProjectFiles=true, this is the game name we're generating projects for
Whether we should include configurations for "Test" and "Shipping" in generated projects. Pass "-NoShippingConfigs" to disable this.
Whether we should include configurations for "Debug" and "DebugGame" in generated projects. Pass "-NoDebugConfigs" to disable this.
Whether we should include configurations for "Development" in generated projects. Pass "-NoDevelopmentConfigs" to disable this.
True if intellisense data should be generated (takes a while longer).
True if visual studio project should be generated in linux mode.
True if we should include documentation in the generated projects.
True if all documentation languages should be included in generated projects, otherwise only INT files will be included.
True if build targets should pass the -useprecompiled argument.
True if we should include engine source in the generated solution.
True if shader source files should be included in generated projects.
True if build system files should be included.
True if we should include config (.ini) files in the generated project.
True if we should include localization files in the generated project.
True if we should include template files in the generated project.
True if we should include program projects in the generated solution.
Whether to include C++ targets
True if we should include csharp program projects in the generated solution. Pass "-DotNet" to enable this.
Whether to include temporary targets generated by UAT to support content only projects with non-default settings.
True if we should reflect "Source" sub-directories on disk in the primary project as project directories.
This (arguably) adds some visual clutter to the primary project but it is truer to the on-disk file organization.
Names of platforms to include in the generated project files
Names of configurations to include in the generated project files.
See UnrealTargetConfiguration for valid entries
If set, strip out other found Target.cs files
If true, this generator wants to have a project for each target type (UnrealGame, UnrealEditor, etc) and has only the straight configs (Debug, Development)
If true, this generator will add modules to multiple suitable projects (i.e. QAGame.Build.cs will be added to both QAGame and QAGameEditor), only makes sense when bMakeProjectPerTarget is true
If true, the project generator will allow conetnt-only projects for games with no targets, when generating for a single game target with -game
Relative path to the directory where the primary project file will be saved to
Name of the UE engine project that contains all of the engine code, config files and other files
Name of the UE engine project that contains all of the engine code, config files and other files
Name of the UE engine project that contains all of the engine code, config files and other files
When ProjectsAreIntermediate is true, this is the directory to store generated project files
@todo projectfiles: Ideally, projects for game modules/targets would be created in the game's Intermediate folder!
Global static new line string used by ProjectFileGenerator to generate project files.
If true, we'll parse subdirectories of third-party projects to locate source and header files to include in the
generated projects. This can make the generated projects quite a bit bigger, but makes it easier to open files
directly from the IDE.
Name of the primary project file -- for example, the base file name for the Visual Studio solution file, or the Xcode project file on Mac.
If true, sets the primary project name according to the name of the folder it is in.
Maps all module files that were included in generated project files, to actual project file objects.
Maps all module files that were included in generated project files, to actual project file objects.
If generating project files for a single project, the path to its .uproject file.
File extension for project files we'll be generating (e.g. ".vcxproj")
True if we should include IntelliSense data in the generated project files when possible
True if this project generator requires a compile environment for Intellisense data.
Platforms we should generate IntelliSense data for, default is only build host platform.
Allows each project generator to indicate whether target rules should be used to explicitly enable or disable plugins.
Default is false - since usually not needed for project generation unless project files indicate whether referenced plugins should be built or not.
Default constructor.
The project file passed in on the command line
Adds all rules project files to the solution.
Adds all the DotNet folder to the solution.
Creates a .props file next to each project which specifies the path to the engine directory
The properties file path
Finds all csproj within Engine/Source/Programs, and add them if their .uprogram file exists.
Finds the game projects that we're generating project files for
List of project files
Gets the user's preferred IDE from their editor settings
Project file being built
Preferred format for the project being built
True if a preferred IDE was set, false otherwise
Generates a Visual Studio solution file and Visual C++ project files for all known engine and game targets.
Does not actually build anything.
The registered platform project generators
Command-line arguments
If true, write out target data for the editor
Logger for output
Adds detected UBT configuration files (BuildConfiguration.xml) to engine project.
Engine project to add files to.
Clean project files
The primary project directory
The name of the primary project
The intermediate path of project files
Logger for output
Configures project generator based on command-line options
Arguments passed into the program
True if all platforms should be included
Logger for output
Adds all game project files, including target projects and config files
Adds all engine localization text files to the specified project
Adds all engine template text files to the specified project
Adds all engine config files to the specified project
Adds all engine extras files to the specified project
Adds additional files from the platform extensions folder
Adds UnrealHeaderTool config files to the specified project
Finds all module files (filtering by platform)
Filtered list of module files
List of non-redistributable folders
Checks if a module is in a non-redistributable folder
Finds all target files (filtering by platform)
Filtered list of target files
Returns a list of all sub-targets that are specialized for a given platform.
List of target files to find sub-targets for
List of sub-targets in a flat list
List of sub-targets bucketed by their parent target
Recursively collapses all sub-folders that are redundant. Should only be called after we're done adding
files and projects to the primary project.
The folder whose sub-folders we should potentially collapse into
Validate the specified Folder. Default implementation requires
for project file names to be unique!
Folder.
Parent primary project folder path.
Adds UnrealBuildTool to the primary project
Adds a C# project to the primary project
Name of project file to add
Logger for output
ProjectFile if the operation was successful, otherwise null.
Adds all of the config files for program targets to their project files
Generates data for IntelliSense (compile definitions, include paths)
Incoming command-line arguments to UBT
Targets to build for intellisense
Logger for output
Whether the process was successful or not
Selects which platforms and build configurations we want in the project file
True if we should include ALL platforms that are supported on this machine. Otherwise, only desktop platforms will be included.
Output string for supported platforms, returned as comma-separated values.
Is this a valid platform. Used primarily for Installed vs non-Installed builds.
true if valid, false if not
Find the game which contains a given input file.
All game folders
Full path of the file to search for
Finds all modules and code files, given a list of games to process
All game folders
Map of generated Project File to the .uproject file for a given game.
All program projects
All mod projects
List of *.Build.cs files for all engine programs and games
True to gather source code from third party projects too
Logger for output
Creates project entries for all known targets (*.Target.cs files)
The registered platform project generators
All game folders
All the target files to add
The commandline arguments used
The engine projects we created
Map of game folder name to all of the game projects we created
Map of generated Project File to the .uproject file for a given game.
Map of program names to all of the program projects we created
Map of RuleAssemblies to their base folders
Logger for output
Adds separate project files for all mods
List of game project files
Receives the list of mod projects on success
Gets the location for a project file
The base name for the project file
Full path to the project file
Adds shader source code to the specified project
Adds engine build infrastructure files to the specified project
Adds engine documentation to the specified project
Adds a new project file and returns an object that represents that project file (or if the project file is already known, returns that instead.)
Full path to the project file
Base directory for files in this project
True if this project should be included in the set of generated projects. Only matters when actually generating project files.
True if we already had this project file
Object that represents this project file in Unreal Build Tool
Allocates a generator-specific project file object
Path to the project file
The base directory for files within this project
The newly allocated project file object
Returns a list of all the known project files
Project file list
Writes the project files to disk
True if successful
Writes the primary project file (e.g. Visual Studio Solution file)
The UnrealBuildTool project
The platform project file generators
True if successful
Writes any additional solution-wide debug files (e.g. UnrealVS hints)
The platform project generators
Intermediate project files folder
Logger for output
Allows the generator to XXXXXXXxXXXXXXXxXXXXXXXxXXXXXXXx
Writes the specified string content to a file. Before writing to the file, it loads the existing file (if present) to see if the contents have changed
File to write
File content
True if the file was saved, or if it didn't need to be overwritten because the content was unchanged
Adds the given project to the OtherProjects list
The project to add
True if successful
Retrieves the user-set default target name for a given target type. This is used for cases where
a target type can have multiple target names but only one is used for default builds.
The project directory to find the configuration files in
The target type to find a default value for.
The name of the default target, or null
The default project to be built for the solution.
The project for UnrealBuildTool. Note that when generating project files for installed builds, we won't have
an UnrealBuildTool project at all.
List of platforms that we'll support in the project files
List of build configurations that we'll support in the project files
Map of project file names to their project files. This includes every single project file in memory or otherwise that
we know about so far. Note that when generating project files, this map may even include project files that we won't
be including in the generated projects.
List of project files that we'll be generating
List of other project files that we want to include in a generated solution file, even though we
aren't generating them ourselves. Note that these may *not* always be C++ project files (e.g. C#)
List of top-level folders in the primary project file
Helper class used for comparing the existing and generated project files.
Used by CompareOrdinalIgnoreWhitespaceAndCase to determine if a whitespace can be ignored.
Whitespace character.
true if the character can be ignored, false otherwise.
Compares two project files ignoring whitespaces, case and GUIDs.
Compares two specified String objects by evaluating the numeric values of the corresponding Char objects in each string.
Only space and tabulation characters are ignored. Ignores leading whitespaces at the beginning of each line and
differences in whitespace sequences between matching non-whitespace sub-strings.
The first string to compare.
The second string to compare.
An integer that indicates the lexical relationship between the two comparands.
Compares two project files ignoring case and GUIDs.
The first string to compare.
The second string to compare.
An integer that indicates the lexical relationship between the two comparands.
Compares two project files ignoring case and GUIDs.
The first string to compare.
The second string to compare.
True if whitsapces should be ignored.
An integer that indicates the lexical relationship between the two comparands.
A single targeted (with a TargetFilePath) project within a project. A project may have any number of targets within it.
in themselves that the project wraps up.
The target rules file path on disk, if we have one
The project file path on disk
Delegate for creating a rules instance for a given platform/configuration
QMakefile project file generator implementation
Default constructor
File extension for project files we'll be generating (e.g. ".vcxproj")
Splits the definition text into macro name and value (if any).
Definition text
Out: The definition name
Out: The definition value or null if it has none
Pair representing macro name and value.
Adds the include directory to the list, after converting it to relative to Unreal root
ProjectFileGenerator interface
ProjectFileGenerator interface
Allocates a generator-specific project file object
Path to the project file
The base directory for files within this project
The newly allocated project file object
ProjectFileGenerator interface
Write project file info in JSON file.
For every combination of UnrealTargetPlatform, UnrealTargetConfiguration and TargetType
will be generated separate JSON file.
Project file will be stored:
For UE: {UnrealRoot}/Engine/Intermediate/ProjectFiles/.Rider/{Platform}/{Configuration}/{TargetType}/{ProjectName}.json
For game: {GameRoot}/Intermediate/ProjectFiles/.Rider/{Platform}/{Configuration}/{TargetType}/{ProjectName}.json
* TargetType.Editor will be generated for current platform only and will ignore UnrealTargetConfiguration.Test and UnrealTargetConfiguration.Shipping configurations
* TargetType.Program will be generated for current platform only and UnrealTargetConfiguration.Development configuration only
Write a Target to a JSON writer. Is array is empty, don't write anything
Writer for the array data
Logger for output
Write a Module to a JSON writer. If array is empty, don't write anything
Writer for the array data
Write an array of Modules to a JSON writer. If array is empty, don't write anything
Writer for the array data
Name of the array property
Sequence of Modules to write. May be null.
Write an array of strings to a JSON writer. Ifl array is empty, don't write anything
Writer for the array data
Name of the array property
Sequence of strings to write. May be null.
Write uplugin content to a JSON writer
Uplugin description
JSON writer
Setup plugins for Target and write plugins to JSON writer. Don't write anything if there are no plugins
Write information about this binary to a JSON file
Writer for this binary's data
Write C++ toolchain information to JSON writer
List of deprecated platforms.
Don't generate project model for these platforms unless they are specified in "Platforms" console arguments.
When specified only primary project file (root.json) will be generated.
Normally project files for specific configurations are generated together with primary project file.
Platforms to generate project files for
Target types to generate project files for
Target configurations to generate project files for
Projects to generate project files for
Should format JSON files in human readable form, or use packed one without indents
Includes all files in the generated workspace.
Whether VS Code project generation should include debug configurations to allow attaching to already running processes
Whether VS Code project generation should include debug configurations to allow core dump debugging
Do not create compile commands json files with compiler arguments for each file; works better with VS Code extension using
UBT server mode.
Create a workspace file for use with VS Code extension that communicates directly with UBT.
Visual Studio for Mac project file generator implementation
Default constructor
The single project to generate project files for, or null
Additional command line arguments
True if we should include IntelliSense data in the generated project files when possible
Writes the project files to disk
True if successful
Collection of output files for this project
Collect available configurations for the project storing it at availableConfigurations dictionary.
Keys for the dictionary are available project names.
Write project file info in JSON file.
For every combination of UnrealTargetPlatform, UnrealTargetConfiguration and TargetType
will be generated separate JSON file.
* TargetType.Editor will be generated for current platform only and will ignore UnrealTargetConfiguration.Test and UnrealTargetConfiguration.Shipping configurations
* TargetType.Program will be generated for current platform only and UnrealTargetConfiguration.Development configuration only
Filter configurations based on what is supported by the project.
Write a Target to a JSON writer. Is array is empty, don't write anything
Logger for output
Project file format.
Write a Module to a JSON writer. If array is empty, don't write anything
List of deprecated platforms.
Don't generate project model for these platforms unless they are specified in "Platforms" console arguments.
Platforms to generate project files for
Target types to generate project files for
Target configurations to generate project files for
Projects to generate project files for
Should format JSON files in human readable form, or use packed one without indents
Specifies the context for building an MSBuild project
Name of the configuration
Name of the platform
Whether this context should be built by default
Whether this context should be deployed by default
Constructor
Name of this configuration
Name of this platform
The name of this context
Serializes this context to a string for debugging
Name of this context
Represents an arbitrary MSBuild project
The project file version string
The build configuration name to use for stub project configurations. These are projects whose purpose
is to make it easier for developers to find source files and to provide IntelliSense data for the module
to Visual Studio
The name of the Visual C++ platform to use for stub project configurations
NOTE: We always use Win32 for the stub project's platform, since that is guaranteed to be supported by Visual Studio
The Guid representing the project type e.g. C# or C++
Constructs a new project file object
The path to the project file on disk
The base directory for files within this project
Attempts to load the project's GUID from an existing project file on disk
Get the project context for the given solution context
The solution target type
The solution configuration
The solution platform
Set of platform project generators
The target architecture
Logger for output
Project context matching the given solution context
Checks to see if the specified solution platform and configuration is able to map to this project
The target that we're checking for a valid platform/config combination
Platform
Configuration
Logger for output
True if this is a valid combination for this project, otherwise false
Escapes characters in a filename so they can be stored in an XML attribute
The filename to escape
The escaped filename
GUID for this Visual C++ project file
This is the platform name that Visual Studio is always guaranteed to support. We'll use this as
a platform for any project configurations where our actual platform is not supported by the
installed version of Visual Studio (e.g, "iOS")
Constructs a new project file object
The path to the project file on disk
The base directory for files within this project
Visual C++ project file version
Whether to add the -UsePrecompiled argumemnt when building targets
Whether to add roll the target type into the config (ie "Development Editor")
Optional arguments to pass to UBT when building
Other settings
Gets highest C++ version which is used in this project
C++ standard version
Gets compiler switch for specifying in AdditionalOptions in .vcxproj file for specific C++ version
Gets compiler switch for specifying in AdditionalOptions in .vcxproj file for coroutines support
If found writes a debug project file to disk
True on success
Append a list of include paths to a property list
String builder for the property value
Collection of include paths
Set of paths to ignore
Implements Project interface
Write additional Target elements if needed by per-platform generators.
Returns the VCFileType string based on the VCFileType enum.
Name of the element in MSBuild project file for this file type
Returns the VCFileType enum value based on the file path.
The path of the file to return type for.
VCFileType enum value for this file.
A Visual C# project.
This is the GUID that Visual Studio uses to identify a C# project file in the solution
Platforms that this project supports
Configurations that this project supports
Constructs a new project file object
The path to the project file on disk
Logger for output
The base directory for files within this project - if not specified, InitFilePath.Directory will be used
Extract information from the csproj file based on the supplied configuration
Determine if this project is a .NET Core project
Gets a property from the project
Basic csproj file support. Generates C# library project with one build config.
Not used.
Not Used.
Set of platform project generators
true if the opration was successful, false otherwise
Cache of parsed info about this project
The version of Visual Studio to generate project files for.
Puts the most common include paths in the IncludePath property in the MSBuild project. This significantly reduces Visual Studio
memory usage (measured 1.1GB -> 500mb), but seems to be causing issues with Visual Assist. Value here specifies maximum length
of the include path list in KB.
Semi-colon separated list of paths that should not be added to the projects include paths. Useful for omitting third-party headers
(e.g ThirdParty/WebRTC) from intellisense suggestions and reducing memory footprints.
Semi-colon separated list of paths that should not be added to the projects. Useful for omitting third-party files
(e.g ThirdParty/WebRTC) from intellisense suggestions and reducing memory footprints.
Whether to write a solution option (suo) file for the sln.
Whether to write a .vsconfig file next to the sln to suggest components to install.
Forces UBT to be built in debug configuration, regardless of the solution configuration
Whether to add the -FastPDB option to build command lines by default.
Whether to generate per-file intellisense data.
Whether to include a dependency on ShaderCompileWorker when generating project files for the editor.
Whether to include a dependency on LiveCodingConsole when building targets that support live coding.
Whether to generate a project file for each individual target, and not include e.g. Editor/Client/Server in the Configuration.
Visual C++ project file generator implementation
The settings object
Set to true to enable a project for each target, and do not put the target type into the configuration
Override for the build tool to use in generated projects. If the compiler version is specified on the command line, we use the same argument on the
command line for generated projects.
Default constructor
The single project to generate project files for, or null
Override the project file format to use
Additional command line arguments
File extension for project files we'll be generating (e.g. ".vcxproj")
Allocates a generator-specific project file object
Path to the project file
The base directory for files within this project
The newly allocated project file object
"4.0", "12.0", or "14.0", etc...
for instance: v110
Returns a list of architectures to generate unique VS platforms for.
Selects which platforms and build configurations we want in the project file
True if we should include ALL platforms that are supported on this machine. Otherwise, only desktop platforms will be included.
Output string for supported platforms, returned as comma-separated values.
Used to sort VC solution config names along with the config and platform values
Visual Studio solution configuration name for this config+platform
Configuration name
Platform name
The target type
The target architecture
Composes a string to use for the Visual Studio solution configuration, given a build configuration and target rules configuration name
The build configuration
The type of target being built
True if we are making one project per target type, instead of rolling them into the configs
The generated solution configuration name
Writes the project files to disk
True if successful
Takes a string and "cleans it up" to make it parsable by the Visual Studio source control provider's file format
String to clean up
The cleaned up string
Generates an Xcode project that acts as a native wrapper for an Unreal Project built as a framework.
Recursively copies all of the files and directories that are inside into .
The directory whose contents should be copied.
The directory into which the files should be copied.
An enumeration specifying the type of a filesystem entry, either directory, file, or something else.
Gets the type of filesystem entry pointed to by .
The type of filesystem entry pointed to by .
The path to a filesystem entry.
Recursively renames all files and directories that contain in their name by replacing
with .
Root directory.
Old value.
New value.
Opens each file in and replaces all occurrences of
with .
The directory in which all files should be subject to replacements.
Only replace text in files that match this pattern. Default is all files.
The value that should be replaced in all files.
The replacement value.
Modifies the Xcode project file to change a few build settings.
The root directory of the template project that was created.
The name of the framework that this project is wrapping.
The Bundle ID to give to the wrapper project.
The path to the directory containing the framework to be wrapped.
The path to the root Unreal Engine directory.
The path to the 'cookeddata' folder that accompanies the framework.
Removes the readonly attribute from all files in a directory file while retaining all other attributes, thus making them writeable.
The path to the directory that will be make writeable.
Changes the value of a setting in a project file.
The project file contents with the setting replaced.
The contents of a settings file.
The name of the setting to change.
The new value for the setting.
There are some autogenerated directories that could have accidentally made it into the template.
This method tries to delete those directories as an extra precaution.
The directory which should be recursively searched for unwanted directories.
Generates an Xcode project that acts as a native wrapper around an Unreal Project built as a framework.
Wrapper projects are generated by copying a template xcode project from the Build Resources directory,
deleting any user-specific or build files, renaming files and folders to match the framework, setting specific
settings in the project to accommodate the framework, and replacing text in all the files to match the framework.
The directory in which to place the framework. The framework will be placed in 'outputDirectory/frameworkName/'.
The name of the project. If blueprint-only, use the actual name of the project, not just UnrealGame.
The name of the framework that this project is wrapping.
The Bundle ID to give to the wrapper project.
The path to the directory containing the framework to be wrapped.
The path to the root Unreal Engine directory.
The path to the 'cookeddata' folder that accompanies the framework.
Used to mark the project for distribution (some platforms require this)
Override for bundle identifier
Override AppName
Architectures supported for iOS
UBT logger object
Abstract function the individual node classes must override to write out the node to the project file
Walks the references of the given node to find all nodes of the given type.
Parent class of the nodes to return
Root node to start with
Set of matching nodes
THhis will walk the node reference tree and call WRite on each node to add all needed nodes to the xcode poject file
Let subclasses add extra properties into this target section
Write some scripts to do some fixup with how UBT links files. There is currently a difference between Mac and IOS/TVOS:
All:
- The staged files gets pulled into the .app for a self-contained app, created at Xcode build time, unless an envvar is set
that tells this script to skip the copy. This allows UAT to potentially skip copying staged files before we stage
("BuildCookRun -build -cook -stage -package" can skip the copying until the -package step).
Also we don't copy anything if this is the engine, no-project, build, and an
Mac:
- UBT will link executable next to .app
- We will copy it into .app here, similar to iOS
- However, during Archiving, the .app is created in a intermediate location, so then here we copy from Binaries/Mac to the intermediate location
- Trying to have UBT link directly to the intermeidate location causes various issues, so we copy it like IOS does
IOS/TVOS:
- IOS will link to Binaries/IOS/Foo
- During normal operation, here we copy from Binaries/IOS/Foo to Binaries/IOS/Foo.app/Foo
- Note that IOS and Mac have different internal directory structures (which EXECUTABLE_PATH expresses)
- When Archiving, we copy from Binaries/IOS/Foo to the intermediate location's .app
All:
- At this point, the executable is in the correct spot, and so CONFIGURATION_BUILD_DIR/EXECUTABLE_PATH points to it
- So here we gneerate a dSYM from the executable, copying it to where Xcode wants it (DWARF_DSYM_FOLDER_PATH/DWARF_DSYM_FILE_NAME), and
then we strip the executable in place
Constructs a new project file object
The path to the project file on disk
The base directory for files within this project
True for distribution builds
Override option for bundle identifier
The PBXPRoject node, root of everything
Gathers the files and generates project sections
Allocates a generator-specific source file object
Path to the source file on disk
Optional sub-folder to put the file in. If empty, this will be determined automatically from the file's path relative to the project file
The newly allocated source file object
Generates bodies of all sections that contain a list of source files plus a dictionary of project navigator groups.
Implements Project interface
Info needed to make a file a member of specific group
Constructor
File Guid for use in Xcode project
File reference Guid for use in Xcode project
Represents a group of files shown in Xcode's project navigator as a folder
The project needs to point to the product group, so we expose the Guid here
Gets Xcode file type based on its extension
Returns true if Extension is a known extension for files containing source code
Returns true if Extension is a known extension for files containing resource data
Cache the folders excluded by Mac
Returns a project navigator group to which the file should belong based on its path.
Creates a group tree if it doesn't exist yet.
Convert all paths to Apple/Unix format (with forward slashes)
The path to convert
The normalized path
Returns the Mac architectures that should be configured for the provided target. If the target has a project we'll adhere
to whether it's set as Intel/Universal/Apple unless the type is denied (pretty much just Editor)
If the target has no project we'll support allow-listed targets for installed builds and all non-editor architectures
for source builds. Not all programs are going to compile for Apple Silicon, but being able to build and fail is useful...
The target we're generatin forg
Path to the project file, or null if the target has no project
Xcode project file generator implementation
Xcode makes a project per target, for modern to be able to pull in Cooked data
Mark for distribution builds
Override BundleID
Override AppName
Store the single game project (when using -game -project=...) to a place that XcodeProjectLegacy can easily retrieve it
Shared file that the project agnostic projects can point to to get content only projects working nicely in Xcode
A static copy of ProjectPlatforms from the base class
Should we generate only a run project (no build/index targets)
Platforms we should generate IntelliSense data for, Xcode projects should index for each Apple platform.
Make a random Guid string usable by Xcode (24 characters exactly)
File extension for project files we'll be generating (e.g. ".vcxproj")
Allocates a generator-specific project file object
Path to the project file
The base directory for files within this project
The newly allocated project file object
Represents a group of files shown in Xcode's project navigator as a folder
Constructs a new project file object
The path to the project file on disk
The base directory for files within this project
True for distribution builds
Override option for bundle identifier
Temporary for developing this feature
Used to mark the project for distribution (some platforms require this)
Override for bundle identifier
Override AppName
Architectures supported for iOS
Gets Xcode file category based on its extension
Gets Xcode file type based on its extension
Returns true if Extension is a known extension for files containing source code
Returns a project navigator group to which the file should belong based on its path.
Creates a group tree if it doesn't exist yet.
Convert all paths to Apple/Unix format (with forward slashes)
The path to convert
The normalized path
Allocates a generator-specific source file object
Path to the source file on disk
Optional sub-folder to put the file in. If empty, this will be determined automatically from the file's path relative to the project file
The newly allocated source file object
Generates bodies of all sections that contain a list of source files plus a dictionary of project navigator groups.
Returns the Mac architectures that should be configured for the provided target. If the target has a project we'll adhere
to whether it's set as Intel/Universal/Apple unless the type is denied (pretty much just Editor)
If the target has no project we'll support allow-listed targets for installed builds and all non-editor architectures
for source builds. Not all programs are going to compile for Apple Silicon, but being able to build and fail is useful...
Build config for the target we're generating
Path to the project file, or null if the target has no project
Implements Project interface
Storage provider which uses the filesystem
Cached copy of the current process id
Implements for writes to the backing storage
Represents a write transaction to the cache. Commit() should be called once the transaction is complete.
Attempts to open a file from the output cache
Digest of the item to retrieve
Reader interface for the file
Opens a stream for writing into the cache. The digest
Gets the filename on disk to use for a particular digest
The digest to find a filename for
Filename to use for the given digest
Interface for reads from content-addressible storage
Accessor for the read stream
Whether the reader contains any data
Interface for writes to content-addressible storage
Accessor for the write stream
Commits the written data to the cache
Interface for an artifact cache
Attempts to open a file from the output cache
Digest of the item to retrieve
True if the item exists in the cache, false otherwise
Opens a stream for writing into the cache. The digest
Enumerates build action types.
Defines the action's support for artifacts
Cached artifacts aren't enabled
If set, the outputs should be cached but respect the flags below
Absolute file paths must be used when recording inputs and outputs
For actions that can't be cached, by setting this flag, the inputs for the action in question
will be used as additional inputs for any action that references outputs of this action.
For example, PCH files shouldn't be cached, but compiles that use the PCH should still be
valid if consider the inputs used to create the PCH file.
The type of this action (for debugging purposes).
Artifact support for this step
Every file this action depends on. These files need to exist and be up to date in order for this action to even be considered
The files that this action produces after completing
Items that should be deleted before running this action
Root paths for this action (generally engine root project root, toolchain root, sdk root)
For C++ source files, specifies a dependency list file used to check changes to header files
Directory from which to execute the program to create produced items
The command to run to create produced items
Command-line parameters to pass to the program
Version of the command used for this action. This will be considered a dependency.
Optional friendly description of the type of command being performed, for example "Compile" or "Link". Displayed by some executors.
Human-readable description of this action that may be displayed as status while invoking the action. This is often the name of the file being compiled, or an executable file name being linked. Displayed by some executors.
True if this action is allowed to be run on a remote machine when a distributed build system is being used, such as XGE
True if this action is allowed to be run on a remote machine with SNDBS. Files with #import directives must be compiled locally. Also requires bCanExecuteRemotely = true.
True if this action is allowed to be run on a remote machine with XGE. Files with #import directives must be compiled locally. Also requires bCanExecuteRemotely = true.
True if this action can be executed by box
True if this action is using the GCC compiler. Some build systems may be able to optimize for this case.
Whether we should log this action, whether executed locally or remotely. This is useful for actions that take time
but invoke tools without any console output.
Whether we should output log of this action, whether executed locally or remotely. This is useful for actions that spam
logs to console output with non critical data
True if any libraries produced by this action should be considered 'import libraries'
Whether changes in the command line used to generate these produced items should invalidate the action
True if this action should be scheduled early. Some actions can take a long time (pch) and need to start very early
If set to true it will propagate high priority to all its prerequisite tasks
Used to determine how much weight(CPU and Memory work) this action is.
A build action.
Preparation and Assembly (serialized)
The type of this action (for debugging purposes).
Artifact support for this step
Every file this action depends on. These files need to exist and be up to date in order for this action to even be considered
The files that this action produces after completing
Items that should be deleted before running this action
Root paths for this action (generally engine root project root, toolchain root, sdk root)
Order needs to be mainted, so a list is used
For C++ source files, specifies a dependency list file used to check changes to header files
Directory from which to execute the program to create produced items
The command to run to create produced items
Command-line parameters to pass to the program
Version of the command used for this action. This will be considered a dependency.
Optional friendly description of the type of command being performed, for example "Compile" or "Link". Displayed by some executors.
Human-readable description of this action that may be displayed as status while invoking the action. This is often the name of the file being compiled, or an executable file name being linked. Displayed by some executors.
True if this action is allowed to be run on a remote machine when a distributed build system is being used, such as XGE
True if this action is allowed to be run on a remote machine with SNDBS. Files with #import directives must be compiled locally. Also requires bCanExecuteRemotely = true.
True if this action is allowed to be run on a remote machine with XGE. Files with #import directives must be compiled locally. Also requires bCanExecuteRemotely = true.
True if this action can be executed in box
True if this action is using the GCC compiler. Some build systems may be able to optimize for this case.
Whether we should log this action, whether executed locally or remotely. This is useful for actions that take time
but invoke tools without any console output.
True if any libraries produced by this action should be considered 'import libraries'
ISerializable: Called when serialized to report additional properties that should be saved
Writes an action to a json file
The object to parse
Interface that is used when -SingleFile=xx is used on the cmd line to make specific files compile
Actions that has this interface can be used to create real actions that can compile the specific files
The directory this action can create actions for
Creates an action for a specific file. It can return null if for example file extension is not handled
Extension methods for action classes
Writes an action to a json file
The action to write
Map of action to unique id
Writer to receive the output
Determine if this Action ignores output conficts.
The Action to check
True if conflicts are ignored, else false.
Default serializer for instances
Information about an action queued to be executed
The inner action instance
A target that this action contributes to
Set of other actions that this action depends on. This set is built when the action graph is linked.
Total number of actions depending on this one.
Additional field used for sorting that can be used to control sorting of link actions from outside
True if this action should be scheduled early. Some actions can take a long time (pch) and need to start very early
If set to 1 it will propagate high priority to all its prerequisite tasks. (Note it is an int to be able to do interlocked operations)
If set, will be output whenever the group differs to the last executed action. Set when executing multiple targets at once.
Constructor
The inner action instance
Increment the number of dependents, recursively
Set of visited actions
Propagate high priority to this and prerequisite actions
Compares two actions based on total number of sort index, priority and dependent items, descending.
Action to compare
Action to compare
Allow targets to override the expected amount of memory required for compiles, used to control the number
of parallel action processes.
Execute the given actions
Actions to be executed
Logger for output
Cache used to read/write action outputs.
True if the build succeeded, false otherwise
When completed, get a populated telemetry event for this executor
Post a telemetry event if enabled
Will verify that produced items exists on disk
Enum describing why an Action is in conflict with another Action
Links the actions together and sets up their dependencies
List of actions in the graph
Logger for output
Optional sorting of actions
Checks a set of actions for conflicts (ie. different actions producing the same output items)
The set of actions to check
Logger for output
Finds conflicts between two actions, and prints them to the log
The first action
The second action
Logger for output
True if no conflicts were found, false otherwise.
Adds the description of a merge error to an output message
The first action with the conflict
The second action with the conflict
Enum flags for which properties are in conflict
Logger for output
Builds a list of actions that need to be executed to produce the specified output items.
Checks that there aren't any intermediate files longer than the max allowed path length
The build configuration
List of actions in the graph
Selects an ActionExecutor
Executes a list of actions.
Sorts the action list for improved parallelism with local execution.
Checks for cycles in the action graph.
Determines the full set of actions that must be built to produce an item.
All the actions in the graph
Set of output items to be built
Set of prerequisite actions
Determines the full set of actions that must be built to produce an item.
The root action to scan
Set of prerequisite actions
Determines whether an action is outdated based on the modification times for its prerequisite
and produced items, without considering the full set of prerequisites.
Writes to OutdatedActionDictionary iff the action is found to be outdated.
Safe to run in parallel, but only with different RootActions.
- The action being considered.
-
true if outdated
Determines whether an action is outdated by examining the up-to-date state of all of its prerequisites, recursively.
Not thread safe. Typically very fast.
- The action being considered.
-
Logger instance
true if outdated
Determines if the dependency between two actions is only for an import library
The action to check
The action that it depends on
True if the only dependency between two actions is for an import library
Determines if the dependency on a between two actions is only for an import library
The action to check
The dependency that is out of date
True if the only dependency between two actions is for an import library
Test to see if the given file is a library file (or in the case of linux/mac, a dynamic library)
File to test
True if the file is a library file
Builds a dictionary containing the actions from AllActions that are outdated by calling
IsActionOutdated.
Deletes all the items produced by actions in the provided outdated action dictionary.
List of outdated actions
Logger for output
Creates directories for all the items produced by actions in the provided outdated action
dictionary.
Imports an action graph from a JSON file
The file to read from
List of actions
Exports an action graph to a JSON file
The actions to write
Output file to write the actions to
Interface for toolchain operations that produce output
Adds an action to this graph
Action to add
Creates a response file for use in the action graph
Location of the response file
Contents of the file
Allows the backend to write the file in a separate task.
New file item
Creates a response file for use in the action graph, with a newline between each string in ContentLines
Location of the response file
Contents of the file
Allows the backend to write the file in a separate task.
New file item
Adds a file which is in the non-unity working set
The file to add to the working set
Adds a file which is a candidate for being in the non-unity working set
The file to add to the working set
Adds a source directory. These folders are scanned recursively for C++ source files.
Base source directory
Adds the given source files as dependencies
Source directory containing files to build
Contents of the directory
Adds a list of known header files
List of header files to track
Sets the output items which belong to a particular module
Name of the module
Array of output items for this module
Adds a diagnostic message
Message to display
Implementation of IActionGraphBuilder which discards all unnecessary operations
Constructor
Implementation of IActionGraphBuilder which forwards calls to an underlying implementation, allowing derived classes to intercept certain calls
The inner graph builder
Constructor
Builder to pass all calls to
Extension methods for IActionGraphBuilder classes
Creates a new action to be built as part of this target
Graph to add the action to
Type of action to create
New action
Creates an action which copies a file from one location to another
The action graph
The source file location
The target file location
File item for the output file
Creates an action which copies a file from one location to another
List of actions to be executed. Additional actions will be added to this list.
The source file location
The target file location
File item for the output file
Creates an action which calls UBT recursively
The action graph
Type of the action
Arguments for the action
New action instance
Creates a text file with the given contents. If the contents of the text file aren't changed, it won't write the new contents to
the file to avoid causing an action to be considered outdated.
The action graph
Path to the intermediate file to create
Contents of the new file
Allows the backend to write the file in a separate task.
File item for the newly created file
Creates a text file with the given contents. If the contents of the text file aren't changed, it won't write the new contents to
the file to avoid causing an action to be considered outdated.
The action graph
Path to the intermediate file to create
Contents of the new file
Allows the backend to write the file in a separate task.
File item for the newly created file
Caches include dependency information to speed up preprocessing on subsequent runs.
Version number to check
Path to store the cache data to.
The Attributes used to produce files, keyed by the absolute file paths.
Whether the dependency cache is dirty and needs to be saved.
Constructor
File to store this history in
Logger for output
Attempts to load this action history from disk
Saves this action history to disk
Computes the case-invariant IoHash for a string
The text to hash
IoHash of the string
Gets the producing attributes for the given file
The output file to look for
Receives the Attributes used to produce this file
True if Attributes have changed and is updated, false otherwise
Gets the location for the engine action history
Target name being built
The platform being built
Type of the target being built
The target architecture(s)
Path to the engine action history for this target
Gets the location of the project action history
Path to the project file
Platform being built
Name of the target being built
The target architecture(s)
Path to the project action history
Enumerates all the locations of action history files for the given target
Project file for the target being built
Name of the target
Platform being built
The target type
The target architecture(s)
Dependency cache hierarchy for the given project
Information about actions producing artifacts under a particular directory
The base directory for this partition
Used to ensure exclusive access to the layers list
Map of filename to layer
Construct a new partition
The base directory for this partition
Attempt to update the producing command line for the given file
The file to update
The new attributes
Logger for output
True if the attributes were updated, false otherwise
Get the path to the action history layer to use for the given file
Path to the file to use
Path to the file
Attempts to match a substring of a path with the given fragment
Path to match against
Offset of the substring to match
Length of the substring to match
The path fragment
True if the substring matches
Saves the modified layers
A collection of ActionHistory layers
The lock object for this history
List of partitions
Constructor
Reads a cache from the given location, or creates it with the given settings
Base directory for files that this cache should store data for
Reference to a dependency cache with the given settings
Gets the producing command line for the given file
The output file to look for
Receives the Attributes used to produce this file
Logger for output
True if the output item exists
Saves all layers of this action history
Interface for a class that can serialize an action type
The action type
Read the action from an archive
Reader for the action
New action
Writes an action to an archive
Writer for the archive
The action to write
Generic base class for an action serializer
Read the action from an archive
Reader for the action
New action
Writes an action to an archive
Writer for the archive
The action to write
Helper methods for registering serializers and serializing actions
Map from type name to deserializing constructor
Map from serializer name to instance
Creates a map of type name to constructor
Read an action from the given archive
Reader to deserialize from
New action
Reads a type name and find its registered constructor from an archive
Archive to read from
New constructor info
Writes an action to the given archive
Writer to serialize the action to
Action to serialize
Parser for ASN.1 BER formats (eg. iOS mobile provisions)
Base class for exceptions thrown by UBT
Constructor
The error message to display.
Constructor which wraps another exception
An inner exception to wrap
The error message to display.
Constructor
Formatting string for the error message
Arguments for the formatting string
Constructor which wraps another exception
The inner exception being wrapped
Format for the message string
Format arguments
Log BuildException with a provided ILogger
The ILogger to use to log this exception
Returns the string representing the exception. Our build exceptions do not show the callstack since they are used to report known error conditions.
Message for the exception
Implementation of that captures a full structured logging event.
The event object
Constructor
Event to construct from
Constructor which wraps another exception
The inner exception
Event to construct from
Constructor which wraps another exception
Event id for the error
Inner exception to wrap
Structured logging format string
Argument objects
Implementation of that will return a unique exit code.
The exit code associated with this exception
Constructor
The resulting exit code
Constructor
The resulting exit code
Event to construct from
Constructor which wraps another exception
The resulting exit code
The inner exception
Event to construct from
Constructor
The resulting exit code
Event id for the error
Formatting string for the error message
Arguments for the formatting string
Constructor
The resulting exit code
Formatting string for the error message
Arguments for the formatting string
Constructor which wraps another exception
The resulting exit code
The inner exception being wrapped
Format for the message string
Format arguments
Constructor which wraps another exception
The resulting exit code
Event id for the error
Inner exception to wrap
Structured logging format string
Argument objects
Extension methods for build exceptions
Log Exception with a provided ILogger
The exception to log
The ILogger to use to log this exception
Get the CompilationResult for a provided Exception
The exception to get the result for
CompilationResult
The type of shell supported by this platform. Used to configure command line arguments.
The Bourne shell
Windows command interpreter
Host platform abstraction
Host platform singleton.
Gets the current host platform type.
Gets the path to the shell for this platform
The type of shell returned by the Shell parameter
The executable binary suffix for this platform
Class that holds information about a running process
Process ID
Name of the process
Filename of the process binary
Constructor
The process ID
The process name
The process filename
Constructor
Process to take information from
Format as a string for debugging
String containing process info
Gets all currently running processes.
Gets a process by name.
Name of the process to get information for.
Gets processes by name.
Name of the process to get information for.
Gets the filenames of all modules associated with a process
Process ID
Filename of the binary associated with the process.
An array of all module filenames associated with the process. Can be empty of the process is no longer running.
Determines if the UBT process is running through WINE
Sequence of project file formats
Determines the default project file formats for this platform
Sequence of project file formats
(needs confirmation) Currently returns incomplete process names in Process.GetProcesses() so we need to parse 'ps' output.
(needs confirmation) Currently returns incomplete list of modules for Process.Modules so we need to parse vmmap output.
(needs confirmation) Currently returns incomplete process names in Process.GetProcesses() so we need to use /proc
(also, locks up during process traversal sometimes, trying to open /dev/snd/pcm*)
(needs confirmation) Currently returns incomplete list of modules for Process.Modules so we need to parse /proc/PID/maps.
(also, locks up during process traversal sometimes, trying to open /dev/snd/pcm*)
Holds information about the current engine version
The major engine version (5 for UE5)
The minor engine version
The hotfix/patch version
The changelist that the engine is being built from
The changelist that the engine maintains compatibility with
Whether the changelist numbers are a licensee changelist
Whether the current build is a promoted build, that is, built strictly from a clean sync of the given changelist
Name of the current branch, with '/' characters escaped as '+'
The current build id. This will be generated automatically whenever engine binaries change if not set in the default Engine/Build/Build.version.
The build version string
Optional URL for a continuous integration job associated with this build version. (e.g. the job that build a set of binaries)
Returns the value which can be used as the compatible changelist. Requires that the regular changelist is also set, and defaults to the
regular changelist if a specific compatible changelist is not set.
Try to read a version file from disk
Path to the version file
The version information
True if the version was read successfully, false otherwise
Get the default path to the build.version file on disk
Path to the Build.version file
Get the default path for a target's version file.
The output directory for the executable. For MacOS, this is the directory containing the app bundle.
Name of the target being built
Platform the target is being built for
The configuration being built
Architecture of the target being built
Path to the target's version file
Parses a build version from a JsonObject
The object to read from
The resulting version field
True if the build version could be read, false otherwise
Exports this object as Json
The filename to write to
Exports this object as Json
The filename to write to
Logger for output
Exports this object as Json
Writer for output text
Exports this object as Json
The json writer to receive the version settings
True if the build version could be read, false otherwise
Read-only wrapper for a BuildVersion instance
The inner build version
Cached copy of the current build version
Constructor
The writable build version instance
Gets the current build version
Accessors for fields on the inner BuildVersion instance
Functions for parsing command line arguments
Stores information about the field to receive command line arguments
Prefix for the argument.
Field to receive values for this argument
The attribute containing this argument's info
Constructor
Parse the given list of arguments and apply them to the given object
List of arguments. Parsed arguments will be removed from this list when the function returns.
Object to receive the parsed arguments. Fields in this object should be marked up with CommandLineArgumentAttribute's to indicate how they should be parsed.
Parse the given list of arguments and apply them to the given object
List of arguments. Parsed arguments will be removed from this list when the function returns.
Object to receive the parsed arguments. Fields in this object should be marked up with CommandLineArgumentAttribute's to indicate how they should be parsed.
Logger for output
Parse the given list of arguments, and remove any that are parsed successfully
List of arguments. Parsed arguments will be removed from this list when the function returns.
Object to receive the parsed arguments. Fields in this object should be marked up with CommandLineArgumentAttribute's to indicate how they should be parsed.
Logger for output
Checks that the list of arguments is empty. If not, throws an exception listing them.
List of remaining arguments
Logger for output
Parses and assigns a value to a field
The parameter being parsed
Argument text
The target object to assign values to
Maps assigned fields to the parameter that wrote to it. Used to detect duplicate and conflicting arguments.
Logger for output
Attempts to parse the given string to a value
Type of the field to convert to
The value text
On success, contains the parsed object
True if the text could be parsed, false otherwise
Caches config files and config file hierarchies
Delegate to add a value to an ICollection in a target object
The object containing the field to be modified
The value to add
Caches information about a member with a [ConfigFile] attribute in a type
The attribute instance
For fields implementing ICollection, specifies the element type
For fields implementing ICollection, a callback to add an element type.
Constructor
Returns Reflection.MemberInfo describing the target class member.
Returns Reflection.Type of the target class member.
Returns the value setter of the target class member.
Returns the value getter of the target class member.
Caches information about a field with a [ConfigFile] attribute in a type
Reflection description of the field with the config attribute.
Constructor
Caches information about a property with a [ConfigFile] attribute in a type
Reflection description of the property with the config attribute.
Constructor
Allowed modification types allowed for default config files
Used for non-array types, this will replace a setting, or it will add a setting if it doesn't exist
Used to add an array entry to the end of any existing array entries, or will add to the end of the section
Stores information identifying a unique config hierarchy
The hierarchy type
The project directory to read from
Which platform-specific files to read
Custom config subdirectory to load
Custom override strings
A hotfix directory where modifications/additions to config files can be read from
If specified, this hierarchy will include plugins enabled for the given target type
Constructor
The hierarchy type
The project directory to read from
Which platform-specific files to read
Custom config subdirectory to load
Custom override strings
A hotfix directory where modifications/additions to config files can be read from
If specified, this hierarchy will unclude plugins enabled for the given target type
Test whether this key is equal to another object
The object to compare against
True if the objects match, false otherwise
Returns a stable hash of this object
Hash value for this object
Cache of individual config files
Cache of config hierarchies by project
Cache of config fields by type
Attempts to read a config file (or retrieve it from the cache)
Location of the file to read
On success, receives the parsed config file
True if the file exists and was read, false otherwise
Reads a config hierarchy (or retrieve it from the cache)
The type of hierarchy to read
The project directory to read the hierarchy for
Which platform to read platform-specific config files for
Optional override config directory to search, for support of multiple target types
Optional list of command line arguments added to the existing command line arguments
A hotfix directory where modifications/additions to config files can be read from
If specified, this hierarchy will unclude plugins enabled for the given target type
The requested config hierarchy
Reads a config hierarchy (or retrieve it from the cache)
The type of hierarchy to read
The project directory to read the hierarchy for
Which platform to read platform-specific config files for
Optional override config directory to search, for support of multiple target types
The command line arguments to parse
A hotfix directory where modifications/additions to config files can be read from
If specified, this hierarchy will unclude plugins enabled for the given target type
The requested config hierarchy
Gets a list of ConfigFields for the given type
Type to get configurable fields for
List of config fields for the given type
Read config settings for the given object
Path to the project directory
The platform being built
Object to receive the settings
Optional override config directory to search, for support of multiple target types
Read config settings for the given object
Path to the project directory
The platform being built
Object to receive the settings
Will be populated with config values that were retrieved. May be null.
Command line arguments, if null the application's command line arguments will be used
Optional override config directory to search, for support of multiple target types
Attempts to parse the given text into an object which matches a specific field type
The text to parse
The type of field to parse
If successful, a value of type 'FieldType'
True if the value could be parsed, false otherwise
Calculates the path to where the project's Default config of the type given (ie DefaultEngine.ini)
Game, Engine, etc
Project directory, used to find Config/Default[Type].ini
Calculates the path to where the project's platform specific config of the type given (ie DefaultEngine.ini)
Game, Engine, etc
Project directory, used to find Config/Default[Type].ini
Platform name
Updates a section in a Default***.ini, and will write it out. If the file is not writable, p4 can attempt to check it out.
Game, Engine, etc
Project directory, used to find Config/Default[Type].ini
How to modify the secion
Name of the section with the Key in it
Key to update
Value to write for te Key
Logger for output
Updates a section in a Default***.ini, and will write it out. If the file is not writable, p4 can attempt to check it out.
Game, Engine, etc
Project directory, used to find Config/Default[Type].ini
Platform name. Must have a directory under projects Platforms subdirectory
How to modify the secion
Name of the section with the Key in it
Key to update
Value to write for te Key
Logger for output
Updates a section in config file, and will write it out. If the file is not writable, p4 can attempt to check it out.
Config file (.ini) name
How to modify the secion
Name of the section with the Key in it
Key to update
Value to write for te Key
Logger for output
Invalidates the hierarchy internal caches so that next call to ReadHierarchy will re-read from disk
but existing ones will still be valid with old values
Specifies the action to take for a config line, as denoted by its prefix.
Assign the value to the key
Add the value to the key (denoted with +X=Y in config files)
Remove the key without having to match value (denoted with !X in config files)
Remove the matching key and value (denoted with -X=Y in config files)
Contains a pre-parsed raw config line, consisting of action, key and value components.
The action to take when merging this key/value pair with an existing value
Name of the key to modify
Value to assign to the key
Whether to preserve enclosing quotations around
Constructor.
Action to take when merging this key/value pair with an existing value
Name of the key to modify
Value to assign
Constructor.
Action to take when merging this key/value pair with an existing value
Name of the key to modify
Value to assign
Whether to preserve enclosing quotations around
Formats this object for the debugger
The original config line
Contains the lines which appeared in a config section, with all comments and whitespace removed
Name of the section
Lines which appeared in the config section
Construct an empty config section with the given name
Name of the config section
try to get a line using it's name, if the line doesn't exist returns false
Name of the line you want to get
The result of the operation
return true if the line is retrieved return false and null OutLine if Name isn't found in this section
Represents a single config file as stored on disk.
Maps names to config sections
Static (class) constructor which is called before any ConfigFile instance is created
Constructs a new, empty config file
The default action to take when encountering arrays without a '+' prefix
Reads config data from the given file.
File to read from
The default action to take when encountering arrays without a '+' prefix
Reads config data from the given string.
Single line string of config settings in the format [Section1]:Key1=Value1,[Section2]:Key2=Value2
The default action to take when encountering arrays without a '+' prefix
Try to parse a key/value pair from the given line, and add it to a config section
The section to receive the parsed config line
Optional map to change names of keys on read
Optional map to change names of keys on read
Text to parse
Index of the first non-whitespace character in this line
Index of the last (exclusive) non-whitespace character in this line
The default action to take if '+' or '-' is not specified on a config line
The sections to find the redirected section for receiving the config line
True if the line was parsed correctly, false otherwise
Names of sections in this file
Tries to get a config section by name, or creates one if it doesn't exist
Name of the section to look for
The config section
Tries to get a config section by name
Name of the section to look for
On success, the config section that was found
True if the section was found, false otherwise
Write the config file out to the given location. Useful for debugging.
The file to write
Attribute indicating a value which should be populated from a UE .ini config file
Name of the config hierarchy to read from
Section containing the setting
Key name to search for
Constructor
Type of the config hierarchy to read from
Section containing the setting
Key name to search for. Optional; uses the name of the field if not set.
Types of config file hierarchy
BaseGame.ini, DefaultGame.ini, etc...
BaseEngine.ini, DefaultEngine.ini, etc...
BaseEditor.ini, DefaultEditor.ini, etc...
BaseEditorPerProjectUserSettings.ini, DefaultEditorPerProjectUserSettings.ini, etc..
BaseEncryption.ini, DefaultEncryption.ini, etc..
BaseCrypto.ini, DefaultCrypto.ini, etc..
BaseEditorSettings.ini, DefaultEditorSettings.ini, etc...
BaseInstallBundle.ini, DefaultInstallBundle.ini, etc...
BasePakFileRules.ini, DefaultPakFileRules.ini, etc, etc....
Stores a set of merged key/value pairs for a config section
Map of key names to their values
Construct a merged config section from the given per-file config sections
Config sections from individual files
Returns a list of key names
Tries to find the value for a given key
The key name to search for
On success, receives the corresponding value
True if the key was found, false otherwise
Tries to find the values for a given key
The key name to search for
On success, receives a list of the corresponding values
True if the key was found, false otherwise
Encapsulates a hierarchy of config files, merging sections from them together on request
Array of
Cache of requested config sections
Lock for NameToSection
Construct a config hierarchy from the given files
Set of files to include (in order)
Names of all sections in all config files
Finds a config section with the given name
Name of the section to look for
The merged config section
Legacy function for ease of transition from ConfigCacheIni to ConfigHierarchy. Gets a bool with the given key name.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Legacy function for ease of transition from ConfigCacheIni to ConfigHierarchy. Gets an array with the given key name, returning null on failure.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Legacy function for ease of transition from ConfigCacheIni to ConfigHierarchy. Gets a string with the given key name, returning an empty string on failure.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Legacy function for ease of transition from ConfigCacheIni to ConfigHierarchy. Gets an int with the given key name.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single string value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single bool value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single Int32 value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single GUID value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single-precision floating point value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a double-precision floating point value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets an enumeration value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets all values associated with the specified key
Section where the key is located
Key name
Copy of the list containing all values associated with the specified key
True if the key exists
Gets the value for the given type. Can return a full struct hierarchy.
Section where the key is located
Key name
Value hierarchy associated with the specified key. All field names must exist
True if the key exists and could be parsed
Gets the array of values for the given type. Can return a full struct hierarchy.
Section where the key is located
Key name
Array of values associated with the specified key. All field names must exist
True if the key exists and could be parsed
Parse a string as a boolean value
The text to parse
The parsed value, if successful
True if the text was parsed, false otherwise
Parse a string as an integer value
The text to parse
The parsed value, if successful
True if the text was parsed, false otherwise
Parse a string as a GUID value
The text to parse
The parsed value, if successful
True if the text was parsed, false otherwise
Parse a string as a single-precision floating point value
The text to parse
The parsed value, if successful
True if the text was parsed, false otherwise
Parse a string as a double-precision floating point value
The text to parse
The parsed value, if successful
True if the text was parsed, false otherwise
Attempts to parse the given line as a UE config object (eg. (Name="Foo",Number=1234)).
Line of text to parse
Receives key/value pairs for the config object
True if an object was parsed, false otherwise
Attempts to parse the given line as a UE config array (eg. ("one", "two", "three") ).
Line of text to parse
Receives array for the config array
True if an array was parsed, false otherwise
Attempts to parse the given line as a UE map (eg. (("key1","value1"), ("key2","value2")).
Line of text to parse
Receives dictionary for the config map
True if a map was parsed, false otherwise
Returns a list of INI filenames for the given project
Returns a list of INI filenames for the given project
Determines the path to the generated config directory (same as FPaths::GeneratedConfigDir())
Determes the path to the game-agnostic saved directory (same as FPaths::GameAgnosticSavedDir())
Returns the platform name to use as part of platform-specific config files
Gets an ini setting, and then pulls the value for a property out of a struct, in the format:
[SomeSection]
SomeStruct=(Foo=Bar,Prop="My Value")
Ini section ('SomeSection' in this example)
Name of the struct setting ('SomeStruct' in this example)
Name of the property inside the struct ('Prop' in this example)
The value retrieved from the struct ('My Value' in this example), or null if anything was not found
Pulls the value for a property out of a struct in the given input, in the format:
(Foo=Bar,Prop="My Value")
The entire struct as retrieved from the ini via GetString()
Name of the property inside the struct ('Prop' in this example)
Pass true when the value pulled is an array, like (Foo=(X=1,Y=2)), this would return X=1,Y=2
The value retrieved from the struct ('My Value' in this example), or null if anything was not found
Gets an ini setting, and then pulls the value for a property out of a map, in the format:
[SomeSection]
SomeMap=((Foo=Bar),(SomeKey="My Value"))
Ini section ('SomeSection' in this example)
Name of the struct setting ('SomeMap' in this example)
Name of the key inside the struct ('SomeKey' in this example)
The value retrieved from the map ('My Value' in this example), or null if anything was not found
Pulls the value for a property out of a struct in the given input, in the format:
((Foo=Bar),(SomeKey="My Value"))
The entire struct as retrieved from the ini via GetString()
Name of the key inside the struct ('SomeKey' in this example). Key cannot have escaped quotes or commas
The value retrieved from the map ('My Value' in this example), or null if anything was not found
Load a ini value for the given key, then use GetStructKeyValuePairs to return the key/value pairs of the struct
Ini section to read from
Name of the ini key to read from
Dictionary of struct vars/values
Given a string input (a struct loaded from a .ini file usually), like (Foo=A, Bar="Hello world"), this will return a dictionary of all values, with quotes trimmed off
In this example, { { Foo, A } , { Bar, Hello world } }
String containing a struct representation
Dictionary of struct vars/values
Functionality for parsing values from a config value
Attempts to parse the given line as the given type. Struct member variables are expected to match
Type to attempt to parse
Line of text to parse
Receives parse result
True if the parse was successful, false otherwise
Attempts to parse the given line as the given template type
Line of text to parse
Receives parse result
True if the parse was successful, false otherwise
Attempts to parse the given array of lines as array of the given template type
Line of text to parse
Receives parse result
True if the parse was successful, false otherwise
Identifier for a config file key, including information about the hierarchy used to read it
The config hierarchy type
Project directory to read config files from
The platform being built
The section name
The key name
Constructor
The config hierarchy type
Project directory to read config files from
The platform being built
The section name
The key name
Construct a key from an archive
Archive to read from
Writes this key to an archive
Archive to write to
Tests whether this key is equal to another object
The object to compare to
True if the keys are equal, false otherwise
Tests whether this key is equal to another key
The key to compare to
True if the keys are equal, false otherwise
Gets a hash code for this object
Hash code for the object
Stores a list of config key/value pairs that have been read
The dependencies list
Constructor
Construct an object from an archive on disk
Archive to read from
Write the dependencies object to disk
Archive to write to
Checks whether the list of dependencies is still valid
Compiler configuration. This controls whether to use define debug macros and other compiler settings. Note that optimization level should be based on the bOptimizeCode variable rather than
this setting, so it can be modified on a per-module basis without introducing an incompatibility between object files or PCHs.
Specifies which language standard to use. This enum should be kept in order, so that toolchains can check whether the requested setting is >= values that they support.
Supports C++14. No longer supported, code may not compile with this version.
Supports C++17. No longer supported, code may not compile with this version.
Supports C++20
Latest standard supported by the compiler
Use the default standard version (BuildSettingsVersion.V1-V3: Cpp17, V4: Cpp20)
Use the default standard version for engine modules
Specifies which C language standard to use. This enum should be kept in order, so that toolchains can check whether the requested setting is >= values that they support.
Supports no additional standard version flag
Supports C89
Supports C99
Supports C11
Supports C17
Latest standard supported by the compiler
Use the default standard version
Specifies the architecture for code generation on x64 for windows platforms.
Note that by enabling this you are changing the minspec for the PC platform, and the resultant executable will crash on machines without AVX support.
For more details please see https://learn.microsoft.com/en-us/cpp/build/reference/arch-x64
No minimum architecure
Enables the use of Intel Advanced Vector Extensions instructions
Enables the use of Intel Advanced Vector Extensions 2 instructions
Enables the use of Intel Advanced Vector Extensions 512 instructions
Use the default minimum architecure
The optimization level that may be compilation targets for C# files.
The possible interactions between a precompiled header and a C++ file being compiled.
Encapsulates the compilation output of compiling a set of C++ files.
Encapsulates the environment that a C++ file is compiled in.
The platform to be compiled/linked for.
The configuration to be compiled/linked for.
The architecture that is being compiled/linked (empty string by default)
Gets the Architecture in the normal case where there is a single Architecture in Architectures
Cache of source file metadata
Templates for shared precompiled headers
The name of the header file which is precompiled.
Whether the compilation should create, use, or do nothing with the precompiled header.
Will replace pch with ifc and use header units instead
Whether artifacts from this compile are shared with other targets. If so, we should not apply any target-wide modifications to the compile environment.
Use run time type information
Whether to direct MSVC to remove unreferenced COMDAT functions and data.
zc-inline-remove-unreferenced-comdat
Use Position Independent Executable (PIE). Has an overhead cost
Use Stack Protection. Has an overhead cost
Enable inlining.
Whether to compile ISPC files.
Enable buffer security checks. This should usually be enabled as it prevents severe security risks.
Whether the AutoRTFM compiler is being used or not.
Disables AutoRTFM instrumentation to this cpp file only when AutoRTFMCompiler is enabled
Whether AutoRTFM instrumentation is enabled or not.
Whether AutoRTFM verification is enabled or not.
If unity builds are enabled this can be used to override if this specific module will build using Unity.
This is set using the per module configurations in BuildConfiguration.
The number of source files in this module before unity build will be activated for that module. If set to
anything besides -1, will override the default setting which is controlled by MinGameModuleSourceFilesForUnityBuild
The minimum number of files that must use a pre-compiled header before it will be created and used.
Module uses a #import so must be built locally when compiling with SN-DBS
Whether to retain frame pointers
Enable exception handling
Enable objective C exception handling
Enable objective C automatic reference counting (ARC)
If you set this to true you should not use shared PCHs for this module. The engine won't be extensively using ARC in the short term
Not doing this will result in a compile errors because shared PCHs were compiled with different flags than consumer
How to treat any warnings in the code
Whether to warn about deprecated variables
Whether to warn about the use of shadow variables
How to treat unsafe implicit type cast warnings (e.g., double->float or int64->int32)
Indicates what warning/error level to treat undefined identifiers in conditional expressions.
Whether to treat all warnings as errors
Whether to disable all static analysis - Clang, MSVC, PVS-Studio.
Enable additional analyzer extension warnings using the EspXEngine plugin. This is only supported for MSVC.
See https://learn.microsoft.com/en-us/cpp/code-quality/using-the-cpp-core-guidelines-checkers
This will add a large number of warnings by default. It's recommended to use StaticAnalyzerRulesets if this is enabled.
The static analyzer rulesets that should be used to filter warnings. This is only supported for MSVC.
See https://learn.microsoft.com/en-us/cpp/code-quality/using-rule-sets-to-specify-the-cpp-rules-to-run
The static analyzer checkers that should be enabled rather than the defaults. This is only supported for Clang.
The static analyzer default checkers that should be disabled. Unused if StaticAnalyzerCheckers is populated. This is only supported for Clang.
The static analyzer non-default checkers that should be enabled. Unused if StaticAnalyzerCheckers is populated. This is only supported for Clang.
The PVS Studio analysis warnings that should be disabled.
True if compiler optimizations should be enabled. This setting is distinct from the configuration (see CPPTargetConfiguration).
True if the compilation should produce tracing output for code coverage.
Allows to fine tune optimizations level for speed and\or code size
Determines the FP semantics.
True if debug info should be created.
True if debug info should only generate line number tables (clang)
True if we're compiling .cpp files that will go into a library (.lib file)
True if we're compiling a DLL
Whether we should compile using the statically-linked CRT. This is not widely supported for the whole engine, but is required for programs that need to run without dependencies.
Whether to use the debug CRT in debug configurations
Whether to omit frame pointers or not. Disabling is useful for e.g. memory profiling on the PC
Whether we should compile with support for OS X 10.9 Mavericks. Used for some tools that we need to be compatible with this version of OS X.
Whether PDB files should be used for Visual C++ builds.
Whether to just preprocess source files
Should an assembly file be generated while compiling. Works exclusively on MSVC compilers for now.
Whether to support edit and continue. Only works on Microsoft compilers in 32-bit compiles.
Whether to use incremental linking or not.
Whether to allow the use of LTCG (link time code generation)
Whether to enable Profile Guided Optimization (PGO) instrumentation in this build.
Whether to optimize this build with Profile Guided Optimization (PGO).
Platform specific directory where PGO profiling data is stored.
Platform specific filename where PGO profiling data is saved.
Whether to log detailed timing info from the compiler
When enabled, allows XGE to compile pre-compiled header files on remote machines. Otherwise, PCHs are always generated locally.
Ordered list of include paths for the module
The include paths where changes to contained files won't cause dependent C++ source files to
be recompiled, unless BuildConfiguration.bCheckSystemHeadersForModification==true.
The include paths which were previously in UserIncludePaths, but are now in a shared response file, persisted in the environment for validation.
Do not add to this set unless a shared response is in use, and only when removing those headers from UserIncludePaths.
The include paths which were previously in SystemIncludePaths, but are now in a shared response file, persisted in the environment for validation.
Do not add to this set unless a shared response is in use, and only when removing those headers from SystemIncludePaths.
Enumerable of all possible include paths
List of paths to search for compiled module interface (*.ifc) files
Whether headers in system paths should be checked for modification when determining outdated actions.
List of header files to force include
List of files that need to be up to date before compile can proceed
A dictionary of the source file items and the inlined gen.cpp files contained in it
Non-default naming conventions that generated CPP files can have (this uses a filter to check the file name for matches)
FileItems with colliding names. (Which means they would overwrite each other in intermediate folder
The C++ preprocessor definitions to use.
Additional response files that will be used by main response file
Whether the compile environment has a response file in AdditionalResponseFiles that contains global compiler arguments.
Additional arguments to pass to the compiler.
A list of additional frameworks whose include paths are needed.
A dictionary of PCH files for multiple architectures
The instance containing the precompiled header data.
The file containing the precompiled header data.
The parent PCH instance used when creating this PCH.
The parent's PCH header file.
True if a single PRecompiledHeader exists, or at least one PerArchPrecompiledHeaderFile exists
Whether or not UHT is being built
Whether to hide symbols by default
Whether this environment should be treated as an engine module.
Which C++ standard to support for engine modules. CppStandard will be set to this for engine modules and CppStandardEngine should not be checked in any toolchain. May not be compatible with all platforms.
Which C++ standard to support. May not be compatible with all platforms.
Which C standard to support. May not be compatible with all platforms.
Direct the compiler to generate AVX instructions wherever SSE or AVX intrinsics are used.
Note that by enabling this you are changing the minspec for the PC platform, and the resultant executable will crash on machines without AVX support.
The amount of the stack usage to report static analysis warnings.
Enable C++ coroutine support.
For MSVC, adds "/await:strict" to the command line. Program should #include <coroutine>
For Clang, adds "-fcoroutines-ts" to the command line. Program should #include <experimental/coroutine> (not supported in every clang toolchain)
What version of include order specified by the module rules. Used to determine shared PCH variants.
Set flags for determinstic compiles.
Set flags for determinstic compile warnings.
Emits compilation errors for incorrect UE_LOG format strings.
Emits deprecated warnings\errors for internal API usage for non-engine modules.
Directory where to put crash report files for platforms that support it
Default constructor.
Copy constructor.
Environment to copy settings from
Reads the contents of C++ dependency files, and caches them for future iterations.
Contents of a single dependency file
The current file version
Location of this dependency cache
Directory for files to cache dependencies for.
Map from file item to dependency info
Whether the cache has been modified and needs to be saved
Constructs a dependency cache. This method is private; call CppDependencyCache.Create() to create a cache hierarchy for a given project.
File to store the cache
Base directory for files that this cache should store data for
Logger for output
Reads data for this dependency cache from disk
Writes data for this dependency cache to disk
List of partitions
Static cache of all constructed dependency caches
Minimum version of a MSVC source dependency json
Minimum version of a MSVC source dependency json that supports additional module info
Constructs a dependency cache. This method is private; call CppDependencyCache.Create() to create a cache hierarchy for a given project.
Gets the produced module from a dependencies file
The dependencies file
Logger for output
The produced module name
True if a produced module was found
Attempts to get a list of imported modules for the given file
The dependency file to query
Logger for output
List of imported modules
True if a list of imported modules was obtained
Attempts to read the dependencies from the given input file
File to be read
Logger for output
Receives a list of output items
True if the input file exists and the dependencies were read
Attempts to read the dependencies from the given input file
File to be read
Logger for output
The dependency info
True if the input file exists and the dependencies were read
Attempts to read dependencies from the given file.
File to be read
The dependency info
True if the input file exists and the dependencies were read
Attempts to read the dependencies from the given input file. This static version will not use any caches.
File to be read
Receives a list of output items
True if the input file exists and the dependencies were read
Creates a cache hierarchy for a particular target
Target descriptor being built
The target type
Logger for output
Dependency cache hierarchy for the given project
Creates a cache hierarchy for a particular target
Project file for the target being built
Name of the target
Platform being built
Configuration being built
The target type
The target architectures
Intermediate environment to use
Logger for output
Dependency cache hierarchy for the given project
Reads a cache from the given location, or creates it with the given settings
File to store the cache
Base directory for files that this cache should store data for
Logger for output
Reference to a dependency cache with the given settings
Save all the caches that have been modified
Reads dependencies from the given file.
The file to read from
List of included dependencies
Attempts to read a single token from a makefile
Text to read from
Current position within the file
Receives the token characters
True if a token was read, false if the end of the buffer was reached
Builds a reverse lookup table for finding all source files that includes a set of headers
Parses include directives from cpp source files, to make dedicated PCHs
Copies include directives from one file to another, until an unsafe directive (or non-#include line) is found.
Stream to read from
Stream to write directives to
Reads an individual token from the input stream
Stream to read from
Buffer to store token read from the stream
True if a token was read, false otherwise
Stores custom build steps to be executed by a project or plugin
Construct a custom build steps object from a Json object.
Reads a list of build steps from a Json project or plugin descriptor
The json descriptor object
Name of the field to read
Output variable to store the sorted dictionary that was read
True if the field was read (and OutBuildSteps is set), false otherwise.
Reads a list of build steps from a Json project or plugin descriptor
Writer to receive json output
Name of the field to read
True if the field was read (and OutBuildSteps is set), false otherwise.
Converts this object to a JsonObject to be saved or manipulated.
The JsonObject representation of this object.
Tries to get the commands for a given host platform
The host platform to look for
Array of commands
True if a list of commands was generated
Class to manage looking up data driven platform information (loaded from .ini files instead of in code)
All data driven information about a platform
Is the platform a confidential ("console-style") platform
Is the platform enabled on this host platform
If true, this platform can stage the crashreporter
Additional restricted folders for this platform.
the compression format that this platform wants; overrides game unless bForceUseProjectCompressionFormat
The online account can't be set from the command line
Entire ini parent chain, ending with this platform
The raw DataDrivenPlatformInfo.ini file
Return all data driven infos found
Return the data driven info for the given platform name
Return the data driven info for the given UnrealTargetPlatform
General deploy support functions, exported for UAT
The max length of the deploy folder name.
Gets the default deploy folder name on the format ShortProjectName-RootDirectoryName-UserName,
truncated to DeployFolderMaxLength characters, with dots '.' and whitespace ' ' stripped.
Project to deploy
The default deploy folder name.
Methods for dynamically compiling C# source files
Checks to see if the assembly needs compilation
Set of source files
File containing information about this assembly, like which source files it was built with and engine version
Output path for the assembly
Logger for output
True if the assembly needs to be built
Dynamically compiles an assembly for the specified source file and loads that assembly into the application's
current domain. If an assembly has already been compiled and is not out of date, then it will be loaded and
no compilation is necessary.
Full path to the assembly to be created
List of source file name
Logger for output
The assembly that was loaded
Helper functions for dealing with encryption and pak signing
Wrapper class for a single RSA key
Exponent
Modulus
Determine if this key is valid
Wrapper class for an RSA public/private key pair
Public key
Private key
Determine if this key is valid
Returns TRUE if this is a short key from the old 256-bit system
Wrapper class for a 128 bit AES encryption key
Optional name for this encryption key
Optional guid for this encryption key
AES key
Determine if this key is valid
Wrapper class for all crypto settings
AES encyption key
RSA public/private key
Enable pak signature checking
Encrypt the index of the pak file. Stops the pak file being easily accessible by unrealpak
Encrypt all ini files in the pak. Good for game data obsfucation
Encrypt the uasset files in the pak file. After cooking, uasset files only contain package metadata / nametables / export and import tables. Provides good string data obsfucation without
the downsides of full package encryption, with the security drawbacks of still having some data stored unencrypted
Encrypt all assets data files (including exp and ubulk) in the pak file. Likely to be slow, and to cause high data entropy (bad for delta patching)
Some platforms have their own data crypto systems, so allow the config settings to totally disable our own crypto
Config setting to enable pak encryption
Config setting to enable pak signing
A set of named encryption keys that can be used to encrypt different sets of data with a different key that is delivered dynamically (i.e. not embedded within the game executable)
Returns whether the specified encryption key exist.
Helper class for formatting incoming hex signing key strings
Helper function for comparing two AES keys
Parse crypto settings from INI file
Take a hex string and parse into an array of bytes
Information about a module that needs to be passed to UnrealHeaderTool for code generation
Module name
Path to the module rules file
Paths to all potential module source directories (with platform extension directories added in)
The include search path for generated headers to include other headers
Module type
Overridden package module type to add more flags
Public UObject headers found in the Classes directory (legacy)
Public headers with UObjects
Internal headers with UObjects
Private headers with UObjects
Directory containing generated code
Collection of the module's public defines
Path and base filename, without extension, of the .gen files
Version of code generated by UHT
Whether this module is read-only
Path of the verse generated types
Scope of the verse definitions
If true, verse scripts were found
Verse plugin name
This handles all running of the UnrealHeaderTool
Gets the module type for a given rules object
The rules object
Descriptor for the project being built
The module type
Find all the headers under the given base directory, excluding any other platform folders.
Base directory to search
Array of folders to exclude
Receives the list of headers that was found
Gets UnrealHeaderTool.exe path. Does not care if UnrealheaderTool was build as a monolithic exe or not.
Gets the latest write time of any of the UnrealHeaderTool binaries (including DLLs and Plugins) or DateTime.MaxValue if UnrealHeaderTool does not exist
Latest timestamp of UHT binaries or DateTime.MaxValue if UnrealHeaderTool is out of date and needs to be rebuilt.
Gets the timestamp of CoreUObject.gen.cpp file.
Last write time of CoreUObject.gen.cpp or DateTime.MaxValue if it doesn't exist.
Checks the class header files and determines if generated UObject code files are out of date in comparison.
Build configuration
Modules that we generate headers for
Timestamp for UHT
Logger for output
True if the code files are out of date
Determines if any external dependencies for generated code is out of date
Path to the external dependencies file
True if any external dependencies are out of date
Updates the recorded timestamps of all the passed in UObject modules
Run an external native executable (and capture the output), given the executable path and the commandline.
Simple function to pipe output asynchronously
Builds and runs the header tool and touches the header directories.
Performs any early outs if headers need no changes, given the UObject modules, tool path, game name, and configuration
Return the file reference for the UHT manifest file
Input makefile
Name of the target
Manifest file name
Return the file reference for the UHT deps file
Manifest info file name
UHT dependency file name
Convert the makefile to a UHTManifest object
Input makefile
Name of the target
Name of the dependencies file.
Output UHT manifest
Write the manifest to disk
Input makefile
Name of the target
Destination file name. If not supplied, it will be generated.
Name of the dependencies file. If not supplied, it will be generated.
Return the latest of two date/times
First date/time to compare
Second date/time to compare
Latest of the two dates
Builds and runs the header tool and touches the header directories.
Performs any early outs if headers need no changes, given the UObject modules, tool path, game name, and configuration
Prefetches metadata from the filesystem, by populating FileItem and DirectoryItem objects for requested directory trees. Since
Queue for tasks added to the thread pool
Used to cancel any queued tasks
The cancellation token
Set of all the directory trees that have been queued up, to save adding any more than once.
Enqueue the engine directory for prefetching
Enqueue a project directory for prefetching
The project directory to prefetch
Enqueue a directory tree for prefetching
Directory to start searching from
Wait for the prefetcher to complete all reqeusted tasks
Stop prefetching items, and cancel all pending tasks. synchronous.
Enqueue a task which checks for the cancellation token first
Action to enqueue
Scans the engine directory, adding tasks for subdirectories
Scans a project directory, adding tasks for subdirectories
The project directory to search
Scans a plugin parent directory, adding tasks for subdirectories
The directory which may contain plugin directories
Scans an arbitrary directory tree
Root of the directory tree
A single "node" in a directed graph
Describes an edge in the directed graph
Attribute for a graph node
Gexf ID for this attribute
Name of the attribute
Gexf type name
Writes a GEXF graph file for the specified graph nodes and edges
The file name to write
The description to include in the graph file's metadata
List of all graph nodes. Index order is important and must match with the individual node Id members!
List of all graph edges. Index order is important and must match with the individual edge Id members!
The current hot reload mode
Stores the current hot reload state, tracking temporary files created by previous invocations.
Suffix to use for the next hot reload invocation
Map from original filename in the action graph to hot reload file
Set of all temporary files created for hot reload
Adds all the actions into the hot reload state, so we can restore the action graph on next iteration
The actions being executed
Mapping from file from their original location (either a previously hot-reloaded file, or an originally compiled file)
Gets the location of the hot-reload state file for a particular target
Descriptor for the target
Location of the hot reload state file
Gets the location of the hot-reload state file for a particular target
Project containing the target
Name of the target
Platform being built
Configuration being built
Architecture(s) being built
Location of the hot reload state file
Read the hot reload state from the given location
Location to read from
New hot reload state instance
Writes the state to disk
Location to write to
Contents of the JSON version of the live coding modules file
These modules have been loaded by a process and are enabled for patching
These modules have been loaded by a process, but not explicitly enabled
Getts the default hot reload mode for the given target
The target being built
Makefile for the target
Global build configuration
Logger for output
Default hotreload mode
Sets the appropriate hot reload mode for a target, and cleans up old state.
The target being built
Makefile for the target
Actions for this target
Global build configuration
Logger for output
Checks whether a live coding session is currently active for a target. If so, we don't want to allow modifying any object files before they're loaded.
Makefile for the target being built
Logger for output
True if a live coding session is active, false otherwise
Checks if the editor is currently running and this is a hot-reload
Delete all temporary files created by previous hot reload invocations
Location of the state file
Logger for output
Apply a saved hot reload state to a makefile
The hot-reload state
Makefile to apply the state
Actions for this makefile
Given a collection of strings which are file paths, create a hash set from the file name and extension.
Empty strings are eliminated.
Source collection
Trimmed and unique collection
Determine what needs to be built for a target
The build configuration
Target being built
Makefile generated for this target
The actions to execute
Actions to execute for this target
Collection of all the renamed as part of module reload requests. Can be null
Logger for output
Set of actions to execute
Replaces a hot reload suffix in a filename.
Replaces a base filename within a string. Ensures that the filename is not a substring of another longer string (eg. replacing "Foo" will match "Foo.Bar" but not "FooBar" or "BarFooBar").
Text to replace within
Old filename
New filename
Text with file names replaced
Determines if a character should be treated as part of a base filename, when updating strings for hot reload
The character to check
True if the character is part of a base filename, false otherwise
Test to see if the action is an action live coding supports. All other actions will be filtered
Action in question
True if the action is a compile action for the compiler. This filters out RC compiles.
Patches a set of actions for use with live coding. The new action list will output object files to a different location.
Set of actions
Dictionary that receives a map of original object file to patched object file
Requested hot reload mode
Patch the action graph for hot reloading, mapping files according to the given dictionary.
Patches a set of actions to use a specific list of suffixes for each module name
Map of module name to suffix
Makefile for the target being built
Actions to be executed for this makefile
Collection of file names patched. Can be null.
Writes a manifest containing all the information needed to create a live coding patch
File to write to
List of actions that are part of the graph
Map of original object files to patched object files
The project type that support is required for
Support for code projects
Support for deploying content projects
The state of a downloaded platform
Query whether the platform is supported
Query whether the platform has been downloaded
Contains methods to allow querying the available installed platforms
Information about a single installed platform configuration
Build Configuration of this combination
Platform for this combination
Type of Platform for this combination
Architecture for this combination
Location of a file that must exist for this combination to be valid (optional)
Type of project this configuration can be used for
Whether to display this platform as an option even if it is not valid
Constructor
Initializes the InstalledPlatformInfo. While this is not necessary to be called, it allows timing the static constructor call.
Determine if the given configuration is available for any platform
Configuration type to check
The type of project
True if supported
Determine if the given platform is available
Platform to check
The type of project
True if supported
Determine whether the given platform/configuration/project type combination is supported
Configuration for the project
Platform for the project
Type of the project
True if the combination is supported
Determines whether the given target type is supported
The target type being built
The platform being built
The configuration being built
The project type required
State of the given platform support
True if the target can be built
Loads JunkManifest.txt file and removes all junk files/folders defined in it.
Loads JunkManifest.txt file.
Junk manifest file contents.
Goes through each entry from the junk manifest and deletes it.
JunkManifest.txt entries.
Logger for output
Deletes a directory recursively gracefully handling all exceptions.
Path.
Logger for output
Deletes a file gracefully handling all exceptions.
Filename.
Logger for output
Encapsulates the environment that is used to link object files.
The platform to be compiled/linked for.
The configuration to be compiled/linked for.
The architecture that is being compiled/linked (empty string by default)
Gets the Architecture in the normal case where there is a single Architecture in Architectures
On Mac, indicates the path to the target's application bundle
The directory to put the non-executable files in (PDBs, import library, etc)
Intermediate file directory
The directory to shadow source files in for syncing to remote compile servers
The file path for the executable file that is output by the linker.
Returns the OutputFilePath is there is only one entry in OutputFilePaths
List of libraries to link in
A list of additional libraries to link in (using the list of library search paths)
A list of the paths used to find libraries.
A list of libraries to exclude from linking.
Paths to add as search paths for runtime libraries
A list of additional frameworks to link in.
The iOS/Mac frameworks to link in
iOS/Mac resources that should be copied to the app bundle
A list of the dynamically linked libraries that shouldn't be loaded until they are first called
into.
Per-architecture lists of dependencies for linking to ignore (useful when building for multiple architectures, and a lib only is needed for one architecture), it's up to the Toolchain to use this
Additional arguments to pass to the linker.
True if debug info should be created.
True if runtime symbols files should be generated as a post build step for some platforms.
These files are used by the engine to resolve symbol names of callstack backtraces in logs.
True if debug symbols that are cached for some platforms should not be created.
True if we're compiling .cpp files that will go into a library (.lib file)
True if we're compiling a DLL
The method of linking the target uses
Whether we should compile using the statically-linked CRT. This is not widely supported for the whole engine, but is required for programs that need to run without dependencies.
Whether to use the debug CRT in debug configurations
True if this is a console application that's being build
If set, overrides the program entry function on Windows platform. This is used by the base Unreal
program so we can link in either command-line mode or windowed mode without having to recompile the Launch module.
True if we're building a EXE/DLL target with an import library, and that library is needed by a dependency that
we're directly dependent on.
True if the application we're linking has any exports, and we should be expecting the linker to
generate a .lib and/or .exp file along with the target output file
True if we're building a .NET assembly (e.g. C# project)
The default stack memory size allocation
The amount of the default stack size to commit initially. Set to 0 to allow the OS to decide.
Wether to link code coverage / tracing libs
Whether to omit frame pointers or not. Disabling is useful for e.g. memory profiling on the PC
Whether to support edit and continue. Only works on Microsoft compilers in 32-bit compiles.
Whether to use incremental linking or not.
Whether to allow the use of LTCG (link time code generation)
Whether to enable Profile Guided Optimization (PGO) instrumentation in this build.
Whether to optimize this build with Profile Guided Optimization (PGO).
Platform specific directory where PGO profiling data is stored.
Platform specific filename where PGO profiling data is saved.
Platform specific filename where pre-merged PGO profiling data is saved.
Whether to request the linker create a map file as part of the build
Whether PDB files should be used for Visual C++ builds.
Whether to use the :FASTLINK option when building with /DEBUG to create local PDBs
Use Position Independent Executable (PIE). Has an overhead cost
Whether to ignore dangling (i.e. unresolved external) symbols in modules
Set flags for determinstic compiles.
Whether to log detailed timing information
Package full path (directory + filename) where to store input files used at link time
Normally used to debug a linker crash for platforms that support it
Directory where to put crash report files for platforms that support it
Directory where to put the ThinLTO cache for platforms that support it
Arguments that will be applied to prune the ThinLTO cache for platforms that support it.
The arguments will only be applied if ThinLTOCacheDirectory is set.
Bundle version for Mac apps
When building a dynamic library on Apple platforms, specifies the installed name for other binaries that link against it.
A list of the object files to be linked.
The default resource file to link in to every binary if a custom one is not provided
Resource files which should be compiled into every binary
List of functions that should be exported from this module
Debugger visualizer files to build into debug info for this binary.
Provides a Module Definition File (.def) to the linker to describe various attributes of a DLL.
Necessary when exporting functions by ordinal values instead of by name.
All the additional properties from the modules linked into this binary
List of all of the runtime dependencies.
Default constructor.
Copy constructor.
Construct a LinkEnvironment from another, and filter it down to only files/dependencies that apply to the given architecture
Parent LinkEnvironment to start with that may have been created from multiple architectures (arch1+arch2)
The single architecture to filter down to
Manifest file (.loadorder) describing the order in which all dynamic modules should be loaded.
For this reason, it's only relevant to modular builds on some platforms.
This file exists because on some non-Windows platforms dynamic modules (such as DLLs) don't support
dependencies and it's our responsibility to load them in the right order (Windows DLLs know which other
DLLs they rely on and these dependencies are guaranteed to be loaded first).
If we fail respect this order, we're likely to get crashes e.g. when global statics are being initialized
because some dereferenced globals may not be available yet (null).
List of all project's dynamic modules in the order in which they should be loaded.
All paths are relative to the main binary's directory.
Gets a filename for a load order manifest for a build with the given platform/configuration.
The modular app name being built
The target configuration
The target platform
The architecture of the target platform
Filename for the app receipt
Read the load order manifest from a file.
Filename to read from
The receipt that was read
Write the load order manifest to a file.
Filename to write to
Write the load order manifest to a text writer.
The writer to output to
How this localization target should be generated during the localization gather pipeline
This localization target should never have localization config files associated with it during the localization gather pipeline.
This localization target should only use user generated localization config files during the localization gather pipeline.
Default auto-generated localization config files will be used to generate the localization target and localization content files during the localization gather pipeline
Description of a localization target.
Name of this target
When should the localization data associated with a target should be loaded?
How should this localization target's localization config files be generated during a localization gather.
Constructor
Name of the target
When should the localization data associated with a target should be loaded?
Constructor
The name of the localization target.
When the localization data associated with this localization target should be loaded.
How the localization config files should be generated during a localization gather to create the localization data files.
Constructs a LocalizationTargetDescriptor from a Json object
The new localization target descriptor
Write this target to a JsonWriter
Writer to output to
Write an array of target descriptors
The Json writer to output to
Name of the array
Array of targets
Updates a JsonObject with an array of localization target descriptors.
The Json object to update.
Name of the array
Array of targets
The type of host that can load a module
Any target using the UE runtime
Any target except for commandlet
Any target or program
Loaded only in cooked builds
Loaded only in uncooked builds
Loaded only when the engine has support for developer tools enabled
Loads on any targets where bBuildDeveloperTools is enabled
Loaded only by the editor
Loaded only by the editor, except when running commandlets
Loaded by the editor or program targets
Loaded only by programs
Loaded only by servers
Loaded only by clients, and commandlets, and editor....
Loaded only by clients and editor (editor can run PIE which is kinda a commandlet)
External module, should never be loaded automatically only referenced
Indicates when the engine should attempt to load this module
Loaded at the default loading point during startup (during engine init, after game modules are loaded.)
Right after the default phase
Right before the default phase
Loaded as soon as plugins can possibly be loaded (need GConfig)
Loaded before the engine is fully initialized, immediately after the config system has been initialized. Necessary only for very low-level hooks
The first screen to be rendered after system splash screen
After PostConfigInit and before coreUobject initialized. used for early boot loading screens before the uobjects are initialized
Loaded before the engine is fully initialized for modules that need to hook into the loading screen before it triggers
After the engine has been initialized
Do not automatically load this module
Class containing information about a code module
Name of this module
Usage type of module
When should the module be loaded during the startup sequence? This is sort of an advanced setting.
List of allowed platforms
List of disallowed platforms
List of allowed targets
List of disallowed targets
List of allowed target configurations
List of disallowed target configurations
List of allowed programs
List of disallowed programs
List of allowed game targets
List of disallowed game targets
List of additional dependencies for building this module.
When true, an empty PlatformAllowList is interpreted as 'no platforms' with the expectation that explicit platforms will be added in plugin extensions */
Constructor
Name of the module
Type of target that can host this module
Constructs a ModuleDescriptor from a Json object
The new module descriptor
Write this module to a JsonWriter
Writer to output to
Write an array of module descriptors
The Json writer to output to
Name of the array
Array of modules
Updates a JsonObject with an array of module descriptors
The JsonObject to update.
Name of the array
Array of modules
Produces any warnings and errors for the module settings
File containing the module declaration
Determines whether the given plugin module is part of the current build.
The platform being compiled for
The target configuration being compiled for
Name of the target being built
The type of the target being compiled
Whether the configuration includes developer tools (typically UEBuildConfiguration.bBuildDeveloperTools for UBT callers)
Whether the configuration requires cooked content (typically UEBuildConfiguration.bBuildRequiresCookedData for UBT callers)
Attribute which can be applied to a ModuleRules-dervied class to indicate which module groups it belongs to
Array of module group names
Initialize the attribute with a list of module groups
Variable-length array of module group arguments
Stores the version (or a unique build ID) for the modules for a target in a certain folder.
This allows the runtime to identify which modules are used for which files, and which version they're at. This prevents stale binaries from being
loaded by the runtime when making a local unversioned build, and allows faster incremental builds than compiling the build changelist into every
module when making versioned builds.
Unique build id for the modules described in the manifest.
Map of module name to file name.
Constructs the module map with the given changelist
The unique build id
Merge another manifest into this one
The manifest to merge in
Gets the standard path for an manifest
The modular app name being built
The target configuration
The target platform
The architecture of the target platform
Filename for the app receipt
Read an app receipt from disk
Filename to read from
The receipt that was read
Tries to read a receipt from disk.
The filename that was read
If successful, the receipt that was read. Null otherwise.
True if the file was read succesfully.
Write the receipt to disk.
The file to write to
Write the receipt to disk.
The writer to output to
Utility functions for querying native projects (ie. those found via a .uprojectdirs query)
Cached map of target names to the project file they belong to
Clear our cached properties. Generally only needed if your script has modified local files...
Get the project folder for the given target name
Name of the target of interest
Logger for output
The project filename
True if the target was found
Returns true if this project is a Hybrid content only project that requires it to be built as code
Creates temporary target files, if needed, for a hybrid content only project
True if the project is hybrid
Determines if a project (given a .uproject file) has source code. This is determined by finding at least one .Target.cs file
Path to a .uproject file
If true, search Intermediate/Source for target files
True if this is a source-based project
NOTE: This function must mirror the functionality of TargetPlatformBase::RequiresTempTarget
NOTE: This function must mirror FPluginManager::RequiresTempTargetForCodePlugin
NOTE: This function must mirror FPluginManager::GetCodePluginsForTarget
NOTE: This function should mirror FPluginManager::ConfigureEnabledPluginForTarget
Attribute used to denote that a method should no longer be overriden. Used by RulesCompiler.
Message to display to the user if the method is overridden.
Constructor
Message to display to the user if the method is overridden
General platform support functions, exported for UAT
Checks whether the given platform is available
Platform to check
True if the platform is available, false otherwise
Gets a list of the registered platforms
List of platforms
Checks whether the given project has a default build configuration
The project file
Platform to check settings for
True if the project uses the default build configuration
Checks whether the given project requires a build because of platform needs
The project file
Platform to check settings for
True if the project requires a build for the platform
Returns an array of all platform folder names
All platform folder names
Returns an array of all platform folder names
The platform to get the included folder names for
All platform folder names
Returns all the excluded folder names for a given platform
The platform to get the excluded folder names for
Array of folder names
Check whether the given platform supports XGE
Platform to check
Logger for output
True if the platform supports XGE
Check whether the given platform supports the parallel executor in UAT
Platform to check
Logger for output
True if the platform supports the parallel executor in UAT
Gets the path for the XGE console executable
On success, receives the path to the XGE console executable
True if the path was found, false otherwise
Initialize UBT in the context of another host process (presumably UAT)
Command Line arguments that UBT may need access to for initializing platforms
Logger for output
True if initialization was successful
The version format for .uplugin files. This rarely changes now; plugin descriptors should maintain backwards compatibility automatically.
Invalid
Initial version
Adding SampleNameHash
Unifying plugin/project files (since abandoned, but backwards compatibility maintained)
This needs to be the last line, so we can calculate the value of Latest below
The latest plugin descriptor version
In-memory representation of a .uplugin file
Descriptor version number
Version number for the plugin. The version number must increase with every version of the plugin, so that the system
can determine whether one version of a plugin is newer than another, or to enforce other requirements. This version
number is not displayed in front-facing UI. Use the VersionName for that.
Name of the version for this plugin. This is the front-facing part of the version number. It doesn't need to match
the version number numerically, but should be updated when the version number is increased accordingly.
Friendly name of the plugin
Description of the plugin
The name of the category this plugin
The company or individual who created this plugin. This is an optional field that may be displayed in the user interface.
Hyperlink URL string for the company or individual who created this plugin. This is optional.
Documentation URL string.
Marketplace URL for this plugin. This URL will be embedded into projects that enable this plugin, so we can redirect to the marketplace if a user doesn't have it installed.
Support URL/email for this plugin.
Sets the version of the engine that this plugin is compatible with.
Sets the version of the engine at which this plugin has been deprecated.
4
If true, this plugin from a platform extension extending another plugin */
List of platforms supported by this plugin. This list will be copied to any plugin reference from a project file, to allow filtering entire plugins from staged builds.
List of programs supported by this plugin.
List of all modules associated with this plugin
List of all localization targets associated with this plugin
The Verse path to the root of this plugin's content directory
Origin/visibility of Verse code in this plugin's Content/Verse folder
The version of the Verse language that this plugin targets.
If no value is specified, the latest stable version is used.
Whether this plugin should be enabled by default for all projects
Can this plugin contain content?
Can this plugin contain Verse code (either in content directory or in any of its modules)?
Marks the plugin as beta in the UI
Marks the plugin as experimental in the UI
Set for plugins which are installed
For plugins that are under a platform folder (eg. /IOS/), determines whether compiling the plugin requires the build platform and/or SDK to be available
When true, prevents other plugins from depending on this plugin
When true, this plugin should not contain any code or modules.
When true, this plugin's modules will not be loaded automatically nor will it's content be mounted automatically. It will load/mount when explicitly requested and LoadingPhases will be ignored
When true, an empty SupportedTargetPlatforms is interpreted as 'no platforms' with the expectation that explicit platforms will be added in plugin platform extensions
Set of pre-build steps to execute, keyed by host platform name.
Set of post-build steps to execute, keyed by host platform name.
Additional plugins that this plugin depends on
Plugins that this plugin should never depend on
The JsonObject created from reading a .uplugin on disk or from parsing a json text
This preserves the order of all the fields from the source json as well as account for any custom fields.
Reads a plugin descriptor from a json object
The object to read from
New plugin descriptor
Creates a plugin descriptor from a file on disk preserving all custom fields in the file.
The filename to read
New plugin descriptor
Saves the descriptor to disk. This only saves the default fields in a .uplugin and does not account for cusotm fields.
The filename to write to
Saves the descriptor to disk preserving all custom fields that were read in.
The filename to write to
Writes the plugin descriptor to an existing Json writer
The writer to receive plugin data
Produces any warnings and errors for the plugin descriptor
File containing the plugin
Determines if this reference enables the plugin for a given platform
The platform to check
True if the plugin should be enabled
Retrieve the list of supported target platforms as a string list
String list of supported target platforms
Indicates whether it is acceptable for the given platform to be missing
Typically for platform extensions that are not covered by NDA in third party plugins
Representation of a reference to a plugin from a project file
Name of the plugin
Whether it should be enabled by default
Whether this plugin is optional, and the game should silently ignore it not being present
Description of the plugin for users that do not have it installed.
URL for this plugin on the marketplace, if the user doesn't have it installed.
If enabled, list of platforms for which the plugin should be enabled (or all platforms if blank).
If enabled, list of platforms for which the plugin should be disabled.
If enabled, list of target configurations for which the plugin should be enabled (or all target configurations if blank).
If enabled, list of target configurations for which the plugin should be disabled.
If enabled, list of targets for which the plugin should be enabled (or all targets if blank).
If enabled, list of targets for which the plugin should be disabled.
The list of supported platforms for this plugin. This field is copied from the plugin descriptor, and supplements the user's allowed/denied platforms.
When true, empty SupportedTargetPlatforms and PlatformAllowList are interpreted as 'no platforms' with the expectation that explicit platforms will be added in plugin platform extensions
When set, specifies a specific version of the plugin that this references.
Constructor
Name of the plugin
The marketplace URL for plugins which are not installed
Whether the plugin is enabled
Construct a PluginReferenceDescriptor from a Json object
The writer for output fields
Write an array of module descriptors
The Json writer to output to
Name of the array
Array of plugins
Updates the json object with an array of plugin descriptors.
The Json object to update.
Name of the array
Array of plugins
Checks the given platform names array and logs a message about any that are not known. This may simply be due to not having the platform synced in Engine/Platforms/[PlatformName].
Construct a PluginReferenceDescriptor from a Json object
The Json object containing a plugin reference descriptor
New PluginReferenceDescriptor object
Determines if this reference enables the plugin for a given platform
The platform to check
True if the plugin should be enabled
Determines if this reference enables the plugin for a given target configuration
The target configuration to check
True if the plugin should be enabled
Determines if this reference enables the plugin for a given target
The target to check
True if the plugin should be enabled
Determines if this reference is valid for the given target platform.
The platform to check
True if the plugin for this target platform
Where a plugin was loaded from
Plugin is built-in to the engine
Project-specific plugin, stored within a game project directory
Where a plugin was loaded from. The order of this enum is important; in the case of name collisions, larger-valued types will take precedence. Plugins of the same type may not be duplicated.
Plugin is built-in to the engine
Project-specific plugin, stored within a game project directory
Plugin found in an external directory (found in an AdditionalPluginDirectory listed in the project file, or referenced on the command line)
Project-specific mod plugin
Information about a single plugin
Plugin name
Path to the plugin
Path to the plugin's root directory
Children plugin files that can be added to this plugin (platform extensions)
The plugin descriptor
The type of this plugin
Used to indicate whether a plugin is being explicitly packaged via the -plugin command line
Constructs a PluginInfo object
Path to the plugin descriptor
The type of this plugin
Determines whether the plugin should be enabled by default
Determines where the plugin was loaded from
Represents a group of plugins all sharing the same name -- notionally all different versions of the same plugin.
Since UE can only manage a single plugin of a given name (to avoid module conflicts, etc.), this object
prioritizes and bubbles up a single "choice" plugin from the set -- see `ChoiceVersion`.
Shared name that all the plugins in the set go by.
Unordered list of all the discovered plugins matching the above name.
Constructor which takes the specified PluginInfo and adds it to the set.
The fist plugin discovered for this set -- will automatically be prioritized as the "choice" plugin.
Pushes the specified PluginInfo into the set, and optionally promotes it to the new "choice" version.
The new plugin to add to this set (its name should match this set's name)
Whether or not to make this the new prioritized "choice" plugin in the set.
The single plugin, out of the entire set, that we prioritize to be built and utilized by UE.
An index that we use to identify which plugin in the list is the prioritized "choice" version.
Class for enumerating plugin metadata
Cache of plugins under each directory
Invalidate cached plugin data so that we can pickup new things
Warning: Will make subsequent plugin lookups and directory scans slow until the caches are repopulated
Add a means to retrieve a plugin to determine if it is present.
The name of the plugin.
The cached plugin info, or null if not found.
Returns a filtered list of plugins as a name:plugin dictionary to ensure that any game plugins override engine plugins with the same
name, and otherwise that no two plugins with the same name exist.
List of plugins to filter
Filtered Dictionary of plugins
Filters the list of plugins to ensure that any game plugins override engine plugins with the same name, and otherwise that no two
plugins with the same name exist.
List of plugins to filter
Filtered list of plugins in the original order
Read all the plugins available to a given project
Path to the engine directory
Path to the project directory (or null)
List of additional directories to scan for available plugins
Sequence of PluginInfo objects, one for each discovered plugin
Read all the plugin descriptors under the given engine directory
The parent directory to look in.
Sequence of the found PluginInfo object.
Read all the plugin descriptors under the given project directory
The parent directory to look in.
Sequence of the found PluginInfo object.
Read all of the plugins found in the project specified additional plugin directories
The additional directory to scan
Logger for output
List of the found PluginInfo objects
Determines whether the given suffix is valid for a child plugin
Whether the suffix is appopriate
Attempt to merge a child plugin up into a parent plugin (via file naming scheme). Very little merging happens
but it does allow for platform extensions to extend a plugin with module files
Child plugin that needs to merge to a main, parent plugin
Child plugin's filename, used to determine the parent's name
Read all the plugin descriptors under the given directory
The directory to look in.
A subdirectory to look in in RootDirectory and any other Platform directories under Root
The plugin type
Sequence of the found PluginInfo object.
Determine if a plugin is enabled for a given project
The project to check. May be null.
Information about the plugin
The target platform
The target configuration
The type of target being built
True if the plugin should be enabled for this project
Determine if a plugin is enabled for a given project
The project to check. May be null.
Information about the plugin
The target platform
The target configuration
The type of target being built
Whether the target requires cooked data
True if the plugin should be enabled for this project
Information about a PCH instance
The file to include to use this shared PCH
The definitions file
The compile environment for this shared PCH
The output files for the shared PCH
List of modules using this instance
These are definitions that are immutable and should never be #undef. There are a few exceptions and we make sure those are not ending up in this list
Parent PCH instance used in PCH chaining
Dictionary of definitions use in the CppCompileEnvironment
Constructor
Return a string representation of this object for debugging
String representation of the object
A template for creating a shared PCH. Instances of it are created depending on the configurations required.
Module providing this PCH.
The base compile environment, including all the public compile environment that all consuming modules inherit.
The header file
Output directory for instances of this PCH.
Instances of this PCH
All the module dependencies this template has
Constructor
The module with a valid shared PCH
The compile environment to use
The header file to generate a PCH from
Output directory for instances of this PCH
All the module dependencies this template has
Checks whether this template is valid for the given compile environment
Compile environment to check with
True if the template is compatible with the given compile environment
Return a string representation of this object for debugging
String representation of the object
Stores information about a compiled binary or module, including the build products and intermediate folders.
List of files produced by compiling the module. These are within the module output directory.
Default constructor
Read a receipt from disk.
Filename to read from
Try to read a manifest from disk, failing gracefully if it can't be read.
Filename to read from
If successful, the manifest that was read
True if successful
Write the receipt to disk.
Output filename
Class to display an incrementing progress percentage. Handles progress markup and direct console output.
Global setting controlling whether to output markup
Logger for output
The name to include with the status message
The inner scope object
The current progress message
Constructor
The message to display before the progress percentage
Whether to write messages to the console
Logger for output
Write the terminating newline
Writes the current progress
Numerator for the progress fraction
Denominator for the progress fraction
The version format for .uproject files. This rarely changes now; project descriptors should maintain backwards compatibility automatically.
Invalid
Initial version
Adding SampleNameHash
Unifying plugin/project files (since abandoned, but backwards compatibility maintained)
This needs to be the last line, so we can calculate the value of Latest below
The latest plugin descriptor version
In-memory representation of a .uproject file
Descriptor version number.
The engine to open this project with.
Category to show under the project browser
Description to show in the project browser
List of all modules associated with this project
List of plugins for this project (may be enabled/disabled)
Array of additional root directories
List of additional plugin directories to scan for available plugins
Array of platforms that this project is targeting
A hash that is used to determine if the project was forked from a sample
Steps to execute before creating rules assemblies in this project
Steps to execute before building targets in this project
Steps to execute before building targets in this project
Indicates if this project is an Enterprise project
Indicates that enabled by default engine plugins should not be enabled unless explicitly enabled by the project or target files.
Constructor.
Constructor
Raw JSON object to parse
Base directory for resolving relative paths
Creates a plugin descriptor from a file on disk
The filename to read
New plugin descriptor
Creates a plugin descriptor based on a directory, searching for best uproject
The directory to search for a uproject
New plugin descriptor
If the descriptor has either additional plugin directories or additional root directories
then it is considered to have additional paths. The additional paths will be relative
to the provided directory.
The directory set to add the paths too.
The directory which is used to setup the additional paths
Saves the descriptor to disk
The filename to write to
Writes the plugin descriptor to an existing Json writer
The writer to receive plugin data
Base directory to save paths relative to
Names of restricted folders. Note: The name of each entry is used to search for/create folders
Values for RestrictedFolder
Unique Id for this folder
Mapping for unique ids
Array of all restricted folder names
Array of all restricted folders
Set of permitted references for each restricted folder. Determined via data-driven platform info.
Constructor
Id of the string
Creates a restricted folder instance from a string
Name of the folder
New restricted folder instance
Tests for equality between two restricted folder instances
First instance
Second instance
True if the two instances are equal
Tests for inequality between two restricted folder instances
First instance
Second instance
True if the two instances are not equal
Tests whether two restricted folder instances are equal
The restricted folder to compare against
True if the restricted folder is equal to the other instance
Gets a hash code for this object
Hash code for the object
Returns an array of folders which are allowed to be referenced from this restricted folder
Collection of restricted folders
Creates entries for all the confidential platforms. Should be called before returning any list of all folder values.
Gets an array of all the restricted folder names
Ensures that we've added all the restricted folders, and return an array of them
Array of restricted folder values
Return the string representation
Legacy. Should not be used any more.
Can be used by UE but not required
Epic Employees and Contractors as well as some explicitly permitted external groups
Epic Employees and Contractors
Epic Employees only
Utility functions for getting restricted folder
Finds all the restricted folder names relative to a base directory
The base directory to check against
The file or directory to check
Array of restricted folder names
Finds all the permitted restricted folder references for a given path
The base directory to check against
The file or directory to check
Array of restricted folder names
Controls how the target and SDK are validated in CreateTargetRulesInstance
This will perform full target validation (allows the platform to update the target to make sure it's valid), and
SDK validation (makes sure SDK overrides are not conflicting).
This is the standard, default mode.
This will validate the target only (see ValidateTargetAndSDK)
This will validate the SDK only (see ValidateTargetAndSDK)
This will perform neither of the validations
Stores information about a compiled rules assembly and the types it contains
Outers scope for items created by this assembly. Used for chaining assemblies together.
The compiled assembly
Returns the simple name of the assembly e.g. "UE5ProgramRules"
Returns all the types contained in the compiled rules assembly
The base directories for this assembly
All the plugins included in this assembly
Maps module names to their actual xxx.Module.cs file on disk
Maps target names to their actual xxx.Target.cs file on disk
Mapping from module file to its context.
Whether this assembly contains engine modules. Used to set default values for bTreatAsEngineModule.
Whether to use backwards compatible default settings for module and target rules. This is enabled by default for game projects to support a simpler migration path, but
is disabled for engine modules.
Whether the modules and targets in this assembly are read-only
The parent rules assembly that this assembly inherits. Game assemblies inherit the engine assembly, and the engine assembly inherits nothing.
The set of files that were compiled to create this assembly
Any preprocessor defines that were set when this assembly was created
Constructor. Compiles a rules assembly from the given source files.
The scope of items created by this assembly
The base directories for this assembly
All the plugins included in this assembly
List of module files to compile
List of target files to compile
The output path for the compiled assembly
Whether this assembly contains engine modules. Used to initialize the default value for ModuleRules.bTreatAsEngineModule.
Optional override for the default build settings version for modules created from this assembly.
Whether the modules and targets in this assembly are installed, and should be created with the bUsePrecompiled flag set
Whether to skip compiling this assembly
Whether to always compile this assembly
The parent rules assembly
Determines if the given path is read-only
The location to check
True if the path is read-only, false otherwise
Finds all the preprocessor definitions that need to be set for the current engine.
List of preprocessor definitions that should be set
Fills a list with all the module names in this assembly (or its parent)
List to receive the module names
Fills a list with all the target names in this assembly
List to receive the target names
Whether to include targets in the parent assembly
Tries to get the filename that declared the given type
True if the type was found, false otherwise
Gets the source file containing rules for the given module
The name of the module
The filename containing rules for this module, or an empty string if not found
Gets the type defining rules for the given module
The name of the module
The rules type for this module, or null if not found
Gets the type defining rules for the given module within this assembly
The name of the module
The rules type for this module, or null if not found
Gets the source file containing rules for the given target
The name of the target
The filename containing rules for this target, or an empty string if not found
Creates an instance of a module rules descriptor object for the specified module name
Name of the module
Information about the target associated with this module
Chain of references leading to this module
Logger for output
Compiled module rule info
Construct an instance of the given target rules
Will return null if the requested type name does not exist in the assembly
Type name of the target rules
Target configuration information to pass to the constructor
Logger for output
If building a low level tests target
Controls validation of target and SDK
Instance of the corresponding TargetRules or null if requested type name does not exist
Creates a target rules object for the specified target name.
Name of the target
Platform being compiled
Configuration being compiled
Architectures being built
Path to the project file for this target
Command line arguments for this target
If building a low level test target
Controls validation of target and SDK
Intermediate environment to use
The build target rules for the specified target
Determines a target name based on the type of target we're trying to build
The type of target to look for
The platform being built
The configuration being built
Project file for the target being built
Logger for output
Name of the target for the given type
Enumerates all the plugins that are available
Enumerates all the plugins that are available
Tries to find the ModuleRulesContext associated with a given module file
Class which compiles (and caches) rules assemblies for different folders.
Find all the module rules files under a given directory
The directory to search under
The module context for each found rules instance
Map of module files to their context
Find all the module rules files under a given directory
The directory to search under
Name of the subdirectory to look under
The module context for each found rules instance
The UHT module type
Map of module files to their context
The cached rules assembly for engine modules and targets.
Map of assembly names we've already compiled and loaded to their Assembly and list of game folders. This is used to prevent
trying to recompile the same assembly when ping-ponging between different types of targets
Creates the engine rules assembly
Whether to use a precompiled engine
Whether to skip compilation for this assembly
Whether to always compile this assembly
Logger for output
New rules assembly
Creates a rules assembly
The root directories to create rules for
A prefix for the assembly file name
List of plugins to include in this assembly
Whether the assembly should be marked as installed
Whether to skip compilation for this assembly
Whether to always compile this assembly
The parent rules assembly
Logger for output
New rules assembly
Creates a rules assembly
List of plugins to include in this assembly
Whether the assembly should be marked as installed
Whether to skip compilation for this assembly
Whether to always compile this assembly
The parent rules assembly
New rules assembly
Creates a rules assembly with the given parameters.
The project file to create rules for. Null for the engine.
Whether to use a precompiled engine
Whether to skip compilation for this assembly
Whether to always compile this assembly
Logger for output
New rules assembly
Creates a rules assembly with the given parameters.
The plugin file to create rules for
Whether to skip compilation for this assembly
Whether to always compile this assembly
The parent rules assembly
Whether the plugin should be built as though it is a local plugin.
Whether the plugin contains engine modules. Used to initialize the default value for ModuleRules.bTreatAsEngineModule.
Logger for ouptut
The new rules assembly
Compile a rules assembly for the current target
The project file being compiled
The target being built
Whether to skip compiling any rules assemblies
Whether to always compile all rules assemblies
Whether to use a precompiled engine build
Foreign plugin to be compiled
Whether the plugin should be built as though it is a local plugin
Logger for output
The compiled rules assembly
Finds all the module rules for plugins under the given directory.
The list of plugins to search modules for
The default context for any files that are enumerated
Dictionary which is filled with mappings from the module file to its corresponding context
Finds all the module and target rules for plugins' tests.
The list of plugins to search test rules for
The default context for any files that are enumerated
Dictionary which is filled with mappings from the module file to its corresponding context
List of target files to add test target rules to
Finds all the module rules for a given plugin in a specified folder.
The plugin to search module rules for
The folder relative to the plugin root to look into, usually "Source" or "Tests"
The default context for any files that are enumerated
Dictionary which is filled with mappings from the module file to its corresponding context
Gets the filename that declares the given type.
The type to search for.
The filename that declared the given type, or null
Gets the XML comment for a particular field
The XML documentation
The member to search for
Logger for output
Receives the description for the requested field
True if a comment was found for the field
Gets the XML comment for a particular field
The XML documentation
The member to search for
Logger for output
Receives the description for the requested field
True if a comment was found for the field
Gets the XML comment for a particular field
The XML documentation
The member to search for (field or property)
Logger for output
Receives the description for the requested member
True if a comment was found for the member
Gets the XML comment for a particular field
The XML documentation
The member to search for
Logger for output
Receives the description for the requested field
True if a comment was found for the field
Represents a layer within the rules hierarchy. Any module is created within a certain scope, and may only reference modules in an equal or parent scope (eg. engine modules cannot reference project modules).
Name of this scope
The parent scope
Constructor
Name of this scope
The parent scope
Checks whether this scope contains another scope
The other scope to check
True if this scope contains the other scope
Formats the hierarchy of scopes
String representing the hierarchy of scopes
Scoped timer, start is in the constructor, end in Dispose. Best used with using(ScopedTimer Timer = new ScopedTimer()). Suports nesting.
Constructor
Name of the block being measured
Logger for output
Verbosity for output messages
Whether gobal indent should be increased or not; set to false when running a scope in parallel. Message will still be printed indented relative to parent scope.
Prints out the timing message
System-wide mutex allowing only one instance of the program to run at a time
The global mutex instance
Constructor. Attempts to acquire the global mutex
Name of the mutex to acquire
Gets the name of a mutex unique for the given path
Base name of the mutex
Path to identify a unique mutex
Release the mutex and dispose of the object
The header unit type markup is used for multiple things:
1. To figure out if a header can be compiled by itself or not. Many includes are included in the middle of other includes and those can never be compiled by themselves
This markup is used by both msvc header unit feature and IWYU toolchain
2. Tell if the header even supports being part of a header unit. If it does not support it will also prevent all includes including it from producing a header unit
This is how to markup in headers to provide above info:
// HEADER_UNIT_SKIP - Here you can write why this file can't be compiled standalone
// HEADER_UNIT_UNSUPPORTED - Here you can write why this file can't be part of header units.
Caches information about C++ source files; whether they contain reflection markup, what the first included header is, and so on.
Source(cpp/c) file info
Last write time of the file when the data was cached
Contents of the include directive
List of files this particular file is inlining
Header file info
Last write time of the file when the data was cached
Whether or not the file contains reflection markup
Whether or not the file has types that use DLL export/import defines
List of includes that header contains
The current file version
Location of this dependency cache
Directory for files to cache dependencies for.
The parent cache.
Map from file item to source file info
Map from file item to header file info
Map from file item to source file
Whether the cache has been modified and needs to be saved
Logger for output
Regex that matches C++ code with UObject declarations which we will need to generated code for.
Regex that matches #include UE_INLINE_GENERATED_CPP_BY_NAME(****) statements.
Regex that matches #include statements.
Regex that matches #import directives in mm files
Static cache of all constructed dependency caches
Constructs a dependency cache. This method is private; call CppDependencyCache.Create() to create a cache hierarchy for a given project.
File to store the cache
Base directory for files that this cache should store data for
The parent cache to use
Logger for output
Returns a SourceFileInfo struct for a file (and parse the file if not already cached)
The file to parse
SourceFileInfo for file
Parse the first include directive from a source file
The source file to parse
The source file contents
The first include directive
Read entire header file to find markup and includes
A HeaderInfo struct containing information about header
Gets the first included file from a source file
The source file to parse
Text from the first include directive. Null if the file did not contain any include directives.
Finds or adds a SourceFile class for the given file
File to fetch the source file data for
SourceFile instance corresponding to the given source file
Returns a list of inlined generated cpps that this source file contains.
The source file to parse
List of marked files this source file contains
Determines whether the given file contains reflection markup
The source file to parse
True if the file contains reflection markup
Determines whether the given file uses the *_API define
The source file to parse
True if the file uses the *_API define
Returns header unit type for a header file (and parse the file if not already cached)
The header file to parse
Header unit type
Returns all #includes existing inside a header file (and parse the file if not already cached)
The header file to parse
List of includes
Creates a cache hierarchy for a particular target
Project file for the target being built
Logger for output
Dependency cache hierarchy for the given project
Enumerates all the locations of metadata caches for the given target
Project file for the target being built
Dependency cache hierarchy for the given project
Reads a cache from the given location, or creates it with the given settings
File to store the cache
Base directory for files that this cache should store data for
The parent cache to use
Reference to a dependency cache with the given settings
Save all the caches that have been modified
Reads data for this dependency cache from disk
Writes data for this dependency cache to disk
Finds mouse source files
Fills in a project file with source files discovered in the specified list of paths
Directory to search
Directory base names to ignore when searching subdirectories. Can be null.
True to include subdirectories, otherwise we only search the list of base directories
If non-null, is updated with a list of the directories searched
Defines an interface which allows querying the working set. Files which are in the working set are excluded from unity builds, to improve iterative compile times.
Checks if the given file is part of the working set
File to check
True if the file is part of the working set, false otherwise
Implementation of ISourceFileWorkingSet which does not contain any files
Dispose of the current instance.
Checks if the given file is part of the working set
File to check
True if the file is part of the working set, false otherwise
Queries the working set for files tracked by Perforce.
Dispose of the current instance.
Checks if the given file is part of the working set
File to check
True if the file is part of the working set, false otherwise
Queries the working set for files tracked by Git.
Constructor
Path to the Git executable
Root directory to run queries from (typically the directory containing the .git folder, to ensure all subfolders can be searched)
An inner working set. This allows supporting multiple Git repositories (one containing the engine, another containing the project, for example)
Logger for output
Terminates the background process.
Waits for the background to terminate.
Dispose of this object
Checks if the given file is part of the working set
File to check
True if the file is part of the working set, false otherwise
Parse output text from Git
Handle error output text from Git
Add a path to the working set
Path to be added
Utility class for ISourceFileWorkingSet
Sets the provider to use for determining the working set.
Sets the path to use for the repository. Interpreted relative to the Unreal Engine root directory (the folder above the Engine folder) -- if relative.
Sets the path to use for the Git executable. Defaults to "git" (assuming it is in the PATH).
Create an ISourceFileWorkingSet instance suitable for the given project or root directory
The root directory
The project directories
Logger for output
Working set instance for the given directory
Represents an IP subnet
The prefix address
Number of bits that need to match in an IP address for this subnet
Bytes corresponding to the prefix address
Constructor
The prefix IP address
Number of bits to match for this subnet
Parses a subnet from a string
The string to parse
New subnet that was parsed
Checks if this subnet contains the given address
IP address to test
True if the subnet contains this address
Checks if this subnet contains the given address bytes
Bytes of the IP address to text
True if the subnet contains this address
Formats this subnet as text
String representation of the subnet
Attribute which can be applied to a TargetRules-dervied class to indicate which configurations it supports
Array of supported platforms
Initialize the attribute with a list of configurations
Variable-length array of configuration arguments
Attribute which can be applied to a TargetRules-dervied class to indicate which platforms it supports
Initialize the attribute with a list of platform groups
Variable-length array of platform group arguments
Attribute which can be applied to a TargetRules-dervied class to indicate which platforms it supports
Array of supported platforms
Initialize the attribute with a list of platforms
Variable-length array of platform arguments
Initialize the attribute with all the platforms in a given category
Category of platforms to add
Attribute which can be applied to a TargetRules-dervied class to indicate which target types it supports
Array of supported target types
Initialize the attribute with a list of target types
Variable-length array of target type arguments
Hash of all the gen.cpp files being inlined in this source file
Helper function to calculate a hash for the passed in inline gen.cpp file names
Gen.cpp file names
Hash of file names
Cached list of actions that need to be executed to build a target, along with the information needed to determine whether they are valid.
The version number to write
The time at which the makefile was created
The time at which the makefile was modified
Additional diagnostic output to print before building this target (toolchain version, etc...)
Any additional information about the build environment which the platform can use to invalidate the makefile
The main executable output by this target
Path to the receipt file for this target
The project intermediate directory
The project intermediate directory without architecture info
Type of the target
Is test target?
Map of config file keys to values. Makefile will be invalidated if any of these change.
Whether the target should be deployed after being built
Collection of all located UBT C# plugins regardless of if they are in an enabled plugin (project file)
Collection of UBT C# plugins contained in enabled plugins (project file)
Collection of UHT C# plugins contained in enabled plugins (target assembly file)
The array of command-line arguments. The makefile will be invalidated whenever these change.
The array of command-line arguments passed to UnrealHeaderTool.
Scripts which should be run before building anything
Targets which should be build before building anything
Every action in the action graph
Environment variables that we'll need in order to invoke the platform's compiler and linker
The final output items for all target
Maps module names to output items
List of game module names, for hot-reload
List of all source directories
Set of all source directories. Any files being added or removed from these directories will invalidate the makefile.
Set of all known header files, changes will not invalidate the makefile but are used to determine if a header is included in the target.
The set of source files that UnrealBuildTool determined to be part of the programmer's "working set". Used for adaptive non-unity builds.
Set of files which are currently not part of the working set, but could be.
Maps each target to a list of UObject module info structures
Used to map names of modules to their .Build.cs filename
All build modules containing Verse code
If Verse should use the BPVM backend
List of config settings in generated config files
List of all plugin names. The makefile will be considered invalid if any of these changes, or new plugins are added.
Set of external (ie. user-owned) files which will cause the makefile to be invalidated if modified after
Set of internal (eg. response files, unity files) which will cause the makefile to be invalidated if modified.
TargetRules-set memory estimate per action. Used to control the number of parallel actions that are spawned.
Enumerable of all source and header files tracked by this makefile.
Constructor
External build metadata from the platform
Path to the executable or primary output binary for this target
Path to the receipt file
Path to the project intermediate directory
Path to the project intermediate directory
The type of target
Set of dependencies on config files
Whether to deploy the target after compiling
Collection of UBT plugins
Collection of UBT plugins
Collection of UBT plugins for UHT
Constructor. Reads a makefile from disk.
The archive to read from
Last modified time for the makefile
Write the makefile to the given archive
The archive to write to
Saves a makefile to disk
Path to save the makefile to
Loads a makefile from disk
Path to the makefile to load
Path to the project file
Platform for this makefile
Command line arguments for this target
Logger for output
If the function returns null, this string will contain the reason why
The loaded makefile, or null if it failed for some reason. On failure, the 'ReasonNotLoaded' variable will contain information about why
Checks if the makefile is valid for the current set of source files. This is done separately to the Load() method to allow pre-build steps to modify source files.
The makefile that has been loaded
Path to the project file
The platform being built
The current working set of source files
Logger for output diagnostics
If the makefile is not valid, is set to a message describing why
True if the makefile is valid, false otherwise
Determines if a directory, or any subdirectory of it, contains new source files or headers
Directory to search through
Set of directory names to exclude
Logger for output diagnostics
True if the directory contains any source files
Finds all the source files under a directory that contain reflection markup
The directory to search
Cache of source file metadata
Set of folder names to ignore when recursing the directory tree
Receives the set of files which contain reflection markup
Queue to add sub-tasks to
Gets the location of the makefile for particular target
Project file for the build
Name of the target being built
The platform that the target is being built for
The architectures the target is being built for (can be blank to signify a default)
The configuration being built
Intermediate environment to use
Path to the makefile
Type of a build product
An executable file
A dynamically loaded module.
A symbol file. Not required for the executable to run.
A map file. Not required for the executable to run.
A resource file which was generated by the build and is required for the executable to run.
A build resource which was generated by the build, but is not required for the executable to run.
A package which can be deployed on device (eg. *.apk for Android, *.stub for iOS)
A file that was created as part of the build process
Path to the file.
Type of the build product.
Private constructor, for serialization.
Constructor.
Path to the build product
Type of the build product
Copy constructor.
Build product to copy settings from
Convert this object to a string, for debugging.
Path to this build product
How a file may be staged
Only accessed through Unreal filesystem functions; may be included in a PAK file.
Must be kept as part of the loose filesystem.
Debug file which must be kept as part of the loose filesystem.
System file which must be kept as part of the loose filesystem. System files are not subject to being automatic remapping or renaming by the platform layer.
Information about a file which is required by the target at runtime, and must be moved around with it.
The file that should be staged. Should use $(EngineDir) and $(ProjectDir) variables as a root, so that the target can be relocated to different machines.
How to stage this file.
Private constructor, for serialization.
Constructor
Path to the runtime dependency
How to stage the given path
Copy constructor
Runtime dependency to copy settings from
Convert this object to a string for debugging
String representation of the object
List of runtime dependencies, with convenience methods for adding new items
Default constructor
Copy constructor
Sequence of runtime dependencies to initialize with
Add a runtime dependency to the list
Path to the runtime dependency. May include wildcards.
How to stage this file
Arbitrary property name/value which metadata from the build scripts can be passed on to downstream tasks
Property name
Value of the property
Construct a property with the given name and value
Name of the property
Value of the property
Stores a record of a built target, with all metadata that other tools may need to know about the build.
Path to the project file for this target
The project directory
The name of this target
Which platform the target is compiled for
Which platform the target is compiled for
Which configuration this target is compiled in
The type of the target
Whether it's a low level tests target
Version information for this target.
The exectuable to launch for this target
The console subsystem/commmandlet exectuable to launch for this target
The build products which are part of this target
All the runtime dependencies that this target relies on
All plugins that were either enabled or disabled via the target rules.
All plugins that were built via the target rules.
Additional build properties passed through from the module rules
Constructor
Path to the project file for this target
The name of the target being compiled
The type of target
Platform for the target being compiled
Configuration of the target being compiled
Version information for the target
Architecture information for the target
Whether it's a target for low level tests
Adds a build product to the receipt. Does not check whether it already exists.
Path to the build product.
Type of build product.
The BuildProduct object that was created
Merges another receipt to this one.
Receipt which should be merged
Inserts variables to make a file relative to $(EngineDir) or $(ProjectDir)
The file to insert variables into.
Value of the $(EngineDir) variable.
Value of the $(ProjectDir) variable.
Converted path for the file.
Inserts variables to make a file relative to $(EngineDir) or $(ProjectDir)
The path to insert variables into.
Value of the $(EngineDir) variable.
Value of the $(ProjectDir) variable.
Converted path for the file.
Returns the standard path to the build receipt for a given target
Base directory for the target being built; either the project directory or engine directory.
The target being built
The target platform
The target configuration
The architecture being built
Path to the receipt for this target
Determine whether a BuildProduct Type is NonUFS or DebugNonUFS
The build product to check
Checks the Additional properties for one with the given name that matches the given value
Property name to search for
Value to compare against (with StringComparison.InvariantCultureIgnoreCase)
True if any property with PropertyName has a value matching Value
Read a receipt from disk.
Filename to read from
Read a receipt from disk.
Filename to read from
Engine directory for expanded variables
Try to read a receipt from disk, failing gracefully if it can't be read.
Filename to read from
If successful, the receipt that was read
True if successful
Try to read a receipt from disk, failing gracefully if it can't be read.
Filename to read from
Engine directory for expanded paths
If successful, the receipt that was read
True if successful
Write the receipt to disk.
Output filename
Write the receipt to disk.
Output filename
Engine directory for expanded paths
Telemetry service for UnrealBuildTool
Dispose
Public interface for a timeline scope. Should be disposed to exit the scope.
Tracks simple high-level timing data
A marker in the timeline
Name of the marker
Time at which the event ocurred
Time at which the event ended
The trace span for external tracing
Constructor
Event name
Time of the event
Finish time for the event. May be null.
Finishes the current event
Disposes of the current event
The stopwatch used for timing
The recorded events
Property for the total time elapsed
Start the stopwatch
Records a timeline marker with the given name
The marker name
Enters a scope event with the given name. Should be disposed to terminate the scope.
Name of the event
Event to track the length of the event
Prints this information to the log
Updates the last event time
Prints an individual event to the log
Start time for the event
Finish time for the event. May be null.
Event name
List of all the start times for parent events
Verbosity for the output
Logger for output
Formats a timespan in milliseconds
The time to format
Formatted timespan
Types of timing data events.
No type assigned.
This event represents an aggregate of summary events.
This event represents a summary of related include, class, and function events, usually
summarizing a single compilation unit or part of a compilation unit.
Timing related to compiling include files.
Timing related to compiling classes.
Timing related to compiling functions.
Class used to capture timing data from events like those generated by MSVC when timing data
is being generated.
Constructs a new instance of .
Constructs a new instance of using data from a .
The to get the data from.
The name of the event being represented, such as a file or category name.
The type of timing data this event represents.
Gets the number of times this event was encountered.
Gets the amount of time, in milliseconds, that the event took to complete disregarding its sub-events.
Gets the amount of time, in milliseconds, that the event took including its sub-events.
If this event is a sub-event, the parent is the event it is the sub-event to.
Any sub-events of this event.
Adds a sub-event (child) to this event if it doesn't exist, or increase the duration by the
duration of the provided event.
The sub-event to add to this event.
Creates a deep clone of this event.
A deep clone of this event.
Writes a binary representation of this event and its sub-events.
The to write the binary representation to.
Systems that need to be configured to execute a tool mode
Do not initialize anything
Start prefetching metadata for the engine folder as early as possible
Initializes the XmlConfig system
Registers build platforms
Registers build platforms
Registers build platforms for validation
Only allow a single instance running in the branch at once
Print out the total time taken to execute
Capture logs as early as possible in a StartupTraceListener object
Attribute used to specify options for a UBT mode.
Name of this mode
Options for executing this mode
Constructor
Name of the mode
Options for this mode
Base class for standalone UBT modes. Different modes can be invoked using the -Mode=[Name] argument on the command line, where [Name] is determined by
the ToolModeAttribute on a ToolMode derived class. The log system will be initialized before calling the mode, but little else.
Entry point for this command.
List of command line arguments
Exit code for the process
Helper class implementing the standard topological sorting algorithm for directed graphs.
It generates a flattened sequence of nodes in the order that respects all the given dependencies
between nodes (edges). So, if we have edges A -> B and B -> C, A will be always before B and C, and
B will be before C.
In many cases there are more than one possible solutions. This helper just generates one of them.
The algorithm only works for directed acyclic graphs, as otherwise it's impossible to order the nodes.
In this implementation we can choose how cycles should be handled (CycleHandling member). By default
sorting fails, but we may set the class to arbitrarily break cycles and complete the task.
Type of node objects
Enumeration indicating how graph cycles should be handled.
Fail sorting on the first cycle encountered (the algorithmically correct solution).
Break cycles at the point they are detected (allows the algorithm to always complete but may skip some edges).
Break cycles at the point they are detected (same as Break but outputs warning logs with information about the cycles).
Determines what should be done when a cycle in the graph is encountered.
UBT's logger object. Necessary if we want to get diagnostics, especially when BreakWithInfo is used.
Functor returning a node's name. Necessary for some logging diagnostics, especially when BreakWithInfo is used.
List of all graph nodes (each user-provided node T is wrapped in an internal GraphNode).
When traversing the graph, it represents all the nodes visited in the current sequence.
For instance, if we go from node A to K and then X, Callstack will store A, K, X.
It's only needed for diagnostic purposes i.e. when we find a cycle we use Callstack
to output all the cycle's nodes.
The resulting sequence of nodes (T, provided by the user) in the topological order.
Initialize the sorter object and create the internal graph representation.
The list of all the graph nodes doesn't need to be provided because it's internally generated
from Edges (union of all edges' Item1 and Item2.
List of connections between nodes
Sort the graph to generate a flat sequence of nodes respecting all graph dependencies.
True on success, false if failed (most likely a cycle encountered)
Get the list of sorted nodes (valid after successfully calling Sort).
Process a single node.
True on success, false if failed (most likely a cycle encountered)
Create the internal graph structure for the provided list of edges.
List of tuples representing connections between nodes
Clear the state (in-progress, done) of all graph nodes.
Member executed when a graph cycle is encountered.
True if operation should continue, false if a cycle is considered an error
Returns all nodes being part of a cycle (call valid only if we've really detected a cycle).
Returns a string with a list of names of nodes forming a graph cycle (call valid only if we've really detected a cycle).
Graph node's state wrt the traversal.
Internal helper representing a graph node (wrapping the user-provided node and storing internal state).
User-provided node object.
List of graph nodes we can visit starting from this one.
Traversal state (in-progress, done).
Maps a unique string to an integer
Default constructor
See if string is in registry
True if string is present in registry
Add string if missing and/or lookup
String instance id
Get list of strings
String list
Get list of string ids
String id list
Get string given instance id
String
See if alias exists in registry
True if alias exists
Get instance id of alias
Instance id of alias
Add alias if missing and/or lookup
Instance id of alias
Prefix used for all dynamically created Unity modules
A class which represents a list of files and the sum of their lengths.
The length of this file collection, plus any additional virtual space needed for bUseAdapativeUnityBuild.
See the comment above AddVirtualFile() below for more information.
Doesn't actually add a file, but instead reserves space. This is used with "bUseAdaptiveUnityBuild", to prevent
other compiled unity blobs in the module's numbered set from having to be recompiled after we eject source files
one of that module's unity blobs. Basically, it can prevent dozens of files from being recompiled after the first
time building after your working set of source files changes
The virtual file to add to the collection
A class for building up a set of unity files. You add files one-by-one using AddFile then call EndCurrentUnityFile to finish that one and
(perhaps) begin a new one.
Constructs a new UnityFileBuilder.
The accumulated length at which to automatically split a unity file, or -1 to disable automatic splitting.
Adds a file to the current unity file. If splitting is required and the total size of the
unity file exceeds the split limit, then a new file is automatically started.
The file to add.
Doesn't actually add a file, but instead reserves space, then splits the unity blob normally as if it
was a real file that was added. See the comment above FileCollection.AddVirtualFile() for more info.
The file to add virtually. Only the size of the file is tracked.
Starts a new unity file. If the current unity file contains no files, this function has no effect, i.e. you will not get an empty unity file.
Returns the list of built unity files. The UnityFileBuilder is unusable after this.
Given a set of C++ files, generates another set of C++ files that #include all the original
files, the goal being to compile the same code in fewer translation units.
The "unity" files are written to the IntermediateDirectory.
The target we're building
The C++ files to #include.
The header files that might correspond to the C++ files.
The environment that is used to compile the C++ files.
Interface to query files which belong to the working set
Base name to use for the Unity files
Intermediate directory for unity cpp files
The makefile being built
Receives a mapping of source file to unity file
Receives the files to compile using the normal configuration.
Receives the files to compile using the adaptive unity configuration.
An approximate number of bytes of C++ code to target for inclusion in a single unified C++ file.
The merged XML program to run
XML namespace
Trace flag to enable debugging
Project file reference
Variable state
Local context trace
Equivalent of FConfigCacheIni_UPL. Parses ini files. This version reads ALL sections since ConfigCacheIni_UPL does NOT
Exception when parsing ini files
command class for being able to create config caches over and over without needing to read the ini files
List of values (or a single value)
Ini section (map of keys and values)
True if we are loading a hierarchy of config files that should be merged together
All sections parsed from ini file
Constructor. Parses a single ini file. No Platform settings, no engine hierarchy. Do not use this with ini files that have hierarchy!
The ini file to load
Constructor. Parses ini hierarchy for the specified project. No Platform settings.
Ini name (Engine, Editor, etc)
Project path
Logger for
Constructor. Parses ini hierarchy for the specified project. No Platform settings.
Ini name (Engine, Editor, etc)
Project path
Logger for output
Constructor. Parses ini hierarchy for the specified platform and project.
Project path
Target platform
Ini name (Engine, Editor, etc)
Constructor. Parses ini hierarchy for the specified platform and project.
Project path
Target platform
Ini name (Engine, Editor, etc)
Finds a section in INI
Found section or null
Finds values associated with the specified key (does not copy the list)
Gets all values associated with the specified key
Section where the key is located
Key name
Copy of the list containing all values associated with the specified key
True if the key exists
Gets a single string value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single bool value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single Int32 value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single GUID value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single float value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
Gets a single double value associated with the specified key.
Section name
Key name
Value associated with the specified key. If the key has more than one value, only the first one is returned
True if the key exists
List of actions that can be performed on a single line from ini file
Checks what action should be performed on a single line from ini file
Loads and parses ini file.
Splits a line into key and value
Processes parsed key/value pair
Finds an existing section or adds a new one
Returns a list of INI filenames for the engine
Returns a list of INI filenames for the given project
Returns the platform name to use as part of platform-specific config files
Utility functions
Searches for a flag in a set of command-line arguments.
Regular expression to match $(ENV) and/ or %ENV% environment variables.
Resolves $(ENV) and/ or %ENV% to the value of the environment variable in the passed in string.
String to resolve environment variable in.
String with environment variable expanded/ resolved.
Expands variables in $(VarName) format in the given string. Variables are retrieved from the given dictionary, or through the environment of the current process.
Any unknown variables are ignored.
String to search for variable names
Lookup of variable names to values
If true, then Environment.GetEnvironmentVariable will not be used if the var is not found in AdditionalVariables
String with all variables replaced
Makes sure path can be used as a command line param (adds quotes if it contains spaces)
Path to convert
Makes sure path can be used as a command line param (adds quotes if it contains spaces)
Path to convert
Escapes whitespace in the given command line argument with a backslash. Used on Unix-like platforms for command line arguments in shell commands.
The argument to escape
Escaped shell argument
This is a faster replacement of File.ReadAllText. Code snippet based on code
and analysis by Sam Allen
http://dotnetperls.com/Content/File-Handling.aspx
Source file to fully read and convert to string
Textual representation of file.
Reads the specified environment variable
the environment variable to read
the default value to use if missing
the value of the environment variable if found and the default value if missing
Reads the specified environment variable
the environment variable to read
the default value to use if missing
the value of the environment variable if found and the default value if missing
Reads the specified environment variable
the environment variable to read
the default value to use if missing
the value of the environment variable if found and the default value if missing
Reads the specified environment variable
the environment variable to read
the default value to use if missing
the value of the environment variable if found and the default value if missing
Try to launch a local process, and produce a friendly error message if it fails.
Runs a local process and pipes the output to the log
Output a line of text from a local process. Implemented as a separate function to give a useful function name in the UAT log prefix.
Runs a local process and pipes the output to a file
Runs a local process and pipes the output to the log
Runs a command line process, and returns simple StdOut output. This doesn't handle errors or return codes
The entire StdOut generated from the process as a single trimmed string
Command to run
Arguments to Command
Runs a command line process, and returns simple StdOut output. This doesn't handle errors or return codes
The entire StdOut generated from the process as a single trimmed string
Command to run
Arguments to Command
Logger for output
Runs a command line process, and returns simple StdOut output.
The entire StdOut generated from the process as a single trimmed string
Command to run
Arguments to Command
The return code from the process after it exits
Runs a command line process, and returns simple StdOut output.
The entire StdOut generated from the process as a single trimmed string
Command to run
Arguments to Command
The return code from the process after it exits
Whether to also log standard output and standard error
Runs a command line process, and returns simple StdOut output.
The entire StdOut generated from the process as a single trimmed string
Command to run
Arguments to Command
Logger for output. No output if null.
The return code from the process after it exits
Find all the platforms in a given class
Class of platforms to return
Array of platforms in the given class
Retrieve the list of platforms in this group (if any)
Given a list of supported platforms, returns a list of names of platforms that should not be supported
List of supported platforms
If true, add platforms that are present but not available for compiling
List of unsupported platforms in string format
Takes a path string and makes all of the path separator characters consistent. Also removes unnecessary multiple separators.
File path with potentially inconsistent slashes
The directory separator to use
File path with consistent separators
Correctly collapses any ../ or ./ entries in a path.
The path to be collapsed
true if the path could be collapsed, false otherwise.
Given a file path and a directory, returns a file path that is relative to the specified directory
File path to convert
The directory that the source file path should be converted to be relative to. If this path is not rooted, it will be assumed to be relative to the current working directory.
True if we should treat the source path like a directory even if it doesn't end with a path separator
Converted relative path
Backspaces the specified number of characters, then displays a progress percentage value to the console
Progress numerator
Progress denominator
Number of characters to backspace before writing the text. This value will be updated with the length of the new progress string. The first time progress is displayed, you should pass 0 for this value.
Reads a class using XML serialization
The type to read
The XML file to read from
Logger for output
New deserialized instance of type T
Serialize an object to an XML file
Type of the object to serialize
Object to write
File to write to
Default namespace for the output elements
Logger for output
True if the file was written successfully
Returns true if the specified Process has been created, started and remains valid (i.e. running).
Process object to test
True if valid, false otherwise.
Removes multi-dot extensions from a filename (i.e. *.automation.csproj)
Filename to remove the extensions from
Clean filename.
Returns Filename with path but without extension.
Filename
Path to the file with its extension removed.
Returns true if the specified file's path is located under the specified directory, or any of that directory's sub-folders. Does not care whether the file or directory exist or not. This is a simple string-based check.
The path to the file
The directory to check to see if the file is located under (or any of this directory's subfolders)
Checks if given type implements given interface.
Interface to check.
Type to check.
True if TestType implements InterfaceType. False otherwise.
Returns the User Settings Directory path. This matches FPlatformProcess::UserSettingsDir().
NOTE: This function may return null. Some accounts (eg. the SYSTEM account on Windows) do not have a personal folder, and Jenkins
runs using this account by default.
Gets the number of logical cores. We use this rather than Environment.ProcessorCount when possible to handle machines with > 64 cores (the single group limit available to the .NET framework).
The number of logical cores.
Gets the number of physical cores, excluding hyper threading.
The number of physical cores, or -1 if it could not be obtained
Gets if the processos has asymmetrical cores (Windows only)
Gets the total memory bytes available, based on what is known to the garbage collector.
This will return a max of 2GB for a 32bit application.
The total memory available, in bytes.
Gets the total system memory in bytes based on what is known to the garbage collector.
This will return a max of 2GB for a 32bit application.
The total system memory free, in bytes.
Gets the total memory bytes free, based on what is known to the garbage collector.
This will return a max of 2GB for a 32bit application.
The total memory free, in bytes.
Gives the current CPU utilization.
Percentage of CPU utilization currently.
Whether or not it was successful in getting the CPU utilization.
Determines the maximum number of actions to execute in parallel, taking into account the resources available on this machine.
How many actions to execute in parallel. When 0 a default will be chosen based on system resources
Physical processor count multiplier for local execution. Can be below 1 to reserve CPU for other tasks.
Consider logical cores when determing max actions to execute in parallel. Unused if ProcessorCountMultiplier is not 1.0.
Limit max number of actions based on total system memory.
Max number of actions to execute in parallel
Executes a list of custom build step scripts
List of script files to execute
Logger for output
True if the steps succeeded, false otherwise
Parses a command line into a list of arguments
The command line to parse
List of output arguments
Formats a list of arguments as a command line, inserting quotes as necessary
List of arguments to format
Command line string
Writes a file if the contents have changed
Location of the file
New contents of the file
Logger for output
Writes a file if the contents have changed
Location of the file
New contents of the file
The type of string comparison to use
Logger for output
Writes a file if the contents have changed
Location of the file
New contents of the file
Logger for output
Writes a file if the contents have changed
Location of the file
New contents of the file
The type of string comparison to use
Logger for output
Record each file that has been requested written, with the number of times the file has been written
Writes a file if the contents have changed
Location of the file
New contents of the file
Logger for output
Writes a file if the contents have changed
Location of the file
New contents of the file
The type of string comparison to use
Logger for output
Writes a file if the contents have changed
Location of the file
New contents of the file
Logger for output
Writes a file if the contents have changed
Location of the file
New contents of the file
The type of string comparison to use
Logger for output
Determines the appropriate encoding for a string: either ASCII or UTF-8.
If the string length is equivalent to the encoded length, then no non-ASCII characters were present in the string.
Don't write BOM as it messes with clang when loading response files.
The string to test.
Either System.Text.Encoding.ASCII or System.Text.Encoding.UTF8, depending on whether or not the string contains non-ASCII characters.
Determines the appropriate encoding for a list of strings: either ASCII or UTF-8.
If the string length is equivalent to the encoded length, then no non-ASCII characters were present in the string.
Don't write BOM as it messes with clang when loading response files.
The string to test.
Either System.Text.Encoding.ASCII or System.Text.Encoding.UTF8, depending on whether or not the strings contains non-ASCII characters.
Attempts to create a symbolic link at location specified by Path pointing to location specified by PathToTarget.
Soft symlinks are available since Windows 10 build 14972 without elevated privileges if developer mode is enabled.
Hard links are available since Windows 8 for NTFS/NFS file systems.
Path to create the symbolic link at.
Path to which the symbolic link should point to.
Logger for output.
True if symlink was created, false if failed.
If this is an immediate operand, the value will be embedded in the opcode itself.
This should be set to the the string name of the underlying operand native type.
Generates bytecode and bytecode helpers for the VerseVM.
Entrypoint to generate the bytecode. Generated code will go in Directory.
Functions for manipulating the XML config cache
An input config file
Location of the file
Which folder to display the config file under in the generated project files
Constructor
The cache file that is being used
Parsed config values
Cached serializer for the XML schema
Initialize the config system with the given types
Force use of the cached XML config without checking if it's valid (useful for remote builds)
Read XML configuration with a Project directory
Logger for output
Find all the configurable types in the current assembly
List of configurable types
Determines whether the given type has a field with an XmlConfigFile attribute
The type to check
True if the type has a field with the XmlConfigFile attribute
Find the location of the XML config schema
Optional project root directory
The location of the schema file
Initialize the list of input files
Create a default config file at the given location
Location to read from
Applies config values to the given object
The object instance to be configured
Instances a value for assignment to a target object
The value to instance
The type of value
New instance of the given value, if necessary
Gets a config value for a single value, without writing it to an instance of that class
Type to find config values for
Name of the field to receive
On success, receives the value of the field
True if the value was read, false otherwise
Find all the configurable fields in the given types by searching for XmlConfigFile attributes.
Array of types to search
Dictionaries populated with category -> name -> field mappings on return
Creates a schema from attributes in the given types
Lookup for all field settings
New schema instance
Creates an XML schema element for reading a value of the given type
Name of the field
Type of the field
New schema element representing the field
Writes a schema to the given location. Avoids writing it if the file is identical.
The schema to be written
Location to write to
Tests whether a type is a nullable struct, and extracts the inner type if it is
Reads an XML config file and merges it to the given cache
Location to read from
Lookup for configurable fields by category
Map of types to fields and their associated values
Schema to validate against
Logger for output
True if the file was read successfully
Parse the value for a field from its text based representation in an XML file
The type of field being read
Text to parse
The object that was parsed
Checks that the given cache file exists and is newer than the given input files, and attempts to read it. Verifies that the resulting cache was created
from the same input files in the same order.
Path to the config cache file
The expected set of input files in the cache
True if the cache was valid and could be read, false otherwise.
Generates documentation files for the available settings, by merging the XML documentation from the compiler.
The documentation file to write
Logger for output
Writes out documentation in UDN format
The output file
The XML documentation for this assembly
Map of string to types to fields
Logger for output
Writes out documentation in HTML format
The output file
The XML documentation for this assembly
Map of string to types to fields
Logger for output
Stores parsed values from XML config files which can be applied to a configurable type. Can be serialized to disk in binary form as a cache.
The current cache serialization version
List of input files. Stored to allow checking cache validity.
Abstract description of a target data member.
Returns Reflection.MemberInfo describing the target class member.
Returns Reflection.Type of the target class member.
Indicates whether the target class member is static or not.
Returns the value setter of the target class member.
Returns the value getter of the target class member.
Description of a field member.
Description of a property member.
Stores a mapping from type -> member -> value, with all the config values for configurable fields.
Constructor
Attempts to read a previous block of config values from disk
The file to read from
Array of valid types. Used to resolve serialized type names to concrete types.
On success, receives the parsed data
True if the data was read and is valid
Find a data member (field or property) with the given name and attribute and returns TargetMember wrapper created for it.
Attribute a member has to have to be considered.
Type which members are to be searched
Name of a member (field or property) to find.
TargetMember wrapper or null if no member has been found.
Writes the coalesced config hierarchy to disk
File to write to
Implementation of XmlDocument which preserves line numbers for its elements
Root element for the XML document
Namespace for the XML schema
The file being read
Interface to the LineInfo on the active XmlReader
Set to true if the reader encounters an error
Private constructor. Use XmlConfigFile.TryRead to read an XML config file.
Overrides XmlDocument.CreateElement() to construct ScriptElements rather than XmlElements
Loads a script document from the given file
The file to load
The schema to validate against
Logger for output
If successful, the document that was read
True if the document could be read, false otherwise
Callback for validation errors in the document
Standard argument for ValidationEventHandler
Standard argument for ValidationEventHandler
Implementation of XmlElement which preserves line numbers
The file containing this element
The line number containing this element
Constructor
Marks a field as being serializable from a config file
The category for this config value. Optional; defaults to the declaring type name.
Name of the key to read. Optional; defaults to the field name.
Use this field to indicate that the XML attribute has been deprecated, and that a warning should
be shown to the user if it is used.
A deprecated field should also be marked with the [Obsolete] attribute.
If the attribute has been deprecated because it has been renamed, this field can be used to apply the
value used for this field to another.
Helper class for managing Xcode paths, versions, etc. Helps to differentiate between Apple xcode platforms
Which developer directory to root from? If this is "xcode-select", UBT will query for the currently selected Xcode
Directory for the developer binaries
A portion of the target "tuple"
The version of the iOS SDK to target at build time.
The version in a floating point value for easy comparison
Cache SDK dir for device and simulator (for non-Mac)
Constructor, called by platform sybclasses
SDK name (like "MacOSX")
Sinulator SDK name (like "iPhoneOSSimulator")
Platform name used in the -target parameter
Get the path to the SDK diretory in xcode for the given architecture
Gets the string used by xcode to taget a platform and version (will return something like "arm64-apple-ios17.0-simulator"
Find the Xcode developer directory
Takes an architecture string as provided by UBT for the target and formats it for Clang. Supports
multiple architectures joined with '+'
Writes a versions.xcconfig file for xcode to pull in when making an app plist
FileItem describing the Prerequisite that this will this depends on (executable or similar)
List of actions to be executed. Additional actions will be added to this list.
If the project is a UnrealGame project, Target.ProjectDirectory refers to the engine dir, not the actual dir of the project. So this method gets the
actual directory of the project whether it is a UnrealGame project or not.
The actual project directory.
The path to the project file
Genearate an run-only Xcode project, that is not meant to be used for anything else besides code-signing/running/etc of the native .app bundle
Location of .uproject file (or null for the engine project
The platform to generate a project for
The name of the target being built, so we can generate a more minimal project
True if this is making a bild for uploading to app store
Logging object
Returns the .xcworkspace that was made
Single
Common option flags for the Clang toolchains.
Usage of these flags is currently inconsistent between various toolchains.
No custom options
Enable address sanitzier
Enable hardware address sanitzier
Enable thread sanitizer
Enable undefined behavior sanitizer
Enable minimal undefined behavior sanitizer
Enable memory sanitizer
Enable Shared library for the Sanitizers otherwise defaults to Statically linked
Enables link time optimization (LTO). Link times will significantly increase.
Enable thin LTO
Enable tuning of debug info for LLDB
Whether or not to preserve the portable symbol file produced by dump_syms
(Apple toolchains) Whether we're outputting a dylib instead of an executable
Enables the creation of custom symbol files used for runtime symbol resolution.
Enables dead code/data stripping and common code folding.
Indicates that the target is a moduler build i.e. Target.LinkType == TargetLinkType.Modular
Disable Dump Syms step for faster iteration
Indicates that the AutoRTFM Clang compiler should be used instead of the standard clang compiler
Enable LibFuzzer
Modify code generation to help with debugging optimized builds e.g. by extending lifetimes of local variables.
It may slightly reduce performance. Thus, it's meant to be used during development only.
Supported only on some platforms.
Enables compressing the debug sections if the platform supports this
Constructor for ClangToolChainInfo
The base path to the clang sdk root, if available
The path to the compiler
The path to the archiver
Logging interface
Lazily query the clang version. Will only be executed once.
The version of clang
Lazily query the clang version output. Will only be executed once.
The standard output when running Clang --version
Lazily query the archiver version output. Will only be executed once.
The standard output when running Archiver --version
Sanitizes a preprocessor definition argument if needed.
A string in the format "foo=bar" or "foo".
An escaped string
Checks if compiler version matches the requirements
Checks if compiler version matches the requirements
Common compile arguments that control which warnings are enabled.
https://clang.llvm.org/docs/DiagnosticsReference.html
Compile arguments for FP semantics
Compile arguments for optimization settings, such as profile guided optimization and link time optimization
Compile arguments for debug settings
Compile arguments for sanitizers
Additional compile arguments.
Compile arguments for running clang-analyze.
Common compile arguments for all files in a module.
Override and call base.GetCompileArguments_Global() in derived classes.
Compile arguments for specific files in a module. Also updates Action and CPPOutput results.
Path to the target file (such as .o)
Used by other tools to get the extra arguments to run vanilla clang for a particular platform.
List of extra arguments to add to.
Get CPU Instruction set targets for ISPC.
Which OS platform to target.
Which architecture inside an OS platform to target. Only used for Android currently.
List of instruction set targets passed to ISPC compiler
Get OS target for ISPC.
Which OS platform to target.
OS string passed to ISPC compiler
Get CPU architecture target for ISPC.
Which OS platform to target.
Which architecture inside an OS platform to target. Only used for Android currently.
Arch string passed to ISPC compiler
Get CPU target for ISPC.
Which OS platform to target.
CPU string passed to ISPC compiler
Get host compiler path for ISPC.
Which OS build platform is running on.
Path to ISPC compiler
Get the host bytecode-to-obj compiler path for ISPC. Only used for platforms that support compiling ISPC to LLVM bytecode
Which OS build platform is running on.
Path to bytecode to obj compiler
Returns the version of the ISPC compiler for the specified platform. If GetISPCHostCompilerPath() doesn't return a valid path
this will return a -1 version.
Which OS build platform is running on.
Version reported by the ISPC compiler
Get object file format for ISPC.
Which OS build platform is running on.
Object file suffix
Get object file suffix for ISPC.
Which OS build platform is running on.
Object file suffix
Normalize a path for use in a command line, making it relative to Engine/Source if under the root directory
The FileSystemReference to normalize
Normalized path as a string
Normalize a path for use in a command line, making it relative if under the Root Directory
The FileItem to normalize
Normalized path as a string
Stores information about how a local directory maps to a remote directory
Handles uploading and building on a remote Mac
These two variables will be loaded from the XML config file in XmlConfigLoader.Init().
The remote username.
If set, instead of looking for RemoteToolChainPrivate.key in the usual places (Documents/Unreal, Engine/UnrealBuildTool/SSHKeys or Engine/Build/SSHKeys), this private key will be used.
The authentication used for Rsync (for the -e rsync flag).
The authentication used for SSH (probably similar to RsyncAuthentication).
Save the specified port so that RemoteServerName is the machine address only
Path to Rsync
Path to SSH
The project being built. Settings will be read from config files in this project.
The project descriptor for the project being built.
A set of directories containing additional paths to be built.
The base directory on the remote machine
Mappings from local directories to remote directories
Arguments that are used by every Ssh call
Arguments that are used by every Rsync call
Arguments that are used by directory Rsync call
Constructor
Project to read settings from
Logger for output
Is the primary Remote Mac or not. True by default.
Added arguments when preparing a secondary Mac for debug. False by default.
Attempts to get the SSH private key from the standard locations
If successful, receives the location of the private key that was found
True if a private key was found, false otherwise
Expand all the variables in the given string
The input string
String with any variables expanded
Flush the remote machine, removing all existing files
Returns true if the remote executor supports this target platform
The platform to check
True if the remote mac handles this target platform
Clean a target remotely
Descriptor for the target to build
Logger for diagnostic output
True if the build succeeded, false otherwise
Build a target remotely
Descriptor for the target to build
Path to store the remote log file
If true then any PreBuildTargets will be skipped
Logger for diagnostic output
True if the build succeeded, false otherwise
Creates a temporary directory for the given target
The target descriptor
Directory to use for temporary files
Translate the arguments for a target descriptor for the remote machine
The target descriptor
Manifest files to be output from this target
List of remote arguments
Runs the actool utility on a directory to create an Assets.car file
The target platform
Input directory containing assets
Path to the Assets.car file to produce
Logger for output
Prepare the remotely built iOS or tvOS client to de debugged on Mac
Where the content has been previously cooked
The project file
The logger
Retrieves data from the primary Mac to the Windows machine
The project file
The logger
The platfrom for the client (typically iOS or tvOS)
Upload retrieved data from the primary Mac from the Windows machine to the secondary Mac
The project file
The logger
Convers a remote path into local form
The remote filename
Local filename corresponding to the remote path
Converts a local path into a remote one
The local path to convert
Equivalent remote path
Converts a local path into a remote one
The local path to convert
Equivalent remote path
Gets the local path in Cygwin format (eg. /cygdrive/C/...)
Local path
Path in cygwin format
Escapes spaces and brackets in a shell command argument
The argument to escape
The escaped argument
Upload a single file to the remote
The file to upload
Logger for output
Upload a single file to the remote
The base directory to copy
The remote directory
The file to upload
Logger for output
Upload a single directory to the remote
The local directory to upload
Logger for output
Uploads a directory to the remote using a specific filter list
The local directory to copy from
The remote directory to copy to
List of paths to filter
Logger for output
Upload all the files in the workspace for the current project
Downloads a single file from the remote
The file to download
Logger for output
Download multiple files from the remote Mac
List of local files to download
Logger for output
Checks whether a directory exists on the remote machine
Path to the directory on the local machine
Logger for output
True if the remote directory exists
Download a directory from the remote Mac
Directory to download
Logger for output
Execute Rsync
Arguments for the Rsync command
Logger for output
Exit code from Rsync
Handles data output by rsync
The received datae
whether the data was received on stderr
Logger for output
Execute a command on the remote in the remote equivalent of a local directory
Logger for output
Execute a remote command, capturing the output text
The remote working directory
Command to be executed
Logger for output
If true, logging is suppressed
Handler for output from running remote SSH commands
whether the data was received on stderr
Logger for output
Execute a remote command, capturing the output text
Command to be executed
Logger for output
Receives the output text
Converts any remote paths within the given string to local format
The text containing strings to convert
The string with paths converted to local format
Allows a toolchain to decide to create an import library if needed for this Environment
Get the name of the response file for the current compile environment and output file
Get the name of the response file for the current linker environment and output file
Adds a build product and its associated debug file to a receipt.
Build product to add
The type of build product
This is the extension of the file that is added as extra link object. It can be an obj file but also a dynamic list.. depends on the platform
The extension (without dot)
Runs the provided tool and argument. Returns the output, using a rexex capture if one is provided
Full path to the tool to run
Argument that will be passed to the tool
null, or a Regular expression to capture in the output
Runs the provided tool and argument and parses the output to retrieve the version
Full path to the tool to run
Argument that will result in the version string being shown (it's ok this is a byproduct of a command that returns an error)
Regular expression to capture the version. By default we look for four integers separated by periods, with the last two optional
Save the application startup time. This can be used as the timestamp for build makefiles, to determine a base time after which any
modifications should invalidate it.
Whether this is a recursive run of of the application
Unique id to track this session
The mode of this instance
The result of running the application
The environment at boot time.
The full name of the Engine/Source directory
Cached copy of the source root directory that was used to compile the installed engine
Used to remap source code paths when debugging.
Writable engine directory. Uses the user's settings folder for installed builds.
The engine programs directory
The original root directory that was used to compile the installed engine
Used to remap source code paths when debugging.
The Remote Ini directory. This should always be valid when compiling using a remote server.
Returns true if UnrealBuildTool is running using an installed project (ie. a mod kit)
True if running using an installed project
Gets the installed project file
Location of the installed project file
Checks whether the given file is under an installed directory, and should not be overridden
File to test
True if the file is part of the installed distribution, false otherwise
Gets the absolute path to the UBT assembly.
A string containing the path to the UBT assembly.
The Unreal remote tool ini directory. This should be valid if compiling using a remote server
The directory path
Global options for UBT (any modes)
User asked for help
The amount of detail to write to the log
Specifies the path to a log file to write. Note that the default mode (eg. building, generating project files) will create a log file by default if this not specified.
Log all attempts to write to the specified file
Whether to include timestamps in the log
Whether to format messages in MsBuild format
Whether or not to suppress warnings of missing SDKs from warnings to LogEventType.Log in UEBuildPlatformSDK.cs
Whether to write progress markup in a format that can be parsed by other programs
Whether to ignore the mutex
Whether to wait for the mutex rather than aborting immediately
The mode to execute
Whether to backup an existing log file, rather than overwriting it.
The number of log file backups to preserve. Older backups will be deleted.
If set TMP\TEMP will be overidden to this directory, each process will create a unique subdirectory in this folder.
If set the application temp directory will be deleted on exit, only when running with a single instance mutex.
Providers to load opt-in telemetry connection information from ini. If unset, or the provider categories do not contain connection info, no telemetry will be sent.
Additional command line providers to load opt-in telemetry connection information from ini.
Session identifier for this run of UBT, if unset defaults to a random Guid
Initialize the options with the given command line arguments
Get all the valid Modes
Print (incomplete) usage information
Read extra command-line arguments from an environment variable
Double-quote any argument containing whitespace, as they are split by just that.
Extra arguments
Event handler for the Console.CancelKeyPress event
Main entry point. Parses any global options and initializes the logging system, then invokes the appropriate command.
NB: That the entry point is deliberately NOT async, since we have a single-instance mutex that cannot be disposed from a different thread.
Command line arguments
Zero on success, non-zero on error
Helper functionality for easier F5 debugging for blueprint-only projects
Path to the .uproject file to use when F5 debugging a content-only project via the UE5 engine project
Get the configured content-only debug project, if any
Helper function to get the content-only debug project for the given target, if applicable and supported
Stores the path to the content-only debug project in the target receipt
Retrieves the path to the project from the given target receipt
Retrieves the path to the project from the given target
Helper functionality for optionally auditing the GDK edition on any used lib and dll files
Whether to verify that any libs the application links to are using the same GDK edition
Whether to verify that any DLLs the application links to are using the same GDK edition
Submission validator xml report can suggest multiple GDK editions for a single executable - the additional ones come from the libs that are linked to.
This function checks all the libs we are planning to link against and warns if they were built against a different GDK
Optionally verify that any DLLs the application links to are using the same GDK edition
Public GDK functions exposed to UAT
Returns the top-level root directory of the GameCore SDK
Returns the root directory for the current version of the GameCore SDK
Returns the SDK binaries directory
Determines the directory containing the MSVC toolchain
Major version of the compiler to use
The minimum compiler version to use. Can be "Latest"
Architecture that is required
Logger for output
Receives the directory containing the toolchain
Receives the optional directory containing redistributable components
True if the toolchain directory was found correctly
Returns the directory where GDK Extension SDKs are located
Returns the installed version of the GDK
Returns the installed version number of the GDK
(Experimental and unsupported) Modifies the given target rules so that it will produce a build that is compatible with PC GDK. Expected for Win64 TargetInfo only.
If using bUseCustomConfig=true, it is necessary to add the following entries to {project dir}/Config/Windows/Custom/MSGameStore/WindowsEngine.ini
Otherwise, when bUseCustomConfig=false, add these to {project dir}/Config/Windows/WindowsEngine.ini
; (required) this is required to make BuildCookRun generate, deploy and launch msixvc packages
[/Script/WindowsTargetPlatform.WindowsTargetSettings]
CustomDeployment=MSGameStore
; (recommended) add this if you are expecting to do intelligent delivery and use on-demand chunks etc
[StreamingInstall]
DefaultProviderName=GDKPackageChunkInstall
; (recommended) add these if you are planning on using Xbox cross-platform save games
[PlatformFeatures]
PlatformFeaturesModule=MSGameStorePlatformFeatures
SaveGameSystemModule=GDKSaveGameSystem
; (optional) set this if you are using EOSSDK
[/Script/MSGamingRuntimeEditor.MSGamingRuntimeSettings]
+AllowedMissingSymbolFiles="EOSSDK-Win64-Shipping.DLL"
; (optional) set this if you use bWithOSS=true
[OnlineSubsystem]
DefaultPlatformService=GDK
; (optional) only need the following sections if you use bWithPlayFab=true
[/Script/Engine.Engine]
!NetDriverDefinitions=ClearArray
+NetDriverDefinitions=(DefName="GameNetDriver",DriverClassName="/Script/PlayFabParty.PlayFabPartyNetDriver",DriverClassNameFallback="/Script/PlayFabParty.PlayFabPartyNetDriver")
+NetDriverDefinitions=(DefName="BeaconNetDriver",DriverClassName="/Script/PlayFabParty.PlayFabPartyNetDriver",DriverClassNameFallback="/Script/PlayFabParty.PlayFabPartyNetDriver")
+NetDriverDefinitions=(DefName="DemoNetDriver",DriverClassName="/Script/Engine.DemoNetDriver",DriverClassNameFallback="/Script/Engine.DemoNetDriver")
[PlayFab]
AppId={Your Hex PlayFab Title ID String Here}
If using bUseCustomConfig=true, it is necessary to add the following entries to {project dir}/Config/Windows/Custom/MSGameStore/WindowsGame.ini:
Othewreise, when bUseCustomConfig=false, add these to {project dir}/Config/Windows/WindowsGame.ini
; (required) this is necessary to stage the game for Win64 because GDK is a restricted platform folder
[Staging]
+RemapDirectories=(From="Engine/Platforms/GDK", To="Engine")
+RemapDirectories=(From="{project dir}/Platforms/GDK", To="{project dir}")
Whether you have put all MSGameStore config settings in Config/Custom/MSGameStore/*.ini - typically done with a custom MSG build target MyGameMSGTarget : MyGameTarget
Whether to include the OnlineSubsystemGDK plugin. Requires additional config settings
Whether to include the PlayFab plugin. Requires additional config settings
GDK-specific appx manifest generator (MicrosoftGame.config)
Platform-specific target device family
Platform-specific architecture
DLC file to use, if any
Cached properties for the current DLC
Helper to check if we are dealing with DLC
Whether we have a bootstrap exe (Windows only) - affects dependencies
Create a manifest generator for the given platform variant.
Create a manifest for the given platform and return the list of modified files
Get the Game element
Get the executable list element
Get the executable element for the given configuration
Get the protocol list element
Get the media capture element
Get the shell visuals element
Get the default display name for the project
Gets the package identity name string for the main package, disregarding any current DLC
Get the package identity name string
Get the package version string
manifest version. 0 = original, 1 = March 2022 GDK and above
Perform any additional initialization once all parameters and configuration are ready
Create all the localization data. Returns whether there is any localization data
Return the entire manifest element
Register the locations where resource binary files can be found
Perform any platform-specific processing on the manifest before it is saved
Returns the package full name for the given project
Returns the package family name for the given project
Returns the AUMID for the given project and configuration
Get the manifest generator for the given platform
ToolMode to create a MicrosoftGame.config for a single executable pair
Helper function to create an action that will run this ToolMode
Helper class used to manage GDK manifest identities
Regular expression for standard Micrososoft full package name: Name_Version_ProcessorArchitecture_ResourceId_PublisherId
Regular expression for standard Microsoft AUMID: Name_PublisherId!AppName
Architecture to use when none is specified
Version to use when none is specified
The package identity. e.g. "GameName"
The package version. e.g. "1.0.0.0"
The package Architecture. e.g. "neutral", "x64" etc.
The package resource id. (not used on GDK)
The package publisher id. e.g. "z844xmwvfmpty"
The full Package Name. e.g. "GameName_1.0.0.0_neutral__z844xmwvfmpty"
The package family name. e.g. "GameName_z844xmwvfmpty"
only valid if we are created from a MicrosoftGame.config
only valid if we are created from a MicrosoftGame.config or via ParseAppList
Create empty manifest identity
Create a manifest based on a given package full name. e.g. "GameName_1.0.0.0_neutral__z844xmwvfmpty"
Create a manifest identity from the given manifest file
Query whether there are executables available in this manifest
Look up the relative path to the given executable, if it is mentioned
Returns the AUMID for the given manifest and executable file name. e.g. GameName_z844xmwvfmpty!AppGameNameDevelopment
Returns the AUMID that matches the given configuration
Returns the executable that matches the given configuration
Returns the executable that matches the given AUMID
Returns all AUMIDs in the manifest
Standard ToString override
Converts a human-readable Publisher Name into the Publisher Id used by MS app manifests
Returns the full package name from the given manifest. e.g. GameName_1.0.0.0_neutral__z844xmwvfmpty
Returns the package family name from the given manifest. e.g. GameName_z844xmwvfmpty
Returns the AUMID for the given manifest and executable file name. e.g. GameName_z844xmwvfmpty!AppGameNameDevelopment
Returns the AUMID that matches the given configuration from a list of AUMIDs
Structure containing information about an installed GDK application
The type of application
Unknown
Loose folder
Installed package
Network share
core MicrosoftGame.config information
deployment type - staged or packaged
registration state
display name
deployment path
Returns a list of all applications from the given app list /json output
List of all applications
Create a manifest generator for Win64 using MSGameStore
Create a manifest generator for other platforms
Register the locations where resource binary files can be found
Create a manifest generator for WinGDK
Create a manifest generator for XB1
Create a manifest generator for the given platform variant
Create a manifest generator for XSX
Whether platform supports switching SDKs during runtime
true if supports
platforms can choose if they prefer a correct the the AutoSDK install over the manual install.
The minimum Windows SDK version to be used. If this is null then it means there is no minimum version
The maximum Windows SDK version to be used. If this is null then it means "Latest"
Public MSGameStore functions exposed to UAT
Type of custom install action
command for installing
command for repairing
command for uninstalling
a custom install action
location to copy the custom installs to when staging
name of the install action
source folder, relative to engine root
a command to run and its arguments
command to run
arguments to pass to the given command
the commands to run for each action
read the given config key and return the actions
Determine whether Windows is in developer mode. PC GDK packages can't be sideloaded without it
Determine if the Microsoft.GamingServices package is installed.
Determine whether the local version of Windows can support GDK
Base Nintendo functions exposed to UAT
Which UnrealTargetConfiguration to build the meta file for
Zero out the version when creating the meta file, used when generating small app big patch scenario
Suggested ApplicationVersion to override what's in meta
Path to .desc file for referenced project
Determines if the megazarf can be installed to the default Install RootDir set in the MZ.
This decision is based on whether the drive specified is valid
The platform to use
The path of the megazarf to inspect
Whether NNPM must be used to install the megazarf
An alternate path to install the MZ to. It is
based on the directory structure of the original path, and the first available,
valid drive.
An alternate environment name to install the MZ to. It is
based on the directory structure of the original path, and the first available,
valid drive.
true if the destination drive is invalid, otherwise false
Returns an integer value for the installed Switch SDK version.
Returns the Major, Minor, Patch values ored together.
Returns if the platform is using an SDK that uses the new refactored directory structure
Returns an integer value for the supplied Major, Minor, and Patch Switch SDK version strings.
The Major version number.
The Minor version number.
The Patch version number.
Returns the Major, Minor, Patch values ored together.
Returns an integer value for the supplied Major, Minor, and Patch Switch SDK version strings.
The Major version number.
The Minor version number.
The Patch version number.
Returns the Major, Minor, Patch values ored together.
Returns the semantic version given an integer version.
The version as an integer.
Returns the Major, Minor, Patch values.
Searches Target Manager folders for requested file.
The name of the file requested.
This will contain the root Target Manager directory if the file is found.
Returns the path to the file or null if it wasn't found.
Searches Target Manager folders for requested file.
The name of the file requested.
Returns the path to the file or null if it wasn't found.
location of libraries in the SDK
location of libraries in the SDK
location of the SDK on disk (requires the NINTENDO_SDK_ROOT environment variable)
Defines which Nintendo online server the game is connecting to
Doesn't connect to Nintendo Online Servers.
Use Nintendo NEX Game Servers (deprecated, requires Nintendo Online subscription)
Use Nintendo NPLN Game Servers (requires Nintendo Online subscription)
Nintendo platform target settings
base frameworks used for all projects.
stored here so we have access to them in ModifyBuildProducts()
Enable/disable NEX library support. Allows fully compiling out NEX support.
Deprecated: Use "NintendoGameServersMode" instead
Choose which online service we are currently targeting. If NEX/NPLN are not selected, they will be compiled out.
Possible Options:
None (default)
NEX (legacy,deprecated)
NPLN (new Nintendo online service)
Generate symbols with Breakpad (non shipping only).
Generate symbols with Breakpad (non shipping only), and only when compiled from a machine with the IsBuildMachine environment variable enabled.
Enable/disable system profilers, this can reduce program size.
Enable/disable the custom user exception handler.
Enable the custom user exception handler, only when compiled from a machine with the IsBuildMachine environment variable enabled.
Force Development libraries.
Enable Aftermath per build configuration (automatically opted out in shipping)
Enabling it automatically disables LLGD and NVNGD
Override malloc heap size.
NOTE this has been removed. There is no longer a separate heap for malloc, allocations now go through FNintendoPlatformMemory::BaseAllocator.
Max number of slots FNintendoPlatformTLS::AllocTlsSlot can allocate.
Max number threads that can use FNintendoPlatformTLS at one time.
The amount of memory donated to the NVN graphics firmware (must be a multiple of 4).
Controls how the game uses the touchscreen.
Due to LotCheck, this will force a full recompile to add/remove the touch APIs from the code.
Content-only projects will convert to code if this is not the default value!
Enable the four finger tap debugging option to show a web page for entering console commands, which will force touch screen usage
to Supported in non-Shipping builds (since it needs touch support!)
NOTE: Content-only projects will convert to code if this is not the default value!
Optional application error code prefix - 5 characters
Enable the mechanism to monitor write speeds to system storage.
Note, this is a best effort mechanism and may not catch all overages. Use the SDK tool FsAccessLogChecker
for official results. See SDK Guideline 0011 for more info.
Size of the cache data storage in KB.
Size of the temp data storage in KB.
Modify code generation to help with debugging optimized builds by extending lifetimes of local variables, parameters and this.
It may slightly reduce performance. Thus, it's meant to be used during development only.
Read-only wrapper around an existing NintendoTargetRules instance. This exposes target settings to modules without letting them to modify the global environment.
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
If this platform can be compiled with SN-DBS
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Setup the configuration environment for building
The target being built
The global compile environment
The global link environment
Whether platform supports switching SDKs during runtime
true if supports
Construct properly formatted version string from raw numbers
Version string with dot separating parts
Base class for platform-specific project generators
No documentation available.
Constructor
Command line arguments passed to the project generator
Enumerate all the platforms that this generator supports
Helper for parsing, generating and comparing PS4 version strings, in the form "xx.xx" where x is a digit.
The integer value representing this version.
Version string, as it appears in param.sfx/sfo
Parses the version string into its integer representation.
Parses the version string into its integer representation. Returns false if parsing failed.
Equality function
Returns the formatted version string
Returns the underlying value hashcode
Comparison function
Less than operator
Greater than operator
Equal operator
Not equal operator
Represent the types of packages the publishing tools can produce.
A regular, standalone package. Used for master release, and development.
A patch package based off a previous release.
A remaster package based off a previous release.
Helper class used to generate and parse package/GP4 file names according to their Content ID / versions etc in the form:
XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ_11.11-22.22_Submission-TargetName-PS4-Configuration.pkg
where:
"XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ" is the package Content ID
"11.11" is the Master Version
"22.22" is the Application Version
"Submission-" is optional, and denotes a submission package (--for_submission / -distribution)
"TargetName" is the name of the UBT target binary the package was created for
"Configuration" is the UBT target configuration
The generated name of the GP4 file
The generated name of the PKG file.
The generated build info string to embed in the .pkg file
Full Content ID string in the format "XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ"
The title ID portion of the content ID string in the format "XXXXYYYYY".
The version of an application or additional content to be submitted.
The version of an application or additional content to be updated.
True if this is a submission package.
The name of the target this package is built for.
The binary configuration included in the package.
Whether this is a standard, patch or remaster package.
Parses the given package filename into its component parts
Builds a PackageInfo instance from a title configuration and other properties.
Parses the given .pkg/.gp4 filename into its component parts. Returns false if parsing failed.
Parses the given .pkg/.gp4 filename into its component parts. Returns null if parsing failed.
Returns true if the specified package matches the current one (i.e. binary, config, submission etc match)
Searches the specified directory for a package matching this package info.
Contains the title configuration required for producing a packaged PS4 build.
This code is shared between UBT project generation, and UAT packaging automation.
See PS4ProjectGenerator.cs and PS4Platform.Automation.cs.
A regex pattern that matches valid content IDs
Full Content ID string in the format "XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ"
Just the Title ID portion of the full Content ID
True will suppress automation warnings about incorrect title configuration (e.g. missing passcodes / missing content ID / no default language).
Used only for Unreal Engine sample projects which are not intended to be shipped as retail titles. Do not enable this if you are making a real game.
Represents the DRM type of the application, as specified by packaging documentation.
Allowed values are "full", "upgradable", "demo", "freemium". If unspecified, assumes "full".
Indicates if this title configuration is allowed to include trophy data
The version of an application or additional content to be submitted.
The version of an application or additional content to be updated.
This setting selects whether packaging automation produces "remaster" or "patch" packages when building releases with the "-basedonreleaseversion" option.
Refer to Sony packaging documentation for more information about which option to use for your title. By default, "patch" packages will be produced.
A map of ASA codes. Use of this field is only necessary if Sony requires specific ASA codes to be enabled for your title.
This setting selects whether packaging automation sets the 'Video Recording Library' option.
The default title name to use if a localized name is not provided for a specific culture in the title names map.
A map of culture IDs to title names for display in the system software.
e.g. { "en-US" : "Game Name for English (US)", "fr" : Game Name for French" }
Passcode used for package creation.
The storage type of the package. The choice made here determines how the package can be shipped to
retail (i.e. digital only, or via BluRay disc). Refer to Sony packaging documentation for more information.
The storage type to use when creating remaster packages. Refer to Sony packaging documentation for more information.
True indicates this package is to be distributed on blu-ray disc.
True indicates this package is to be distributed on a multi-layer blu-ray disc.
True indicates the UAT packaging process should generate the .iso disc image in addition to the .pkg package file.
The size in MiB of the /download0 data area for the title.
Available options are 0, 256, 512, or 1024.
The size in MiB of the /download1 data area for the title.
Available options are 0, 3328, 6656, 9984, 13312, or 16640.
The parent control level applied to the package. Refer to Sony TRC R4005 documentation for a
detailed description of the meaning of this value, and set an appropriate value for your title.
Indicates that the title supports HDR output. This setting is reflected
in the generated param.sfo file in staged and packaged builds.
Indicates if the application runs on the PlayStation 5 system, and adheres to TRC R4211. See Sony documentation.
Indicates if the application uses the sceKernelIsProspero API. See Sony documentation.
Settings of the proxy server to be used when checking the version of the Publishing Tools or the SDK online.
- When using the system's proxy settings: "ie"
- When manually entering proxy server information: "(IP address):(port number)"
- When not using a proxy server: "none"
Project type (output format)
Entitlement key (only for additional content package)
DLC plugin name (only for additional content package)
Custom ParamSFO attribute2
Retrieves the title configurations from the specific config hierarchy.
Retrieves the title configurations from the specific config hierarchy.
Also returns the default title configuration to use when a title or content ID is not provided on UBT command line.
Read overrides for TitleConfiguration fields from Engine's .ini scripts and return as a data structure
compatible with what Json loading returns (ParseJson).
This way, the overrides may be merged with the contents of the .jsons we load.
Note: it only supports simple fields (bool, long, string); arrays and subobjects are ignored.
Engine configuration hierarchy
Content id of the SKU for which to load overrides (global overrides a loaded when null)
PS4-specific target settings
Enable Razor CPU profiling
Set this to true to register shaders with the standalone GPU debugger.
Set this to true to enable Sulpha host side audio debugging.
Enables support for the PS4 Memory Analyzer tool.
Set this to true to enable gnm asserts and validations in the LCUE
Enable link time optimization for test/shipping builds.
Enable link time optimization for development/test/shipping builds.
Move the audio rendering and stats thread to the 7th core when available
Enables address sanitizer (ASan)
Enables undefined behavior sanitizer (UBSan)
Enables thread sanitizer (TSan) [not available on PS4]
Enables shader performance analysis
Enable support for edit and continue code modification on ps4
Per-platform override enabling support for edit and continue.
If not provided, the global bSupportEditAndContinue setting will be applied.
Whether to improve iteration of a developer's build by skipping certain steps (currently, .uesym generation)
Disabled static analyzer checkers
Enable system runtime object stats in non shipping build
Modify code generation to help with debugging optimized builds by extending lifetimes of local variables, parameters and this.
Set this true to use the CrossgenSDK
Set this to true to disable NpToolkit
Read-only wrapper around an existing PS4TargetRules instance. This exposes target settings to modules without letting them to modify the global environment.
The private mutable settings object
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
Set this true to use the CrossgenSDK
Set this true to disable the NpToolkit
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Modify the rules for a newly created module, in a target that's being built for this platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Deploys the given target
Receipt for the target being deployed
Register the platform with the UEBuildPlatform class
Provides support for applying Kraken compression to staged builds, using
split-compress-merge workflow if distributed build systems are available.
Whether platform supports switching SDKs during runtime
true if supports
Construct properly formatted version string from raw numbers
Version string with dot separating parts
Base class for platform-specific project generators
When enabled, generates project files that default to using the PS5 application debugger.
When enabled, generates project files where the PS5 local debugger is set to use a .gp5 file from the StagedBuild directory.
Otherwise, the StagedBuild directory itself is set as the working directory, and the title is launched without the help of a .gp5 file.
Enumerate all the platforms that this generator supports
Helper for parsing, generating and comparing PS5 master version strings, in the form "xx.xx" where x is a digit.
The integer value representing this master version.
Master version string, as it appears in param.json
Parses the master version string into its integer representation.
Parses the master version string into its integer representation. Returns false if parsing failed.
Equality function
Returns the formatted version string
Returns the underlying value hashcode
Comparison function
Less than operator
Greater than operator
Equal operator
Not equal operator
Helper for parsing, generating and comparing PS5 content version strings, in the form "xx.xxx.xxx" where x is a digit.
The integer value representing this content version.
Content version string, as it appears in param.json
Parses the master version string into its integer representation.
Parses the content version string into its integer representation. Returns false if parsing failed.
Equality function
Returns the formatted version string
Returns the underlying value hashcode
Comparison function
Less than operator
Greater than operator
Equal operator
Not equal operator
Helper class used to generate and parse package/GP5 file names according to their Content ID / versions etc in the form:
XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ_01.00-01.000.000_Shared-Submission-TargetName-PS5-Configuration.pkg
where:
"XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ" is the package Content ID
"01.00" is the MasterVersion
"01.000.000" is the ContentVersion
"Shared-" is optional, and denotes a shared binary package
"Submission-" is optional, and denotes a submission package (--for_submission / -distribution)
"TargetName" is the name of the UBT target binary the package was created for
"Configuration" is the UBT target configuration
The generated name of the build.
The generated name of the GP5 file.
The generated name of the PKG file.
Full Content ID string in the format "XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ"
The title ID portion of the content ID string in the format "XXXXYYYYY".
The version of an application or additional content to be submitted.
The version of an application or additional content to be updated.
True indicates the title should be packaged as a shared binary. This means a single package is produced,
containing the files for all listed Content IDs, rather than one package per Content ID.
True if this is a submission package.
The name of the target this package is built for.
The binary configuration included in the package.
Parses the given package filename into its component parts
Builds a PackageInfo instance from a title configuration and other properties.
Parses the given .pkg/.gp5 filename into its component parts. Returns false if parsing failed.
Parses the given .pkg/.gp5 filename into its component parts. Returns null if parsing failed.
Returns true if the specified package matches the current one, and has an older ContentVersion.
Contains the title configuration required for producing a packaged PS5 build.
This code is shared between UBT project generation, and UAT packaging automation.
See PS5ProjectGenerator.cs and PS5Platform.Automation.cs.
A regex pattern that matches valid content IDs
Full Content ID string in the format "XXYYYY-XXXXYYYYY_00-ZZZZZZZZZZZZZZZZ"
Just the Title ID portion of the full Content ID
The Concept ID value for the title, as provided by the GEMS tool.
Passcode used for package creation.
Represents the DRM type of the application, as specified by packaging documentation.
Allowed values are "standard", "upgradable", or "demo". If unspecified, assumes "standard".
The version of an application or additional content to be submitted.
The version of an application or additional content to be updated.
True indicates the title should be packaged as a shared binary. This means a single package is produced,
containing the files for all listed Content IDs, rather than one package per Content ID.
True will suppress automation warnings about incorrect title configuration (e.g. missing passcodes / missing content ID / no default language).
Used only for Unreal Engine sample projects which are not intended to be shipped as retail titles. Do not enable this if you are making a real game.
Determines whether generated packages support Blu-ray disc distribution, and if so, what type of Blu-ray disc.
If unspecified, assumes "nwonly", i.e. online distribution only, no Blu-ray disc.
True indicates that the title correctly handles log in/log out of the initial user.
True indicates the title supports HDR rendering.
True indicates the title uses the content search library rendering.
True indicates the title uses the share library capture API.
True indicates the title is a beta release.
When true, indicates the title will use the faster startup splash screen animation, which reduces the time it takes for the game logo (pic2.png) to appear.
See the "Content Information Specifications -> 7. Start-up Image [Application Information]" section of the Sony documentation.
If VR support is enabled a value of 1 indicates that the app Supports VR, a value of 2 indicates that the app Requires VR.
Allowed values are "supported", or "required". If unspecified, assumes "supported".
The size in MiB of the download data area for the title.
Available options are 0, 256, 512, or 1024.
The content badge type value for the title, as provided by the GEMS tool.
A map of region IDs to age levels required to play the title.
The entry with an empty string "" key is used as the default age level.
e.g. { "": 15, "US": 10, "JP": 14 }
The default title name to use if a localized name is not provided for a specific culture in the title names map.
A map of culture IDs to title names for display in the system software.
The entry with an empty string "" key is used as the default name.
e.g. { "": "Default Game Name", "en-US" : "Game Name for English (US)" }
A list of game intents applicable to this title.
The version file uri string as provided by the GEMS tool in param_cp_values.json.
A map of ASA codes. Use of this field is only necessary if Sony requires specific ASA codes to be enabled for your title.
A list of ASA signatures. Use of this field is only necessary if Sony requires specific ASA signatures to be enabled for your title.
Project type (output format)
Entitlement key (only for additional content package)
DLC plugin name (only for additional content package)
A dictionary of properties which should also be included in the generated param.json file. This
dictionary is merged with the values that are generated from the above properties. Useful if a
property needs to be added to param.json, but there is no explicit UAT code support for that property.
A map of configuration to size to override flexible memory size.
Contains the title and description of a scenario for a given language.
The title of the scenario.
A description of the scenario.
Contains the configuration for an individual scenario.
Constructor
A map of culture IDs to scenario title names / descriptions for display in the system software.
A map of scenario IDs their configuration data.
Retrieves the title configurations from the specific config hierarchy.
Retrieves the title configurations from the specific config hierarchy.
Also returns the default title configuration to use when a title or content ID is not provided on UBT command line.
Read overrides for TitleConfiguration fields from Engine's .ini scripts and return as a data structure
compatible with what Json loading returns (ParseJson).
This way, the overrides may be merged with the contents of the .jsons we load.
Note: it only supports simple fields (bool, long, string); arrays and subobjects are ignored.
Engine configuration hierarchy
Content id of the SKU for which to load overrides (global overrides a loaded when null)
PS5-specific target settings
Enable Razor CPU profiling
Set this to true to register shaders with the standalone GPU debugger.
Set this to true to enable Sulpha host side audio debugging.
Enables support for the PS5 Memory Analyzer tool.
Enable link time optimization for test/shipping builds.
Enable link time optimization for development/test/shipping builds.
Enables address sanitizer (ASan)
Address sanitizer significantly increases the amount of flexible memory used by a title.
For this reason, a staged build with a manually updated param.json with the following
change is generally needed (the required size is title-dependent):
"kernel": {
"flexibleMemorySize": 1073741824
},
Alternatively, a flexible memory override may be specified when launching from Visual Studio
or Sony tools (Target Manager, Remote Viewer).
Enables undefined behavior sanitizer (UBSan)
Enables thread sanitizer (TSan)
Enables shader live editing support.
Enable support for edit and continue code modification
Per-platform override enabling support for edit and continue.
If not provided, the global bSupportEditAndContinue setting will be applied.
Whether to improve iteration of a developer's build by skipping certain steps (currently, .uesym generation)
Disabled static analyzer checkers
Enable system runtime object stats in non shipping build
Modify code generation to help with debugging optimized builds by extending lifetimes of local variables, parameters and this.
Indicates whether the PS5 kernel extension allowing us to load more than 255 .prx modules is available.
It's really only necessary when using modular builds (which itself is an experimental feature at the moment).
Read-only wrapper around an existing PS5TargetRules instance. This exposes target settings to modules without letting them to modify the global environment.
The private mutable settings object
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
Modify the rules for a newly created module, where the target is a different host platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Modify the rules for a newly created module, in a target that's being built for this platform.
This is not required - but allows for hiding details of a particular platform.
The name of the module
The module rules
The target being build
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Deploys the given target
Information about the target being deployed
Register the platform with the UEBuildPlatform class
Construct properly formatted version string from raw numbers
Version string with dot separating parts
Base class for project generators for Sony platforms.
Get host compiler path for ISPC.
Which OS build platform is running on.
Path to ISPC compiler
Get the host bytecode-to-obj compiler path for ISPC. Only used for platforms that support compiling ISPC to LLVM bytecode
Which OS build platform is running on.
Path to bytecode to obj compiler
Sony-specific target settings
Enable Razor CPU profiling
Set this to true to register shaders with the standalone GPU debugger.
Set this to true to enable Sulpha host side audio debugging.
Enables support for the Sony Memory Analyzer tool.
Enable link time optimization for test/shipping builds.
Enable link time optimization for development/test/shipping builds.
Enables address sanitizer (ASan)
Enables undefined behavior sanitizer (UBSan)
Enables thread sanitizer (TSan)
Enable support for edit and continue code modification on Sony
Per-platform override enabling support for edit and continue.
If not provided, the global bSupportEditAndContinue setting will be applied.
Whether to improve iteration of a developer's build by skipping certain steps (currently, .uesym generation)
Disabled static analyzer checkers
Enable system runtime object stats in non shipping build
Modify code generation to help with debugging optimized builds by extending lifetimes of local variables, parameters and this.
It may slightly reduce performance. Thus, it's meant to be used during development only.
Read-only wrapper around an existing SonyTargetRules instance. This exposes target settings to modules without letting them to modify the global environment.
Constructor
The settings object to wrap
Accessors for fields on the inner TargetRules instance
If this platform can be compiled with XGE
If this platform can be compiled with SN-DBS
Determines if the given name is a build product for a target.
The name to check
Target or application names that may appear at the start of the build product name (eg. "UnrealEditor", "ShooterGameEditor")
Suffixes which may appear at the end of the build product name
True if the string matches the name of a build product, false otherwise
Get the extension to use for the given binary type
The binrary type being built
string The binary extenstion (ie 'exe' or 'dll')
Get the extensions to use for debug info for the given binary type
Rules for the target being built
The binary type being built
string[] The debug info extensions (i.e. 'pdb')
Whether this platform should build a monolithic binary
Whether this platform should create debug information or not
The target being built
bool true if debug info should be generated, false if not
Setup the configuration environment for building
The target being built
The global compile environment
The global link environment
Setup the binaries for this specific platform.
The target being built
Public Switch functions exposed to UAT
location of libraries in the SDK
Base class for platform-specific project generators
Constructor
Command line arguments passed to the project generator
Logger for output
Enumerate all the platforms that this generator supports
Switch-specific target settings
Name to use for the Runtime Settings section in the INI config files
base frameworks used for all projects.
stored here so we have access to them in ModifyBuildProducts()
Enable/disable NEX library support. Allows fully compiling out NEX support.
Deprecated: Use "NintendoGameServersMode" instead
Choose which online service we are currently targeting. If NEX/NPLN are not selected, they will be compiled out.
Possible Options:
None (default)
NEX (legacy,deprecated)
NPLN (new Nintendo online service)
Generate symbols with Breakpad (non shipping only).
Generate symbols with Breakpad (non shipping only), and only when compiled from a machine with the IsBuildMachine environment variable enabled.
Enable/disable system profilers, this can reduce program size.
Enable/disable the custom user exception handler.
Enable the custom user exception handler, only when compiled from a machine with the IsBuildMachine environment variable enabled.
Force Development libraries.
Enable Aftermath per build configuration (automatically opted out in shipping)
Enabling it automatically disables LLGD and NVNGD
Override malloc heap size.
NOTE this has been removed. There is no longer a separate heap for malloc, allocations now go through FSwitchPlatformMemory::BaseAllocator.
Max number of slots FSwitchPlatformTLS::AllocTlsSlot can allocate.
Max number threads that can use FSwitchPlatformTLS at one time.
The amount of memory donated to the NVN graphics firmware (must be a multiple of 4).
Controls how the game uses the touchscreen.
Due to LotCheck, this will force a full recompile to add/remove the touch APIs from the code.
Content-only projects will convert to code if this is not the default value!
Enable the four finger tap debugging option to show a web page for entering console commands, which will force touch screen usage
to Supported in non-Shipping builds (since it needs touch support!)
NOTE: Content-only projects will convert to code if this is not the default value!
Optional application error code prefix - 5 characters
Enable the mechanism to monitor write speeds to system storage.
Note, this is a best effort mechanism and may not catch all overages. Use the SDK tool FsAccessLogChecker
for official results. See SDK Guideline 0011 for more info.
Size of the cache data storage in KB.
Size of the temp data storage in KB.
Modify code generation to help with debugging optimized builds by extending lifetimes of local variables, parameters and this.
It may slightly reduce performance. Thus, it's meant to be used during development only.
Read-only wrapper around an existing SwitchTargetRules instance. This exposes target settings to modules without letting them to modify the global environment.
Constructor
The settings object to wrap
Setup the target environment for building
Settings for the target being compiled
The compile environment for this target
The link environment for this target
Creates a toolchain instance for the given platform.
The target being built
New toolchain instance.
Register the platform with the UEBuildPlatform class
Public VisionOS functions exposed to UAT
Constructor
Command line arguments passed to the project generator
Logger for output
Enumerate all the platforms that this generator supports
Target rules for WinGDK
Whether exceptions should be ultimately passed on to Windows Error Reporting
Whether the embadded manifest will indicate the application is DPI aware
Read only target rules for WinGDK
Base class for platform-specific project generators
Constructor
Command line arguments passed to the project generator
Enumerate all the platforms that this generator supports
Target rules for XB1
Name to use for the Runtime Settings section in the INI config files
Report warnings about migrating deprecated XboxOneGDK platform to XB1
Read only target rules for XB1
Target rules for XboxCommon
Enable PIX debugging (automatically disabled in Shipping and Test configs)
Register the log file with Wer so it'll be uploaded along with crash dumps
Register screenshot file with Wer so it'll be uploaded along with crash dumps
Always run Wer even in non-shipping builds. Default value for xb.AlwayRunWer cvar.
The stack size when linking. 0 signifies use of system default.
The stack size override when linking for the debug configuration. 0 signifies use of system default.
The stack size to commit when linking. 0 signifies use of system default.
If -PGOOptimize is specified but the linker flags have changed since the last -PGOProfile, this will emit a warning and build without PGO instead of failing during link with LNK1268.
Note that the PLATFORM_COMPILER_OPTIMIZATION_PG definition will still be 1 but FPlatformMisc::IsPGOEnabled() will return false in this case.
If specified along with -PGOProfile, then /FASTGENPROFILE will be used instead of /GENPROFILE.
This usually means that the PGO data is generated faster, but the resulting data may not yield as efficient optimizations during -PGOOptimize
If specified along with -PGOProfile, prevent the usage of extra counters. Please note that by default /FASTGENPROFILE doesn't use extra counters
https://learn.microsoft.com/en-us/cpp/build/reference/genprofile-fastgenprofile-generate-profiling-instrumented-build?view=msvc-170
Override the default compiler
Override the default compiler version
True if we should use the LLVM linker (LLD-Link.exe) when we are compiling with Clang. Otherwise we'll use the MSVC linker (Link.exe).
This is required for LTO and PGO
Xbox should use the onecore libraries by default. This is included for backwards compatibility on some titles
ASan runtime options (delimited with colons ":")
Whether to support /host/ prefix in file system paths, allowing access to files on the host PC. It requires a full PC path but only files within the current solution dir are available. For example, -cvarsini=/host/D:\UE5\Engine\Config\ConsoleVariables.ini
Whether to improve iteration of a developer's build by skipping certain steps (currently, debug symbol lookup generation)
Read only target rules for XboxCommon
This adds support for a range of extra deployment scenarios for F5 in Visual Studio, including package debugging assistance.
Disabling this may yield minor deployment speed increase at the cost of ease-of-use for more advanced deployment scenarios
Whether to deploy the current Staged build when F5 debugging from Visual Studio
Whether the staged build deployment will be skipped if there is already a build installed.
Prevents VS deployment if there will not be a build installed - otherwise VS will just deploy the Layout folder but no content and the game would likely crash.
Logs out additional information during package debugging assistance. Mostly useful for debugging this system
Prepare the target for deployment. This is done after the executable has been built, including when pressing F5 in Visual Studio.
Receipt for the target being deployed
True if successful, false if not
Utility function to delete a file even if it is read-only
Helper function for copying modified files
Target rules for XSX
Name to use for the Runtime Settings section in the INI config files
Enables support for 120hz and 40hz display output. Use 'r.SetFramePace' to configure the desired output frame rate at runtime.
Enables support for SMT (Simultaneous Multi-threading) this is an immediate drop in cpu frequency of 10% but with hyperthreading.
Read only target rules for XSX
Return the AutoSDK property include to set global platform properties if AutoSDK is in use.
Attempts to optimize the module dependencies found in the build.cs files
Regex that matches #include statements.
Execute the command
Command line arguments
Exit code
Information about a module that needs to be passed to the Verse VNI tool for code generation
Module name
Name of plugin this module belongs to, "Engine" or "Game"
Verse path of the root Verse module associated with this build module
If Verse code associated with this module is allowed to be seen by users outside of Epic
Path to the module rules file
Directory where the Verse package is located
Names of modules with Verse code that this module's Verse code depends on
Directory containing generated code
This handles all running of the VNI tool
Create a Verse vproject file from a list of VNIModuleInfo
Gets VNI Tool binary path
Runs the precompiled VNI tool
Since the VNI tool performs extensive file date/manifest checking already we're not spending time here
determining if it should be run in the first place, but run it _always_
Extension methods for JsonObject to provide some deprecated field helpers
Tries to read a string array field by the given name from the object; if that's not found, checks for an older deprecated name
JSON object to check
Name of the field to get
Backup field name to check
On success, receives the field value
True if the field could be read, false otherwise
Tries to read an enum array field by the given name from the object; if that's not found, checks for an older deprecated name
JSON object to check
Name of the field to get
Backup field name to check
On success, receives the field value
True if the field could be read, false otherwise
Whether this platform should build a monolithic binary
Allows the platform header name to be overridden to differ from the platform name.
GDK platforms do not utilize an override for the platform header name.
Register the platform with the UEBuildPlatform class
Adds the XB1-specific shader format definitions
Register the platform with the UEBuildPlatform class
Whether this platform should create debug information or not
The target being built
bool true if debug info should be generated, false if not
Whether this platform should build a monolithic binary
Get a list of extra modules the platform requires.
This is to allow undisclosed platforms to add modules they need without exposing information about the platform.
The target being build
List of extra modules the platform needs to add to the target
Allows the platform header name to be overridden to differ from the platform name.
Adds the GDK-specific shader format definitions
Register the platform with the UEBuildPlatform class