summaryrefslogtreecommitdiff
path: root/src/testdir
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2016-11-14 21:50:00 +0100
committerBram Moolenaar <Bram@vim.org>2016-11-14 21:50:00 +0100
commit8a01f969c198eeb655ad2f96f2796a6f6f4a1924 (patch)
tree3d71f55b5f569b7468dc82c026d0f808021b889d /src/testdir
parent7618e00d3b8bfe064cfc524640d754607361f9df (diff)
downloadvim-8a01f969c198eeb655ad2f96f2796a6f6f4a1924.zip
patch 8.0.0085
Problem: Using freed memory with recursive function call. (Dominique Pelle) Solution: Make a copy of the function name.
Diffstat (limited to 'src/testdir')
-rw-r--r--src/testdir/test_nested_function.vim36
1 files changed, 23 insertions, 13 deletions
diff --git a/src/testdir/test_nested_function.vim b/src/testdir/test_nested_function.vim
index f88173052..7e301ed33 100644
--- a/src/testdir/test_nested_function.vim
+++ b/src/testdir/test_nested_function.vim
@@ -1,32 +1,42 @@
"Tests for nested functions
"
-function! NestedFunc()
- fu! Func1()
+func NestedFunc()
+ func! Func1()
let g:text .= 'Func1 '
- endfunction
+ endfunc
call Func1()
- fu! s:func2()
+ func! s:func2()
let g:text .= 's:func2 '
- endfunction
+ endfunc
call s:func2()
- fu! s:_func3()
+ func! s:_func3()
let g:text .= 's:_func3 '
- endfunction
+ endfunc
call s:_func3()
let fn = 'Func4'
- fu! {fn}()
+ func! {fn}()
let g:text .= 'Func4 '
- endfunction
+ endfunc
call {fn}()
let fn = 'func5'
- fu! s:{fn}()
+ func! s:{fn}()
let g:text .= 's:func5'
- endfunction
+ endfunc
call s:{fn}()
-endfunction
+endfunc
-function! Test_nested_functions()
+func Test_nested_functions()
let g:text = ''
call NestedFunc()
call assert_equal('Func1 s:func2 s:_func3 Func4 s:func5', g:text)
endfunction
+
+func Test_nested_argument()
+ func g:X()
+ let g:Y = function('sort')
+ endfunc
+ let g:Y = function('sort')
+ echo g:Y([], g:X())
+ delfunc g:X
+ unlet g:Y
+endfunc