mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2024-12-28 20:39:40 -08:00
feat(shell): perform cleanup for a new initialization
This commit is contained in:
parent
8de89185e2
commit
4e25c7c1c9
|
@ -55,6 +55,14 @@ function postexec_omp --on-event fish_postexec
|
|||
set --global --export omp_lastcommand $argv
|
||||
end
|
||||
|
||||
# perform cleanup so a new initialization in current session works
|
||||
if test "$(string match -e '_render_transient' $(bind \r --user 2>/dev/null))" != ''
|
||||
bind -e \r
|
||||
end
|
||||
if test "$(string match -e '_render_tooltip' $(bind \x20 --user 2>/dev/null))" != ''
|
||||
bind -e \x20
|
||||
end
|
||||
|
||||
# tooltip
|
||||
|
||||
function _render_tooltip
|
||||
|
|
|
@ -102,7 +102,7 @@ New-Module -Name "oh-my-posh-core" -ScriptBlock {
|
|||
}
|
||||
|
||||
if ("::TOOLTIPS::" -eq "true") {
|
||||
Set-PSReadLineKeyHandler -Key SpaceBar -ScriptBlock {
|
||||
Set-PSReadLineKeyHandler -Key Spacebar -BriefDescription 'OhMyPoshSpaceKeyHandler' -ScriptBlock {
|
||||
[Microsoft.PowerShell.PSConsoleReadLine]::Insert(' ')
|
||||
$position = $host.UI.RawUI.CursorPosition
|
||||
$cleanPWD, $cleanPSWD = Get-PoshContext
|
||||
|
@ -118,7 +118,7 @@ New-Module -Name "oh-my-posh-core" -ScriptBlock {
|
|||
}
|
||||
|
||||
if ("::TRANSIENT::" -eq "true") {
|
||||
Set-PSReadLineKeyHandler -Key Enter -ScriptBlock {
|
||||
Set-PSReadLineKeyHandler -Key Enter -BriefDescription 'OhMyPoshEnterKeyHandler' -ScriptBlock {
|
||||
$previousOutputEncoding = [Console]::OutputEncoding
|
||||
try {
|
||||
$parseErrors = $null
|
||||
|
@ -350,6 +350,16 @@ Example:
|
|||
function Enable-PoshTransientPrompt {}
|
||||
function Enable-PoshLineError {}
|
||||
|
||||
# perform cleanup on removal so a new initialization in current session works
|
||||
$ExecutionContext.SessionState.Module.OnRemove += {
|
||||
if ((Get-PSReadLineKeyHandler -Key Spacebar).Function -eq 'OhMyPoshSpaceKeyHandler') {
|
||||
Remove-PSReadLineKeyHandler -Key Spacebar
|
||||
}
|
||||
if ((Get-PSReadLineKeyHandler -Key Enter).Function -eq 'OhMyPoshEnterKeyHandler') {
|
||||
Set-PSReadLineKeyHandler -Key Enter -Function AcceptLine
|
||||
}
|
||||
}
|
||||
|
||||
Export-ModuleMember -Function @(
|
||||
"Set-PoshContext"
|
||||
"Enable-PoshTooltips"
|
||||
|
|
|
@ -42,7 +42,15 @@ if [ "$TERM" != "linux" ]; then
|
|||
_install-omp-hooks
|
||||
fi
|
||||
|
||||
function self-insert() {
|
||||
# perform cleanup so a new initialization in current session works
|
||||
if [[ "$(zle -lL self-insert)" = *"_posh-self-insert"* ]]; then
|
||||
zle -N self-insert
|
||||
fi
|
||||
if [[ "$(zle -lL zle-line-init)" = *"_posh-zle-line-init"* ]]; then
|
||||
zle -N zle-line-init
|
||||
fi
|
||||
|
||||
function _posh-self-insert() {
|
||||
# ignore an empty buffer
|
||||
if [[ -z "$BUFFER" ]]; then
|
||||
zle .self-insert
|
||||
|
@ -50,10 +58,10 @@ function self-insert() {
|
|||
fi
|
||||
# trigger a tip check only if the input is a space character
|
||||
if [[ "$KEYS" = " " ]]; then
|
||||
tooltip=$(::OMP:: print tooltip --config="$POSH_THEME" --shell=zsh --error="$omp_last_error" --command="$BUFFER" --shell-version="$ZSH_VERSION")
|
||||
local tooltip=$(::OMP:: print tooltip --config="$POSH_THEME" --shell=zsh --error="$omp_last_error" --command="$BUFFER" --shell-version="$ZSH_VERSION")
|
||||
fi
|
||||
# ignore an empty tooltip
|
||||
if [[ ! -z "$tooltip" ]]; then
|
||||
if [[ -n "$tooltip" ]]; then
|
||||
RPROMPT=$tooltip
|
||||
zle .reset-prompt
|
||||
fi
|
||||
|
@ -61,7 +69,7 @@ function self-insert() {
|
|||
}
|
||||
|
||||
if [[ "::TOOLTIPS::" = "true" ]]; then
|
||||
zle -N self-insert
|
||||
zle -N self-insert _posh-self-insert
|
||||
fi
|
||||
|
||||
function _posh-zle-line-init() {
|
||||
|
|
Loading…
Reference in a new issue