mirror of
https://github.com/neovim/neovim.git
synced 2025-10-04 17:06:30 +00:00
vim-patch:8.2.0095: cannot specify exit code for :cquit (#13407)
Problem: Cannot specify exit code for :cquit.
Solution: Add optional argument. (Thinca, Yegappan Lakshmanan, closes vim/vim#5442)
1860bde9d3
Co-authored-by: erw7 <erw7.github@gmail.com>
This commit is contained in:
@@ -6317,17 +6317,14 @@ static void ex_quit(exarg_T *eap)
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* ":cquit".
|
||||
*/
|
||||
/// ":cquit".
|
||||
static void ex_cquit(exarg_T *eap)
|
||||
{
|
||||
// this does not always pass on the exit code to the Manx compiler. why?
|
||||
getout(eap->addr_count > 0 ? (int)eap->line2 : EXIT_FAILURE);
|
||||
}
|
||||
|
||||
/*
|
||||
* ":qall": try to quit all windows
|
||||
*/
|
||||
/// ":qall": try to quit all windows
|
||||
static void ex_quit_all(exarg_T *eap)
|
||||
{
|
||||
if (cmdwin_type != 0) {
|
||||
|
@@ -3,6 +3,8 @@
|
||||
source check.vim
|
||||
CheckFeature quickfix
|
||||
|
||||
source screendump.vim
|
||||
|
||||
set encoding=utf-8
|
||||
|
||||
func s:setup_commands(cchar)
|
||||
@@ -4410,6 +4412,31 @@ func Test_search_in_dirstack()
|
||||
call delete('Xtestdir', 'rf')
|
||||
endfunc
|
||||
|
||||
" Test for :cquit
|
||||
func Test_cquit()
|
||||
" Exit Vim with a non-zero value
|
||||
if RunVim([], ["cquit 7"], '')
|
||||
call assert_equal(7, v:shell_error)
|
||||
endif
|
||||
|
||||
if RunVim([], ["50cquit"], '')
|
||||
call assert_equal(50, v:shell_error)
|
||||
endif
|
||||
|
||||
" Exit Vim with default value
|
||||
if RunVim([], ["cquit"], '')
|
||||
call assert_equal(1, v:shell_error)
|
||||
endif
|
||||
|
||||
" Exit Vim with zero value
|
||||
if RunVim([], ["cquit 0"], '')
|
||||
call assert_equal(0, v:shell_error)
|
||||
endif
|
||||
|
||||
" Exit Vim with negative value
|
||||
call assert_fails('-3cquit', 'E16:')
|
||||
endfunc
|
||||
|
||||
" Test for adding an invalid entry with the quickfix window open and making
|
||||
" sure that the window contents are not changed
|
||||
func Test_add_invalid_entry_with_qf_window()
|
||||
|
Reference in New Issue
Block a user