mirror of
https://github.com/neovim/neovim.git
synced 2026-02-19 01:48:30 +00:00
fix(messages): message not flushed at end of command #37904
Problem: Logic determining messages belonging to the last command to
show with "g<" does not flush pending messages. This can
result in clearing the temporary message history before a
message still belonging to the previous command was emitted.
Solution: Flush pending messages when marking the end of messages
belonging to previous command.
This commit is contained in:
@@ -2738,8 +2738,9 @@ static void store_sb_text(const char **sb_str, const char *s, int hl_id, int *sb
|
||||
/// Finished showing messages, clear the scroll-back text on the next message.
|
||||
void may_clear_sb_text(void)
|
||||
{
|
||||
msg_ext_ui_flush(); // ensure messages until now are emitted
|
||||
do_clear_sb_text = SB_CLEAR_ALL;
|
||||
do_clear_hist_temp = !msg_ext_append;
|
||||
do_clear_hist_temp = true;
|
||||
}
|
||||
|
||||
/// Starting to edit the command line: do not clear messages now.
|
||||
|
||||
@@ -439,8 +439,8 @@ describe('vim.ui_attach', function()
|
||||
|
|
||||
{1:~ }|*2
|
||||
{3: }|
|
||||
{9:Lua callback:} |
|
||||
{9:[string "<nvim>"]:3: foo} |
|
||||
{9:Error in "msg_show" UI event handler (ns=(UNKNOWN PLUGIN)):} |
|
||||
{9:Lua: [string "<nvim>"]:3: foo} |
|
||||
{9:stack traceback:} |
|
||||
{9: [C]: in function 'error'} |
|
||||
{9: [string "<nvim>"]:3: in function <[string "<nvim>"]:1>} |
|
||||
|
||||
@@ -94,8 +94,19 @@ describe('messages2', function()
|
||||
{1:~ }|*12
|
||||
0,0-1 All|
|
||||
]])
|
||||
-- g< shows messages from last command
|
||||
feed('g<lt>')
|
||||
screen:expect([[
|
||||
|
|
||||
{1:~ }|*8
|
||||
{3: }|
|
||||
fo^o |
|
||||
bar |
|
||||
1 %a "[No Name]" line 1 |
|
||||
1,3 All|
|
||||
]])
|
||||
-- edit_unputchar() does not clear already updated screen #34515.
|
||||
feed('ix<Esc>dwi<C-r>')
|
||||
feed('qix<Esc>dwi<C-r>')
|
||||
screen:expect([[
|
||||
{18:^"} |
|
||||
{1:~ }|*12
|
||||
|
||||
Reference in New Issue
Block a user