oh-my-posh/packages/powershell/go-my-posh/go-my-posh.psm1

122 lines
4.1 KiB
PowerShell
Raw Normal View History

2020-09-11 23:42:26 -07:00
<#
.SYNOPSIS
Generates the prompt before each line in the console
#>
$global:PoshSettings = New-Object -TypeName PSObject -Property @{
Theme = "$PSScriptRoot\Themes\jandedobbeleer.json"
}
function Get-PoshCommand {
$poshCommand = "$PSScriptRoot/bin/posh-windows-amd64.exe"
if ($IsMacOS) {
$poshCommand = "$PSScriptRoot/bin/posh-darwin-amd64"
}
if ($IsLinux) {
$poshCommand = "$PSScriptRoot/bin/posh-linux-amd64"
}
return $poshCommand
}
# Set the right binary to executable before doing anything else
if (!$IsWindows) {
$executable = Get-PoshCommand
Invoke-Expression -Command "chmod +x $executable"
}
if ($IsWindows) {
# When this is not set, outputted fonts aren't rendered correctly in some terminals for the prompt function
[console]::OutputEncoding = New-Object System.Text.UTF8Encoding
# Not running it beforehand in the terminal will fail the prompt somehow
$poshCommand = Get-PoshCommand
Invoke-Expression -Command $poshCommand | Out-Null
}
2020-09-11 23:42:26 -07:00
function Set-PoshPrompt {
param(
[Parameter(Mandatory = $false)]
2020-09-11 23:42:26 -07:00
[string]
$Theme
)
if (Test-Path "$PSScriptRoot/Themes/$Theme.json") {
$global:PoshSettings.Theme = "$PSScriptRoot/Themes/$Theme.json"
2020-09-11 23:42:26 -07:00
}
elseif (Test-Path $Theme) {
$global:PoshSettings.Theme = $Theme
2020-09-11 23:42:26 -07:00
}
[ScriptBlock]$Prompt = {
$realLASTEXITCODE = $global:LASTEXITCODE
$poshCommand = Get-PoshCommand
$config = $global:PoshSettings.Theme
Invoke-Expression -Command "$poshCommand -config $config -error $realLASTEXITCODE"
$global:LASTEXITCODE = $realLASTEXITCODE
Remove-Variable realLASTEXITCODE -Confirm:$false
}
Set-Item -Path Function:prompt -Value $Prompt -Force
}
function Get-PoshThemes {
$esc = [char]27
$consoleWidth = $Host.UI.RawUI.WindowSize.Width
$logo = @'
__ _ __
/ / | | \ \
/ / __ _ ___ _ __ ___ _ _ _ __ ___ ___| |__ \ \
< < / _` |/ _ \ | '_ ` _ \| | | | | '_ \ / _ \/ __| '_ \ > >
\ \ | (_| | (_) | | | | | | | |_| | | |_) | (_) \__ \ | | | / /
\_\ \__, |\___/ |_| |_| |_|\__, | | .__/ \___/|___/_| |_| /_/
__/ | __/ | | |
|___/ |___/ |_|
'@
Write-Host $logo
$poshCommand = Get-PoshCommand
Get-ChildItem -Path "$PSScriptRoot\Themes\*" -Include '*.json' | Sort-Object Name | ForEach-Object -Process {
Write-Host ("=" * $consoleWidth)
Write-Host "$esc[1m$($_.BaseName)$esc[0m"
Write-Host ""
Invoke-Expression -Command "$poshCommand -config $($_.FullName)"
Write-Host ""
}
Write-Host ("=" * $consoleWidth)
}
function Write-PoshTheme {
$poshCommand = Get-PoshCommand
Invoke-Expression -Command "$poshCommand -print-config"
}
# Helper function to create argument completion results
function New-CompletionResult {
param(
[Parameter(Mandatory)]
[string]$CompletionText,
[string]$ListItemText = $CompletionText,
[System.Management.Automation.CompletionResultType]$CompletionResultType = [System.Management.Automation.CompletionResultType]::ParameterValue,
[string]$ToolTip = $CompletionText
)
New-Object System.Management.Automation.CompletionResult $CompletionText, $ListItemText, $CompletionResultType, $ToolTip
}
function ThemeCompletion {
param(
$commandName,
$parameterName,
$wordToComplete,
$commandAst,
$fakeBoundParameter
)
$themes = Get-ChildItem -Path "$PSScriptRoot\Themes\*" -Include '*.json' | Sort-Object Name | Select-Object -Property BaseName
$themes |
Where-Object { $_.BaseName.ToLower().StartsWith($wordToComplete.ToLower()); } |
Select-Object -Unique -ExpandProperty BaseName |
ForEach-Object { New-CompletionResult -CompletionText $_ }
}
Register-ArgumentCompleter `
-CommandName Set-PoshPrompt `
-ParameterName Theme `
-ScriptBlock $function:ThemeCompletion