summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMaxime Coste <mawww@kakoune.org>2019-11-26 21:35:05 +1100
committerMaxime Coste <mawww@kakoune.org>2019-11-26 21:35:05 +1100
commita933cae7b9ea84b4e4f2cc69a9f7444db0abf78b (patch)
treea74a50bbc5b65188d81b7ff1ba4125fdb2e75191
parent9716c7c82d43af3c6ffe2a4ad534a19c7728b866 (diff)
parent2cdf86d6745d3dcd06fbd6687b68fb76894a16a5 (diff)
Merge remote-tracking branch 'lenormf/complete-expansion-reg'
-rw-r--r--src/command_manager.cc5
-rw-r--r--src/register_manager.cc30
-rw-r--r--src/register_manager.hh2
3 files changed, 25 insertions, 12 deletions
diff --git a/src/command_manager.cc b/src/command_manager.cc
index 7eca7cd6..3a3654f8 100644
--- a/src/command_manager.cc
+++ b/src/command_manager.cc
@@ -676,6 +676,11 @@ Completions CommandManager::complete(const Context& context,
switch (token.type)
{
+ case Token::Type::RegisterExpand:
+ return {start , cursor_pos,
+ RegisterManager::instance().complete_register_name(
+ token.content, cursor_pos_in_token) };
+
case Token::Type::OptionExpand:
return {start , cursor_pos,
GlobalScope::instance().option_registry().complete_option_name(
diff --git a/src/register_manager.cc b/src/register_manager.cc
index 3abbd61b..37c93628 100644
--- a/src/register_manager.cc
+++ b/src/register_manager.cc
@@ -7,23 +7,24 @@
namespace Kakoune
{
+static const HashMap<String, Codepoint> reg_names = {
+ { "slash", '/' },
+ { "dquote", '"' },
+ { "pipe", '|' },
+ { "caret", '^' },
+ { "arobase", '@' },
+ { "percent", '%' },
+ { "dot", '.' },
+ { "hash", '#' },
+ { "underscore", '_' },
+ { "colon", ':' }
+};
+
Register& RegisterManager::operator[](StringView reg) const
{
if (reg.length() == 1)
return (*this)[reg[0_byte]];
- static const HashMap<String, Codepoint> reg_names = {
- { "slash", '/' },
- { "dquote", '"' },
- { "pipe", '|' },
- { "caret", '^' },
- { "arobase", '@' },
- { "percent", '%' },
- { "dot", '.' },
- { "hash", '#' },
- { "underscore", '_' },
- { "colon", ':' }
- };
auto it = reg_names.find(reg);
if (it == reg_names.end())
throw runtime_error(format("no such register: '{}'", reg));
@@ -47,4 +48,9 @@ void RegisterManager::add_register(Codepoint c, std::unique_ptr<Register> reg)
reg_ptr = std::move(reg);
}
+CandidateList RegisterManager::complete_register_name(StringView prefix, ByteCount cursor_pos) const
+{
+ return complete(prefix, cursor_pos, reg_names | transform([](auto& i) { return i.key; }) | gather<Vector<String>>());
+}
+
}
diff --git a/src/register_manager.hh b/src/register_manager.hh
index 9d3ea3d9..f18bc989 100644
--- a/src/register_manager.hh
+++ b/src/register_manager.hh
@@ -2,6 +2,7 @@
#define register_manager_hh_INCLUDED
#include "array_view.hh"
+#include "completion.hh"
#include "exception.hh"
#include "utils.hh"
#include "hash_map.hh"
@@ -146,6 +147,7 @@ public:
Register& operator[](StringView reg) const;
Register& operator[](Codepoint c) const;
void add_register(Codepoint c, std::unique_ptr<Register> reg);
+ CandidateList complete_register_name(StringView prefix, ByteCount cursor_pos) const;
protected:
HashMap<Codepoint, std::unique_ptr<Register>, MemoryDomain::Registers> m_registers;