-
-
Notifications
You must be signed in to change notification settings - Fork 809
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
One attempt at providing a prompt function during module import. #349
Changes from 5 commits
8908f89
dd95dfe
f7525bc
46933f8
0cedf56
cfcd365
9b54150
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -96,6 +96,9 @@ $global:GitPromptSettings = New-Object PSObject -Property @{ | |
|
||
EnableWindowTitle = 'posh~git ~ ' | ||
|
||
PromptSuffix = '> ' | ||
PromptDebugSuffix = ' [DBG]>> ' | ||
|
||
Debug = $false | ||
|
||
BranchNameLimit = 0 | ||
|
@@ -306,8 +309,4 @@ $PoshGitVcsPrompt = { | |
Write-GitStatus $GitStatus | ||
} | ||
|
||
# Install handler for removal/unload of the module | ||
$Global:VcsPromptStatuses += $PoshGitVcsPrompt | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
I wonder if this should move alongside the removal operation? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If we do that, should we also move the decl/assignment of |
||
$ExecutionContext.SessionState.Module.OnRemove = { | ||
$Global:VcsPromptStatuses = $Global:VcsPromptStatuses | Where-Object { $_ -ne $PoshGitVcsPrompt } | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
param([switch]$NoVersionWarn = $false) | ||
param([switch]$NoVersionWarn) | ||
|
||
if (Get-Module posh-git) { return } | ||
|
||
|
@@ -11,26 +11,98 @@ if ($psv.Major -lt 3 -and !$NoVersionWarn) { | |
"To suppress this warning, change your profile to include 'Import-Module posh-git -Args `$true'.") | ||
} | ||
|
||
Push-Location $psScriptRoot | ||
.\CheckVersion.ps1 > $null | ||
& $PSScriptRoot\CheckVersion.ps1 > $null | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Are we just getting lucky that nobody using PS v2 has complained about this breaking anything? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a pop-location later but if something crashed out before the pop-location, it would have left the current location to the module's root dir. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Oh yeah, $PSScriptRoot works only inside module (PSM1) files for PS v2 but not in PS1 files IIRC. That was fixed in v3 I believe. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ah, that makes more sense 👍 |
||
|
||
. .\Utils.ps1 | ||
. .\GitUtils.ps1 | ||
. .\GitPrompt.ps1 | ||
. .\GitTabExpansion.ps1 | ||
. .\TortoiseGit.ps1 | ||
Pop-Location | ||
. $PSScriptRoot\Utils.ps1 | ||
. $PSScriptRoot\GitUtils.ps1 | ||
. $PSScriptRoot\GitPrompt.ps1 | ||
. $PSScriptRoot\GitTabExpansion.ps1 | ||
. $PSScriptRoot\TortoiseGit.ps1 | ||
|
||
if (!$Env:HOME) { $Env:HOME = "$Env:HOMEDRIVE$Env:HOMEPATH" } | ||
if (!$Env:HOME) { $Env:HOME = "$Env:USERPROFILE" } | ||
|
||
Get-TempEnv 'SSH_AGENT_PID' | ||
Get-TempEnv 'SSH_AUTH_SOCK' | ||
|
||
Export-ModuleMember ` | ||
-Alias @( | ||
'??') ` | ||
-Function @( | ||
# Get the default prompt definition. | ||
if ($psv.Major -eq 2) { | ||
$defaultPromptDef = "`$(if (test-path variable:/PSDebugContext) { '[DBG]: ' } else { '' }) + 'PS ' + `$(Get-Location) + `$(if (`$nestedpromptlevel -ge 1) { '>>' }) + '> '" | ||
} | ||
else { | ||
$defaultPromptDef = [Runspace]::DefaultRunspace.InitialSessionState.Commands['prompt'].Definition | ||
} | ||
|
||
# If there is no prompt function or the prompt function is the default, replace the current prompt function definition | ||
$promptReplaced = $false | ||
$poshGitPromptScriptBlock = $null | ||
|
||
$currentPromptDef = if ($funcInfo = Get-Command prompt -ErrorAction SilentlyContinue) { $funcInfo.Definition } | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Is there a reason to prefer your construction over this one? $currentPromptDef = Get-Command prompt -ErrorAction SilentlyContinue) | Select-Object -ExpandProperty Definition |
||
if (!$currentPromptDef -or ($currentPromptDef -eq $defaultPromptDef)) { | ||
# Have to use [scriptblock]::Create() to get debugger detection to work in PS v2 | ||
$poshGitPromptScriptBlock = [scriptblock]::Create(@' | ||
$origLastExitCode = $global:LASTEXITCODE | ||
|
||
# A UNC path has no drive so it's better to use the ProviderPath e.g. "\\server\share". | ||
# However for any path with a drive defined, it's better to use the Path property. | ||
# In this case, ProviderPath is "\LocalMachine\My"" whereas Path is "Cert:\LocalMachine\My". | ||
# The latter is more desirable. | ||
$pathInfo = $ExecutionContext.SessionState.Path.CurrentLocation | ||
$currentPath = if ($pathInfo.Drive) { $pathInfo.Path } else { $pathInfo.ProviderPath } | ||
|
||
# File system paths are case-sensitive on Linux and case-insensitive on Windows and macOS | ||
if (($PSVersionTable.PSVersion.Major -ge 6) -and $IsLinux) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Micro-optimization, but we could calculate |
||
$stringComparison = [System.StringComparison]::Ordinal | ||
} | ||
else { | ||
$stringComparison = [System.StringComparison]::OrdinalIgnoreCase | ||
} | ||
|
||
# Abbreviate path by replacing beginning of path with ~ *iff* the path is in the user's home dir | ||
if ($currentPath -and $currentPath.StartsWith($Home, $stringComparison)) | ||
{ | ||
$currentPath = "~" + $currentPath.SubString($Home.Length) | ||
} | ||
|
||
# Write the abbreviated current path | ||
Write-Host $currentPath -NoNewline | ||
|
||
# Write the Git status summary information | ||
Write-VcsStatus | ||
|
||
# If stopped in the debugger, the prompt needs to indicate that in some fashion | ||
$debugMode = (Test-Path Variable:/PSDebugContext) -or [runspace]::DefaultRunspace.Debugger.InBreakpoint | ||
$promptSuffix = if ($debugMode) { $GitPromptSettings.PromptDebugSuffix } else { $GitPromptSettings.PromptSuffix } | ||
|
||
$global:LASTEXITCODE = $origLastExitCode | ||
$promptSuffix | ||
'@) | ||
|
||
# Set the posh-git prompt as the default prompt | ||
Set-Item Function:\prompt -Value $poshGitPromptScriptBlock | ||
|
||
$promptReplaced = $true | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Could we attach a property to our |
||
} | ||
|
||
# Install handler for removal/unload of the module | ||
$ExecutionContext.SessionState.Module.OnRemove = { | ||
$global:VcsPromptStatuses = $global:VcsPromptStatuses | Where-Object { $_ -ne $PoshGitVcsPrompt } | ||
|
||
if ($promptReplaced) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Wondering if this flag has been made obsolete by the |
||
# Check if the posh-git prompt function itself has been replaced. If so, do not restore the prompt function | ||
$promptDef = if ($funcInfo = Get-Command prompt -ErrorAction SilentlyContinue) { $funcInfo.Definition } | ||
if ($promptDef -eq $poshGitPromptScriptBlock) { | ||
Set-Item Function:\prompt -Value ([scriptblock]::Create($defaultPromptDef)) | ||
return | ||
} | ||
} | ||
|
||
Write-Warning 'If your prompt function uses any posh-git commands, it may cause the module to be re-imported.' | ||
} | ||
|
||
$exportModuleMemberParams = @{ | ||
Alias = @('??') # TODO: Remove in 1.0.0 | ||
Function = @( | ||
'Invoke-NullCoalescing', | ||
'Write-GitStatus', | ||
'Write-Prompt', | ||
|
@@ -46,6 +118,8 @@ Export-ModuleMember ` | |
'Add-SshKey', | ||
'Get-SshPath', | ||
'Update-AllBranches', | ||
'tgit') | ||
|
||
'tgit' | ||
) | ||
} | ||
|
||
Export-ModuleMember @exportModuleMemberParams |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why remove?
Update: Nevermind, I see it was just moved into the .psm1.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
BTW I need to update that logic a bit to check if someone might have installed a different prompt function after we installed the posh-git default one.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And as a "module level" operation, posh-git.psm1 seemed like a more fitting place for this handler.