mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 05:53:59 +00:00
Prefer using clr_eos to clear "remaining lines"
This is both more efficient than multiple clr_eol sequences, and also works better with shell-integration.
This commit is contained in:
parent
09a97528a9
commit
d502ad2c25
1 changed files with 3 additions and 1 deletions
|
@ -642,6 +642,8 @@ static void s_update(screen_t *scr, const wcstring &left_prompt, const wcstring
|
|||
// Determine how many lines have stuff on them; we need to clear lines with stuff that we don't
|
||||
// want.
|
||||
const size_t lines_with_stuff = std::max(actual_lines_before_reset, scr->actual.line_count());
|
||||
if (scr->desired.line_count() < lines_with_stuff)
|
||||
need_clear_screen = true;
|
||||
|
||||
if (left_prompt != scr->actual_left_prompt) {
|
||||
s_move(scr, 0, 0);
|
||||
|
@ -792,7 +794,7 @@ static void s_update(screen_t *scr, const wcstring &left_prompt, const wcstring
|
|||
}
|
||||
|
||||
// Clear remaining lines (if any) if we haven't cleared the screen.
|
||||
if (!has_cleared_screen && scr->desired.line_count() < lines_with_stuff && clr_eol) {
|
||||
if (!has_cleared_screen && need_clear_screen && clr_eol) {
|
||||
s_set_color(scr, vars, highlight_spec_t{});
|
||||
for (size_t i = scr->desired.line_count(); i < lines_with_stuff; i++) {
|
||||
s_move(scr, 0, (int)i);
|
||||
|
|
Loading…
Reference in a new issue