blob: 712733149892ef8503aa405f9c94b121789177d0 [file] [log] [blame]
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +02001" Test various aspects of the Vim9 script language.
2
3source check.vim
4source view_util.vim
Bram Moolenaar04b12692020-05-04 23:24:44 +02005source vim9.vim
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +02006
7func Test_def_basic()
8 def SomeFunc(): string
9 return 'yes'
10 enddef
11 call assert_equal('yes', SomeFunc())
12endfunc
13
14def ReturnString(): string
15 return 'string'
16enddef
17
18def ReturnNumber(): number
19 return 123
20enddef
21
22let g:notNumber = 'string'
23
24def ReturnGlobal(): number
25 return g:notNumber
26enddef
27
28def Test_return_something()
29 assert_equal('string', ReturnString())
30 assert_equal(123, ReturnNumber())
31 assert_fails('call ReturnGlobal()', 'E1029: Expected number but got string')
32enddef
33
34let s:nothing = 0
35def ReturnNothing()
36 s:nothing = 1
37 if true
38 return
39 endif
40 s:nothing = 2
41enddef
42
43def Test_return_nothing()
44 ReturnNothing()
45 assert_equal(1, s:nothing)
46enddef
47
48func Increment()
49 let g:counter += 1
50endfunc
51
52def Test_call_ufunc_count()
53 g:counter = 1
54 Increment()
55 Increment()
56 Increment()
57 " works with and without :call
58 assert_equal(4, g:counter)
59 call assert_equal(4, g:counter)
60 unlet g:counter
61enddef
62
63def MyVarargs(arg: string, ...rest: list<string>): string
64 let res = arg
65 for s in rest
66 res ..= ',' .. s
67 endfor
68 return res
69enddef
70
71def Test_call_varargs()
72 assert_equal('one', MyVarargs('one'))
73 assert_equal('one,two', MyVarargs('one', 'two'))
74 assert_equal('one,two,three', MyVarargs('one', 'two', 'three'))
75enddef
76
77def MyDefaultArgs(name = 'string'): string
78 return name
79enddef
80
81def Test_call_default_args()
82 assert_equal('string', MyDefaultArgs())
83 assert_equal('one', MyDefaultArgs('one'))
84 assert_fails('call MyDefaultArgs("one", "two")', 'E118:')
85
Bram Moolenaar04b12692020-05-04 23:24:44 +020086 CheckScriptFailure(['def Func(arg: number = asdf)', 'enddef'], 'E1001:')
87 CheckScriptFailure(['def Func(arg: number = "text")', 'enddef'], 'E1013: argument 1: type mismatch, expected number but got string')
88enddef
89
90def Test_nested_function()
91 def Nested(arg: string): string
92 return 'nested ' .. arg
93 enddef
94 assert_equal('nested function', Nested('function'))
95
96 CheckDefFailure(['func Nested()', 'endfunc'], 'E1086:')
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +020097enddef
98
99func Test_call_default_args_from_func()
100 call assert_equal('string', MyDefaultArgs())
101 call assert_equal('one', MyDefaultArgs('one'))
102 call assert_fails('call MyDefaultArgs("one", "two")', 'E118:')
103endfunc
104
105func TakesOneArg(arg)
106 echo a:arg
107endfunc
108
109def Test_call_wrong_args()
110 call CheckDefFailure(['TakesOneArg()'], 'E119:')
111 call CheckDefFailure(['TakesOneArg(11, 22)'], 'E118:')
112 call CheckDefFailure(['bufnr(xxx)'], 'E1001:')
Bram Moolenaar1c0d44f2020-05-02 19:04:58 +0200113 call CheckScriptFailure(['def Func(Ref: func(s: string))'], 'E475:')
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200114enddef
115
116" Default arg and varargs
117def MyDefVarargs(one: string, two = 'foo', ...rest: list<string>): string
118 let res = one .. ',' .. two
119 for s in rest
120 res ..= ',' .. s
121 endfor
122 return res
123enddef
124
125def Test_call_def_varargs()
126 call assert_fails('call MyDefVarargs()', 'E119:')
127 assert_equal('one,foo', MyDefVarargs('one'))
128 assert_equal('one,two', MyDefVarargs('one', 'two'))
129 assert_equal('one,two,three', MyDefVarargs('one', 'two', 'three'))
Bram Moolenaar49cf7cc2020-04-07 22:45:00 +0200130 call CheckDefFailure(['MyDefVarargs("one", 22)'], 'E1013: argument 2: type mismatch, expected string but got number')
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200131enddef
132
Bram Moolenaar1378fbc2020-04-11 20:50:33 +0200133let s:value = ''
134
135def FuncOneDefArg(opt = 'text')
136 s:value = opt
137enddef
138
139def FuncTwoDefArg(nr = 123, opt = 'text'): string
140 return nr .. opt
141enddef
142
143def FuncVarargs(...arg: list<string>): string
144 return join(arg, ',')
145enddef
146
147def Test_func_type_varargs()
148 let RefDefArg: func(?string)
149 RefDefArg = FuncOneDefArg
150 RefDefArg()
151 assert_equal('text', s:value)
152 RefDefArg('some')
153 assert_equal('some', s:value)
154
155 let RefDef2Arg: func(?number, ?string): string
156 RefDef2Arg = FuncTwoDefArg
157 assert_equal('123text', RefDef2Arg())
158 assert_equal('99text', RefDef2Arg(99))
159 assert_equal('77some', RefDef2Arg(77, 'some'))
160
161 call CheckDefFailure(['let RefWrong: func(string?)'], 'E1010:')
162 call CheckDefFailure(['let RefWrong: func(?string, string)'], 'E1007:')
163
164 let RefVarargs: func(...list<string>): string
165 RefVarargs = FuncVarargs
166 assert_equal('', RefVarargs())
167 assert_equal('one', RefVarargs('one'))
168 assert_equal('one,two', RefVarargs('one', 'two'))
169
170 call CheckDefFailure(['let RefWrong: func(...list<string>, string)'], 'E110:')
171 call CheckDefFailure(['let RefWrong: func(...list<string>, ?string)'], 'E110:')
172enddef
173
Bram Moolenaar0b76b422020-04-07 22:05:08 +0200174" Only varargs
175def MyVarargsOnly(...args: list<string>): string
176 return join(args, ',')
177enddef
178
179def Test_call_varargs_only()
180 assert_equal('', MyVarargsOnly())
181 assert_equal('one', MyVarargsOnly('one'))
182 assert_equal('one,two', MyVarargsOnly('one', 'two'))
183 call CheckDefFailure(['MyVarargsOnly(1)'], 'E1013: argument 1: type mismatch, expected string but got number')
184 call CheckDefFailure(['MyVarargsOnly("one", 2)'], 'E1013: argument 2: type mismatch, expected string but got number')
185enddef
186
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200187def Test_using_var_as_arg()
188 call writefile(['def Func(x: number)', 'let x = 234', 'enddef'], 'Xdef')
189 call assert_fails('so Xdef', 'E1006:')
190 call delete('Xdef')
191enddef
192
193def Test_call_func_defined_later()
Bram Moolenaar1df8b3f2020-04-23 18:13:23 +0200194 call assert_equal('one', g:DefinedLater('one'))
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200195 call assert_fails('call NotDefined("one")', 'E117:')
196enddef
197
Bram Moolenaar1df8b3f2020-04-23 18:13:23 +0200198func DefinedLater(arg)
199 return a:arg
200endfunc
201
202def Test_call_funcref()
203 assert_equal(3, g:SomeFunc('abc'))
204 assert_fails('NotAFunc()', 'E117:')
205 assert_fails('g:NotAFunc()', 'E117:')
206enddef
207
208let SomeFunc = function('len')
209let NotAFunc = 'text'
210
Bram Moolenaar99aaf0c2020-04-12 14:39:53 +0200211def CombineFuncrefTypes()
212 " same arguments, different return type
213 let Ref1: func(bool): string
214 let Ref2: func(bool): number
215 let Ref3: func(bool): any
216 Ref3 = g:cond ? Ref1 : Ref2
217
218 " different number of arguments
219 let Refa1: func(bool): number
220 let Refa2: func(bool, number): number
221 let Refa3: func: number
222 Refa3 = g:cond ? Refa1 : Refa2
223
224 " different argument types
225 let Refb1: func(bool, string): number
226 let Refb2: func(string, number): number
227 let Refb3: func(any, any): number
228 Refb3 = g:cond ? Refb1 : Refb2
229enddef
230
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200231def FuncWithForwardCall()
Bram Moolenaar1df8b3f2020-04-23 18:13:23 +0200232 return g:DefinedEvenLater("yes")
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200233enddef
234
235def DefinedEvenLater(arg: string): string
236 return arg
237enddef
238
239def Test_error_in_nested_function()
240 " Error in called function requires unwinding the call stack.
241 assert_fails('call FuncWithForwardCall()', 'E1029')
242enddef
243
244def Test_return_type_wrong()
245 CheckScriptFailure(['def Func(): number', 'return "a"', 'enddef'], 'expected number but got string')
246 CheckScriptFailure(['def Func(): string', 'return 1', 'enddef'], 'expected string but got number')
247 CheckScriptFailure(['def Func(): void', 'return "a"', 'enddef'], 'expected void but got string')
248 CheckScriptFailure(['def Func()', 'return "a"', 'enddef'], 'expected void but got string')
249
250 CheckScriptFailure(['def Func(): number', 'return', 'enddef'], 'E1003:')
251
252 CheckScriptFailure(['def Func(): list', 'return []', 'enddef'], 'E1008:')
253 CheckScriptFailure(['def Func(): dict', 'return {}', 'enddef'], 'E1008:')
Bram Moolenaaree4e0c12020-04-06 21:35:05 +0200254 CheckScriptFailure(['def Func()', 'return 1'], 'E1057:')
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200255enddef
256
257def Test_arg_type_wrong()
258 CheckScriptFailure(['def Func3(items: list)', 'echo "a"', 'enddef'], 'E1008: Missing <type>')
Bram Moolenaaree4e0c12020-04-06 21:35:05 +0200259 CheckScriptFailure(['def Func4(...)', 'echo "a"', 'enddef'], 'E1055: Missing name after ...')
Bram Moolenaarf93c7fe2020-04-23 22:16:53 +0200260 CheckScriptFailure(['def Func5(items:string)', 'echo "a"'], 'E1069:')
Bram Moolenaar6e949782020-04-13 17:21:00 +0200261 CheckScriptFailure(['def Func5(items)', 'echo "a"'], 'E1077:')
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200262enddef
263
264def Test_vim9script_call()
265 let lines =<< trim END
266 vim9script
267 let var = ''
268 def MyFunc(arg: string)
269 var = arg
270 enddef
271 MyFunc('foobar')
272 assert_equal('foobar', var)
273
274 let str = 'barfoo'
275 str->MyFunc()
276 assert_equal('barfoo', var)
277
278 let g:value = 'value'
279 g:value->MyFunc()
280 assert_equal('value', var)
281
282 let listvar = []
283 def ListFunc(arg: list<number>)
284 listvar = arg
285 enddef
286 [1, 2, 3]->ListFunc()
287 assert_equal([1, 2, 3], listvar)
288
289 let dictvar = {}
290 def DictFunc(arg: dict<number>)
291 dictvar = arg
292 enddef
293 {'a': 1, 'b': 2}->DictFunc()
294 assert_equal(#{a: 1, b: 2}, dictvar)
295 def CompiledDict()
296 {'a': 3, 'b': 4}->DictFunc()
297 enddef
298 CompiledDict()
299 assert_equal(#{a: 3, b: 4}, dictvar)
300
301 #{a: 3, b: 4}->DictFunc()
302 assert_equal(#{a: 3, b: 4}, dictvar)
303
304 ('text')->MyFunc()
305 assert_equal('text', var)
306 ("some")->MyFunc()
307 assert_equal('some', var)
308 END
309 writefile(lines, 'Xcall.vim')
310 source Xcall.vim
311 delete('Xcall.vim')
312enddef
313
314def Test_vim9script_call_fail_decl()
315 let lines =<< trim END
316 vim9script
317 let var = ''
318 def MyFunc(arg: string)
319 let var = 123
320 enddef
321 END
322 writefile(lines, 'Xcall_decl.vim')
323 assert_fails('source Xcall_decl.vim', 'E1054:')
324 delete('Xcall_decl.vim')
325enddef
326
327def Test_vim9script_call_fail_const()
328 let lines =<< trim END
329 vim9script
330 const var = ''
331 def MyFunc(arg: string)
332 var = 'asdf'
333 enddef
334 END
335 writefile(lines, 'Xcall_const.vim')
336 assert_fails('source Xcall_const.vim', 'E46:')
337 delete('Xcall_const.vim')
338enddef
339
340" Test that inside :function a Python function can be defined, :def is not
341" recognized.
342func Test_function_python()
343 CheckFeature python3
344 let py = 'python3'
345 execute py "<< EOF"
346def do_something():
347 return 1
348EOF
349endfunc
350
351def Test_delfunc()
352 let lines =<< trim END
353 vim9script
Bram Moolenaar4c17ad92020-04-27 22:47:51 +0200354 def g:GoneSoon()
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200355 echo 'hello'
356 enddef
357
358 def CallGoneSoon()
359 GoneSoon()
360 enddef
361
Bram Moolenaar4c17ad92020-04-27 22:47:51 +0200362 delfunc g:GoneSoon
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200363 CallGoneSoon()
364 END
365 writefile(lines, 'XToDelFunc')
366 assert_fails('so XToDelFunc', 'E933')
367 assert_fails('so XToDelFunc', 'E933')
368
369 delete('XToDelFunc')
370enddef
371
372def Test_redef_failure()
373 call writefile(['def Func0(): string', 'return "Func0"', 'enddef'], 'Xdef')
374 so Xdef
375 call writefile(['def Func1(): string', 'return "Func1"', 'enddef'], 'Xdef')
376 so Xdef
377 call writefile(['def! Func0(): string', 'enddef'], 'Xdef')
378 call assert_fails('so Xdef', 'E1027:')
379 call writefile(['def Func2(): string', 'return "Func2"', 'enddef'], 'Xdef')
380 so Xdef
381 call delete('Xdef')
382
Bram Moolenaar1df8b3f2020-04-23 18:13:23 +0200383 call assert_equal(0, g:Func0())
384 call assert_equal('Func1', g:Func1())
385 call assert_equal('Func2', g:Func2())
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200386
387 delfunc! Func0
388 delfunc! Func1
389 delfunc! Func2
390enddef
391
Bram Moolenaarf93c7fe2020-04-23 22:16:53 +0200392def Test_vim9script_func()
393 let lines =<< trim END
394 vim9script
395 func Func(arg)
396 echo a:arg
397 endfunc
398 Func('text')
399 END
400 writefile(lines, 'XVim9Func')
401 so XVim9Func
402
403 delete('XVim9Func')
404enddef
405
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200406" Test for internal functions returning different types
407func Test_InternalFuncRetType()
408 let lines =<< trim END
409 def RetFloat(): float
410 return ceil(1.456)
411 enddef
412
413 def RetListAny(): list<any>
414 return items({'k' : 'v'})
415 enddef
416
417 def RetListString(): list<string>
418 return split('a:b:c', ':')
419 enddef
420
421 def RetListDictAny(): list<dict<any>>
422 return getbufinfo()
423 enddef
424
425 def RetDictNumber(): dict<number>
426 return wordcount()
427 enddef
428
429 def RetDictString(): dict<string>
430 return environ()
431 enddef
432 END
433 call writefile(lines, 'Xscript')
434 source Xscript
435
436 call assert_equal(2.0, RetFloat())
437 call assert_equal([['k', 'v']], RetListAny())
438 call assert_equal(['a', 'b', 'c'], RetListString())
439 call assert_notequal([], RetListDictAny())
440 call assert_notequal({}, RetDictNumber())
441 call assert_notequal({}, RetDictString())
442 call delete('Xscript')
443endfunc
444
445" Test for passing too many or too few arguments to internal functions
446func Test_internalfunc_arg_error()
447 let l =<< trim END
448 def! FArgErr(): float
449 return ceil(1.1, 2)
450 enddef
451 END
452 call writefile(l, 'Xinvalidarg')
453 call assert_fails('so Xinvalidarg', 'E118:')
454 let l =<< trim END
455 def! FArgErr(): float
456 return ceil()
457 enddef
458 END
459 call writefile(l, 'Xinvalidarg')
460 call assert_fails('so Xinvalidarg', 'E119:')
461 call delete('Xinvalidarg')
462endfunc
463
464let s:funcResult = 0
465
466def FuncNoArgNoRet()
467 funcResult = 11
468enddef
469
470def FuncNoArgRetNumber(): number
471 funcResult = 22
472 return 1234
473enddef
474
Bram Moolenaarec5929d2020-04-07 20:53:39 +0200475def FuncNoArgRetString(): string
476 funcResult = 45
477 return 'text'
478enddef
479
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200480def FuncOneArgNoRet(arg: number)
481 funcResult = arg
482enddef
483
484def FuncOneArgRetNumber(arg: number): number
485 funcResult = arg
486 return arg
487enddef
488
Bram Moolenaar08938ee2020-04-11 23:17:17 +0200489def FuncTwoArgNoRet(one: bool, two: number)
490 funcResult = two
491enddef
492
Bram Moolenaarec5929d2020-04-07 20:53:39 +0200493def FuncOneArgRetString(arg: string): string
494 return arg
495enddef
496
Bram Moolenaar89228602020-04-05 22:14:54 +0200497def FuncOneArgRetAny(arg: any): any
498 return arg
499enddef
500
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200501def Test_func_type()
502 let Ref1: func()
503 funcResult = 0
504 Ref1 = FuncNoArgNoRet
505 Ref1()
506 assert_equal(11, funcResult)
Bram Moolenaar4c683752020-04-05 21:38:23 +0200507
508 let Ref2: func
509 funcResult = 0
510 Ref2 = FuncNoArgNoRet
511 Ref2()
512 assert_equal(11, funcResult)
513
514 funcResult = 0
515 Ref2 = FuncOneArgNoRet
516 Ref2(12)
517 assert_equal(12, funcResult)
518
519 funcResult = 0
520 Ref2 = FuncNoArgRetNumber
521 assert_equal(1234, Ref2())
522 assert_equal(22, funcResult)
523
524 funcResult = 0
525 Ref2 = FuncOneArgRetNumber
526 assert_equal(13, Ref2(13))
527 assert_equal(13, funcResult)
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200528enddef
529
Bram Moolenaarec5929d2020-04-07 20:53:39 +0200530def Test_func_type_part()
531 let RefVoid: func: void
532 RefVoid = FuncNoArgNoRet
533 RefVoid = FuncOneArgNoRet
534 CheckDefFailure(['let RefVoid: func: void', 'RefVoid = FuncNoArgRetNumber'], 'E1013: type mismatch, expected func() but got func(): number')
535 CheckDefFailure(['let RefVoid: func: void', 'RefVoid = FuncNoArgRetString'], 'E1013: type mismatch, expected func() but got func(): string')
536
537 let RefAny: func(): any
538 RefAny = FuncNoArgRetNumber
539 RefAny = FuncNoArgRetString
540 CheckDefFailure(['let RefAny: func(): any', 'RefAny = FuncNoArgNoRet'], 'E1013: type mismatch, expected func(): any but got func()')
541 CheckDefFailure(['let RefAny: func(): any', 'RefAny = FuncOneArgNoRet'], 'E1013: type mismatch, expected func(): any but got func(number)')
542
543 let RefNr: func: number
544 RefNr = FuncNoArgRetNumber
545 RefNr = FuncOneArgRetNumber
546 CheckDefFailure(['let RefNr: func: number', 'RefNr = FuncNoArgNoRet'], 'E1013: type mismatch, expected func(): number but got func()')
547 CheckDefFailure(['let RefNr: func: number', 'RefNr = FuncNoArgRetString'], 'E1013: type mismatch, expected func(): number but got func(): string')
548
549 let RefStr: func: string
550 RefStr = FuncNoArgRetString
551 RefStr = FuncOneArgRetString
552 CheckDefFailure(['let RefStr: func: string', 'RefStr = FuncNoArgNoRet'], 'E1013: type mismatch, expected func(): string but got func()')
553 CheckDefFailure(['let RefStr: func: string', 'RefStr = FuncNoArgRetNumber'], 'E1013: type mismatch, expected func(): string but got func(): number')
554enddef
555
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200556def Test_func_type_fails()
557 CheckDefFailure(['let ref1: func()'], 'E704:')
558
559 CheckDefFailure(['let Ref1: func()', 'Ref1 = FuncNoArgRetNumber'], 'E1013: type mismatch, expected func() but got func(): number')
560 CheckDefFailure(['let Ref1: func()', 'Ref1 = FuncOneArgNoRet'], 'E1013: type mismatch, expected func() but got func(number)')
561 CheckDefFailure(['let Ref1: func()', 'Ref1 = FuncOneArgRetNumber'], 'E1013: type mismatch, expected func() but got func(number): number')
Bram Moolenaar08938ee2020-04-11 23:17:17 +0200562 CheckDefFailure(['let Ref1: func(bool)', 'Ref1 = FuncTwoArgNoRet'], 'E1013: type mismatch, expected func(bool) but got func(bool, number)')
563 CheckDefFailure(['let Ref1: func(?bool)', 'Ref1 = FuncTwoArgNoRet'], 'E1013: type mismatch, expected func(?bool) but got func(bool, number)')
564 CheckDefFailure(['let Ref1: func(...bool)', 'Ref1 = FuncTwoArgNoRet'], 'E1013: type mismatch, expected func(...bool) but got func(bool, number)')
565
566 call CheckDefFailure(['let RefWrong: func(string ,number)'], 'E1068:')
567 call CheckDefFailure(['let RefWrong: func(string,number)'], 'E1069:')
568 call CheckDefFailure(['let RefWrong: func(bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool, bool)'], 'E740:')
569 call CheckDefFailure(['let RefWrong: func(bool):string'], 'E1069:')
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200570enddef
571
Bram Moolenaar89228602020-04-05 22:14:54 +0200572def Test_func_return_type()
573 let nr: number
574 nr = FuncNoArgRetNumber()
575 assert_equal(1234, nr)
576
577 nr = FuncOneArgRetAny(122)
578 assert_equal(122, nr)
579
580 let str: string
581 str = FuncOneArgRetAny('yes')
582 assert_equal('yes', str)
583
584 CheckDefFailure(['let str: string', 'str = FuncNoArgRetNumber()'], 'E1013: type mismatch, expected string but got number')
585enddef
586
Bram Moolenaar5e774c72020-04-12 21:53:00 +0200587def MultiLine(
588 arg1: string,
589 arg2 = 1234,
590 ...rest: list<string>
591 ): string
592 return arg1 .. arg2 .. join(rest, '-')
593enddef
594
Bram Moolenaar2c330432020-04-13 14:41:35 +0200595def MultiLineComment(
596 arg1: string, # comment
597 arg2 = 1234, # comment
598 ...rest: list<string> # comment
599 ): string # comment
600 return arg1 .. arg2 .. join(rest, '-')
601enddef
602
Bram Moolenaar5e774c72020-04-12 21:53:00 +0200603def Test_multiline()
604 assert_equal('text1234', MultiLine('text'))
605 assert_equal('text777', MultiLine('text', 777))
606 assert_equal('text777one', MultiLine('text', 777, 'one'))
607 assert_equal('text777one-two', MultiLine('text', 777, 'one', 'two'))
608enddef
609
Bram Moolenaar23e03252020-04-12 22:22:31 +0200610func Test_multiline_not_vim9()
611 call assert_equal('text1234', MultiLine('text'))
612 call assert_equal('text777', MultiLine('text', 777))
613 call assert_equal('text777one', MultiLine('text', 777, 'one'))
614 call assert_equal('text777one-two', MultiLine('text', 777, 'one', 'two'))
615endfunc
616
Bram Moolenaar5e774c72020-04-12 21:53:00 +0200617
Bram Moolenaaree4e0c12020-04-06 21:35:05 +0200618" When using CheckScriptFailure() for the below test, E1010 is generated instead
619" of E1056.
620func Test_E1056_1059()
621 let caught_1056 = 0
622 try
623 def F():
624 return 1
625 enddef
626 catch /E1056:/
627 let caught_1056 = 1
628 endtry
629 call assert_equal(1, caught_1056)
630
631 let caught_1059 = 0
632 try
633 def F5(items : list)
634 echo 'a'
635 enddef
636 catch /E1059:/
637 let caught_1059 = 1
638 endtry
639 call assert_equal(1, caught_1059)
640endfunc
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200641
Bram Moolenaarc8cd2b32020-05-01 19:29:08 +0200642def RefFunc(Ref: func(string): string): string
643 return Ref('more')
644enddef
645
646def Test_closure_simple()
647 let local = 'some '
648 assert_equal('some more', RefFunc({s -> local .. s}))
649enddef
650
Bram Moolenaarbf67ea12020-05-02 17:52:42 +0200651def MakeRef()
652 let local = 'some '
653 g:Ref = {s -> local .. s}
654enddef
655
656def Test_closure_ref_after_return()
657 MakeRef()
658 assert_equal('some thing', g:Ref('thing'))
659 unlet g:Ref
660enddef
661
Bram Moolenaar5adc55c2020-05-02 23:12:58 +0200662def MakeTwoRefs()
663 let local = ['some']
664 g:Extend = {s -> local->add(s)}
665 g:Read = {-> local}
666enddef
667
668def Test_closure_two_refs()
669 MakeTwoRefs()
670 assert_equal('some', join(g:Read(), ' '))
671 g:Extend('more')
672 assert_equal('some more', join(g:Read(), ' '))
673 g:Extend('even')
674 assert_equal('some more even', join(g:Read(), ' '))
675
676 unlet g:Extend
677 unlet g:Read
678enddef
679
Bram Moolenaar5adc55c2020-05-02 23:12:58 +0200680def ReadRef(Ref: func(): list<string>): string
681 return join(Ref(), ' ')
682enddef
683
684def ExtendRef(Ref: func(string), add: string)
685 Ref(add)
686enddef
687
688def Test_closure_two_indirect_refs()
Bram Moolenaarf7779c62020-05-03 15:38:16 +0200689 MakeTwoRefs()
Bram Moolenaar5adc55c2020-05-02 23:12:58 +0200690 assert_equal('some', ReadRef(g:Read))
691 ExtendRef(g:Extend, 'more')
692 assert_equal('some more', ReadRef(g:Read))
693 ExtendRef(g:Extend, 'even')
694 assert_equal('some more even', ReadRef(g:Read))
695
696 unlet g:Extend
697 unlet g:Read
698enddef
Bram Moolenaarbf67ea12020-05-02 17:52:42 +0200699
Bram Moolenaar2fd4cd72020-05-03 22:30:49 +0200700def MakeArgRefs(theArg: string)
701 let local = 'loc_val'
702 g:UseArg = {s -> theArg .. '/' .. local .. '/' .. s}
703enddef
704
705def MakeArgRefsVarargs(theArg: string, ...rest: list<string>)
706 let local = 'the_loc'
707 g:UseVararg = {s -> theArg .. '/' .. local .. '/' .. s .. '/' .. join(rest)}
708enddef
709
710def Test_closure_using_argument()
711 MakeArgRefs('arg_val')
712 assert_equal('arg_val/loc_val/call_val', g:UseArg('call_val'))
713
714 MakeArgRefsVarargs('arg_val', 'one', 'two')
715 assert_equal('arg_val/the_loc/call_val/one two', g:UseVararg('call_val'))
716
717 unlet g:UseArg
718 unlet g:UseVararg
719enddef
720
Bram Moolenaar04b12692020-05-04 23:24:44 +0200721def Test_nested_closure()
722 let local = 'text'
723 def Closure(arg: string): string
724 return local .. arg
725 enddef
726 assert_equal('text!!!', Closure('!!!'))
727enddef
728
Bram Moolenaarf7779c62020-05-03 15:38:16 +0200729
Bram Moolenaar5deeb3f2020-04-05 17:08:17 +0200730" vim: ts=8 sw=2 sts=2 expandtab tw=80 fdm=marker