From 94c9e4e99b3a72b4a37a87ccce2b87cadaeb7ce0 Mon Sep 17 00:00:00 2001 From: Maxime Coste Date: Mon, 16 Dec 2013 13:39:02 +0000 Subject: [PATCH] Fix select_coord that could select invalid positions --- src/normal.cc | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/src/normal.cc b/src/normal.cc index 052d1fd5..16690f39 100644 --- a/src/normal.cc +++ b/src/normal.cc @@ -168,8 +168,9 @@ template constexpr Select select(T func) { return Select(func); } template -void select_coord(BufferCoord coord, SelectionList& selections) +void select_coord(const Buffer& buffer, BufferCoord coord, SelectionList& selections) { + coord = buffer.clamp(coord); if (mode == SelectMode::Replace) selections = SelectionList { coord }; else if (mode == SelectMode::Extend) @@ -221,7 +222,7 @@ void goto_commands(Context& context, int line) if (line != 0) { context.push_jump(); - select_coord(LineCount{line - 1}, context.selections()); + select_coord(context.buffer(), LineCount{line - 1}, context.selections()); if (context.has_window()) context.window().center_selection(); } @@ -230,13 +231,13 @@ void goto_commands(Context& context, int line) on_next_key_with_autoinfo(context, [](Key key, Context& context) { if (key.modifiers != Key::Modifiers::None) return; - + auto& buffer = context.buffer(); switch (tolower(key.key)) { case 'g': case 'k': context.push_jump(); - select_coord(BufferCoord{0,0}, context.selections()); + select_coord(buffer, BufferCoord{0,0}, context.selections()); break; case 'l': select(select_to_eol)(context, 0); @@ -247,18 +248,18 @@ void goto_commands(Context& context, int line) case 'j': { context.push_jump(); - select_coord({context.buffer().line_count() - 1, 0}, context.selections()); + select_coord(buffer, buffer.line_count() - 1, context.selections()); break; } case 'e': context.push_jump(); - select_coord(context.buffer().back_coord(), context.selections()); + select_coord(buffer, buffer.back_coord(), context.selections()); break; case 't': if (context.has_window()) { auto line = context.window().position().line; - select_coord(line, context.selections()); + select_coord(buffer, line, context.selections()); } break; case 'b': @@ -266,7 +267,7 @@ void goto_commands(Context& context, int line) { auto& window = context.window(); auto line = window.position().line + window.dimensions().line - 1; - select_coord(line, context.selections()); + select_coord(buffer, line, context.selections()); } break; case 'c': @@ -274,14 +275,14 @@ void goto_commands(Context& context, int line) { auto& window = context.window(); auto line = window.position().line + window.dimensions().line / 2; - select_coord(line, context.selections()); + select_coord(buffer, line, context.selections()); } break; case 'a': { auto& buffer_manager = BufferManager::instance(); auto it = buffer_manager.begin(); - if (it->get() == &context.buffer() and ++it == buffer_manager.end()) + if (it->get() == &buffer and ++it == buffer_manager.end()) break; context.push_jump(); auto& client_manager = ClientManager::instance(); @@ -291,7 +292,6 @@ void goto_commands(Context& context, int line) case 'f': { const Range& sel = context.selections().main(); - const Buffer& buffer = context.buffer(); String filename = content(buffer, sel); static constexpr char forbidden[] = { '\'', '\\', '\0' }; for (auto c : forbidden) @@ -893,7 +893,7 @@ void scroll(Context& context, int) auto cursor_pos = utf8::advance(buffer.iterator_at(position.line), buffer.iterator_at(position.line+1), position.column); - select_coord(cursor_pos.coord(), window.selections()); + select_coord(buffer, cursor_pos.coord(), window.selections()); window.set_position(position); }