BufferView: user must call update() after all changes and before vert_iter()

This commit is contained in:
Josh Holtrop 2017-09-03 17:34:41 -04:00
parent 5b35a35b24
commit 14e285041e
3 changed files with 13 additions and 12 deletions

View File

@ -31,17 +31,6 @@ void BufferView::set_scroll_offset(int scroll_offset)
BufferView::Iterator BufferView::vert_iter() BufferView::Iterator BufferView::vert_iter()
{ {
if (m_iterator->valid())
{
/* TODO: user calls update() before vert_iter(). */
update();
}
else
{
m_cursor_screen_row = 0;
m_cursor_screen_column = 0;
m_cursor_virtual_column = 0;
}
return Iterator(*this); return Iterator(*this);
} }
@ -94,6 +83,14 @@ void BufferView::update()
row_offset += ld.n_rows; row_offset += ld.n_rows;
line_iterator->go_next_line(); line_iterator->go_next_line();
} }
/* Reset some fields if buffer becomes empty. */
if (!m_iterator->valid())
{
m_cursor_screen_row = 0;
m_cursor_screen_column = 0;
m_cursor_virtual_column = 0;
}
} }
int BufferView::calculate_rows_in_line(std::shared_ptr<Buffer::Iterator> start_of_line) int BufferView::calculate_rows_in_line(std::shared_ptr<Buffer::Iterator> start_of_line)

View File

@ -56,6 +56,7 @@ public:
CharacterWidthDeterminer & character_width_determiner); CharacterWidthDeterminer & character_width_determiner);
void resize(int width, int height); void resize(int width, int height);
void set_scroll_offset(int scroll_offset); void set_scroll_offset(int scroll_offset);
void update();
Iterator vert_iter(); Iterator vert_iter();
BufferLineWalker horiz_iter(std::shared_ptr<Buffer::Iterator> start_of_line) BufferLineWalker horiz_iter(std::shared_ptr<Buffer::Iterator> start_of_line)
{ {
@ -88,7 +89,6 @@ protected:
{ {
return std::min(m_scroll_offset, (m_height - 1) / 2); return std::min(m_scroll_offset, (m_height - 1) / 2);
} }
void update();
int calculate_rows_in_line(std::shared_ptr<Buffer::Iterator> start_of_line); int calculate_rows_in_line(std::shared_ptr<Buffer::Iterator> start_of_line);
int calculate_rows_in_cursor_line(std::shared_ptr<Buffer::Iterator> start_of_line); int calculate_rows_in_cursor_line(std::shared_ptr<Buffer::Iterator> start_of_line);
int screen_rows_below_line(std::shared_ptr<Buffer::Iterator> line); int screen_rows_below_line(std::shared_ptr<Buffer::Iterator> line);

View File

@ -63,6 +63,7 @@ TEST(BufferViewTest, does_not_iterate_for_empty_buffer)
BufferView bv(b, iterator, Cwd); BufferView bv(b, iterator, Cwd);
bv.resize(40, 8); bv.resize(40, 8);
int iter_count = 0; int iter_count = 0;
bv.update();
for (auto it = bv.vert_iter(); it.is_valid(); it++) for (auto it = bv.vert_iter(); it.is_valid(); it++)
{ {
iter_count++; iter_count++;
@ -80,6 +81,7 @@ TEST(BufferViewTest, iterates_through_screen_lines_with_no_wrapping)
BufferView bv(b, iterator, Cwd); BufferView bv(b, iterator, Cwd);
bv.resize(40, 8); bv.resize(40, 8);
int iter_count = 0; int iter_count = 0;
bv.update();
for (auto it = bv.vert_iter(); it.is_valid(); it++) for (auto it = bv.vert_iter(); it.is_valid(); it++)
{ {
EXPECT_EQ(iter_count, LineNumber(it.iterator())); EXPECT_EQ(iter_count, LineNumber(it.iterator()));
@ -99,6 +101,7 @@ TEST(BufferViewTest, iterates_through_screen_lines_with_wrapping)
bv.resize(3, 10); bv.resize(3, 10);
int iter_count = 0; int iter_count = 0;
int expected_row_offsets[] = {0, 1, 2, 4, 5, 6, 7}; int expected_row_offsets[] = {0, 1, 2, 4, 5, 6, 7};
bv.update();
for (auto it = bv.vert_iter(); it.is_valid(); it++) for (auto it = bv.vert_iter(); it.is_valid(); it++)
{ {
EXPECT_EQ(iter_count, LineNumber(it.iterator())); EXPECT_EQ(iter_count, LineNumber(it.iterator()));
@ -122,6 +125,7 @@ TEST(BufferViewTest, fills_view_with_last_lines_of_buffer_when_cursor_warps_to_l
bv.resize(40, 3); bv.resize(40, 3);
int iter_count = 0; int iter_count = 0;
int expected_row_offsets[] = {0, 1, 2}; int expected_row_offsets[] = {0, 1, 2};
bv.update();
for (auto it = bv.vert_iter(); it.is_valid(); it++) for (auto it = bv.vert_iter(); it.is_valid(); it++)
{ {
EXPECT_EQ(10 + iter_count, LineNumber(it.iterator())); EXPECT_EQ(10 + iter_count, LineNumber(it.iterator()));