utils.ps1
<#
.SYNOPSIS Get current git branch. #> function Get-Git-CurrentBranch { git symbolic-ref --quiet HEAD *> $null if ($LASTEXITCODE -eq 0) { return git rev-parse --abbrev-ref HEAD } else { return } } function Get-Git-MainBranch { git rev-parse --git-dir *> $null if ($LASTEXITCODE -ne 0) { return } $branches = @('main', 'trunk') foreach ($branch in $branches) { & git show-ref -q --verify refs/heads/$branch if ($LASTEXITCODE -eq 0) { return $branch } } return 'master' } # Don't add `Remove-Alias` on PowerShell >= 6. # PowerShell >= 6 already has built-in `Remove-Alias`. # Let use built-in `Remove-Alias` on PowerShell >= 6. if ($PSVersionTable.PSVersion.Major -le 5) { function Remove-Alias ([string] $AliasName) { while (Test-Path Alias:$AliasName) { Remove-Item Alias:$AliasName -Force 2> $null } } } function Format-AliasDefinition { param ( [Parameter(Mandatory = $true)][string] $Definition ) $definitionLines = $Definition.Trim() -split "`n" | ForEach-Object { $line = $_.TrimEnd() # Trim 1 indent if ($_ -match "^`t") { return $line.Substring(1) } elseif ($_ -match '^ ') { return $line.Substring(4) } return $line } return $definitionLines -join "`n" } <# .SYNOPSIS Get git aliases' definition. .DESCRIPTION Get definition of all git aliases or specific alias. .EXAMPLE PS C:\> Get-Git-Aliases Get definition of all git aliases. .EXAMPLE PS C:\> Get-Git-Aliases -Alias gst Get definition of `gst` alias. #> function Get-Git-Aliases ([string] $Alias) { $esc = [char] 27 $green = 32 $magenta = 35 $Alias = $Alias.Trim() $blacklist = @( 'Get-Git-CurrentBranch', 'Remove-Alias', 'Format-AliasDefinition', 'Get-Git-Aliases' ) $aliases = Get-Command -Module git-aliases | Where-Object { $_ -notin $blacklist } if (-not ([string]::IsNullOrEmpty($Alias))) { $foundAliases = $aliases | Where-Object -Property Name -Value $Alias -EQ if ($foundAliases -is [array]) { return Format-AliasDefinition($foundAliases[0].Definition) } else { return Format-AliasDefinition($foundAliases.Definition) } } $aliases = $aliases | ForEach-Object { $name = $_.Name $definition = Format-AliasDefinition($_.Definition) $definition = "$definition`n" # Add 1 line break for some row space return [PSCustomObject]@{ Name = $name Definition = $definition } } $cols = @( @{ Name = 'Name' Expression = { # Print alias name in green "$esc[$($green)m$($_.Name)$esc[0m" } }, @{ Name = 'Definition' Expression = { # Print alias definition in yellow "$esc[$($magenta)m$($_.Definition)$esc[0m" } } ) return Format-Table -InputObject $aliases -AutoSize -Wrap -Property $cols } <# .SYNOPSIS Print deprecated message. .DESCRIPTION Print a colored message telling that a specific alias ($previous) is deprecated, suggesting the use of another alias ($next). .EXAMPLE PS C:\> Write-Host-Deprecated "gup" "gpr" [git-aliases] gup is a deprecated alias, use "gpr" instead. #> function Write-Host-Deprecated { param ( [Parameter(Mandatory = $true)][string] $previous, [Parameter(Mandatory = $true)][string] $next ) Write-Host "[git-aliases] " -ForegroundColor Yellow -NoNewLine Write-Host "${previous}" -ForegroundColor Red -NoNewLine Write-Host " is a deprecated alias, use " -ForegroundColor Yellow -NoNewLine Write-Host """${next}""" -ForegroundColor Green -NoNewLine Write-Host " instead.`n" -ForegroundColor Yellow } |