0
0
mirror of https://github.com/vim/vim.git synced 2025-09-27 04:14:06 -04:00

patch 8.2.4970: "eval 123" gives an error, "eval 'abc'" does not

Problem:    "eval 123" gives an error, "eval 'abc'" does not.
Solution:   Also give an error when evaluating only a string. (closes #10434)
This commit is contained in:
Bram Moolenaar
2022-05-17 12:45:15 +01:00
parent 7ce5b2b590
commit 0d03263fd7
3 changed files with 25 additions and 2 deletions

View File

@@ -888,8 +888,8 @@ report_discard_pending(int pending, void *value)
}
/*
* Return TRUE if "arg" is only a variable, register, environment variable or
* option name.
* Return TRUE if "arg" is only a variable, register, environment variable,
* option name or string.
*/
int
cmd_is_name_only(char_u *arg)
@@ -904,6 +904,17 @@ cmd_is_name_only(char_u *arg)
if (*p != NUL)
++p;
}
else if (*p == '\'' || *p == '"')
{
int r;
if (*p == '"')
r = eval_string(&p, NULL, FALSE, FALSE);
else
r = eval_lit_string(&p, NULL, FALSE, FALSE);
if (r == FAIL)
return FALSE;
}
else
{
if (*p == '&')

View File

@@ -697,6 +697,16 @@ def Test_use_register()
END
v9.CheckDefAndScriptFailure(lines, 'E1207:', 2)
$SomeEnv = ''
lines =<< trim END
eval 'value'
END
v9.CheckDefAndScriptFailure(lines, 'E1207:', 1)
lines =<< trim END
eval "value"
END
v9.CheckDefAndScriptFailure(lines, 'E1207:', 1)
enddef
def Test_environment_use_linebreak()

View File

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