patch 9.1.0817: termdebug: cannot evaluate expr in a popup

Problem:  termdebug: cannot evaluate expr in a popup
Solution: enhance termdebug plugin and allow to evaluate expressions in
          a popup window, add a unit test (Peter Wolf).

fixes: #15877
closes: #15933

Signed-off-by: Peter Wolf <pwolf2310@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Peter Wolf
2024-10-27 21:51:14 +01:00
committed by Christian Brabandt
parent 2abec431e1
commit 8f1d09828a
9 changed files with 230 additions and 12 deletions

View File

@ -121,7 +121,9 @@ var breakpoint_locations: dict<any>
var BreakpointSigns: list<string>
var evalFromBalloonExpr: bool
var evalFromBalloonExprResult: string
var evalInPopup: bool
var evalPopupId: number
var evalExprResult: string
var ignoreEvalError: bool
var evalexpr: string
# Remember the old value of 'signcolumn' for each buffer that it's set in, so
@ -202,7 +204,9 @@ def InitScriptVariables()
BreakpointSigns = []
evalFromBalloonExpr = false
evalFromBalloonExprResult = ''
evalInPopup = false
evalPopupId = -1
evalExprResult = ''
ignoreEvalError = false
evalexpr = ''
# Remember the old value of 'signcolumn' for each buffer that it's set in, so
@ -1478,10 +1482,23 @@ def SendEval(expr: string)
evalexpr = exprLHS
enddef
# Returns whether to evaluate in a popup or not, defaults to false.
def EvaluateInPopup(): bool
if exists('g:termdebug_config')
return get(g:termdebug_config, 'evaluate_in_popup', false)
endif
return false
enddef
# :Evaluate - evaluate what is specified / under the cursor
def Evaluate(range: number, arg: string)
var expr = GetEvaluationExpression(range, arg)
echom $"expr: {expr}"
if EvaluateInPopup()
evalInPopup = true
evalExprResult = ''
else
echomsg $'expr: {expr}'
endif
ignoreEvalError = false
SendEval(expr)
enddef
@ -1541,6 +1558,37 @@ def Balloon_show(expr: string)
endif
enddef
def Popup_format(expr: string): list<string>
var lines = expr
->substitute('{', '{\n', 'g')
->substitute('}', '\n}', 'g')
->substitute(',', ',\n', 'g')
->split('\n')
var indentation = 0
var formatted_lines = []
for line in lines
var stripped = line->substitute('^\s\+', '', '')
if stripped =~ '^}'
indentation -= 2
endif
formatted_lines->add(repeat(' ', indentation) .. stripped)
if stripped =~ '{$'
indentation += 2
endif
endfor
return formatted_lines
enddef
def Popup_show(expr: string)
var formatted = Popup_format(expr)
if evalPopupId != -1
popup_close(evalPopupId)
endif
# Specifying the line is necessary, as the winbar seems to cause issues
# otherwise. I.e., the popup would be shown one line too high.
evalPopupId = popup_atcursor(formatted, {'line': 'cursor-1'})
enddef
def HandleEvaluate(msg: string)
var value = msg
->substitute('.*value="\(.*\)"', '\1', '')
@ -1555,13 +1603,12 @@ def HandleEvaluate(msg: string)
#\ ->substitute('\\0x00', NullRep, 'g')
#\ ->substitute('\\0x\(\x\x\)', {-> eval('"\x' .. submatch(1) .. '"')}, 'g')
->substitute(NullRepl, '\\000', 'g')
if evalFromBalloonExpr
if empty(evalFromBalloonExprResult)
evalFromBalloonExprResult = $'{evalexpr}: {value}'
if evalFromBalloonExpr || evalInPopup
if empty(evalExprResult)
evalExprResult = $'{evalexpr}: {value}'
else
evalFromBalloonExprResult ..= $' = {value}'
evalExprResult ..= $' = {value}'
endif
Balloon_show(evalFromBalloonExprResult)
else
echomsg $'"{evalexpr}": {value}'
endif
@ -1570,8 +1617,12 @@ def HandleEvaluate(msg: string)
# Looks like a pointer, also display what it points to.
ignoreEvalError = true
SendEval($'*{evalexpr}')
else
elseif evalFromBalloonExpr
Balloon_show(evalExprResult)
evalFromBalloonExpr = false
elseif evalInPopup
Popup_show(evalExprResult)
evalInPopup = false
endif
enddef
@ -1588,7 +1639,7 @@ def TermDebugBalloonExpr(): string
return ''
endif
evalFromBalloonExpr = true
evalFromBalloonExprResult = ''
evalExprResult = ''
ignoreEvalError = true
var expr = CleanupExpr(v:beval_text)
SendEval(expr)