X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FEnchantChecker.cpp;h=61127108a44765e72a9f22ebe9ddb818844467b4;hb=b64d17e9dcaeb84a94095622c93a051e4d93eab7;hp=793bc16fb95da8499743b6c8bc4fc26645ff3ee7;hpb=e4f2484cb5899da6d98e0be6db465ca011989e04;p=lyx.git diff --git a/src/EnchantChecker.cpp b/src/EnchantChecker.cpp index 793bc16fb9..61127108a4 100644 --- a/src/EnchantChecker.cpp +++ b/src/EnchantChecker.cpp @@ -113,6 +113,9 @@ SpellChecker::Result EnchantChecker::check(WordLangTuple const & word) enchant::Dict * m = d->speller(word.lang()->code()); if (!m) + return NO_DICTIONARY; + + if (word.word().empty()) return WORD_OK; string utf8word = to_utf8(word.word()); @@ -124,19 +127,39 @@ SpellChecker::Result EnchantChecker::check(WordLangTuple const & 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(); + } } @@ -168,6 +191,12 @@ bool EnchantChecker::hasDictionary(Language const * lang) const } +int EnchantChecker::numDictionaries() const +{ + return d->spellers_.size(); +} + + docstring const EnchantChecker::error() { return docstring();