From b68490ef11734c404f8a18f1babd8004aca2de06 Mon Sep 17 00:00:00 2001 From: Maxime Coste Date: Wed, 18 Dec 2019 11:36:17 +1100 Subject: Cleanup replaced range selection logic Do not access Buffer::m_changes to find the inserted range, return it directly from Buffer::insert and Buffer::replace. This fixes a wrong behaviour where replacing at eof would lose the selected end of line (as the implementation does not actually replace that end of line) --- src/selection.cc | 40 +++++++++++++--------------------------- 1 file changed, 13 insertions(+), 27 deletions(-) (limited to 'src/selection.cc') diff --git a/src/selection.cc b/src/selection.cc index 0a0983a5..781f7c4f 100644 --- a/src/selection.cc +++ b/src/selection.cc @@ -407,38 +407,24 @@ void SelectionList::insert(ConstArrayView strings, InsertMode mode, sel.min() : changes_tracker.get_new_coord(insert_pos[index]); if (mode == InsertMode::Replace) - replace(*m_buffer, sel, str); + { + auto range = replace(*m_buffer, sel, str); + // we want min and max from *before* we do any change + auto& min = sel.min(); + auto& max = sel.max(); + min = range.begin; + max = m_buffer->char_prev(range.end); + } else - m_buffer->insert(pos, str); + { + auto range = m_buffer->insert(pos, str); + sel.anchor() = m_buffer->clamp(update_insert(sel.anchor(), range.begin, range.end)); + sel.cursor() = m_buffer->clamp(update_insert(sel.cursor(), range.begin, range.end)); + } - size_t old_timestamp = m_timestamp; changes_tracker.update(*m_buffer, m_timestamp); - if (out_insert_pos) out_insert_pos->push_back(pos); - - if (mode == InsertMode::Replace) - { - auto changes = m_buffer->changes_since(old_timestamp); - if (changes.size() == 1) // Nothing got inserted, either str was empty, or just \n at end of buffer - sel.anchor() = sel.cursor() = m_buffer->clamp(pos); - else if (changes.size() == 2) - { - // we want min and max from *before* we do any change - auto& min = sel.min(); - auto& max = sel.max(); - min = changes.back().begin; - max = m_buffer->char_prev(changes.back().end); - } - else - kak_assert(changes.empty()); - } - else if (not str.empty()) - { - auto& change = m_buffer->changes_since(0).back(); - sel.anchor() = m_buffer->clamp(update_insert(sel.anchor(), change.begin, change.end)); - sel.cursor() = m_buffer->clamp(update_insert(sel.cursor(), change.begin, change.end)); - } } // We might just have been deleting text if strings were empty, -- cgit v1.2.3