diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/nvim/eval/userfunc.c | 11 | ||||
| -rw-r--r-- | src/nvim/testdir/test_functions.vim | 1 | ||||
| -rw-r--r-- | src/nvim/testdir/test_lambda.vim | 17 | ||||
| -rw-r--r-- | src/nvim/testdir/test_signals.vim | 3 | ||||
| -rw-r--r-- | src/nvim/testdir/test_user_func.vim | 36 | 
5 files changed, 58 insertions, 10 deletions
| diff --git a/src/nvim/eval/userfunc.c b/src/nvim/eval/userfunc.c index 7440044e52..2a7ad792df 100644 --- a/src/nvim/eval/userfunc.c +++ b/src/nvim/eval/userfunc.c @@ -48,6 +48,8 @@ static char *e_funcexts = N_("E122: Function %s already exists, add ! to replace  static char *e_funcdict = N_("E717: Dictionary entry already exists");  static char *e_funcref = N_("E718: Funcref required");  static char *e_nofunc = N_("E130: Unknown function: %s"); +static char e_no_white_space_allowed_before_str_str[] +  = N_("E1068: No white space allowed before '%s': %s");  void func_init(void)  { @@ -149,6 +151,15 @@ static int get_function_args(char **argp, char_u endchar, garray_T *newargs, int          emsg(_("E989: Non-default argument follows default argument"));          mustend = true;        } + +      if (ascii_iswhite(*p) && *skipwhite(p) == ',') { +        // Be tolerant when skipping +        if (!skip) { +          semsg(_(e_no_white_space_allowed_before_str_str), ",", p); +          goto err_ret; +        } +        p = skipwhite(p); +      }        if (*p == ',') {          p++;        } else { diff --git a/src/nvim/testdir/test_functions.vim b/src/nvim/testdir/test_functions.vim index 1b9b9abd91..b751215b79 100644 --- a/src/nvim/testdir/test_functions.vim +++ b/src/nvim/testdir/test_functions.vim @@ -1865,6 +1865,7 @@ func Test_call()    let mydict = {'data': [0, 1, 2, 3], 'len': function("Mylen")}    eval mydict.len->call([], mydict)->assert_equal(4)    call assert_fails("call call('Mylen', [], 0)", 'E715:') +  call assert_fails('call foo', 'E107:')  endfunc  func Test_char2nr() diff --git a/src/nvim/testdir/test_lambda.vim b/src/nvim/testdir/test_lambda.vim index 997c3dcd3a..ce15243993 100644 --- a/src/nvim/testdir/test_lambda.vim +++ b/src/nvim/testdir/test_lambda.vim @@ -126,7 +126,7 @@ func Test_lambda_closure_counter()    endfunc    let l:F = s:foo() -  call garbagecollect() +  call test_garbagecollect_now()    call assert_equal(1, l:F())    call assert_equal(2, l:F())    call assert_equal(3, l:F()) @@ -209,9 +209,9 @@ func Test_lambda_circular_reference()    endfunc    call s:Foo() -  call garbagecollect() +  call test_garbagecollect_now()    let i = 0 | while i < 10000 | call s:Foo() | let i+= 1 | endwhile -  call garbagecollect() +  call test_garbagecollect_now()  endfunc  func Test_lambda_combination() @@ -240,11 +240,16 @@ func Test_closure_counter()    endfunc    let l:F = s:foo() -  call garbagecollect() +  call test_garbagecollect_now()    call assert_equal(1, l:F())    call assert_equal(2, l:F())    call assert_equal(3, l:F())    call assert_equal(4, l:F()) + +  call assert_match("^\n   function <SNR>\\d\\+_bar() closure" +  \              .. "\n1        let x += 1" +  \              .. "\n2        return x" +  \              .. "\n   endfunction$", execute('func s:bar'))  endfunc  func Test_closure_unlet() @@ -258,7 +263,7 @@ func Test_closure_unlet()    endfunc    call assert_false(has_key(s:foo(), 'x')) -  call garbagecollect() +  call test_garbagecollect_now()  endfunc  func LambdaFoo() @@ -295,7 +300,7 @@ func Test_named_function_closure()    endfunc    call Afoo()    call assert_equal(14, s:Abar()) -  call garbagecollect() +  call test_garbagecollect_now()    call assert_equal(14, s:Abar())  endfunc diff --git a/src/nvim/testdir/test_signals.vim b/src/nvim/testdir/test_signals.vim index 719f90c808..e1c6e5d11f 100644 --- a/src/nvim/testdir/test_signals.vim +++ b/src/nvim/testdir/test_signals.vim @@ -129,8 +129,7 @@ func Test_deadly_signal_TERM()    call assert_equal(['foo'], getline(1, '$'))    let result = readfile('XautoOut') -  call assert_match('VimLeavePre triggered', result[0]) -  call assert_match('VimLeave triggered', result[1]) +  call assert_equal(["VimLeavePre triggered", "VimLeave triggered"], result)    %bwipe!    call delete('.Xsig_TERM.swp') diff --git a/src/nvim/testdir/test_user_func.vim b/src/nvim/testdir/test_user_func.vim index 8b5ee72bf1..01bf2e1d0f 100644 --- a/src/nvim/testdir/test_user_func.vim +++ b/src/nvim/testdir/test_user_func.vim @@ -149,8 +149,8 @@ func Test_default_arg()    call assert_equal(res.optional, 2)    call assert_equal(res['0'], 1) -  call assert_fails("call MakeBadFunc()", 'E989') -  call assert_fails("fu F(a=1 ,) | endf", 'E475') +  call assert_fails("call MakeBadFunc()", 'E989:') +  call assert_fails("fu F(a=1 ,) | endf", 'E1068:')    " Since neovim does not have v:none, the ability to use the default    " argument with the intermediate argument set to v:none has been omitted. @@ -445,4 +445,36 @@ func Test_func_arg_error()    delfunc Xfunc  endfunc +func Test_func_dict() +  let mydict = {'a': 'b'} +  function mydict.somefunc() dict +    return len(self) +  endfunc + +  call assert_equal("{'a': 'b', 'somefunc': function('2')}", string(mydict)) +  call assert_equal(2, mydict.somefunc()) +  call assert_match("^\n   function \\d\\\+() dict" +  \              .. "\n1      return len(self)" +  \              .. "\n   endfunction$", execute('func mydict.somefunc')) +endfunc + +func Test_func_range() +  new +  call setline(1, range(1, 8)) +  func FuncRange() range +    echo a:firstline +    echo a:lastline +  endfunc +  3 +  call assert_equal("\n3\n3", execute('call FuncRange()')) +  call assert_equal("\n4\n6", execute('4,6 call FuncRange()')) +  call assert_equal("\n   function FuncRange() range" +  \              .. "\n1      echo a:firstline" +  \              .. "\n2      echo a:lastline" +  \              .. "\n   endfunction", +  \                 execute('function FuncRange')) + +  bwipe! +endfunc +  " vim: shiftwidth=2 sts=2 expandtab | 
