mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.2.1844: using "q" at the more prompt doesn't stop a long message
Problem: Using "q" at the more prompt doesn't stop a long message. Solution: Check for "got_int". (closes #7122)
This commit is contained in:
parent
b9616af23f
commit
3d30af8783
@ -1551,6 +1551,10 @@ msg_outtrans_len_attr(char_u *msgstr, int len, int attr)
|
|||||||
char_u *s;
|
char_u *s;
|
||||||
int mb_l;
|
int mb_l;
|
||||||
int c;
|
int c;
|
||||||
|
int save_got_int = got_int;
|
||||||
|
|
||||||
|
// Only quit when got_int was set in here.
|
||||||
|
got_int = FALSE;
|
||||||
|
|
||||||
// if MSG_HIST flag set, add message to history
|
// if MSG_HIST flag set, add message to history
|
||||||
if (attr & MSG_HIST)
|
if (attr & MSG_HIST)
|
||||||
@ -1568,7 +1572,7 @@ msg_outtrans_len_attr(char_u *msgstr, int len, int attr)
|
|||||||
* Go over the string. Special characters are translated and printed.
|
* Go over the string. Special characters are translated and printed.
|
||||||
* Normal characters are printed several at a time.
|
* Normal characters are printed several at a time.
|
||||||
*/
|
*/
|
||||||
while (--len >= 0)
|
while (--len >= 0 && !got_int)
|
||||||
{
|
{
|
||||||
if (enc_utf8)
|
if (enc_utf8)
|
||||||
// Don't include composing chars after the end.
|
// Don't include composing chars after the end.
|
||||||
@ -1618,10 +1622,12 @@ msg_outtrans_len_attr(char_u *msgstr, int len, int attr)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (str > plain_start)
|
if (str > plain_start && !got_int)
|
||||||
// print the printable chars at the end
|
// print the printable chars at the end
|
||||||
msg_puts_attr_len((char *)plain_start, (int)(str - plain_start), attr);
|
msg_puts_attr_len((char *)plain_start, (int)(str - plain_start), attr);
|
||||||
|
|
||||||
|
got_int |= save_got_int;
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
6
src/testdir/dumps/Test_quit_long_message.dump
Normal file
6
src/testdir/dumps/Test_quit_long_message.dump
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
> +0&#ffffff0@74
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|~| @73
|
||||||
|
|~| @73
|
||||||
|
|~| @73
|
||||||
|
| +0#0000000&@56|0|,|0|-|1| @8|A|l@1|
|
@ -4,6 +4,7 @@ source check.vim
|
|||||||
source shared.vim
|
source shared.vim
|
||||||
source term_util.vim
|
source term_util.vim
|
||||||
source view_util.vim
|
source view_util.vim
|
||||||
|
source screendump.vim
|
||||||
|
|
||||||
func Test_messages()
|
func Test_messages()
|
||||||
let oldmore = &more
|
let oldmore = &more
|
||||||
@ -309,4 +310,20 @@ func Test_mapping_at_hit_return_prompt()
|
|||||||
nunmap <C-B>
|
nunmap <C-B>
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_quit_long_message()
|
||||||
|
CheckScreendump
|
||||||
|
|
||||||
|
let content =<< trim END
|
||||||
|
echom range(9999)->join("\x01")
|
||||||
|
END
|
||||||
|
call writefile(content, 'Xtest_quit_message')
|
||||||
|
let buf = RunVimInTerminal('-S Xtest_quit_message', #{rows: 6})
|
||||||
|
call term_sendkeys(buf, "q")
|
||||||
|
call VerifyScreenDump(buf, 'Test_quit_long_message', {})
|
||||||
|
|
||||||
|
" clean up
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
call delete('Xtest_diff_rnu')
|
||||||
|
endfunc
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -750,6 +750,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
1844,
|
||||||
/**/
|
/**/
|
||||||
1843,
|
1843,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user