PowerShell/docs/list-old-branches.md

88 lines
2.8 KiB
Markdown
Raw Normal View History

2024-11-08 12:38:20 +01:00
The *list-old-branches.ps1* Script
===========================
2024-11-08 12:35:11 +01:00
This PowerShell script lists branches in a Git repository matching: (1) search pattern, (2) already merged, (3) older than 2024
Parameters
----------
```powershell
/home/markus/Repos/PowerShell/scripts/list-old-branches.ps1 [[-pathToRepo] <String>] [[-searchPattern] <String>] [<CommonParameters>]
-pathToRepo <String>
Specifies the path to the Git repository (current working directory by default)
Required? false
Position? 1
Default value "$PWD"
Accept pipeline input? false
Accept wildcard characters? false
-searchPattern <String>
Required? false
Position? 2
Default value origin/dev/*
Accept pipeline input? false
Accept wildcard characters? false
[<CommonParameters>]
This script supports the common parameters: Verbose, Debug, ErrorAction, ErrorVariable, WarningAction,
WarningVariable, OutBuffer, PipelineVariable, and OutVariable.
```
Example
-------
```powershell
PS> ./list-old-branches.ps1 C:\Repos\UFA
q
```
Script Content
--------------
```powershell
<#
.SYNOPSIS
Lists old Git branches
.DESCRIPTION
This PowerShell script lists branches in a Git repository matching: (1) search pattern, (2) already merged, (3) older than 2024
.PARAMETER pathToRepo
Specifies the path to the Git repository (current working directory by default)
.EXAMPLE
PS> ./list-old-branches.ps1 C:\Repos\UFA
q#>
param([string]$pathToRepo = "$PWD", [string]$searchPattern = "origin/dev/*")
try {
"(1/3) Searching for Git executable... "
& git --version
if ($lastExitCode -ne "0") { throw "Can't execute 'git' - make sure Git is installed and available" }
"(2/3) Checking local repository..."
if (!(Test-Path "$pathToRepo" -pathType container)) { throw "Can't access repo folder: $pathToRepo" }
"(3/3) Querying already merged branches with name '$searchPattern'..."
$branches = $(git -C "$pathToRepo" branch --list --remotes --no-color --no-column --merged HEAD "$searchPattern")
if ($lastExitCode -ne "0") { throw "'git branch --list' failed" }
""
"LAST COMMIT DATE BRANCH NAME"
"---------------- -----------"
foreach($branch in $branches) {
$branchName = $branch.Trim() # remove leading spaces
$dateOfLastCommit = (git -C "$pathToRepo" log -1 --format=%cs $branchName)
if ($dateOfLastCommit -like "2024-*") { continue} # too young
"$dateOfLastCommit $branchName"
}
exit 0 # success
} catch {
Write-Error "Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
exit 1
}
```
2024-11-08 12:38:20 +01:00
*(generated by convert-ps2md.ps1 using the comment-based help of list-old-branches.ps1 as of 11/08/2024 12:37:53)*