From 0506de84436ef22e9e31de6709fd7429c3af7271 Mon Sep 17 00:00:00 2001 From: Maxime Coste Date: Fri, 20 Mar 2020 20:31:09 +1100 Subject: [PATCH] Fix compute_pos behaviour not to overflow by one line Thanks to eraserhd for debugging this and proposing an initial fix. Fixes #3414 Close #3418 --- src/terminal_ui.cc | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/terminal_ui.cc b/src/terminal_ui.cc index de6d1576..a3053536 100644 --- a/src/terminal_ui.cc +++ b/src/terminal_ui.cc @@ -124,6 +124,7 @@ struct TerminalUI::Window::Line void TerminalUI::Window::blit(Window& target) { + kak_assert(pos.line + lines.size() <= target.lines.size()); auto target_line = target.lines.begin() + (size_t)pos.line; for (auto& line : lines) { @@ -131,7 +132,7 @@ void TerminalUI::Window::blit(Window& target) target_line->resize(target.size.column); target_line->atoms.insert(target_line->erase_range(pos.column, size.column), line.atoms.begin(), line.atoms.end()); - ++target_line; + ++target_line; } } @@ -1030,10 +1031,10 @@ static DisplayCoord compute_pos(DisplayCoord anchor, DisplayCoord size, if (not prefer_above) { pos = anchor + DisplayCoord{1_line}; - if (pos.line + size.line > rect_end.line) + if (pos.line + size.line >= rect_end.line) pos.line = max(rect.pos.line, anchor.line - size.line); } - if (pos.column + size.column > rect_end.column) + if (pos.column + size.column >= rect_end.column) pos.column = max(rect.pos.column, rect_end.column - size.column); if (to_avoid.size != DisplayCoord{})