Mercurial > vim
view src/testdir/test_expand_dllpath.vim @ 23845:7517eb94239b v8.2.2464
patch 8.2.2464: using freed memory if window closed in autocommand
Commit: https://github.com/vim/vim/commit/8ab375706e6712308f8cf7529bcae56684a6f385
Author: Bram Moolenaar <Bram@vim.org>
Date: Wed Feb 3 21:56:59 2021 +0100
patch 8.2.2464: using freed memory if window closed in autocommand
Problem: Using freed memory if window closed in autocommand. (houyunsong)
Solution: Check the window still exists.
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Wed, 03 Feb 2021 22:00:04 +0100 |
parents | 08940efa6b4e |
children | dbec60b8c253 |
line wrap: on
line source
" Test for expanding dllpath options func s:test_expand_dllpath(optname) let $TEST_EXPAND_DLLPATH = '/dllpath/lib' . substitute(a:optname, '\zedll$', '.', '') execute 'let dllpath_save = &' . a:optname try execute 'set ' . a:optname . '=$TEST_EXPAND_DLLPATH' execute 'call assert_equal("' . $TEST_EXPAND_DLLPATH . '", &' . a:optname . ')' execute 'set ' . a:optname . '=~' . $TEST_EXPAND_DLLPATH let home = substitute($HOME, '\\', '/', 'g') execute 'call assert_equal("' . home . $TEST_EXPAND_DLLPATH . '", &' . a:optname . ')' finally execute 'let &' . a:optname . ' = dllpath_save' let $TEST_EXPAND_DLLPATH = '' endtry endfunc func s:generate_test_if_exists(optname) if exists('+' . a:optname) execute join([ \ 'func Test_expand_' . a:optname . '()', \ ' call s:test_expand_dllpath("' . a:optname . '")', \ 'endfunc' \ ], "\n") endif endfunc call s:generate_test_if_exists('luadll') call s:generate_test_if_exists('perldll') call s:generate_test_if_exists('pythondll') call s:generate_test_if_exists('pythonthreedll') call s:generate_test_if_exists('rubydll') call s:generate_test_if_exists('tcldll') " vim: shiftwidth=2 sts=2 expandtab