Problem: Statusline is sometimes drawn on top of popup.
Solution: Redraw popups after the statusline. (Naruhiko Nishino,
closes #4468)
did_intro = TRUE;
#ifdef FEAT_TEXT_PROP
- // Display popup windows on top of the others.
+ // Display popup windows on top of the windows.
update_popups();
#endif
win_redr_status(wp, FALSE);
}
+#ifdef FEAT_TEXT_PROP
+ // Display popup windows on top of the others.
+ update_popups();
+#endif
+
update_finish();
}
#endif
)
win_redr_status(wp, FALSE);
+#ifdef FEAT_TEXT_PROP
+ // Display popup windows on top of everything.
+ update_popups();
+#endif
+
update_finish();
}
#endif
win_redr_status(wp, FALSE);
if (redraw_tabline)
draw_tabline();
+
+#ifdef FEAT_TEXT_PROP
+ // Display popup windows on top of the status lines.
+ update_popups();
+#endif
}
#if defined(FEAT_WILDMENU) || defined(PROTO)
/* Redraw the tab pages line if needed. */
if (redraw_tabline)
draw_tabline();
+
+#ifdef FEAT_TEXT_PROP
+ // Display popup windows on top of everything.
+ update_popups();
+#endif
}
#ifdef FEAT_CMDL_INFO
--- /dev/null
+| +0&#ffffff0@36||+1&&> +0&&@36
+|~+0#4040ff13&| @35||+1#0000000&|~+0#4040ff13&| @35
+|~| @35||+1#0000000&|~+0#4040ff13&| @35
+|~| @34|l+0#0000001#ffd7ff255|i|n|e|1| +0#4040ff13#ffffff0@33
+|[+1#0000000&|N|o| |N|a|m|e|]| @9|0|,|0|-|1| @9|A|l|l+0#0000001#ffd7ff255|i|n|e|2| +3#0000000#ffffff0|N|a|m|e|]| @9|0|,|0|-|1| @9|A|l@1
+| +0&&@35|l+0#0000001#ffd7ff255|i|n|e|3| +0#0000000#ffffff0@33
+|~+0#4040ff13&| @34|l+0#0000001#ffd7ff255|i|n|e|4| +0#4040ff13#ffffff0@33
+|~| @73
+|[+1#0000000&|N|o| |N|a|m|e|]| @47|0|,|0|-|1| @9|A|l@1
+|A+0&&|l|r|e|a|d|y| |o|n|l|y| |o|n|e| |w|i|n|d|o|w| @51
call assert_equal(2, pos.width)
call assert_equal(3, pos.height)
endfunc
+
+func Test_popup_never_behind()
+ if !CanRunVimInTerminal()
+ return
+ endif
+ " +-----------------------------+
+ " | | |
+ " | | |
+ " | | |
+ " | line1 |
+ " |------------line2------------|
+ " | line3 |
+ " | line4 |
+ " | |
+ " | |
+ " +-----------------------------+
+ let lines =<< trim END
+ only
+ split
+ vsplit
+ let info_window1 = getwininfo()[0]
+ let line = info_window1['height']
+ let col = info_window1['width']
+ call popup_create(['line1', 'line2', 'line3', 'line4'], {
+ \ 'line' : line,
+ \ 'col' : col,
+ \ })
+ END
+ call writefile(lines, 'XtestPopupBehind')
+ let buf = RunVimInTerminal('-S XtestPopupBehind', {'rows': 10})
+ call term_sendkeys(buf, "\<C-W>w")
+ call VerifyScreenDump(buf, 'Test_popupwin_behind', {})
+
+ " clean up
+ call StopVimInTerminal(buf)
+ call delete('XtestPopupBehind')
+endfunc
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 1448,
/**/
1447,
/**/