From 3c73b9ae97a8fdf56566c8e385245e661fc9b5cc Mon Sep 17 00:00:00 2001 From: Josh Holtrop Date: Sat, 24 Dec 2016 14:25:25 -0500 Subject: [PATCH] cursor positioning fix --- src/gui/BufferPane.cc | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/gui/BufferPane.cc b/src/gui/BufferPane.cc index e446869..29fa4d8 100644 --- a/src/gui/BufferPane.cc +++ b/src/gui/BufferPane.cc @@ -137,7 +137,10 @@ int BufferPane::update_cursor_row(std::list> & int rows_below = screen_rows_below_line(*m_iterator) + std::min(0, rows_in_cursor_line - cursor_row_offset - 1); int min_rows_to_leave_above = std::min(rows_above, so); int min_rows_to_leave_below = std::min(rows_below, so); - m_cursor_screen_row = std::max(min_rows_to_leave_above, std::min(m_rows - min_rows_to_leave_below - 1, m_cursor_screen_row)); + m_cursor_screen_row = std::min(m_rows - min_rows_to_leave_below - 1, m_cursor_screen_row); + m_cursor_screen_row = std::max(min_rows_to_leave_above, m_cursor_screen_row); + m_cursor_screen_row = std::max(m_rows - rows_below - 1, m_cursor_screen_row); + m_cursor_screen_row = std::min(rows_above, m_cursor_screen_row); return cursor_row_offset; }