Problem: Vim9: can use reserved words at the script level.
Solution: Check variable names for reserved words. (closes #8253)
{
cc = *endp;
*endp = NUL;
+ if (in_vim9script() && check_reserved_name(lp->ll_name) == FAIL)
+ return;
+
if (lp->ll_blob != NULL)
{
int error = FALSE, val;
void free_all_script_vars(scriptitem_T *si);
svar_T *find_typval_in_script(typval_T *dest);
int check_script_var_type(typval_T *dest, typval_T *value, char_u *name, where_T where);
+int check_reserved_name(char_u *name);
/* vim: set ft=c : */
END
enddef
+def Test_reserved_name()
+ for name in ['true', 'false', 'null']
+ CheckDefExecAndScriptFailure(['var ' .. name .. ' = 0'], 'E1034:')
+ CheckDefExecAndScriptFailure(['var ' .. name .. ': bool'], 'E1034:')
+ endfor
+enddef
+
def Test_skipped_assignment()
var lines =<< trim END
for x in []
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 2897,
/**/
2896,
/**/
return 0;
}
-// words that cannot be used as a variable
-static char *reserved[] = {
- "true",
- "false",
- "null",
- NULL
-};
-
/*
* Generate the load instruction for "name".
*/
}
else
{
- int idx;
-
// No specific kind of variable recognized, just a name.
- for (idx = 0; reserved[idx] != NULL; ++idx)
- if (STRCMP(reserved[idx], lhs->lhs_name) == 0)
- {
- semsg(_(e_cannot_use_reserved_name), lhs->lhs_name);
- return FAIL;
- }
-
+ if (check_reserved_name(lhs->lhs_name) == FAIL)
+ return FAIL;
if (lookup_local(var_start, lhs->lhs_varlen,
&lhs->lhs_local_lvar, cctx) == OK)
}
name = vim_strnsave(arg, p - arg);
- // parse type
+ // parse type, check for reserved name
p = skipwhite(p + 1);
type = parse_type(&p, &si->sn_type_list, TRUE);
- if (type == NULL)
+ if (type == NULL || check_reserved_name(name) == FAIL)
{
vim_free(name);
return p;
return OK; // not really
}
+// words that cannot be used as a variable
+static char *reserved[] = {
+ "true",
+ "false",
+ "null",
+ NULL
+};
+
+ int
+check_reserved_name(char_u *name)
+{
+ int idx;
+
+ for (idx = 0; reserved[idx] != NULL; ++idx)
+ if (STRCMP(reserved[idx], name) == 0)
+ {
+ semsg(_(e_cannot_use_reserved_name), name);
+ return FAIL;
+ }
+ return OK;
+}
+
#endif // FEAT_EVAL