patch 9.0.1130: unexpected output when autoloading a script

Problem:    Unexpected output when autoloading a script for an interactive
            operation.
Solution:   Reset "KeyTyped" while loading a script and when handling a nested
            function. (closes #11773)
This commit is contained in:
Bram Moolenaar
2023-01-02 13:08:01 +00:00
parent 7bdcba08bb
commit 39c82ea656
5 changed files with 65 additions and 3 deletions

View File

@ -1334,10 +1334,10 @@ errret:
* When "ret_sid" is not NULL and we loaded the script before, don't load it
* again.
*
* The 'eap' argument is used when sourcing lines from a buffer instead of a
* The "eap" argument is used when sourcing lines from a buffer instead of a
* file.
*
* If 'clearvars' is TRUE, then for scripts which are loaded more than
* If "clearvars" is TRUE, then for scripts which are loaded more than
* once, clear all the functions and variables previously defined in that
* script.
*
@ -1538,6 +1538,7 @@ do_source_ext(
current_sctx.sc_version = SCRIPT_VERSION_VIM9;
else
current_sctx.sc_version = 1; // default script version
current_sctx.sc_lnum = 0;
#ifdef FEAT_EVAL
# ifdef FEAT_PROFILE
@ -1549,7 +1550,10 @@ do_source_ext(
// Also starts profiling timer for nested script.
save_funccal(&funccalp_entry);
current_sctx.sc_lnum = 0;
// Reset "KeyTyped" to avoid some commands thinking they are invoked
// interactively. E.g. defining a function would output indent.
int save_KeyTyped = KeyTyped;
KeyTyped = FALSE;
// Check if this script was sourced before to find its SID.
// Always use a new sequence number.
@ -1765,6 +1769,7 @@ almosttheend:
# endif
#endif
current_sctx = save_current_sctx;
KeyTyped = save_KeyTyped;
if (cookie.fp != NULL)
fclose(cookie.fp);

View File

@ -0,0 +1,6 @@
| +0&#ffffff0@74
|~+0#4040ff13&| @73
|~| @73
|~| @73
|~| @73
|:+0#0000000&|"> @72

View File

@ -4413,6 +4413,48 @@ def Test_invalid_redir()
delfunc g:Ttwo
enddef
func Test_keytyped_in_nested_function()
CheckRunVimInTerminal
call Run_Test_keytyped_in_nested_function()
endfunc
def Run_Test_keytyped_in_nested_function()
var lines =<< trim END
vim9script
autocmd CmdlineEnter * sample#Init()
exe 'set rtp=' .. getcwd() .. '/Xrtpdir'
END
writefile(lines, 'Xkeytyped', 'D')
var dir = 'Xrtpdir/autoload'
mkdir(dir, 'pR')
lines =<< trim END
vim9script
export def Init(): void
cnoremap <expr>" <SID>Quote('"')
enddef
def Quote(str: string): string
def InPair(): number
return 0
enddef
return str
enddef
END
writefile(lines, dir .. '/sample.vim')
var buf = g:RunVimInTerminal('-S Xkeytyped', {rows: 6})
term_sendkeys(buf, ':"')
g:VerifyScreenDump(buf, 'Test_keytyped_in_nested_func', {})
# clean up
term_sendkeys(buf, "\<Esc>")
g:StopVimInTerminal(buf)
enddef
" The following messes up syntax highlight, keep near the end.
if has('python3')
def Test_python3_command()

View File

@ -695,6 +695,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
1130,
/**/
1129,
/**/

View File

@ -987,7 +987,14 @@ compile_nested_function(exarg_T *eap, cctx_T *cctx, garray_T *lines_to_free)
goto theend;
}
// Make sure "KeyTyped" is not set, it may cause indent to be written.
int save_KeyTyped = KeyTyped;
KeyTyped = FALSE;
ufunc = define_function(eap, lambda_name, lines_to_free, FALSE);
KeyTyped = save_KeyTyped;
if (ufunc == NULL)
{
r = eap->skip ? OK : FAIL;