X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FEnchantChecker.cpp;h=5b42f33fde7e5f575a418d32e18c9ff476f63ffa;hb=a42f7ea7cd0e4d5d9594f363bce628451515d24b;hp=d2b849175ded38ddfcd3534400cc02161dff92a4;hpb=75bfed55079cab6b73fbea6ce4ae3f10d1af3b91;p=lyx.git diff --git a/src/EnchantChecker.cpp b/src/EnchantChecker.cpp index d2b849175d..5b42f33fde 100644 --- a/src/EnchantChecker.cpp +++ b/src/EnchantChecker.cpp @@ -30,13 +30,24 @@ namespace lyx { namespace { +enchant::Broker & broker() +{ +#ifdef HAVE_ENCHANT2 + static enchant::Broker thebroker; + return thebroker; +#else + return *enchant::Broker::instance(); +#endif +} + + struct Speller { enchant::Dict * speller; }; typedef map Spellers; -} // anon namespace +} // namespace struct EnchantChecker::Private { @@ -68,19 +79,18 @@ EnchantChecker::Private::~Private() enchant::Dict * EnchantChecker::Private::addSpeller(string const & lang) { - enchant::Broker * instance = enchant::Broker::instance(); Speller m; try { LYXERR(Debug::FILES, "request enchant speller for language " << lang); - m.speller = instance->request_dict(lang); + m.speller = broker().request_dict(lang); } catch (enchant::Exception & e) { // FIXME error handling? const char * what = e.what(); LYXERR(Debug::FILES, "cannot add enchant speller: " << ((what && *what) ? what : "unspecified enchant exception in request_dict()")); - m.speller = 0; + m.speller = nullptr; } spellers_[lang] = m; return m.speller; @@ -108,7 +118,8 @@ EnchantChecker::~EnchantChecker() } -SpellChecker::Result EnchantChecker::check(WordLangTuple const & word) +SpellChecker::Result EnchantChecker::check(WordLangTuple const & word, + std::vector const & docdict) { enchant::Dict * m = d->speller(word.lang()->code()); @@ -123,6 +134,14 @@ SpellChecker::Result EnchantChecker::check(WordLangTuple const & word) if (m->check(utf8word)) return WORD_OK; + vector::const_iterator it = docdict.begin(); + for (; it != docdict.end(); ++it) { + if (it->lang()->code() != word.lang()->code()) + continue; + if (it->word() == word.word()) + return DOCUMENT_LEARNED_WORD; + } + return UNKNOWN_WORD; } @@ -186,8 +205,7 @@ bool EnchantChecker::hasDictionary(Language const * lang) const { if (!lang) return false; - enchant::Broker * instance = enchant::Broker::instance(); - return (instance->dict_exists(lang->code())); + return broker().dict_exists(lang->code()); }