Skip to content

Commit

Permalink
Code style cleanups around insert completer
Browse files Browse the repository at this point in the history
  • Loading branch information
mawww committed Jun 4, 2022
1 parent a16de52 commit 6ffec75
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 32 deletions.
11 changes: 2 additions & 9 deletions src/input_handler.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1345,18 +1345,14 @@ class Insert : public InputMode
selections.sort_and_merge_overlapping();
}
else if (auto cp = key.codepoint())
{
m_completer.try_accept();
insert(*cp);
}
else if (key == ctrl('r'))
{
on_next_key_with_autoinfo(context(), "register", KeymapMode::None,
[this](Key key, Context&) {
auto cp = key.codepoint();
if (not cp or key == Key::Escape)
return;
m_completer.try_accept();
insert(RegisterManager::instance()[*cp].get(context()));
}, "enter register name", register_doc.str());
update_completions = false;
Expand Down Expand Up @@ -1419,7 +1415,6 @@ class Insert : public InputMode
[this, transient](Key key, Context&) {
if (auto cp = get_raw_codepoint(key))
{
m_completer.try_accept();
insert(*cp);
context().hooks().run_hook(Hook::InsertKey, key_to_str(key), context());
if (enabled() and not transient)
Expand Down Expand Up @@ -1473,6 +1468,7 @@ class Insert : public InputMode

void insert(ConstArrayView<String> strings)
{
m_completer.try_accept();
context().selections().for_each([strings, &buffer=context().buffer()]
(size_t index, Selection& sel) {
Kakoune::insert(buffer, sel, sel.cursor(), strings[std::min(strings.size()-1, index)]);
Expand All @@ -1482,10 +1478,7 @@ class Insert : public InputMode
void insert(Codepoint key)
{
String str{key};
context().selections().for_each([&buffer=context().buffer(), &str]
(size_t index, Selection& sel) {
Kakoune::insert(buffer, sel, sel.cursor(), str);
});
insert(str);
context().hooks().run_hook(Hook::InsertChar, str, context());
}

Expand Down
48 changes: 25 additions & 23 deletions src/insert_completer.cc
Original file line number Diff line number Diff line change
Expand Up @@ -474,38 +474,40 @@ void InsertCompleter::update(bool allow_implicit)
auto& get_first(BufferRange& range) { return range.begin; }
auto& get_last(BufferRange& range) { return range.end; }

bool InsertCompleter::has_candidate_selected() const
{
return m_current_candidate >= 0 and m_current_candidate < m_completions.candidates.size() - 1;
}

void InsertCompleter::try_accept()
{
if (m_completions.is_valid() and m_context.has_client()
and m_current_candidate >= 0 and m_current_candidate < m_completions.candidates.size() - 1)
{
if (m_completions.is_valid() and m_context.has_client() and has_candidate_selected())
reset();
}
}

void InsertCompleter::reset()
{
if (m_explicit_completer or m_completions.is_valid())
if (not m_explicit_completer and not m_completions.is_valid())
return;

String hook_param;
if (m_context.has_client() and has_candidate_selected())
{
String hook_param;
if (m_context.has_client() and m_current_candidate >= 0 and m_current_candidate < m_completions.candidates.size() - 1)
{
auto& buffer = m_context.buffer();
update_ranges(buffer, m_completions.timestamp, m_inserted_ranges);
hook_param = join(m_inserted_ranges | filter([](auto&& r) { return not r.empty(); }) | transform([&](auto&& r) {
return selection_to_string(ColumnType::Byte, buffer, {r.begin, buffer.char_prev(r.end)});
}), ' ');
}
auto& buffer = m_context.buffer();
update_ranges(buffer, m_completions.timestamp, m_inserted_ranges);
hook_param = join(m_inserted_ranges | filter([](auto&& r) { return not r.empty(); }) | transform([&](auto&& r) {
return selection_to_string(ColumnType::Byte, buffer, {r.begin, buffer.char_prev(r.end)});
}), ' ');
}

m_explicit_completer = nullptr;
m_completions = InsertCompletion{};
m_inserted_ranges.clear();
if (m_context.has_client())
{
m_context.client().menu_hide();
m_context.client().info_hide();
m_context.hooks().run_hook(Hook::InsertCompletionHide, hook_param, m_context);
}
m_explicit_completer = nullptr;
m_completions = InsertCompletion{};
m_inserted_ranges.clear();
if (m_context.has_client())
{
m_context.client().menu_hide();
m_context.client().info_hide();
m_context.hooks().run_hook(Hook::InsertCompletionHide, hook_param, m_context);
}
}

Expand Down
1 change: 1 addition & 0 deletions src/insert_completer.hh
Original file line number Diff line number Diff line change
Expand Up @@ -101,6 +101,7 @@ private:
void on_option_changed(const Option& opt) override;

void menu_show();
bool has_candidate_selected() const;

Context& m_context;
OptionManager& m_options;
Expand Down

0 comments on commit 6ffec75

Please sign in to comment.