diff options
author | Bram Moolenaar <Bram@vim.org> | 2016-11-14 21:50:00 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2016-11-14 21:50:00 +0100 |
commit | 8a01f969c198eeb655ad2f96f2796a6f6f4a1924 (patch) | |
tree | 3d71f55b5f569b7468dc82c026d0f808021b889d /src/testdir | |
parent | 7618e00d3b8bfe064cfc524640d754607361f9df (diff) | |
download | vim-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.vim | 36 |
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 |