Skip to content

XistGG/UnrealXistTools

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Unreal Xist Tools

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.

Setup

  • Make sure you are using PowerShell 7+
    • Mac: brew install --cask powershell
    • Windows: winget install Microsoft.PowerShell (issues? try this fix)
  • Clone this repository
  • Add this repository clone folder to your $env:PATH

PowerShell Execution Policy Notice

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.

Build Tools

IDE Tools

Engine Tools

Project Tools

  • UProject.ps1
    • Get Project Settings
  • UProjectFile.ps1
    • Get the .uproject file associated with a path (current directory by default)
  • UProjectSln.ps1
    • Get the .sln file associated with a path (current directory by default)

P4 Tools

  • P4Config.ps1
    • Locate and import .p4config in the given Path or one of its parents
    • -Export the config to the system environment (optional)
  • P4EncodePath.ps1
    • Encode (or -Decode) paths for P4
  • 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)
  • P4Info.ps1
    • Makes it real easy to extract p4 info values
  • P4Reunshelve.ps1
    • Easy repetitive "revert changes and re-unshelve"
    • Useful when coding on 1 workstation and testing on multiple other workstations

UProjectClean.ps1

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.

Usage Examples

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

UEdit.ps1

view source: UEdit.ps1

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.

Usage Examples

Open the .uproject file in the current directory:

UEdit.ps1

Open the .uproject file in the specified directory:

UEdit.ps1 path/to/project

UnrealVersionSelector.ps1

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.

Usage Examples

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/../..

Rider.ps1

view source: Rider.ps1

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.

Usage Examples

Open the .uproject file in the current directory:

Rider.ps1

Open the .sln file in the current directory:

Rider.ps1 -sln

VS.ps1

view source: VS.ps1

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.

Usage Examples

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

MigrateUEMarketplacePlugin.ps1

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
  • -ToThirdParty
    • If present, causes the plugin to be migrated to your Plugins/ThirdParty directory rather than to the default Plugins/Marketplace
  • -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

Usage Examples

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.

UEngine.ps1

view source: UEngine.ps1

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.

Usage Examples

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

UProject.ps1

view source: UProject.ps1

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.

Usage

View the current .uproject in terminal:

UProject.ps1

Get the Engine Association of a specific .uproject:

$(UProject.ps1 project.uproject).EngineAssociation

UProjectFile.ps1

view source: UProjectFile.ps1

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.

Usage

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

UProjectSln.ps1

view source: UProjectSln.ps1

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.

Usage

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

P4Config.ps1

view source: P4Config.ps1

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

Usage

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

P4EncodePath.ps1

view source: P4EncodePath.ps1

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.

P4ImportBulk.ps1

view source: P4ImportBulk.ps1

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.

P4Info.ps1

view source: P4Info.ps1

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.

P4Reunshelve.ps1

view source: P4Reunshelve.ps1

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.

About

Xist's Unreal C++ Build & Dev Tools (PowerShell 7)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published