2020-10-05 17:36:31 +01:00
|
|
|
# Packaging helper
|
|
|
|
# Bumps versions, builds, cooks, packages variants
|
|
|
|
# Put packageconfig.json in your project folder to configure
|
|
|
|
# See packageconfig_template.json
|
2020-10-02 18:27:56 +01:00
|
|
|
[CmdletBinding()] # Fail on unknown args
|
|
|
|
param (
|
|
|
|
[string]$src,
|
|
|
|
[switch]$major = $false,
|
|
|
|
[switch]$minor = $false,
|
|
|
|
[switch]$patch = $false,
|
|
|
|
[switch]$hotfix = $false,
|
|
|
|
# Don't incrememnt version
|
2020-10-05 17:04:35 +01:00
|
|
|
[switch]$keepversion = $false,
|
2020-10-02 18:27:56 +01:00
|
|
|
# Force move tag
|
|
|
|
[switch]$forcetag = $false,
|
|
|
|
# Name of variant to build (optional, uses DefaultVariants from packageconfig.json if unspecified)
|
2020-10-06 12:08:41 +01:00
|
|
|
[array]$variants,
|
2020-10-02 18:27:56 +01:00
|
|
|
# Testing mode; skips clean checks, tags
|
|
|
|
[switch]$test = $false,
|
|
|
|
# Dry-run; does nothing but report what *would* have happened
|
|
|
|
[switch]$dryrun = $false,
|
|
|
|
[switch]$help = $false
|
|
|
|
)
|
|
|
|
|
2020-10-05 17:42:13 +01:00
|
|
|
. $PSScriptRoot\inc\platform.ps1
|
2020-10-02 18:27:56 +01:00
|
|
|
. $PSScriptRoot\inc\packageconfig.ps1
|
|
|
|
. $PSScriptRoot\inc\projectversion.ps1
|
2020-10-05 13:14:23 +01:00
|
|
|
. $PSScriptRoot\inc\uproject.ps1
|
2020-10-05 13:26:41 +01:00
|
|
|
. $PSScriptRoot\inc\ueinstall.ps1
|
2020-10-05 16:18:30 +01:00
|
|
|
. $PSScriptRoot\inc\ueeditor.ps1
|
2020-10-02 18:27:56 +01:00
|
|
|
|
|
|
|
|
|
|
|
function Write-Usage {
|
|
|
|
Write-Output "Steve's UE4 packaging tool"
|
|
|
|
Write-Output "Usage:"
|
|
|
|
Write-Output " ue4-package.ps1 [-src:sourcefolder] [-major|-minor|-patch|-hotfix] [-keepversion] [-force] [-variant=VariantName] [-test] [-dryrun]"
|
|
|
|
Write-Output " "
|
|
|
|
Write-Output " -src : Source folder (current folder if omitted), must contain buildconfig.json"
|
|
|
|
Write-Output " -major : Increment major version i.e. [x++].0.0.0"
|
|
|
|
Write-Output " -minor : Increment minor version i.e. x.[x++].0.0"
|
|
|
|
Write-Output " -patch : Increment patch version i.e. x.x.[x++].0 (default)"
|
|
|
|
Write-Output " -hotfix : Increment hotfix version i.e. x.x.x.[x++]"
|
|
|
|
Write-Output " -keepversion : Keep current version number, doesn't tag unless -forcetag"
|
|
|
|
Write-Output " -forcetag : Move any existing version tag"
|
2020-10-06 12:08:41 +01:00
|
|
|
Write-Output " -variants Name1,Name2,Name3"
|
|
|
|
Write-Output " : Build only named variants instead of DefaultVariants from packageconfig.json"
|
2020-10-02 18:27:56 +01:00
|
|
|
Write-Output " -test : Testing mode, separate builds, allow dirty working copy"
|
|
|
|
Write-Output " -dryrun : Don't perform any actual actions, just report on what you would do"
|
|
|
|
Write-Output " -help : Print this help"
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($src.Length -eq 0) {
|
|
|
|
$src = "."
|
|
|
|
Write-Verbose "-src not specified, assuming current directory"
|
|
|
|
}
|
|
|
|
|
|
|
|
$ErrorActionPreference = "Stop"
|
|
|
|
|
|
|
|
if ($help) {
|
|
|
|
Write-Usage
|
|
|
|
Exit 0
|
|
|
|
}
|
|
|
|
|
2020-10-05 13:14:23 +01:00
|
|
|
Write-Output "~-~-~ UE4 Packaging Helper Start ~-~-~"
|
|
|
|
|
2020-10-02 18:27:56 +01:00
|
|
|
if ($test) {
|
|
|
|
Write-Output "TEST MODE: No tagging, version bumping"
|
|
|
|
}
|
|
|
|
|
|
|
|
if (([bool]$major + [bool]$minor + [bool]$patch + [bool]$hotfix) -gt 1) {
|
|
|
|
Write-Output "ERROR: Can't set more than one of major/minor/patch/hotfix at the same time!"
|
|
|
|
Print-Usage
|
|
|
|
Exit 5
|
|
|
|
}
|
|
|
|
if (($major -or $minor -or $patch -or $hotfix) -and $keepversion) {
|
|
|
|
Write-Output "ERROR: Can't set keepversion at the same time as major/minor/patch/hotfix!"
|
|
|
|
Print-Usage
|
|
|
|
Exit 5
|
|
|
|
}
|
|
|
|
|
|
|
|
# Detect Git
|
|
|
|
if ($src -ne ".") { Push-Location $src }
|
|
|
|
$isGit = Test-Path ".git"
|
|
|
|
if ($src -ne ".") { Pop-Location }
|
|
|
|
|
|
|
|
# Check working copy is clean (Git only)
|
|
|
|
if (-not $test -and $isGit) {
|
|
|
|
if ($src -ne ".") { Push-Location $src }
|
|
|
|
|
|
|
|
if (Test-Path ".git") {
|
|
|
|
git diff --no-patch --exit-code
|
|
|
|
if ($LASTEXITCODE -ne 0) {
|
|
|
|
Write-Output "Working copy is not clean (unstaged changes)"
|
|
|
|
if ($dryrun) {
|
|
|
|
Write-Output "dryrun: Continuing but this will fail without -dryrun"
|
|
|
|
} else {
|
|
|
|
Exit $LASTEXITCODE
|
|
|
|
}
|
|
|
|
}
|
|
|
|
git diff --no-patch --cached --exit-code
|
|
|
|
if ($LASTEXITCODE -ne 0) {
|
|
|
|
Write-Output "Working copy is not clean (staged changes)"
|
|
|
|
if ($dryrun) {
|
|
|
|
Write-Output "dryrun: Continuing but this will fail without -dryrun"
|
|
|
|
} else {
|
|
|
|
Exit $LASTEXITCODE
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($src -ne ".") { Pop-Location }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
2020-10-05 13:14:23 +01:00
|
|
|
# Import config & project settings
|
|
|
|
$config = Read-Package-Config -srcfolder:$src
|
|
|
|
$projfile = Get-Uproject-Filename -srcfolder:$src -config:$config
|
2020-10-05 13:26:41 +01:00
|
|
|
$proj = Read-Uproject $projfile
|
|
|
|
$ueVersion = Get-UE-Version $proj
|
|
|
|
$ueinstall = Get-UE-Install $ueVersion
|
2020-10-05 17:42:13 +01:00
|
|
|
$exeSuffix = ""
|
|
|
|
$batchSuffix = ".sh"
|
|
|
|
if ($IsWindows) {
|
|
|
|
$exeSuffix = ".exe"
|
|
|
|
}
|
|
|
|
if ($IsWindows) {
|
|
|
|
$batchSuffix = ".bat"
|
|
|
|
}
|
2020-10-05 13:14:23 +01:00
|
|
|
|
2020-10-06 11:40:51 +01:00
|
|
|
$chosenVariantNames = $config.DefaultVariants
|
2020-10-06 12:08:41 +01:00
|
|
|
if ($variants) {
|
|
|
|
$chosenVariantNames = $variants
|
|
|
|
}
|
2020-10-06 11:40:51 +01:00
|
|
|
# TODO support overriding default variants with args
|
|
|
|
$chosenVariants = $config.Variants | Where-Object { $chosenVariantNames -contains $_.Name }
|
|
|
|
|
|
|
|
if ($chosenVariants.Count -ne $chosenVariantNames.Count) {
|
|
|
|
$unmatchedVariants = $chosenVariantNames | Where-Object { $chosenVariants.Name -notcontains $_ }
|
|
|
|
Write-Warning "Unknown variant(s) ignored: $($unmatchedVariants -join ", ")"
|
|
|
|
}
|
|
|
|
|
2020-10-06 12:48:10 +01:00
|
|
|
$maps = [System.Collections.Generic.HashSet[string]]::New()
|
|
|
|
if ($config.CookAllMaps) {
|
|
|
|
Get-ChildItem -Path $(Join-Path $src "Content") -Filter *.umap -Recurse | ForEach-Object {
|
|
|
|
if ($config.MapsExcluded -notcontains $_.BaseName) {
|
|
|
|
$maps.Add($_.BaseName)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} elseif ($config.MapsIncluded) {
|
|
|
|
$config.MapsIncluded | ForEach-Object { $maps.Add($_) }
|
|
|
|
}
|
|
|
|
|
2020-10-05 13:14:23 +01:00
|
|
|
Write-Output ""
|
2020-10-06 12:48:10 +01:00
|
|
|
Write-Output "Project File : $projfile"
|
2020-10-06 11:40:51 +01:00
|
|
|
Write-Output "UE Version : $ueVersion"
|
|
|
|
Write-Output "UE Install : $ueinstall"
|
2020-10-06 12:48:10 +01:00
|
|
|
Write-Output "Output Folder : $($config.OutputDir)"
|
|
|
|
Write-Output "Zipped Folder : $($config.ZipDir)"
|
|
|
|
Write-Output ""
|
2020-10-06 11:40:51 +01:00
|
|
|
Write-Output "Chosen Variants : $chosenVariantNames"
|
2020-10-06 12:48:10 +01:00
|
|
|
Write-Output "Maps to Cook : $maps"
|
2020-10-05 13:14:23 +01:00
|
|
|
Write-Output ""
|
|
|
|
|
|
|
|
|
2020-10-02 18:27:56 +01:00
|
|
|
if (([bool]$major + [bool]$minor + [bool]$patch + [bool]$hotfix) -eq 0) {
|
|
|
|
$patch = $true
|
|
|
|
}
|
2020-10-05 17:42:13 +01:00
|
|
|
$versionNumber = $null
|
2020-10-02 18:27:56 +01:00
|
|
|
if ($keepversion) {
|
2020-10-05 17:42:13 +01:00
|
|
|
$versionNumber = Get-Project-Version $src
|
2020-10-02 18:27:56 +01:00
|
|
|
} else {
|
|
|
|
# Bump up version, passthrough options
|
|
|
|
try {
|
2020-10-05 17:42:13 +01:00
|
|
|
$versionNumber = Increment-Project-Version -srcfolder:$src -major:$major -minor:$minor -patch:$patch -hotfix:$hotfix -dryrun:$dryrun
|
2020-10-02 18:27:56 +01:00
|
|
|
if (-not $dryrun -and $isGit) {
|
|
|
|
if ($src -ne ".") { Push-Location $src }
|
|
|
|
|
2020-10-05 13:14:23 +01:00
|
|
|
$verIniFile = Get-Project-Version-Ini-Filename $src
|
2020-10-02 18:27:56 +01:00
|
|
|
git add "$($verIniFile)"
|
|
|
|
if ($LASTEXITCODE -ne 0) { Exit $LASTEXITCODE }
|
2020-10-05 17:42:13 +01:00
|
|
|
git commit -m "Version bump to $versionNumber"
|
2020-10-02 18:27:56 +01:00
|
|
|
if ($LASTEXITCODE -ne 0) { Exit $LASTEXITCODE }
|
|
|
|
|
|
|
|
if ($src -ne ".") { Pop-Location }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch {
|
|
|
|
Write-Output $_.Exception.Message
|
|
|
|
Exit 6
|
|
|
|
}
|
|
|
|
}
|
|
|
|
# Keep test builds separate
|
|
|
|
if ($test) {
|
2020-10-05 17:42:13 +01:00
|
|
|
$versionNumber = "$versionNumber-test"
|
2020-10-02 18:27:56 +01:00
|
|
|
}
|
2020-10-05 17:42:13 +01:00
|
|
|
Write-Output "Next version will be: $versionNumber"
|
2020-10-02 18:27:56 +01:00
|
|
|
|
|
|
|
# For tagging release
|
|
|
|
# We only need to grab the main version once
|
|
|
|
$forcearg = ""
|
|
|
|
if ($forcetag) {
|
|
|
|
$forcearg = "-f"
|
|
|
|
}
|
|
|
|
if (-not $test -and -not $dryrun) {
|
|
|
|
if ($src -ne ".") { Push-Location $src }
|
2020-10-05 17:42:13 +01:00
|
|
|
git tag $forcearg -a $versionNumber -m "Automated release tag"
|
2020-10-02 18:27:56 +01:00
|
|
|
if ($LASTEXITCODE -ne 0) { Exit $LASTEXITCODE }
|
|
|
|
if ($src -ne ".") { Pop-Location }
|
|
|
|
}
|
|
|
|
|
2020-10-05 16:18:30 +01:00
|
|
|
|
|
|
|
$editorprojname = [System.IO.Path]::GetFileNameWithoutExtension($projfile)
|
|
|
|
Close-UE-Editor $editorprojname $dryrun
|
|
|
|
|
2020-10-05 17:42:13 +01:00
|
|
|
$ueEditorCmd = Join-Path $ueinstall "Engine/Binaries/Win64/UE4Editor-Cmd$exeSuffix"
|
|
|
|
$runUAT = Join-Path $ueinstall "Engine/Build/BatchFiles/RunUAT$batchSuffix"
|
|
|
|
|
|
|
|
|
2020-10-06 12:08:41 +01:00
|
|
|
foreach ($var in $chosenVariants) {
|
2020-10-05 17:42:13 +01:00
|
|
|
|
2020-10-06 12:08:41 +01:00
|
|
|
$outDir = Join-Path $config.OutputDir "$versionNumber/$($var.Name)"
|
2020-10-05 17:42:13 +01:00
|
|
|
|
|
|
|
$argList = [System.Collections.ArrayList]@()
|
2020-10-05 16:21:05 +01:00
|
|
|
$argList.Add("-ScriptsForProject=`"$projfile`"") > $null
|
|
|
|
$argList.Add("BuildCookRun") > $null
|
|
|
|
$argList.Add("-nocompileeditor") > $null
|
|
|
|
#$argList.Add("-installed") > $null # don't think we need this, seems to be detected
|
|
|
|
$argList.Add("-nop4") > $null
|
|
|
|
$argList.Add("-project=`"$projfile`"") > $null
|
|
|
|
$argList.Add("-cook") > $null
|
|
|
|
$argList.Add("-stage") > $null
|
|
|
|
$argList.Add("-archive") > $null
|
|
|
|
$argList.Add("-archivedirectory=`"$($outDir)`"") > $null
|
|
|
|
$argList.Add("-package") > $null
|
|
|
|
$argList.Add("-ue4exe=`"$ueEditorCmd`"") > $null
|
|
|
|
$argList.Add("-pak") > $null
|
|
|
|
$argList.Add("-prereqs") > $null
|
|
|
|
$argList.Add("-nodebuginfo") > $null
|
|
|
|
$argList.Add("-build") > $null
|
|
|
|
$argList.Add("-target=$($config.Target)") > $null
|
2020-10-06 12:08:41 +01:00
|
|
|
$argList.Add("-clientconfig=$($var.Configuration)") > $null
|
|
|
|
$argList.Add("-targetplatform=$($var.Platform)") > $null
|
2020-10-05 16:21:05 +01:00
|
|
|
$argList.Add("-utf8output") > $null
|
2020-10-06 12:48:10 +01:00
|
|
|
if ($maps.Count) {
|
|
|
|
$argList.Add("-Map=$($maps -join "+")") > $null
|
|
|
|
}
|
2020-10-05 17:42:13 +01:00
|
|
|
|
2020-10-06 12:08:41 +01:00
|
|
|
Write-Output "Building variant: $($var.Name)"
|
2020-10-06 11:40:51 +01:00
|
|
|
|
2020-10-05 17:42:13 +01:00
|
|
|
if ($dryrun) {
|
|
|
|
Write-Output "Would have run:"
|
2020-10-06 12:12:25 +01:00
|
|
|
Write-Output "> $runUAT $($argList -join " ") $($var.ExtraBuildArguments)"
|
2020-10-05 17:42:13 +01:00
|
|
|
|
2020-10-05 17:04:41 +01:00
|
|
|
} else {
|
|
|
|
$proc = Start-Process $runUAT $argList -Wait -PassThru -NoNewWindow
|
|
|
|
if ($proc.ExitCode -ne 0) {
|
|
|
|
throw "RunUAT failed!"
|
|
|
|
}
|
2020-10-05 17:42:13 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
2020-10-02 18:27:56 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
catch {
|
|
|
|
Write-Output $_.Exception.Message
|
|
|
|
Exit 9
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Write-Output "~-~-~ UE4 Packaging Helper Completed OK ~-~-~"
|