mirror of
https://github.com/neovim/neovim.git
synced 2025-09-27 13:38:34 +00:00
vim-patch:8.2.0946: cannot use "q" to cancel a number prompt
Problem: Cannot use "q" to cancel a number prompt.
Solution: Recognize "q" instead of ignoring it.
eebd555733
This commit is contained in:
@@ -753,9 +753,10 @@ get_number (
|
||||
skip_redraw = TRUE; /* skip redraw once */
|
||||
do_redraw = FALSE;
|
||||
break;
|
||||
} else if (c == CAR || c == NL || c == Ctrl_C || c == ESC)
|
||||
} else if (c == CAR || c == NL || c == Ctrl_C || c == ESC || c == 'q') {
|
||||
break;
|
||||
}
|
||||
}
|
||||
no_mapping--;
|
||||
return n;
|
||||
}
|
||||
@@ -771,11 +772,13 @@ int prompt_for_number(int *mouse_used)
|
||||
int save_cmdline_row;
|
||||
int save_State;
|
||||
|
||||
/* When using ":silent" assume that <CR> was entered. */
|
||||
if (mouse_used != NULL)
|
||||
MSG_PUTS(_("Type number and <Enter> or click with mouse (empty cancels): "));
|
||||
else
|
||||
MSG_PUTS(_("Type number and <Enter> (empty cancels): "));
|
||||
// When using ":silent" assume that <CR> was entered.
|
||||
if (mouse_used != NULL) {
|
||||
MSG_PUTS(_("Type number and <Enter> or click with the mouse "
|
||||
"(q or empty cancels): "));
|
||||
} else {
|
||||
MSG_PUTS(_("Type number and <Enter> (q or empty cancels): "));
|
||||
}
|
||||
|
||||
/* Set the state such that text can be selected/copied/pasted and we still
|
||||
* get mouse events. */
|
||||
|
@@ -1067,6 +1067,18 @@ func Test_inputlist()
|
||||
call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>3\<cr>", 'tx')
|
||||
call assert_equal(3, c)
|
||||
|
||||
" CR to cancel
|
||||
call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>\<cr>", 'tx')
|
||||
call assert_equal(0, c)
|
||||
|
||||
" Esc to cancel
|
||||
call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>\<Esc>", 'tx')
|
||||
call assert_equal(0, c)
|
||||
|
||||
" q to cancel
|
||||
call feedkeys(":let c = inputlist(['Select color:', '1. red', '2. green', '3. blue'])\<cr>q", 'tx')
|
||||
call assert_equal(0, c)
|
||||
|
||||
call assert_fails('call inputlist("")', 'E686:')
|
||||
endfunc
|
||||
|
||||
|
@@ -97,7 +97,7 @@ describe('NULL', function()
|
||||
null_expr_test('makes filter() return v:_null_list', 'filter(L, "1") is# L', 0, 1)
|
||||
null_test('is treated by :let as empty list', ':let [l] = L', 'Vim(let):E688: More targets than List items')
|
||||
null_expr_test('is accepted as an empty list by inputlist()', '[feedkeys("\\n"), inputlist(L)]',
|
||||
'Type number and <Enter> or click with mouse (empty cancels): ', {0, 0})
|
||||
'Type number and <Enter> or click with the mouse (q or empty cancels): ', {0, 0})
|
||||
null_expr_test('is accepted as an empty list by writefile()',
|
||||
('[writefile(L, "%s"), readfile("%s")]'):format(tmpfname, tmpfname),
|
||||
0, {0, {}})
|
||||
|
@@ -811,7 +811,7 @@ describe('ui/ext_messages', function()
|
||||
{1:~ }|
|
||||
{1:^~ }|
|
||||
]], messages={
|
||||
{content = { { 'Change "helllo" to:\n 1 "Hello"\n 2 "Hallo"\n 3 "Helli"\nType number and <Enter> or click with mouse (empty cancels): ' } }, kind = ""}
|
||||
{content = { { 'Change "helllo" to:\n 1 "Hello"\n 2 "Hallo"\n 3 "Helli"\nType number and <Enter> or click with the mouse (q or empty cancels): ' } }, kind = ""}
|
||||
}}
|
||||
|
||||
feed('1')
|
||||
@@ -822,7 +822,7 @@ describe('ui/ext_messages', function()
|
||||
{1:~ }|
|
||||
{1:^~ }|
|
||||
]], messages={
|
||||
{content = { { 'Change "helllo" to:\n 1 "Hello"\n 2 "Hallo"\n 3 "Helli"\nType number and <Enter> or click with mouse (empty cancels): ' } }, kind = ""},
|
||||
{content = { { 'Change "helllo" to:\n 1 "Hello"\n 2 "Hallo"\n 3 "Helli"\nType number and <Enter> or click with the mouse (q or empty cancels): ' } }, kind = ""},
|
||||
{ content = { { "1" } }, kind = "" }
|
||||
}}
|
||||
|
||||
|
Reference in New Issue
Block a user