From 7dc634444db3fc5f2707bd15cfa5091be8f75938 Mon Sep 17 00:00:00 2001 From: Maxime Coste Date: Wed, 7 Nov 2012 20:36:45 +0100 Subject: [PATCH] Fix InputMode::Prompt blocking behaviour when inserting register --- src/input_handler.cc | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/input_handler.cc b/src/input_handler.cc index 44327df9..19d2ce17 100644 --- a/src/input_handler.cc +++ b/src/input_handler.cc @@ -243,7 +243,14 @@ public: { std::vector& history = ms_history[m_prompt]; const String& line = m_line_editor.line(); - if (key == Key{Key::Modifiers::Control, 'm'}) // enter + + if (m_insert_reg) + { + String reg = RegisterManager::instance()[key.key].values(context)[0]; + m_line_editor.insert(reg); + m_insert_reg = false; + } + else if (key == Key{Key::Modifiers::Control, 'm'}) // enter { std::vector::iterator it; while ((it = find(history, line)) != history.end()) @@ -267,9 +274,7 @@ public: } else if (key == Key{Key::Modifiers::Control, 'r'}) { - Key k = context.ui().get_key(); - String reg = RegisterManager::instance()[k.key].values(context)[0]; - m_line_editor.insert(reg); + m_insert_reg = true; } else if (key == Key::Up or key == Key{Key::Modifiers::Control, 'p'}) @@ -362,6 +367,7 @@ private: int m_current_completion = -1; String m_prefix; LineEditor m_line_editor; + bool m_insert_reg = false; static std::unordered_map> ms_history; std::vector::iterator m_history_it;