mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2024-12-31 22:07:25 -08:00
feat(cmd): align tooltip behaviors
This commit is contained in:
parent
b670c95701
commit
820e28c85c
|
@ -22,7 +22,8 @@ end
|
|||
|
||||
local endedit_time
|
||||
local last_duration
|
||||
local tip_word
|
||||
local tip
|
||||
local tooltip_active = false
|
||||
local cached_prompt = {}
|
||||
|
||||
local function omp_exe()
|
||||
|
@ -104,14 +105,13 @@ local function get_posh_prompt(rprompt)
|
|||
return run_posh_command(prompt_exe)
|
||||
end
|
||||
|
||||
local function get_posh_tooltip(command)
|
||||
local function set_posh_tooltip(command)
|
||||
local prompt_exe = string.format('%s print tooltip --shell=cmd --config=%s --command="%s"', omp_exe(), omp_config(), command)
|
||||
local tooltip = run_posh_command(prompt_exe)
|
||||
if tooltip == "" then
|
||||
-- If no tooltip, generate normal rprompt.
|
||||
tooltip = get_posh_prompt(true)
|
||||
if tooltip ~= "" then
|
||||
tooltip_active = true
|
||||
cached_prompt.right = tooltip
|
||||
end
|
||||
return tooltip
|
||||
end
|
||||
|
||||
-- set priority lower than z.lua
|
||||
|
@ -129,10 +129,7 @@ function p:filter(prompt)
|
|||
return cached_prompt.left
|
||||
end
|
||||
function p:rightfilter(prompt)
|
||||
if tip_word == nil then
|
||||
-- No tooltip needed, so generate prompt normally.
|
||||
cached_prompt.right = get_posh_prompt(true)
|
||||
elseif cached_prompt.tip_space and can_async() then
|
||||
if cached_prompt.tip_space and can_async() then
|
||||
-- Generate tooltip asynchronously in response to Spacebar.
|
||||
if cached_prompt.coroutine then
|
||||
-- Coroutine is already in progress. The cached right prompt will
|
||||
|
@ -140,7 +137,7 @@ function p:rightfilter(prompt)
|
|||
else
|
||||
-- Create coroutine to generate tooltip rprompt.
|
||||
cached_prompt.coroutine = coroutine.create(function ()
|
||||
cached_prompt.right = get_posh_tooltip(tip_word)
|
||||
set_posh_tooltip(tip)
|
||||
cached_prompt.tip_done = true
|
||||
-- Refresh the prompt once the tooltip is generated.
|
||||
clink.refilterprompt()
|
||||
|
@ -148,7 +145,7 @@ function p:rightfilter(prompt)
|
|||
end
|
||||
if cached_prompt.tip_done then
|
||||
-- Once the tooltip is ready, clear the Spacebar flag so that if the
|
||||
-- command word changes and the Spacebar is pressed again, we can
|
||||
-- tip changes and the Spacebar is pressed again, we can
|
||||
-- generate a new tooltip.
|
||||
cached_prompt.tip_done = nil
|
||||
cached_prompt.tip_space = nil
|
||||
|
@ -157,7 +154,11 @@ function p:rightfilter(prompt)
|
|||
else
|
||||
-- Tooltip is needed, but not in response to Spacebar, so refresh it
|
||||
-- immediately.
|
||||
cached_prompt.right = get_posh_tooltip(tip_word)
|
||||
set_posh_tooltip(tip)
|
||||
end
|
||||
if not tooltip_active then
|
||||
-- Tooltip is not active, generate rprompt normally.
|
||||
cached_prompt.right = get_posh_prompt(true)
|
||||
end
|
||||
return cached_prompt.right, false
|
||||
end
|
||||
|
@ -192,16 +193,16 @@ end
|
|||
-- Tooltips
|
||||
|
||||
function ohmyposh_space(rl_buffer)
|
||||
local new_tip = string.gsub(rl_buffer:getbuffer(), "^%s*(.-)%s*$", "%1")
|
||||
rl_buffer:insert(" ")
|
||||
local words = string.explode(rl_buffer:getbuffer(), ' ', [["]])
|
||||
if words[1] ~= tip_word then
|
||||
tip_word = words[1] -- remember the first word for use when filtering the prompt
|
||||
if new_tip ~= tip then
|
||||
tip = new_tip -- remember the tip for use when filtering the prompt
|
||||
cached_prompt.tip_space = can_async()
|
||||
clink.refilterprompt() -- invoke the prompt filters so omp can update the prompt per the tip word
|
||||
clink.refilterprompt() -- invoke the prompt filters so OMP can update the prompt per the tip
|
||||
end
|
||||
end
|
||||
|
||||
if rl.setbinding then
|
||||
clink.onbeginedit(function () tip_word = nil cached_prompt = {} end)
|
||||
clink.onbeginedit(function () tip = nil cached_prompt = {} end)
|
||||
rl.setbinding(' ', [["luafunc:ohmyposh_space"]], 'emacs')
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue