From 41979c91f48a06b17a905ca2a84576126761308c Mon Sep 17 00:00:00 2001 From: Maxime Coste Date: Thu, 27 Dec 2012 18:54:52 +0100 Subject: [PATCH] Editor: when replacing, select inserted text --- src/editor.cc | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/editor.cc b/src/editor.cc index 9ed99a93c..c7727a28c 100644 --- a/src/editor.cc +++ b/src/editor.cc @@ -73,6 +73,7 @@ static BufferIterator prepare_insert(Buffer& buffer, const Selection& sel, void Editor::insert(const String& string, InsertMode mode) { scoped_edition edition(*this); + if (mode == InsertMode::Replace) { // do not call Editor::erase as we do not want to avoid end of lines @@ -84,6 +85,11 @@ void Editor::insert(const String& string, InsertMode mode) { BufferIterator pos = prepare_insert(*m_buffer, sel, mode); m_buffer->insert(pos, string); + if (mode == InsertMode::Replace) + { + sel.first() = pos; + sel.last() = pos + (string.empty() ? 0 : string.length() - 1 ); + } sel.avoid_eol(); } } @@ -104,8 +110,13 @@ void Editor::insert(const memoryview& strings, InsertMode mode) { auto& sel = m_selections[i]; BufferIterator pos = prepare_insert(*m_buffer, sel, mode); - size_t index = std::min(i, strings.size()-1); - m_buffer->insert(pos, strings[index]); + const String& str = strings[std::min(i, strings.size()-1)]; + m_buffer->insert(pos, str); + if (mode == InsertMode::Replace) + { + sel.first() = pos; + sel.last() = pos + (str.empty() ? 0 : str.length() - 1); + } sel.avoid_eol(); } }