Problem: Vim9: cannot put an operator on the next line.
Solution: Require a colon before a range to see if that causes problems.
-*vim9.txt* For Vim version 8.2. Last change: 2020 Jun 21
+*vim9.txt* For Vim version 8.2. Last change: 2020 Jun 22
VIM REFERENCE MANUAL by Bram Moolenaar
arg2
)
-For binary operators iin expressions not in [], {} or () a line break is
-possible AFTER the operators. For example: >
- let text = lead ..
- middle ..
- end
+For binary operators in expressions not in [], {} or () a line break is
+possible just before or after the operator. For example: >
+ let text = lead
+ .. middle
+ .. end
let total = start +
end -
correction
- let result = positive ?
- PosFunc(arg) :
- NegFunc(arg)
+ let result = positive
+ ? PosFunc(arg)
+ : NegFunc(arg)
-A special case is "->" for function call chains, it can appear in the next
-line: >
let result = GetBuilder()
->BuilderSetWidth(333)
->BuilderSetHeight(777)
->BuilderBuild()
-Note that "enddef" cannot be used at the start of a continuation line, it ends
-the current function.
+< *E1050*
+To make it possible for the operator at the start of the line to be
+recognized, it is required to put a colon before a range. This will adde
+"start" and print: >
+ let result = start
+ + print
+This will assign "start" and print a line: >
+ let result = start
+ :+ print
It is also possible to split a function header over multiple lines, in between
arguments: >
separator = '-'
): string
+Note that "enddef" cannot be used at the start of a continuation line, it ends
+the current function.
+
No curly braces expansion ~
#ifdef FEAT_EVAL
if (current_sctx.sc_version == SCRIPT_VERSION_VIM9 && !starts_with_colon)
+ {
+ if (ea.cmd > cmd)
+ {
+ emsg(_(e_colon_required));
+ goto doend;
+ }
p = find_ex_command(&ea, NULL, lookup_scriptvar, NULL);
+ }
else
#endif
p = find_ex_command(&ea, NULL, NULL, NULL);
* Backslashed delimiters after / or ? will be skipped, and commands will
* not be expanded between /'s and ?'s or after "'".
*
- * Also skip white space and ":" characters.
+ * Also skip white space and ":" characters after the range.
* Returns the "cmd" pointer advanced to beyond the range.
*/
char_u *
EXTERN char e_type_req[] INIT(= N_("E1022: type or initialization required"));
EXTERN char e_declare_var[] INIT(= N_("E1016: Cannot declare a %s variable: %s"));
EXTERN char e_declare_env_var[] INIT(= N_("E1016: Cannot declare an environment variable: %s"));
+EXTERN char e_colon_required[] INIT(= N_("E1050: Colon required before a range"));
#endif
#if defined(FEAT_GUI) || defined(FEAT_TERMGUICOLORS)
EXTERN char e_alloc_color[] INIT(= N_("E254: Cannot allocate color %s"));
call CheckDefFailure(["let x = '1' ..'2'"], msg)
call CheckDefFailure(["let x = '1'.. '2'"], msg)
- call CheckDefFailure(["let x = 0z1122 + 33"], 'E1035')
- call CheckDefFailure(["let x = 0z1122 + [3]"], 'E1035')
- call CheckDefFailure(["let x = 0z1122 + 'asd'"], 'E1035')
- call CheckDefFailure(["let x = 33 + 0z1122"], 'E1035')
- call CheckDefFailure(["let x = [3] + 0z1122"], 'E1035')
- call CheckDefFailure(["let x = 'asdf' + 0z1122"], 'E1035')
+ call CheckDefFailure(["let x = 0z1122 + 33"], 'E1051')
+ call CheckDefFailure(["let x = 0z1122 + [3]"], 'E1051')
+ call CheckDefFailure(["let x = 0z1122 + 'asd'"], 'E1051')
+ call CheckDefFailure(["let x = 33 + 0z1122"], 'E1051')
+ call CheckDefFailure(["let x = [3] + 0z1122"], 'E1051')
+ call CheckDefFailure(["let x = 'asdf' + 0z1122"], 'E1051')
call CheckDefFailure(["let x = 6 + xxx"], 'E1001')
endfunc
call CheckDefFailure(['const &option'], 'E996:')
endfunc
+def Test_range_no_colon()
+ call CheckDefFailure(['%s/a/b/'], 'E1050:')
+ call CheckDefFailure(['+ s/a/b/'], 'E1050:')
+ call CheckDefFailure(['- s/a/b/'], 'E1050:')
+ call CheckDefFailure(['. s/a/b/'], 'E1050:')
+enddef
+
+
def Test_block()
let outer = 1
{
echomsg 'some' 'more' # comment
assert_match('^some more$', Screenline(&lines))
echo 'clear'
- 1messages
+ :1messages
assert_match('^some more$', Screenline(&lines))
call CheckDefFailure(['echomsg "xxx"# comment'], 'E488:')
'vim9script',
'new'
'call setline(1, ["# define pat", "last"])',
- '$',
+ ':$',
'dsearch /pat/ #comment',
'bwipe!',
])
'vim9script',
'new'
'call setline(1, ["# define pat", "last"])',
- '$',
+ ':$',
'dsearch /pat/#comment',
'bwipe!',
], 'E488:')
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 1042,
/**/
1041,
/**/
|| type2 == VAR_ANY)))
{
if (*op == '+')
- emsg(_("E1035: wrong argument type for +"));
+ emsg(_("E1051: wrong argument type for +"));
else
semsg(_("E1036: %c requires number or float arguments"), *op);
return FAIL;
{
exarg_T ea;
int starts_with_colon = FALSE;
+ char_u *cmd;
// Bail out on the first error to avoid a flood of errors and report
// the right line number when inside try/catch.
/*
* COMMAND after range
*/
+ cmd = ea.cmd;
ea.cmd = skip_range(ea.cmd, NULL);
+ if (ea.cmd > cmd && !starts_with_colon)
+ {
+ emsg(_(e_colon_required));
+ goto erret;
+ }
p = find_ex_command(&ea, NULL, starts_with_colon ? NULL
: (void *(*)(char_u *, size_t, cctx_T *))lookup_local,
&cctx);
line = compile_mult_expr(p, ea.cmdidx, &cctx);
break;
+ // TODO: other commands with an expression argument
+
default:
- // TODO: other commands with an expression argument
// Not recognized, execute with do_cmdline_cmd().
ea.arg = p;
line = compile_exec(line, &ea, &cctx);