PowerShell/scripts/fetch-repo.ps1
2024-09-24 21:28:31 +02:00

44 lines
1.6 KiB
PowerShell
Executable File

<#
.SYNOPSIS
Fetches updates into a Git repo
.DESCRIPTION
This PowerShell script fetches remote updates into a local Git repository (including submodules).
.PARAMETER path
Specifies the file path to the local Git repository (default is working directory).
.EXAMPLE
PS> ./fetch-repo.ps1
⏳ (1/3) Searching for Git executable... git version 2.41.0.windows.3
⏳ (2/3) Checking local repository... C:\Repos\rust
⏳ (3/3) Fetching updates (including submodules)...
✅ Updates fetched into 📂rust repo in 2s.
.LINK
https://github.com/fleschutz/PowerShell
.NOTES
Author: Markus Fleschutz | License: CC0
#>
param([string]$path = "$PWD")
try {
$stopWatch = [system.diagnostics.stopwatch]::startNew()
Write-Host "⏳ (1/3) Searching for Git executable... " -noNewline
& git --version
if ($lastExitCode -ne "0") { throw "Can't execute 'git' - make sure Git is installed and available" }
Write-Host "⏳ (2/3) Checking local repository... $path"
if (!(Test-Path "$path" -pathType container)) { throw "Can't access folder: $path" }
$repoDirName = (Get-Item "$path").Name
Write-Host "⏳ (3/3) Fetching updates (including submodules)..."
& git -C "$path" fetch --all --recurse-submodules --tags --prune --prune-tags --force --quiet
if ($lastExitCode -ne "0") { throw "'git fetch --all' failed with exit code $lastExitCode" }
[int]$elapsed = $stopWatch.Elapsed.TotalSeconds
"✅ Updates fetched into 📂$repoDirName repo in $($elapsed)s."
exit 0 # success
} catch {
"⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
exit 1
}