PowerShell/Scripts/pull-repo.ps1

38 lines
1.2 KiB
PowerShell
Raw Normal View History

2021-04-21 19:53:52 +02:00
<#
2021-04-07 15:17:49 +02:00
.SYNTAX pull-repo.ps1 [<repo-dir>]
.DESCRIPTION pulls updates for a local Git repository (including submodules)
2021-03-22 20:10:18 +01:00
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
2021-03-19 17:47:07 +01:00
#>
param($RepoDir = "$PWD")
try {
2021-06-16 08:38:33 +02:00
"🢃 Pulling updates..."
2021-04-28 07:41:12 +02:00
$StopWatch = [system.diagnostics.stopwatch]::startNew()
2021-03-19 17:47:07 +01:00
if (-not(test-path "$RepoDir" -pathType container)) { throw "Can't access directory: $RepoDir" }
set-location "$RepoDir"
2021-06-08 13:49:01 +02:00
$Result = (git status)
2021-06-08 14:03:12 +02:00
if ($lastExitCode -ne "0") { throw "Can't execute 'git' - make sure Git is installed and available" }
2021-06-08 13:49:01 +02:00
if ("$Result" -match "HEAD detached at ") {
2021-06-08 13:51:56 +02:00
write-warning "Not on a branch, so nothing to pull (in detached HEAD state)"
2021-06-08 14:03:12 +02:00
exit 0
}
& git pull --recurse-submodules --jobs=4
if ($lastExitCode -ne "0") { throw "'git pull' failed" }
2021-03-19 17:47:07 +01:00
2021-06-16 08:38:33 +02:00
& git submodule update --init --recursive
if ($lastExitCode -ne "0") { throw "'git submodule update' failed" }
2021-06-08 14:03:12 +02:00
$RepoDirName = (get-item "$RepoDir").Name
[int]$Elapsed = $StopWatch.Elapsed.TotalSeconds
"✔️ pulled updates for Git repository 📂$RepoDirName in $Elapsed sec"
2021-03-19 17:47:07 +01:00
exit 0
} catch {
2021-04-27 11:12:51 +02:00
write-error "⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
2021-03-19 17:47:07 +01:00
exit 1
}