mirror of
https://github.com/vim/vim.git
synced 2025-09-26 04:04:07 -04:00
patch 9.1.1074: Strange error when heredoc marker starts with "trim"
Problem: Strange error when heredoc marker starts with "trim". Solution: Check for whitespace after "trim" or "eval" (zeertzjq) For :python3 etc., a heredoc marker that starts with a lower-case letter is valid, and when it starts with "trim" it works in a script but not in a function, and this PR makes it works in a function. For :let, a heredoc marker that starts with a lower-case letter is not valid, but when it starts with "trim" or "eval" the error can be a bit confusing in a function, and this PR make it less confusing. closes: #16574 Signed-off-by: zeertzjq <zeertzjq@outlook.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
committed by
Christian Brabandt
parent
23da16d3d0
commit
449c2e5454
@@ -435,6 +435,24 @@ func Test_let_heredoc_fails()
|
|||||||
call assert_report('Caught exception: ' .. v:exception)
|
call assert_report('Caught exception: ' .. v:exception)
|
||||||
endtry
|
endtry
|
||||||
|
|
||||||
|
try
|
||||||
|
let v =<< trim trimm
|
||||||
|
trimm
|
||||||
|
call assert_report('No exception thrown')
|
||||||
|
catch /E221:/
|
||||||
|
catch
|
||||||
|
call assert_report('Caught exception: ' .. v:exception)
|
||||||
|
endtry
|
||||||
|
|
||||||
|
try
|
||||||
|
let v =<< trim trim evall
|
||||||
|
evall
|
||||||
|
call assert_report('No exception thrown')
|
||||||
|
catch /E221:/
|
||||||
|
catch
|
||||||
|
call assert_report('Caught exception: ' .. v:exception)
|
||||||
|
endtry
|
||||||
|
|
||||||
let text =<< trim END
|
let text =<< trim END
|
||||||
func WrongSyntax()
|
func WrongSyntax()
|
||||||
let v =<< that there
|
let v =<< that there
|
||||||
|
@@ -934,7 +934,10 @@ vim.command('let s ..= "B"')
|
|||||||
lua << trim eof
|
lua << trim eof
|
||||||
vim.command('let s ..= "E"')
|
vim.command('let s ..= "E"')
|
||||||
eof
|
eof
|
||||||
call assert_equal('ABCDE', s)
|
lua << trimm
|
||||||
|
vim.command('let s ..= "F"')
|
||||||
|
trimm
|
||||||
|
call assert_equal('ABCDEF', s)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" Test for adding, accessing and removing global variables using the vim.g
|
" Test for adding, accessing and removing global variables using the vim.g
|
||||||
|
@@ -359,7 +359,10 @@ VIM::DoCommand('let s ..= "B"')
|
|||||||
perl << trim eof
|
perl << trim eof
|
||||||
VIM::DoCommand('let s ..= "E"')
|
VIM::DoCommand('let s ..= "E"')
|
||||||
eof
|
eof
|
||||||
call assert_equal('ABCDE', s)
|
perl << trimm
|
||||||
|
VIM::DoCommand('let s ..= "F"')
|
||||||
|
trimm
|
||||||
|
call assert_equal('ABCDEF', s)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
func Test_perl_in_sandbox()
|
func Test_perl_in_sandbox()
|
||||||
|
@@ -263,7 +263,10 @@ s+='B'
|
|||||||
python << trim eof
|
python << trim eof
|
||||||
s+='E'
|
s+='E'
|
||||||
eof
|
eof
|
||||||
call assert_equal('ABCDE', pyxeval('s'))
|
python << trimm
|
||||||
|
s+='F'
|
||||||
|
trimm
|
||||||
|
call assert_equal('ABCDEF', pyxeval('s'))
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" Test for the buffer range object
|
" Test for the buffer range object
|
||||||
|
@@ -467,7 +467,10 @@ s+='B'
|
|||||||
python3 << trim eof
|
python3 << trim eof
|
||||||
s+='E'
|
s+='E'
|
||||||
eof
|
eof
|
||||||
call assert_equal('ABCDE', pyxeval('s'))
|
python3 << trimm
|
||||||
|
s+='F'
|
||||||
|
trimm
|
||||||
|
call assert_equal('ABCDEF', pyxeval('s'))
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" Test for the buffer range object
|
" Test for the buffer range object
|
||||||
|
@@ -140,7 +140,10 @@ result+='B'
|
|||||||
pyx << trim eof
|
pyx << trim eof
|
||||||
result+='E'
|
result+='E'
|
||||||
eof
|
eof
|
||||||
call assert_equal('ABCDE', pyxeval('result'))
|
pyx << trimm
|
||||||
|
result+='F'
|
||||||
|
trimm
|
||||||
|
call assert_equal('ABCDEF', pyxeval('result'))
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -139,7 +139,10 @@ result+='B'
|
|||||||
pyx << trim eof
|
pyx << trim eof
|
||||||
result+='E'
|
result+='E'
|
||||||
eof
|
eof
|
||||||
call assert_equal('ABCDE', pyxeval('result'))
|
pyx << trimm
|
||||||
|
result+='F'
|
||||||
|
trimm
|
||||||
|
call assert_equal('ABCDEF', pyxeval('result'))
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -446,7 +446,10 @@ Vim.command('let s ..= "B"')
|
|||||||
ruby << trim eof
|
ruby << trim eof
|
||||||
Vim.command('let s ..= "E"')
|
Vim.command('let s ..= "E"')
|
||||||
eof
|
eof
|
||||||
call assert_equal('ABCDE', s)
|
ruby << trimm
|
||||||
|
Vim.command('let s ..= "F"')
|
||||||
|
trimm
|
||||||
|
call assert_equal('ABCDEF', s)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -1322,7 +1322,8 @@ get_function_body(
|
|||||||
{
|
{
|
||||||
// ":python <<" continues until a dot, like ":append"
|
// ":python <<" continues until a dot, like ":append"
|
||||||
p = skipwhite(arg + 2);
|
p = skipwhite(arg + 2);
|
||||||
if (STRNCMP(p, "trim", 4) == 0)
|
if (STRNCMP(p, "trim", 4) == 0
|
||||||
|
&& (p[4] == NUL || VIM_ISWHITE(p[4])))
|
||||||
{
|
{
|
||||||
// Ignore leading white space.
|
// Ignore leading white space.
|
||||||
p = skipwhite(p + 4);
|
p = skipwhite(p + 4);
|
||||||
@@ -1367,20 +1368,21 @@ get_function_body(
|
|||||||
current_sctx.sc_version = save_sc_version;
|
current_sctx.sc_version = save_sc_version;
|
||||||
if (arg != NULL && STRNCMP(arg, "=<<", 3) == 0)
|
if (arg != NULL && STRNCMP(arg, "=<<", 3) == 0)
|
||||||
{
|
{
|
||||||
|
int has_trim = FALSE;
|
||||||
|
|
||||||
p = skipwhite(arg + 3);
|
p = skipwhite(arg + 3);
|
||||||
while (TRUE)
|
while (TRUE)
|
||||||
{
|
{
|
||||||
if (STRNCMP(p, "trim", 4) == 0)
|
if (STRNCMP(p, "trim", 4) == 0
|
||||||
|
&& (p[4] == NUL || VIM_ISWHITE(p[4])))
|
||||||
{
|
{
|
||||||
// Ignore leading white space.
|
// Ignore leading white space.
|
||||||
p = skipwhite(p + 4);
|
p = skipwhite(p + 4);
|
||||||
heredoc_trimmedlen = skipwhite(theline) - theline;
|
has_trim = TRUE;
|
||||||
heredoc_trimmed = vim_strnsave(theline, heredoc_trimmedlen);
|
|
||||||
if (heredoc_trimmed == NULL)
|
|
||||||
heredoc_trimmedlen = 0;
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (STRNCMP(p, "eval", 4) == 0)
|
if (STRNCMP(p, "eval", 4) == 0
|
||||||
|
&& (p[4] == NUL || VIM_ISWHITE(p[4])))
|
||||||
{
|
{
|
||||||
// Ignore leading white space.
|
// Ignore leading white space.
|
||||||
p = skipwhite(p + 4);
|
p = skipwhite(p + 4);
|
||||||
@@ -1388,6 +1390,13 @@ get_function_body(
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (has_trim)
|
||||||
|
{
|
||||||
|
heredoc_trimmedlen = skipwhite(theline) - theline;
|
||||||
|
heredoc_trimmed = vim_strnsave(theline, heredoc_trimmedlen);
|
||||||
|
if (heredoc_trimmed == NULL)
|
||||||
|
heredoc_trimmedlen = 0;
|
||||||
|
}
|
||||||
skip_until = vim_strnsave(p, skiptowhite(p) - p);
|
skip_until = vim_strnsave(p, skiptowhite(p) - p);
|
||||||
getline_options = GETLINE_NONE;
|
getline_options = GETLINE_NONE;
|
||||||
is_heredoc = TRUE;
|
is_heredoc = TRUE;
|
||||||
|
@@ -704,6 +704,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1074,
|
||||||
/**/
|
/**/
|
||||||
1073,
|
1073,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user