X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FEnchantChecker.cpp;h=cbccc34aae4ec911914034469fb9700decf9d74a;hb=af92f60df99994db9f88663a62fa276022b3b2b2;hp=e67f525c3ee643a574371e431b4519b6334aca97;hpb=5c59e8c7cb3a804d403061e76a34c0378320b9b0;p=lyx.git diff --git a/src/EnchantChecker.cpp b/src/EnchantChecker.cpp index e67f525c3e..cbccc34aae 100644 --- a/src/EnchantChecker.cpp +++ b/src/EnchantChecker.cpp @@ -34,7 +34,7 @@ struct Speller { enchant::Dict * speller; }; -typedef std::map Spellers; +typedef map Spellers; } // anon namespace @@ -112,31 +112,51 @@ SpellChecker::Result EnchantChecker::check(WordLangTuple const & word) { enchant::Dict * m = d->speller(word.lang()->code()); - if (!m) - return OK; + if (!m || word.word().empty()) + return WORD_OK; - std::string utf8word(to_utf8(word.word())); + string utf8word = to_utf8(word.word()); if (m->check(utf8word)) - return OK; + return WORD_OK; return UNKNOWN_WORD; } +void EnchantChecker::advanceChangeNumber() +{ + nextChangeNumber(); +} + + void EnchantChecker::insert(WordLangTuple const & word) { Spellers::iterator it = d->spellers_.find(word.lang()->code()); - if (it != d->spellers_.end()) + if (it != d->spellers_.end()) { it->second.speller->add(to_utf8(word.word())); + advanceChangeNumber(); + } +} + + +void EnchantChecker::remove(WordLangTuple const & word) +{ + Spellers::iterator it = d->spellers_.find(word.lang()->code()); + if (it != d->spellers_.end()) { + it->second.speller->remove(to_utf8(word.word())); + advanceChangeNumber(); + } } void EnchantChecker::accept(WordLangTuple const & word) { Spellers::iterator it = d->spellers_.find(word.lang()->code()); - if (it != d->spellers_.end()) + if (it != d->spellers_.end()) { it->second.speller->add_to_session(to_utf8(word.word())); + advanceChangeNumber(); + } }