X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FEnchantChecker.cpp;h=5ef399a24ad14ea8769d387223fd36a2a5e69793;hb=19b840ae23a888300f9a5c03971351b546cce93d;hp=77c9e309ed1c79fbb60ec94f5e266e5741ddf971;hpb=aafd52f44167d5510be1ddcb974daa9dae486933;p=lyx.git diff --git a/src/EnchantChecker.cpp b/src/EnchantChecker.cpp index 77c9e309ed..5ef399a24a 100644 --- a/src/EnchantChecker.cpp +++ b/src/EnchantChecker.cpp @@ -35,8 +35,8 @@ struct Speller { }; typedef map Spellers; - -} // anon namespace + +} // namespace struct EnchantChecker::Private { @@ -69,21 +69,21 @@ EnchantChecker::Private::~Private() enchant::Dict * EnchantChecker::Private::addSpeller(string const & lang) { enchant::Broker * instance = enchant::Broker::instance(); + Speller m; - if (!instance->dict_exists(lang)) + try { + LYXERR(Debug::FILES, "request enchant speller for language " << lang); + m.speller = instance->request_dict(lang); + } + catch (enchant::Exception & e) { // FIXME error handling? - return 0; - - enchant::Dict * dict = instance->request_dict(lang); - - if (dict) { - Speller m; - m.speller = dict; - spellers_[lang] = m; - return m.speller; + const char * what = e.what(); + LYXERR(Debug::FILES, "cannot add enchant speller: " << + ((what && *what) ? what : "unspecified enchant exception in request_dict()")); + m.speller = 0; } - // FIXME error handling? - return 0; + spellers_[lang] = m; + return m.speller; } @@ -92,7 +92,7 @@ enchant::Dict * EnchantChecker::Private::speller(string const & lang) Spellers::iterator it = spellers_.find(lang); if (it != spellers_.end()) return it->second.speller; - + return addSpeller(lang); } @@ -135,19 +135,19 @@ void EnchantChecker::advanceChangeNumber() void EnchantChecker::insert(WordLangTuple const & word) { - Spellers::iterator it = d->spellers_.find(word.lang()->code()); - if (it != d->spellers_.end()) { - it->second.speller->add(to_utf8(word.word())); + enchant::Dict * m = d->speller(word.lang()->code()); + if (m) { + m->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())); + enchant::Dict * m = d->speller(word.lang()->code()); + if (m) { + m->remove(to_utf8(word.word())); advanceChangeNumber(); } } @@ -155,9 +155,9 @@ void EnchantChecker::remove(WordLangTuple const & word) void EnchantChecker::accept(WordLangTuple const & word) { - Spellers::iterator it = d->spellers_.find(word.lang()->code()); - if (it != d->spellers_.end()) { - it->second.speller->add_to_session(to_utf8(word.word())); + enchant::Dict * m = d->speller(word.lang()->code()); + if (m) { + m->add_to_session(to_utf8(word.word())); advanceChangeNumber(); } } @@ -176,7 +176,7 @@ void EnchantChecker::suggest(WordLangTuple const & wl, vector suggs = m->suggest(utf8word); vector::const_iterator it = suggs.begin(); - + for (; it != suggs.end(); ++it) suggestions.push_back(from_utf8(*it)); } @@ -195,7 +195,7 @@ int EnchantChecker::numDictionaries() const { return d->spellers_.size(); } - + docstring const EnchantChecker::error() {