Mercurial > vim
view src/testdir/test_signals.vim @ 16113:9994c50f7879 v8.1.1061
patch 8.1.1061: when substitute string throws error, substitute happens anyway
commit https://github.com/vim/vim/commit/0e97b9487571cf725a9cb28fe4dcefc800415f69
Author: Bram Moolenaar <Bram@vim.org>
Date: Wed Mar 27 22:53:53 2019 +0100
patch 8.1.1061: when substitute string throws error, substitute happens anyway
Problem: When substitute string throws error, substitute happens anyway.
Solution: Skip substitution when aborting. (closes https://github.com/vim/vim/issues/4161)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Wed, 27 Mar 2019 23:00:05 +0100 |
parents | ed1482db2d72 |
children | 1ab0d1f7807a |
line wrap: on
line source
" Test signal handling. if !has('unix') finish endif source shared.vim " Test signal WINCH (window resize signal) func Test_signal_WINCH() let signals = system('kill -l') if signals !~ '\<WINCH\>' " signal WINCH is not available, skip the test. return endif " We do not actually want to change the size of the terminal. let old_WS = '' if exists('&t_WS') let old_WS = &t_WS let &t_WS = '' endif let old_lines = &lines let old_columns = &columns let new_lines = &lines - 2 let new_columns = &columns - 2 exe 'set lines=' . new_lines exe 'set columns=' . new_columns call assert_equal(new_lines, &lines) call assert_equal(new_columns, &columns) " Send signal and wait for signal to be processed. " 'lines' and 'columns' should have been restored " after handing signal WINCH. exe 'silent !kill -s WINCH ' . getpid() call WaitForAssert({-> assert_equal(old_lines, &lines)}) call assert_equal(old_columns, &columns) if old_WS != '' let &t_WS = old_WS endif endfunc