PowerShell/Scripts/pull-repo.ps1

48 lines
1.4 KiB
PowerShell
Raw Normal View History

2021-09-27 10:38:12 +02:00
<#
2021-07-13 21:10:02 +02:00
.SYNOPSIS
2022-01-18 21:02:19 +01:00
Pulls updates for a Git repository
2021-10-04 21:29:23 +02:00
.DESCRIPTION
2021-10-16 16:50:10 +02:00
This script pulls updates for a local Git repository (including submodules).
.PARAMETER RepoDir
Specifies the path to the Git repository
2021-07-13 21:10:02 +02:00
.EXAMPLE
2021-09-24 17:19:49 +02:00
PS> ./pull-repo C:\MyRepo
2021-08-29 17:50:03 +02:00
.NOTES
2022-01-18 21:02:19 +01:00
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-04-28 07:41:12 +02:00
$StopWatch = [system.diagnostics.stopwatch]::startNew()
2022-01-18 21:02:19 +01:00
"⏳ Step 1/3: Checking requirements... "
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-09-27 10:09:45 +02:00
exit 0 # success
2021-06-08 14:03:12 +02:00
}
2022-01-18 21:02:19 +01:00
"⏳ Step 2/3: Pulling updates... "
2021-06-08 14:03:12 +02:00
& git pull --recurse-submodules --jobs=4
if ($lastExitCode -ne "0") { throw "'git pull' failed" }
2021-03-19 17:47:07 +01:00
2022-01-18 21:02:19 +01:00
"⏳ Step 3/3: Updating submodules... "
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-09-27 10:09:45 +02:00
exit 0 # success
2021-03-19 17:47:07 +01:00
} catch {
2021-09-16 20:19:10 +02:00
"⚠️ Error: $($Error[0]) ($($MyInvocation.MyCommand.Name):$($_.InvocationInfo.ScriptLineNumber))"
2021-03-19 17:47:07 +01:00
exit 1
}