Xist's Unreal C++ Build & Dev Tools. Requires PowerShell 7+.
Main Branch: https://github.com/XistGG/UnrealXistTools/
UnrealXistTools is intended to work on both Windows and Mac. Each tool below specifies the exact compatibility (some are Windows only).
It should also mostly work on Linux, though I haven't tested it yet.
- Make sure you are using PowerShell 7+
- Mac:
brew install --cask powershell
- Windows:
winget install Microsoft.PowerShell
(issues? try this fix)
- Mac:
- Clone this repository
- Add this repository clone folder to your
$env:PATH
The first time you try to set this up, you may get an error regarding PowerShell execution policy.
By default, Windows wants to protect you from yourself. To configure your system to run PowerShell scripts, you need to explicitly set your PowerShell execution policy.
For example if you want to use my settings, you can do:
Set-ExecutionPolicy -ExecutionPolicy RemoteSigned -Scope CurrentUser
Mine is set to RemoteSigned
and these scripts all run fine.
Note that you must be responsible to ensure you only run PowerShell that you trust!
Also I am no PowerShell security expert, so if you are concerned about this, I encourage you to research it further on your own.
- UProjectClean.ps1
- Completely Clean/Reset Repo/Depot
- Removes all generated C++ Build files
- Regenerate Project Files
- UEdit.ps1
- Edit a project in Unreal Editor
- UnrealVersionSelector.ps1
- Easy-to-use interface to Epic's UnrealVersionSelector.exe
- MigrateUEMarketplacePlugin.ps1
- Migrate a C++ plugin from one Engine version to another
- UEngine.ps1
- View and Modify Custom Engine Builds (read/write Epic's Windows registry keys)
- UProject.ps1
- Get Project Settings
- UProjectFile.ps1
- Get the
.uproject
file associated with a path (current directory by default)
- Get the
- UProjectSln.ps1
- Get the
.sln
file associated with a path (current directory by default)
- Get the
- P4Config.ps1
- Locate and import
.p4config
in the given Path or one of its parents -Export
the config to the system environment (optional)
- Locate and import
- P4EncodePath.ps1
- Encode (or
-Decode
) paths for P4
- Encode (or
- P4ImportBulk.ps1
- Import a massive number of files into a new depot without breaking P4
(tested by importing 800k+ files from UDN P4
//UE5/Release-5.2
)
- Import a massive number of files into a new depot without breaking P4
(tested by importing 800k+ files from UDN P4
- P4Info.ps1
- Makes it real easy to extract
p4 info
values
- Makes it real easy to extract
- P4Reunshelve.ps1
- Easy repetitive "revert changes and re-unshelve"
- Useful when coding on 1 workstation and testing on multiple other workstations
view source: UProjectClean.ps1
Compatibility: Windows only
- Delete all
Binaries
(generated data) - Delete all
Intermediate
(generated data) - Delete all
*.sln
(generated data) - Delete all
.idea
(if you set-Idea
switch or-Nuke
) - Delete
DerivedDataCache
(if you set-DDC
switch or-Nuke
) - Delete
Saved
(if you set-Saved
switch or-Nuke
) - Generate Project Files
Supports the -Debug
flag, add it to any command to gain more insight.
Clean the project in the current directory:
UProjectClean.ps1
Clean a specific MyGame.uproject
:
UProjectClean.ps1 MyGame.uproject
Clean (NUKE) the project in the current directory: (implies flags -DDC
, -Idea
, -Saved
)
UProjectClean.ps1 -Nuke
Compatibility: Windows only
Start Unreal Editor: Open the .uproject
associated with the current directory.
Alias for UnrealVersionSelector.ps1 -Editor $(&UProjectFile.ps1 -Path:$Path).FullName
Note that as this uses UnrealVersionSelector
under the hood, you must have compiled your
editor and project in Development Editor
mode. When opening a project in editor, the
underlying UVS requires that we use a Development editor.
Supports the -Debug
flag, add it to any command to gain more insight.
Open the .uproject
file in the current directory:
UEdit.ps1
Open the .uproject
file in the specified directory:
UEdit.ps1 path/to/project
view source: UnrealVersionSelector.ps1
Compatibility: Windows only
- Allows developer to refer to
.uproject
files via relative paths - Infers the name of
.uproject
files based on current directory - Executes Epic's
UnrealVersionSelector.exe
for base functionality
Supports the -Debug
flag, add it to any command to gain more insight.
See -Help
for Usage.
Generate project files:
UnrealVersionSelector.ps1 -ProjectFiles
Choose which Engine to use:
UnrealVersionSelector.ps1 -SwitchVersion
Choose a Specific Engine:
UnrealVersionSelector.ps1 -SwitchVersionSilent /Project/Root/Engine/Binaries/../..
Compatibility: Mac + Windows
Start Rider: Open the .uproject
associated with the current directory.
Supports the -Debug
flag, add it to any command to gain more insight.
Open the .uproject
file in the current directory:
Rider.ps1
Open the .sln
file in the current directory:
Rider.ps1 -sln
Compatibility: Windows only
Start Visual Studio: Open the .sln
associated with the current directory.
Supports the -Debug
flag, add it to any command to gain more insight.
Open the .sln
file in the current directory:
VS.ps1
Diff 2 files (for example can be used from p4v
as the diff tool)
VS.ps1 -diff file1 file2
view source: MigrateUEMarketplacePlugin.ps1
Compatibility: Mac + Windows
Required Arguments:
-Plugin
Name-PluginSourceName
Name of this plugin's Fab directory-From
PathToSourceEngineRoot-To
PathToDestinationEngineRoot
Optional Arguments:
-PluginDestinationName
- By default, the
-Plugin
Name is also used as the-PluginDestinationName
- You can override this to name the plugin directory something different
- By default, the
-ToThirdParty
- If present, causes the plugin to be migrated to your
Plugins/ThirdParty
directory rather than to the defaultPlugins/Marketplace
- If present, causes the plugin to be migrated to your
-Debug
- If present, this switch causes additional debugging output to be written
-Force
- If the destination plugin already exists, forcefully remove it and overwrite with the newly built plugin
- If this switch is not present, the script will abort rather than overwrite an existing plugin
MigrateUEMarketplacePlugin.ps1 -Plugin AutoSizeComments -PluginSourceName AutoSizec06247d73541V16 -From "E:/EpicLauncher/UE_5.5" -To "E:/MyEngine_5.5" -Debug -Force
MigrateUEMarketplacePlugin.ps1 -Plugin BlueprintAssist -PluginSourceName Blueprin5dd30dcb4d35V14 -From "E:/EpicLauncher/UE_5.5" -To "E:/MyEngine_5.5" -Debug -Force
In the above example, you would have told the Epic Games Launcher to install UE 5.5 into
the folder E:/EpicLauncher/UE_5.5
and you would have installed these plugins from the UE Marketplace into the UE 5.5 Engine.
These commands would then copy 3 plugins from the UE Marketplace into your custom engine
at E:/MyEngine_5.5
including AutoSizeComments
and BlueprintAssist
.
NOTICE: Since UE Marketplace migrated to Fab, Marketplace plugins are now being installed into random-looking (probably Fab ID-based) directory names.
In my case it installed them into these weird directories:
Plugin | Marketplace Directory |
---|---|
AutoSizeComments |
Engine/Plugins/Marketplace/AutoSizec06247d73541V16 |
BlueprintAssist |
Engine/Plugins/Marketplace/Blueprin5dd30dcb4d35V14 |
Whereas the directory name used to match the plugin name, it no longer does.
Thus, you have to use the -PluginSourceName
parameter and set it to the name of the Marketplace directory.
Because this is now required, there is also a new optional -PluginDestinationName
parameter,
which defaults to the same as the Plugin name, but you can set it to this random looking ID
if you want it to be named exactly the same, or choose some other name, etc. It's up to you.
Compatibility: Mac + Windows
- By default selects the engine used by the current or named project
-List
lists all available custom engines-Name
selects from available custom engines-NewName
renames an engine to your choice of names-UProject
selects the engine associated with the given .uproject-Debug
enables more detailed debug information
See -Help
for more Usage info.
Display a list of all custom engines on this system:
UEngine.ps1 -List
Rename the {1234-5678-Random-GUID-Name}
custom engine as MyEngine
:
UEngine.ps1 "{1234-5678-Random-GUID-Name}" -NewName MyEngine
Rename the SomeCustom
custom engine as OtherCustom
with -Debug
info:
UEngine.ps1 SomeCustom -NewName OtherCustom -Debug
Get info about the engine associated with My.uproject
:
UEngine.ps1 -UProject path/to/My.uproject
Get info about the engine associated with the .uproject
in the current directory
with -Debug
info
(errors out if there is no .uproject
in the current directory):
UEngine.ps1 -Debug
Compatibility: Mac + Windows
Returns JSON parsed contents of $UProjectFile
as a PowerShell Object
Supports the -Debug
flag, add it to any command to gain more insight.
View the current .uproject
in terminal:
UProject.ps1
Get the Engine Association of a specific .uproject
:
$(UProject.ps1 project.uproject).EngineAssociation
Compatibility: Mac + Windows
Returns the .uproject
file relevant to the -Path
(implicit first string parameter, or current directory by default).
Example: /project/project.uproject
Supports the -Debug
switch.
Enable it to see debug info to help you understand how the .uproject
is being assigned.
Select the default .uproject
for the current directory:
UProjectFile.ps1
Select the default .uproject
in the specified directory:
UProjectFile.ps1 /project
Select a specific .uproject
:
UProjectFile.ps1 project.uproject
Compatibility: Windows only
Returns the .sln
file relevant to the -Path
(implicit first string parameter, or current directory by default).
Example: /project/project.sln
Supports the -Debug
switch.
Enable it to see debug info to help you understand how the .sln
is being assigned.
Select the default .sln
for the current directory:
UProjectSln.ps1
Select the default .sln
in the specified directory:
UProjectSln.ps1 /project
Select a specific .sln
:
UProjectSln.ps1 project.sln
Compatibility: Mac + Windows
This helpful script can be used before you launch an IDE or other build tool
that requires access to P4 but isn't smart enough to understand that you
have multiple projects existing in the same depot (e.g. a custom Engine and a UProject)
and you just want a single .p4config
in the workspace root that is effective for all
the projects in that workspace.
-Path
is an optional path to work in (Default: Current directory)-Export
causes the found.p4config
file (if any) to be exported to the system environment-Debug
provides helpful debugging info
Find, parse and return the .p4config
relevant to the current directory:
P4Config.ps1 -Debug
Find, parse and inject the .p4config
relevant to the current directory
into the system environment for the current powershell process:
P4Config.ps1 -Export -Debug
Compatibility: Mac + Windows
Encodes or Decodes a P4 path. See -Help
for more details.
See P4 filespecs for more info regarding P4 path encoding requirements.
See -Help
for Usage.
Compatibility: Mac + Windows (only tested on Windows)
Import a massive number of files into a new depot without breaking P4.
As of Jan-2023 I am unable to get P4 to successfully import UDN in one commit. Perhaps it is related to RAM availability?
With this script, I can break the 800k+ files into batches and submit those, which works great.
Supports the -Debug
flag, add it to any command to gain more insight.
See -Help
for Usage.
Compatibility: Mac + Windows
Extracts p4 info
output into a Dictionary, which it returns as the result.
You can then grab specific keys if you want, for example:
$P4Username = (P4Info.ps1)."User name"
You can also use this to initialize .p4config
files like:
P4Info.ps1 -Config > .p4config
Try the -Debug
switch to see the parse info.
Compatibility: Mac + Windows
"Reunshelve" will repeatedly unshelve files into the current workspace.
This script will revert ALL changes in your current workspace (it will
prompt you for every file unless you -Force
) and will then unshelve the
-SCL
changelist into the current workspace.
I use this for example when I am testing on multiple workstations simultaneously. On my primary workstation I make changes, when I'm ready to test, I shelve the changes, then on the other workstations I run this script. The other workstations never have modifications other than the unshelved changes, I just repeatedly "re-unshelve", discarding whatever the previous shelved files were and replacing them with the new variant.
P4Reunshelve.ps1 -SCL 123
The above command will unshelve the files from CL# 123, prompting you for each and every file before it reverts anything.
P4Reunshelve.ps1 -Force -SCL 123
WARNING: The above command with the -Force
flag will revert all changes
in all changelists in your current workspace without prompting you
for confirmation. It will then unshelve CL# 123.