2021-04-21 19:53:52 +02:00
|
|
|
|
<#
|
2021-07-13 21:10:02 +02:00
|
|
|
|
.SYNOPSIS
|
|
|
|
|
pull-repo.ps1 [<repo-dir>]
|
|
|
|
|
.DESCRIPTION
|
2021-08-29 17:50:03 +02:00
|
|
|
|
Pulls updates for a local Git repository (including submodules).
|
2021-07-13 21:10:02 +02:00
|
|
|
|
.EXAMPLE
|
|
|
|
|
PS> .\pull-repo.ps1 C:\MyRepo
|
2021-08-29 17:50:03 +02:00
|
|
|
|
.NOTES
|
|
|
|
|
Author: Markus Fleschutz · License: CC0
|
2021-07-13 21:10:02 +02:00
|
|
|
|
.LINK
|
|
|
|
|
https://github.com/fleschutz/PowerShell
|
2021-03-19 17:47:07 +01:00
|
|
|
|
#>
|
|
|
|
|
|
2021-07-15 15:51:22 +02:00
|
|
|
|
param([string]$RepoDir = "$PWD")
|
2021-03-19 17:47:07 +01:00
|
|
|
|
|
|
|
|
|
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-04-20 08:06:33 +02:00
|
|
|
|
|
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
|
|
|
|
|
}
|