From 70e2122ae6c8e606888e52888acc0b55a9ee0877 Mon Sep 17 00:00:00 2001 From: Maxime Coste Date: Wed, 6 Dec 2017 14:15:36 +0800 Subject: [PATCH] InsertCompleter: only accept words matching the target buffer word definition The words we store in the WordDB are dependent on the extra_word_chars options, which can be different for different buffers. When completing words in a buffer based on the WordDB from another buffer, some candidates might contains characters that are not considered word character for the target buffer, ignore those words. --- src/insert_completer.cc | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/src/insert_completer.cc b/src/insert_completer.cc index 4a4e9be0..95d2713d 100644 --- a/src/insert_completer.cc +++ b/src/insert_completer.cc @@ -134,19 +134,14 @@ InsertCompletion complete_word(const SelectionList& sels, const OptionManager& o }; Vector matches; - auto add_matches = [&](const Buffer& buf) { - auto& word_db = get_word_db(buf); - auto bufmatches = word_db.find_matching(prefix); - for (auto& m : bufmatches) - matches.push_back({ m, &buf }); - }; - - add_matches(buffer); + auto& word_db = get_word_db(buffer); + for (auto& m : word_db.find_matching(prefix)) + matches.push_back({ m, &buffer }); // Remove words that are being edited for (auto& word_count : sel_word_counts) { - if (get_word_db(buffer).get_word_occurences(word_count.key) <= word_count.value) + if (word_db.get_word_occurences(word_count.key) <= word_count.value) unordered_erase(matches, word_count.key); } @@ -156,7 +151,11 @@ InsertCompletion complete_word(const SelectionList& sels, const OptionManager& o { if (buf.get() == &buffer or buf->flags() & Buffer::Flags::Debug) continue; - add_matches(*buf); + for (auto& m : get_word_db(*buf).find_matching(prefix) | + // filter out words that are not considered words for the current buffer + filter([&](auto& rm) { return std::all_of(rm.candidate().begin(), rm.candidate().end(), + is_word_pred); })) + matches.push_back({ m, buf.get() }); } }