You've already forked UnrealEngineUWP
mirror of
https://github.com/izzy2lost/UnrealEngineUWP.git
synced 2026-03-26 18:15:20 -07:00
========================== MAJOR FEATURES + CHANGES ========================== Change 2875445 on 2016/02/22 by Matthew.Griffin Added UE4.natvis to Visual Studio Projects #jira UE-27153 Change 2875456 on 2016/02/22 by Keith.Judge Fix custom stencil shaders on Xbox One #jira UES-1387 Change 2875524 on 2016/02/22 by Robert.Manuszewski More log info when saving shader temp files fails. Increased the number of attemps when moving a file fails. #jira UE-20945 Change 2875698 on 2016/02/22 by Rolando.Caloca UE4.11 - Add new bool for RHIs (unused currently) #jira UE-24967 Change 2875897 on 2016/02/22 by Taizyd.Korambayil #jira UE-20324 Re-imported Cloth Skeletal Meshes to Fix odd Circle Highlights Change 2875922 on 2016/02/22 by Mieszko.Zielinski Fixed BP-implemented EQS generators crashing when trying to add generated value of wrong type #UE4 #jira UE-25034 #rb Lukasz.Furman Change 2875960 on 2016/02/22 by Michael.Trepka Added a way to disable right click emulation on Mac and used it in TabNavigator to fix issues with its widgets not reacting to clicking #jira UE-21895 Change 2875984 on 2016/02/22 by Michael.Schoell Split output struct pins will no longer give a warning about override pins being removed. #jira UE-27150 - Format Text nodes and split nodes reporting warning that override pins are removed. Change 2876169 on 2016/02/22 by Ben.Marsh Changes to support building UHT plugins with the binary release. * Add source code and target files for UHT to binary distribution * Fix UBT deleting build products if we're only compiling a single module. * Fix UBT exception setting up compile environment when a module doesn't have any source files set to build. * Include DLL import libraries for UHT in the build * Add support for compiling UHT modules in BuildPluginCommand. Stages an empty host project to allow UHT to load any enabled plugins. Change 2876219 on 2016/02/22 by Rolando.Caloca UE4.11 - Integration from 2874609 #jira UE-24967 PC: Update D3D12 RHI - Implement _RenderThread versions of Create, Lock and Unlock Index/Vertex Buffer. Only synchronize threads on Readback - Limit GPU starvation on CPU bound scenarios by flushing work when the GPU is idle - Change texture streaming system to correctly account for placed textures. Also fix texture sizes so they accurately represent the real size of the allocation the GPU. - Disable API shader blobs - Add the ability to easily change allocation stategy for a given pool, also add a simple linear allocator and a 'Multi-Buddy Allocator' for efficiency in different scenarios - Pool Fences to prevent creation and destruction every frame when using Async Compute - Implement _RenderThread versions of CreateShaderResourceView and CreateUnorderedAccessView Change 2876232 on 2016/02/22 by Rolando.Caloca UE4.11 - Integration from 2876173 #jira UE-24967 PC: Update D3D12 RHI - Fix ResizeBuffers() failing due to dangling references to the backbuffer if deferred deletion is used. - Reorder when pending FRHIResources are deleted. This still needs to flush all pending deletes and ignore the deferred deletion queue otherwise some items may still be left in the engine's queue. - Fix UT build error due to missing FPlatformMisc::GetGPUDriverInfo() Change 2876366 on 2016/02/22 by Douglas.Copeland Adding Skeletal Meshes for Import Test Case #jira UE-24473 Change 2876401 on 2016/02/22 by Peter.Sauerbrei fix for WindowsClient build from UFE and Project Launcher #jira UE-23897 Change 2876456 on 2016/02/22 by Ben.Marsh Use a more hierarchical directory structure for packaged builds, rather than just dumping everything in the root. Now defaults to <Share>\\PackagedBuilds\\<Branch>\\<CL>\\<ProjectName>_<Platform>_<Configuration>. Change 2876507 on 2016/02/22 by Nick.Shin use HOME (osx) and USERPROFILE (windows) on appropriate target platform #jira UE-26414 -- Mac is missing .emscripten file necessary for packaging or launching onto HTML5 Change 2876537 on 2016/02/22 by Dan.Oconnor Removed dubious fix for an old bug, no longer needed but I havn't figured out what has changed. This fixes a crash on Replace References, but does not reintroduce UE-9497 #jira UE-24891 Change 2876545 on 2016/02/22 by Chad.Taylor SteamVR camera late-update fix #jira UE-27254 Change 2876825 on 2016/02/22 by Dan.Oconnor Unfortunate edge case in lifetime of UEdGraph's schema, schema is assigned after construction so its modification is in the undo buffer, and we clear it after undoing. #jira UE-25956 Change 2876878 on 2016/02/22 by Nick.Whiting PSVR HMD Server support #jira UE-27262 [CL 2905127 by Matthew Griffin in Main branch]
853 lines
31 KiB
C#
853 lines
31 KiB
C#
// Copyright 1998-2016 Epic Games, Inc. All Rights Reserved.
|
|
|
|
using System;
|
|
using System.IO;
|
|
using System.Collections.Generic;
|
|
using System.Xml;
|
|
using System.Reflection;
|
|
|
|
namespace UnrealBuildTool
|
|
{
|
|
public class BuildConfiguration
|
|
{
|
|
static BuildConfiguration()
|
|
{
|
|
if (!UnrealBuildTool.bIsSafeToReferenceConfigurationValues)
|
|
{
|
|
throw new BuildException("UEBuildConfiguration was referenced before the XmlConfig files could be loaded.");
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Whether to unify C++ code into larger files for faster compilation.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseUnityBuild;
|
|
/// <summary>
|
|
/// Whether to _force_ unify C++ code into larger files for faster compilation.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bForceUnityBuild;
|
|
|
|
/// <summary>
|
|
/// An experimental new feature that, when enabled, will try to determine source files that you are actively iteratively changing,
|
|
/// and break those files out of their unity blobs so that you can compile them as individual translation units, much faster than
|
|
/// recompiling the entire unity blob each time.
|
|
/// IMPORTANT: This feature is not complete yet! Currently, it requires source files to be read-only that you aren't actively working with!
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseAdaptiveUnityBuild;
|
|
|
|
/// <summary>
|
|
/// 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.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static int MinGameModuleSourceFilesForUnityBuild;
|
|
|
|
/// <summary>
|
|
/// Forces shadow variable warnings to be treated as errors on platforms that support it.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bShadowVariableErrors;
|
|
|
|
/// <summary>
|
|
/// New Monolithic Graphics drivers have optional "fast calls" replacing various D3d functions
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseFastMonoCalls;
|
|
|
|
/// <summary>
|
|
/// New Xbox driver supports a "fast semantics" context type. This switches it on for the immediate and deferred contexts
|
|
/// EXPERIMENTAL - WILL CAUSE RENDERING ISSUES AND/OR CRASHES AT PRESENT!
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseFastSemanticsRenderContexts;
|
|
|
|
/// Async Compute context support. Requires Mono and Fastcalls
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseAsyncComputeContext;
|
|
|
|
/// <summary>
|
|
/// An approximate number of bytes of C++ code to target for inclusion in a single unified C++ file.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static int NumIncludedBytesPerUnityCPP;
|
|
|
|
/// <summary>
|
|
/// Whether to stress test the C++ unity build robustness by including all C++ files files in a project from a single unified file.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bStressTestUnity;
|
|
|
|
/// <summary>
|
|
/// Whether headers in system paths should be checked for modification when determining outdated actions.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bCheckSystemHeadersForModification;
|
|
|
|
/// <summary>
|
|
/// Whether headers in the Development\External folder should be checked for modification when determining outdated actions.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bCheckExternalHeadersForModification;
|
|
|
|
/// <summary>
|
|
/// Whether to ignore import library files that are out of date when building targets. Set this to true to improve iteration time.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bIgnoreOutdatedImportLibraries;
|
|
|
|
/// <summary>
|
|
/// Whether to globally disable debug info generation; see DebugInfoHeuristics.cs for per-config and per-platform options.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bDisableDebugInfo;
|
|
|
|
/// <summary>
|
|
/// Whether to disable debug info on PC in development builds (for faster developer iteration, as link times are extremely fast with debug info disabled.)
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bOmitPCDebugInfoInDevelopment;
|
|
|
|
/// <summary>
|
|
/// Whether PDB files should be used for Visual C++ builds.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUsePDBFiles;
|
|
|
|
/// <summary>
|
|
/// Whether PCH files should be used.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUsePCHFiles;
|
|
|
|
/// <summary>
|
|
/// Whether to generate command line dependencies for compile actions when requested
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseActionHistory;
|
|
|
|
/// <summary>
|
|
/// The minimum number of files that must use a pre-compiled header before it will be created and used.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static int MinFilesUsingPrecompiledHeader;
|
|
|
|
/// <summary>
|
|
/// 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
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bForcePrecompiledHeaderForGameModules;
|
|
|
|
/// <summary>
|
|
/// Whether debug info should be written to the console.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bPrintDebugInfo;
|
|
|
|
/// <summary>
|
|
/// Allows logging to a file
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static string LogFilename;
|
|
|
|
/// <summary>
|
|
/// Prints performance diagnostics about include dependencies and other bits
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bPrintPerformanceInfo;
|
|
|
|
/// <summary>
|
|
/// Whether to log detailed action stats. This forces local execution.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bLogDetailedActionStats;
|
|
|
|
/// <summary>
|
|
/// Whether to deploy the executable after compilation on platforms that require deployment.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bDeployAfterCompile;
|
|
|
|
/// <summary>
|
|
/// Whether to clean Builds directory on a remote Mac before building
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bFlushBuildDirOnRemoteMac;
|
|
|
|
/// <summary>
|
|
/// Whether XGE may be used.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bAllowXGE;
|
|
|
|
/// <summary>
|
|
/// Whether to use the no_watchdog_thread option to prevent VS2015 toolchain stalls.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bXGENoWatchdogThread;
|
|
|
|
/// <summary>
|
|
/// Whether we should just export the XGE XML and pretend it succeeded
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bXGEExport;
|
|
|
|
/// <summary>
|
|
/// Whether to display the XGE build monitor.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bShowXGEMonitor;
|
|
|
|
/// <summary>
|
|
/// When enabled, XGE will stop compiling targets after a compile error occurs. Recommended, as it saves computing resources for others.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bStopXGECompilationAfterErrors;
|
|
|
|
/// <summary>
|
|
/// When enabled, allows XGE to compile pre-compiled header files on remote machines. Otherwise, PCHs are always generated locally.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bAllowRemotelyCompiledPCHs;
|
|
|
|
/// <summary>
|
|
/// Whether SN-DBS may be used.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bAllowSNDBS;
|
|
|
|
/// <summary>
|
|
/// Whether or not to delete outdated produced items.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bShouldDeleteAllOutdatedProducedItems;
|
|
|
|
/// <summary>
|
|
/// Whether to use incremental linking or not.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseIncrementalLinking;
|
|
|
|
/// <summary>
|
|
/// Whether to allow the use of LTCG (link time code generation)
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bAllowLTCG;
|
|
|
|
/// <summary>
|
|
/// Whether to support edit and continue. Only works on Microsoft compilers in 32-bit compiles.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bSupportEditAndContinue;
|
|
|
|
/// <summary>
|
|
/// Whether to omit frame pointers or not. Disabling is useful for e.g. memory profiling on the PC
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bOmitFramePointers;
|
|
|
|
/// <summary>
|
|
/// What level of logging we wish to show
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static string LogLevel;
|
|
|
|
/// <summary>
|
|
/// Processor count multiplier for local execution. Can be below 1 to reserve CPU for other tasks.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static double ProcessorCountMultiplier;
|
|
|
|
/// <summary>
|
|
/// Maximum processor count for local execution.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static int MaxProcessorCount;
|
|
|
|
/// <summary>
|
|
/// The intermediate folder - i.e. Intermediate/Build.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static string BaseIntermediateFolder;
|
|
|
|
/// <summary>
|
|
/// Relative root engine path.
|
|
/// </summary>
|
|
private static string _RelativeEnginePath = "../../Engine/";
|
|
public static string RelativeEnginePath
|
|
{
|
|
get
|
|
{
|
|
return _RelativeEnginePath;
|
|
}
|
|
set
|
|
{
|
|
_RelativeEnginePath = value;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// The path to the intermediate folder, relative to Engine/Source.
|
|
/// </summary>
|
|
public static string BaseIntermediatePath
|
|
{
|
|
get
|
|
{
|
|
return RelativeEnginePath + BaseIntermediateFolder;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// The intermediate folder - i.e. Intermediate/Build/Platform[-Architecture] for the current platform
|
|
/// </summary>
|
|
private static string _PlatformIntermediateFolder = null;
|
|
public static string PlatformIntermediateFolder
|
|
{
|
|
get
|
|
{
|
|
if (_PlatformIntermediateFolder == null)
|
|
{
|
|
throw new BuildException("Attempted to use PlatformIntermediateFolder before it was initialized");
|
|
}
|
|
return _PlatformIntermediateFolder;
|
|
}
|
|
set { _PlatformIntermediateFolder = value; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// The path to the platform intermediate folder, relative to Engine/Source.
|
|
/// </summary>
|
|
public static string PlatformIntermediatePath
|
|
{
|
|
get
|
|
{
|
|
return RelativeEnginePath + PlatformIntermediateFolder;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Whether to generate a dSYM file or not.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bGeneratedSYMFile;
|
|
|
|
/// <summary>
|
|
/// Whether to strip iOS symbols or not (implied by bGeneratedSYMFile).
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bStripSymbolsOnIOS;
|
|
|
|
/// <summary>
|
|
/// If true, then a stub IPA will be generated when compiling is done (minimal files needed for a valid IPA)
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bCreateStubIPA;
|
|
|
|
/// <summary>
|
|
/// If true, then a stub IPA will be generated when compiling is done (minimal files needed for a valid IPA)
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bCopyAppBundleBackToDevice;
|
|
|
|
/// <summary>
|
|
/// If true, then enable memory profiling in the build (defines USE_MALLOC_PROFILER=1 and forces bOmitFramePointers=false)
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseMallocProfiler;
|
|
|
|
/// <summary>
|
|
/// Enables code analysis mode. Currently, this has specific requirements. It only works on Windows
|
|
/// platform with the MSVC compiler. Also, it requires a version of the compiler that supports the
|
|
/// /analyze option, such as Visual Studio 2013
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bEnableCodeAnalysis;
|
|
|
|
/// <summary>
|
|
/// 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
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseSharedPCHs;
|
|
|
|
/// <summary>
|
|
/// Whether the dependency cache includes pre-resolved include locations so UBT doesn't have to re-resolve each include location just to check the timestamp.
|
|
/// This is technically not fully correct because the dependency cache is global and each module could have a different set of include paths that could cause headers
|
|
/// to resolve files differently. In practice this is not the case, and significantly speeds up UBT when nothing is to be done.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseIncludeDependencyResolveCache;
|
|
|
|
/// <summary>
|
|
/// Used to test the dependency resolve cache. This will verify the resolve cache has no conflicts by resolving every time and checking against any previous resolve attempts.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bTestIncludeDependencyResolveCache;
|
|
|
|
/// <summary>
|
|
/// True if we should compile Debug builds using Debug CRT libs and Debug third party dependencies. Otherwise, we'll actually
|
|
/// compile against the Release CRT but leave optimizations turned off, so that it is still easy to debug. If you enable this
|
|
/// setting, actual Debug versions of third party static libraries will be needed when compiling in Debug.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bDebugBuildsActuallyUseDebugCRT;
|
|
|
|
/// <summary>
|
|
/// True if Development and Release builds should use the release configuration of PhysX/APEX.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseShippingPhysXLibraries;
|
|
|
|
/// <summary>
|
|
/// True if Development and Release builds should use the checked configuration of PhysX/APEX. if bUseShippingPhysXLibraries is true this is ignored
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseCheckedPhysXLibraries;
|
|
|
|
/// <summary>
|
|
/// Tells the UBT to check if module currently being built is violating EULA.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bCheckLicenseViolations;
|
|
|
|
/// <summary>
|
|
/// Tells the UBT to break build if module currently being built is violating EULA.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bBreakBuildOnLicenseViolation;
|
|
|
|
/// <summary>
|
|
/// 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're 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 didn't 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'll load those cached indirect includes and check for outdatedness.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseUBTMakefiles;
|
|
|
|
/// <summary>
|
|
/// Enables support for fast UHT parsing by caching results of previous UHT runs. If a module or *.uhtmanifest
|
|
/// gets changed, all modules up to first changed one get loaded from makefile and the rest is parsed regularly.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseUHTMakefiles;
|
|
|
|
/// <summary>
|
|
/// Whether DMUCS/Distcc may be used.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bAllowDistcc;
|
|
|
|
/// <summary>
|
|
/// When enabled allows DMUCS/Distcc to fallback to local compilation when remote compiling fails. Defaults to true as separation of pre-process and compile stages can introduce non-fatal errors.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bAllowDistccLocalFallback;
|
|
|
|
/// <summary>
|
|
/// When true enable verbose distcc output to aid debugging.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bVerboseDistccOutput;
|
|
|
|
/// <summary>
|
|
/// Path to the Distcc & DMUCS executables.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static string DistccExecutablesPath;
|
|
|
|
/// <summary>
|
|
/// DMUCS coordinator hostname or IP address.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static string DMUCSCoordinator;
|
|
|
|
/// <summary>
|
|
/// The DMUCS distinguishing property value to request for compile hosts.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static string DMUCSDistProp;
|
|
|
|
/// <summary>
|
|
/// Run UnrealCodeAnalyzer instead of regular compilation. Requires setting UCA mode by bUCACheckUObjectThreadSafety or bUCACheckPCHFiles.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bRunUnrealCodeAnalyzer;
|
|
|
|
/// <summary>
|
|
/// Perform basic UObject thread safety checks. Dumps information whether UObject constructors, Serialize and PostInitProperties functions access any global/static variables or functions.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUCACheckUObjectThreadSafety;
|
|
|
|
/// <summary>
|
|
/// Dumps information about header inclusion in PCH.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUCACheckPCHFiles;
|
|
|
|
/// <summary>
|
|
/// Percentage of cpp files in module where header must be included to get included in PCH.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static float UCAUsageThreshold;
|
|
|
|
/// <summary>
|
|
/// If specified, UnrealCodeAnalyzer will analyze only specific module.
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static string UCAModuleToAnalyze;
|
|
|
|
/// <summary>
|
|
/// If specified, we will only build this particular source file, ignore all other outputs. Useful for testing non-Unity builds.
|
|
/// </summary>
|
|
public static string SingleFileToCompile;
|
|
|
|
/// <summary>
|
|
/// Whether to automatically add the -FastPDB option to the build commands in generated project files
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bAddFastPDBToProjects;
|
|
|
|
/// <summary>
|
|
/// Whether to use the :FASTLINK option when building with /DEBUG to create local PDBs
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bUseFastPDBLinking;
|
|
|
|
/// <summary>
|
|
/// Whether to request the linker create a map file as part of the build
|
|
/// </summary>
|
|
[XmlConfig]
|
|
public static bool bCreateMapFile;
|
|
|
|
/// <summary>
|
|
/// Sets the configuration back to defaults.
|
|
/// </summary>
|
|
public static void LoadDefaults()
|
|
{
|
|
bAllowLTCG = false;
|
|
bAllowRemotelyCompiledPCHs = false;
|
|
bAllowXGE = true;
|
|
bXGENoWatchdogThread = false;
|
|
bAllowSNDBS = true;
|
|
|
|
// Don't bother to check external (stable) headers for modification. It slows down UBT's dependency checking.
|
|
bCheckExternalHeadersForModification = false;
|
|
bCheckSystemHeadersForModification = false;
|
|
|
|
bCopyAppBundleBackToDevice = false;
|
|
bCreateStubIPA = true;
|
|
bDeployAfterCompile = false;
|
|
bDisableDebugInfo = false;
|
|
bEnableCodeAnalysis = false;
|
|
bFlushBuildDirOnRemoteMac = false;
|
|
bGeneratedSYMFile = false;
|
|
bStripSymbolsOnIOS = bGeneratedSYMFile;
|
|
|
|
// By default we don't bother relinking targets if only a dependent .lib has changed, as chances are that
|
|
// the import library wasn't actually different unless a dependent header file of this target was also changed,
|
|
// in which case the target would be rebuilt automatically.
|
|
bIgnoreOutdatedImportLibraries = true;
|
|
|
|
bLogDetailedActionStats = false;
|
|
bOmitFramePointers = true;
|
|
bOmitPCDebugInfoInDevelopment = false;
|
|
bPrintDebugInfo = false;
|
|
bPrintPerformanceInfo = false;
|
|
bShouldDeleteAllOutdatedProducedItems = false;
|
|
bShowXGEMonitor = false;
|
|
bStopXGECompilationAfterErrors = true;
|
|
bStressTestUnity = false;
|
|
bSupportEditAndContinue = false;
|
|
bUseActionHistory = true;
|
|
|
|
LogLevel = "Log";
|
|
|
|
// Incremental linking can yield faster iteration times when making small changes
|
|
// NOTE: We currently don't use incremental linking because it tends to behave a bit buggy on some computers (PDB-related compile errors)
|
|
bUseIncrementalLinking = false;
|
|
|
|
bUseMallocProfiler = false;
|
|
bUsePDBFiles = false;
|
|
bUsePCHFiles = true;
|
|
|
|
// Shared PCHs are necessary to avoid generating tons of private PCH files for every single little module. While
|
|
// these private PCHs do yield fastest incremental compiles for single files, it causes full rebuilds to
|
|
// take an inordinate amount of time, and intermediates will use up many gigabytes of disk space.
|
|
bUseSharedPCHs = true;
|
|
|
|
// Using unity build to coalesce source files allows for much faster full rebuild times. For fastest iteration times on single-file
|
|
// changes, consider turning this off. In some cases, unity builds can cause linker errors after iterative changes to files, because
|
|
// the synthesized file names for unity code files may change between builds.
|
|
bUseUnityBuild = true;
|
|
|
|
// This experimental feature may help to improve iterative compile times when working on code, but is
|
|
// disabled by default until we test it sufficiently
|
|
bUseAdaptiveUnityBuild = true;
|
|
|
|
bForceUnityBuild = false;
|
|
|
|
// For programmers working on gameplay code, it's convenient to have fast iteration times when changing only single source
|
|
// files. We've set this default such that smaller gameplay modules will not use the unity build feature, allowing them
|
|
// the fastest possible iterative compile times at the expense of slower full rebuild times. For larger game modules, unity
|
|
// build will automatically be activated.
|
|
MinGameModuleSourceFilesForUnityBuild = 32;
|
|
|
|
// This controls how big unity files are. Use smaller values for faster iterative iteration times at the cost of slower full rebuild times.
|
|
// This setting can greatly affect how effective parallelized compilation can be.
|
|
NumIncludedBytesPerUnityCPP = 384 * 1024;
|
|
|
|
// This sets the number of source files (post-unity-combine) in a module before we'll bother to generate a precompiled header
|
|
// for that module. If you want the fastest iterative builds for non-header changes (at the expense of slower full rebuild times),
|
|
// set this to value to 1
|
|
MinFilesUsingPrecompiledHeader = 6;
|
|
|
|
// We want iterative changes to gameplay modules to be very fast! This makes full rebuilds for small game projects a bit slower,
|
|
// but changes to individual code files will compile quickly.
|
|
bForcePrecompiledHeaderForGameModules = true;
|
|
|
|
// 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.
|
|
ProcessorCountMultiplier = 1.0;
|
|
|
|
MaxProcessorCount = int.MaxValue;
|
|
|
|
bTestIncludeDependencyResolveCache = false;
|
|
// if we are testing the resolve cache, we require UBT to use it.
|
|
bUseIncludeDependencyResolveCache = true;
|
|
|
|
//IMPORTANT THIS IS THE MAIN SWITCH FOR MONO FAST CALLS
|
|
// if this is set to true, then fast calls will be on by default on Dingo, and if false it will be off by default on Dingo.
|
|
// This can be overridden by -fastmonocalls or -nofastmonocalls in the NMAKE params.
|
|
bUseFastMonoCalls = true;
|
|
bUseAsyncComputeContext = bUseFastMonoCalls;
|
|
|
|
// Switch for fast semantics D3D contexts
|
|
// Try disabling this if you see rendering issues or crashes in the Xbox One RHI
|
|
bUseFastSemanticsRenderContexts = false;
|
|
|
|
// By default we use the Release C++ Runtime (CRT), even when compiling Debug builds. This is because the Debug C++
|
|
// Runtime isn't very 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.
|
|
bDebugBuildsActuallyUseDebugCRT = false;
|
|
|
|
// By default we use the Profile PhysX/APEX binaries.
|
|
// We do this in order to keep all configurations the same for behavior consistency. Profile gives some nice debug tools and warnings so we use it instead of Release
|
|
bUseShippingPhysXLibraries = false;
|
|
|
|
// By default we use the Profile PhysX/APEX binaries.
|
|
// We do this in order to keep all configurations the same for behavior consistency.
|
|
bUseCheckedPhysXLibraries = false;
|
|
|
|
// set up some paths
|
|
BaseIntermediateFolder = "Intermediate/Build/";
|
|
|
|
// By default check for EULA violation and warn
|
|
bCheckLicenseViolations = true;
|
|
bBreakBuildOnLicenseViolation = false;
|
|
|
|
// Enables support for fast include dependency scanning, as well as gathering data for 'UBT Makefiles', then quickly
|
|
// assembling builds in subsequent runs using data in those cached makefiles
|
|
// NOTE: This feature is new and has a number of known issues (search the code for '@todo ubtmake')
|
|
bUseUBTMakefiles = true;
|
|
|
|
// Enables support for caching results of previous UHT runs to speed up iterative development.
|
|
// This feature is new and can have issues that weren't discovered in isolated testing so disabling by default.
|
|
bUseUHTMakefiles = false;
|
|
|
|
// Distcc requires some setup - so by default disable it so we don't break local or remote building
|
|
bAllowDistcc = false;
|
|
bAllowDistccLocalFallback = true;
|
|
bVerboseDistccOutput = false;
|
|
|
|
// The normal Posix place to install distcc/dmucs would be /usr/local so start there
|
|
DistccExecutablesPath = "/usr/local/bin";
|
|
|
|
// The standard coordinator is localhost and the default distprop is empty
|
|
DMUCSCoordinator = "localhost";
|
|
DMUCSDistProp = "";
|
|
|
|
// By default compile code instead of analyzing it.
|
|
bRunUnrealCodeAnalyzer = false;
|
|
|
|
// If header is included in 0% or more cpp files in module it should be included in PCH.
|
|
UCAUsageThreshold = 100.0f;
|
|
|
|
// Compile everything by default
|
|
SingleFileToCompile = null;
|
|
|
|
bUCACheckUObjectThreadSafety = false;
|
|
|
|
// Use Fast PDB linking by default in projects but not all builds
|
|
bAddFastPDBToProjects = false;
|
|
bUseFastPDBLinking = false;
|
|
|
|
// Don't create a map file by default
|
|
bCreateMapFile = false;
|
|
|
|
// The default for normal Mac users should be to use DistCode which installs as an Xcode plugin and provides dynamic host management
|
|
if (BuildHostPlatform.Current.Platform == UnrealTargetPlatform.Mac)
|
|
{
|
|
string UserDir = Environment.GetEnvironmentVariable("HOME");
|
|
string MacDistccExecutablesPath = UserDir + "/Library/Application Support/Developer/Shared/Xcode/Plug-ins/Distcc 3.2.xcplugin/Contents/usr/bin";
|
|
|
|
// But we should use the standard Posix directory when not installed - a build farm would use a static .dmucs hosts file not DistCode.
|
|
if (System.IO.Directory.Exists(MacDistccExecutablesPath))
|
|
{
|
|
DistccExecutablesPath = MacDistccExecutablesPath;
|
|
}
|
|
|
|
if (System.IO.File.Exists(UserDir + "/Library/Preferences/com.marksatt.DistCode.plist"))
|
|
{
|
|
using (System.Diagnostics.Process DefaultsProcess = new System.Diagnostics.Process())
|
|
{
|
|
try
|
|
{
|
|
DefaultsProcess.StartInfo.FileName = "/usr/bin/defaults";
|
|
DefaultsProcess.StartInfo.CreateNoWindow = true;
|
|
DefaultsProcess.StartInfo.UseShellExecute = false;
|
|
DefaultsProcess.StartInfo.RedirectStandardOutput = true;
|
|
DefaultsProcess.StartInfo.Arguments = "read com.marksatt.DistCode DistProp";
|
|
DefaultsProcess.Start();
|
|
string Output = DefaultsProcess.StandardOutput.ReadToEnd();
|
|
DefaultsProcess.WaitForExit();
|
|
if (DefaultsProcess.ExitCode == 0)
|
|
{
|
|
DMUCSDistProp = Output;
|
|
}
|
|
}
|
|
catch (Exception)
|
|
{
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Validates the configuration. E.g. some options are mutually exclusive whereof some imply others. Also
|
|
/// some functionality is not available on all platforms.
|
|
/// @warning: the order of validation is important
|
|
/// </summary>
|
|
/// <param name="Configuration">Current configuration (e.g. development, debug, ...)</param>
|
|
/// <param name="Platform">Current platform (e.g. Win32, PS3, ...)</param>
|
|
/// <param name="bCreateDebugInfo">True if debug info should be created</param>
|
|
public static void ValidateConfiguration(CPPTargetConfiguration Configuration, CPPTargetPlatform Platform, bool bCreateDebugInfo, UEBuildPlatformContext PlatformContext)
|
|
{
|
|
UEBuildPlatform BuildPlatform = UEBuildPlatform.GetBuildPlatformForCPPTargetPlatform(Platform);
|
|
|
|
// E&C support.
|
|
if (bSupportEditAndContinue)
|
|
{
|
|
bUseIncrementalLinking = BuildPlatform.ShouldUseIncrementalLinking(Platform, Configuration);
|
|
}
|
|
|
|
// Incremental linking.
|
|
if (bUseIncrementalLinking)
|
|
{
|
|
bUsePDBFiles = BuildPlatform.ShouldUsePDBFiles(Platform, Configuration, bCreateDebugInfo);
|
|
}
|
|
|
|
// Detailed stats
|
|
if (bLogDetailedActionStats && bAllowXGE)
|
|
{
|
|
// Some build machines apparently have this turned on, so if you really want detailed stats, don't run with XGE
|
|
bLogDetailedActionStats = false;
|
|
}
|
|
|
|
// PDB
|
|
if (bUsePDBFiles)
|
|
{
|
|
// NOTE: Currently we allow XGE to run, even with PDBs, until we notice an issue with this
|
|
bool bDisallowXGEWithPDBFiles = false;
|
|
if (bDisallowXGEWithPDBFiles)
|
|
{
|
|
// Force local execution as we have one PDB for all files using the same PCH. This currently doesn't
|
|
// scale well with XGE due to required networking bandwidth. Xoreax mentioned that this was going to
|
|
// be fixed in a future version of the software.
|
|
bAllowXGE = false;
|
|
}
|
|
}
|
|
|
|
// Allow for the build platform to perform custom validation here...
|
|
// NOTE: This CAN modify the static BuildConfiguration settings!!!!
|
|
PlatformContext.ValidateBuildConfiguration(Configuration, Platform, bCreateDebugInfo);
|
|
|
|
if (!BuildPlatform.CanUseXGE())
|
|
{
|
|
bAllowXGE = false;
|
|
}
|
|
|
|
if (!BuildPlatform.CanUseDistcc())
|
|
{
|
|
bAllowDistcc = false;
|
|
}
|
|
|
|
if (!BuildPlatform.CanUseSNDBS())
|
|
{
|
|
bAllowSNDBS = false;
|
|
}
|
|
|
|
// If we're compiling just a single file, we need to prevent unity builds from running
|
|
if(SingleFileToCompile != null)
|
|
{
|
|
bUseUnityBuild = false;
|
|
bForceUnityBuild = false;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Function to call to after reset default data.
|
|
/// </summary>
|
|
public static void PostReset()
|
|
{
|
|
// Analyzing UCA is disabled for debugging convenience.
|
|
if (UnrealBuildTool.CommandLineContains(@"UnrealCodeAnalyzer")
|
|
// UHT is necessary to generate code for proper compilation.
|
|
|| UnrealBuildTool.CommandLineContains(@"UnrealHeaderTool"))
|
|
{
|
|
BuildConfiguration.bRunUnrealCodeAnalyzer = false;
|
|
}
|
|
|
|
// Couple flags have to be set properly when running UCA.
|
|
if (BuildConfiguration.bRunUnrealCodeAnalyzer)
|
|
{
|
|
// Analyzing header usage makes more sense on non unity builds.
|
|
BuildConfiguration.bUseUnityBuild = false;
|
|
|
|
// Unfortunately clang doesn't work with PCH files specified via cl.exe syntax.
|
|
BuildConfiguration.bUsePCHFiles = false;
|
|
BuildConfiguration.bUseSharedPCHs = false;
|
|
|
|
BuildConfiguration.bUseUBTMakefiles = false;
|
|
BuildConfiguration.bUseActionHistory = false;
|
|
}
|
|
}
|
|
}
|
|
}
|