mirror of
https://git.lyx.org/repos/lyx.git
synced 2024-11-09 18:31:04 +00:00
* Singleton-ify the used SpellChecker object.
* Simplify Aspell construction as the object is capable of supporting multiple languages at the same time. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@28974 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
parent
29c40527e5
commit
34bddccb13
@ -25,10 +25,8 @@ using namespace std;
|
||||
|
||||
namespace lyx {
|
||||
|
||||
ASpell::ASpell(BufferParams const &, string const & lang)
|
||||
: els(0), spell_error_object(0)
|
||||
ASpell::ASpell(): els(0), spell_error_object(0)
|
||||
{
|
||||
addSpeller(lang);
|
||||
}
|
||||
|
||||
|
||||
|
@ -25,32 +25,27 @@ struct AspellConfig;
|
||||
|
||||
namespace lyx {
|
||||
|
||||
class BufferParams;
|
||||
|
||||
|
||||
class ASpell : public SpellChecker {
|
||||
class ASpell : public SpellChecker
|
||||
{
|
||||
public:
|
||||
/**
|
||||
* Initialise the spellchecker with the given buffer params and language.
|
||||
*/
|
||||
ASpell(BufferParams const & params, std::string const & lang);
|
||||
|
||||
virtual ~ASpell();
|
||||
ASpell();
|
||||
~ASpell();
|
||||
|
||||
/// check the given word and return the result
|
||||
virtual enum Result check(WordLangTuple const &);
|
||||
enum Result check(WordLangTuple const &);
|
||||
|
||||
/// insert the given word into the personal dictionary
|
||||
virtual void insert(WordLangTuple const &);
|
||||
void insert(WordLangTuple const &);
|
||||
|
||||
/// accept the given word temporarily
|
||||
virtual void accept(WordLangTuple const &);
|
||||
void accept(WordLangTuple const &);
|
||||
|
||||
/// return the next near miss after a SUGGESTED_WORDS result
|
||||
virtual docstring const nextMiss();
|
||||
docstring const nextMiss();
|
||||
|
||||
/// give an error message on messy exit
|
||||
virtual docstring const error();
|
||||
docstring const error();
|
||||
|
||||
private:
|
||||
/// add a speller of the given language
|
||||
|
23
src/LyX.cpp
23
src/LyX.cpp
@ -17,7 +17,7 @@
|
||||
|
||||
#include "LyX.h"
|
||||
|
||||
#include "LayoutFile.h"
|
||||
#include "ASpell_local.h"
|
||||
#include "Buffer.h"
|
||||
#include "BufferList.h"
|
||||
#include "CmdDef.h"
|
||||
@ -31,6 +31,7 @@
|
||||
#include "FuncStatus.h"
|
||||
#include "KeyMap.h"
|
||||
#include "Language.h"
|
||||
#include "LayoutFile.h"
|
||||
#include "Lexer.h"
|
||||
#include "LyXAction.h"
|
||||
#include "LyXFunc.h"
|
||||
@ -127,7 +128,19 @@ struct LyX::Impl
|
||||
// The language used will be derived from the environment
|
||||
// variables.
|
||||
messages_["GUI"] = Messages();
|
||||
|
||||
#if defined(USE_ASPELL)
|
||||
spell_checker_ = new ASpell();
|
||||
#else
|
||||
spell_checker_ = 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
~Impl()
|
||||
{
|
||||
delete spell_checker_;
|
||||
}
|
||||
|
||||
/// our function handler
|
||||
LyXFunc lyxfunc_;
|
||||
///
|
||||
@ -169,6 +182,8 @@ struct LyX::Impl
|
||||
|
||||
///
|
||||
graphics::Previews preview_;
|
||||
///
|
||||
SpellChecker * spell_checker_;
|
||||
};
|
||||
|
||||
///
|
||||
@ -1245,4 +1260,10 @@ CmdDef & theTopLevelCmdDef()
|
||||
return singleton_->pimpl_->toplevel_cmddef_;
|
||||
}
|
||||
|
||||
|
||||
SpellChecker * theSpellChecker()
|
||||
{
|
||||
return singleton_->pimpl_->spell_checker_;
|
||||
}
|
||||
|
||||
} // namespace lyx
|
||||
|
@ -32,6 +32,7 @@ class Movers;
|
||||
class Server;
|
||||
class ServerSocket;
|
||||
class Session;
|
||||
class SpellChecker;
|
||||
|
||||
extern bool use_gui;
|
||||
|
||||
@ -137,6 +138,7 @@ private:
|
||||
friend graphics::Previews & thePreviews();
|
||||
friend Session & theSession();
|
||||
friend CmdDef & theTopLevelCmdDef();
|
||||
friend SpellChecker * theSpellChecker();
|
||||
friend void setRcGuiLanguage();
|
||||
friend void emergencyCleanup();
|
||||
friend void execBatchCommands();
|
||||
@ -158,3 +160,4 @@ void execBatchCommands();
|
||||
} // namespace lyx
|
||||
|
||||
#endif // LYX_H
|
||||
|
||||
|
@ -21,6 +21,7 @@
|
||||
#include "Cursor.h"
|
||||
#include "CutAndPaste.h"
|
||||
#include "Language.h"
|
||||
#include "LyX.h"
|
||||
#include "LyXRC.h"
|
||||
#include "Paragraph.h"
|
||||
|
||||
@ -75,7 +76,6 @@ GuiSpellchecker::GuiSpellchecker(GuiView & lv)
|
||||
|
||||
GuiSpellchecker::~GuiSpellchecker()
|
||||
{
|
||||
delete speller_;
|
||||
}
|
||||
|
||||
|
||||
@ -193,24 +193,11 @@ void GuiSpellchecker::partialUpdate(int state)
|
||||
}
|
||||
|
||||
|
||||
static SpellChecker * createSpeller(BufferParams const & bp)
|
||||
{
|
||||
string lang = lyxrc.spellchecker_use_alt_lang
|
||||
? lyxrc.spellchecker_alt_lang
|
||||
: bp.language->code();
|
||||
|
||||
#if defined(USE_ASPELL)
|
||||
return new ASpell(bp, lang);
|
||||
#endif
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
bool GuiSpellchecker::initialiseParams(string const &)
|
||||
{
|
||||
LYXERR(Debug::GUI, "Spellchecker::initialiseParams");
|
||||
|
||||
speller_ = createSpeller(buffer().params());
|
||||
speller_ = theSpellChecker();
|
||||
if (!speller_)
|
||||
return false;
|
||||
|
||||
@ -225,7 +212,6 @@ bool GuiSpellchecker::initialiseParams(string const &)
|
||||
Alert::error(_("Spellchecker error"),
|
||||
_("The spellchecker could not be started\n")
|
||||
+ speller_->error());
|
||||
delete speller_;
|
||||
speller_ = 0;
|
||||
}
|
||||
|
||||
@ -236,7 +222,6 @@ bool GuiSpellchecker::initialiseParams(string const &)
|
||||
void GuiSpellchecker::clearParams()
|
||||
{
|
||||
LYXERR(Debug::GUI, "Spellchecker::clearParams");
|
||||
delete speller_;
|
||||
speller_ = 0;
|
||||
}
|
||||
|
||||
@ -255,7 +240,9 @@ static WordLangTuple nextWord(Cursor & cur, ptrdiff_t & progress)
|
||||
cur.resetAnchor();
|
||||
cur.setCursor(to);
|
||||
cur.setSelection();
|
||||
string lang_code = from.paragraph().getFontSettings(buf.params(), cur.pos()).language()->code();
|
||||
string lang_code = lyxrc.spellchecker_use_alt_lang
|
||||
? lyxrc.spellchecker_alt_lang
|
||||
: from.paragraph().getFontSettings(buf.params(), cur.pos()).language()->code();
|
||||
++progress;
|
||||
return WordLangTuple(word, lang_code);
|
||||
}
|
||||
@ -304,15 +291,15 @@ void GuiSpellchecker::check()
|
||||
partialUpdate(SPELL_PROGRESSED);
|
||||
}
|
||||
|
||||
// speller might be dead ...
|
||||
if (!checkAlive())
|
||||
return;
|
||||
|
||||
res = speller_->check(word_);
|
||||
|
||||
// ... or it might just be reporting an error
|
||||
if (!checkAlive())
|
||||
// ... just bail out if the spellchecker reports an error.
|
||||
if (!speller_->error().empty()) {
|
||||
docstring const message =
|
||||
_("The spellchecker has failed.\n") + speller_->error();
|
||||
slotClose();
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
LYXERR(Debug::GUI, "Found word \"" << to_utf8(getWord()) << "\"");
|
||||
@ -334,28 +321,9 @@ void GuiSpellchecker::check()
|
||||
}
|
||||
|
||||
|
||||
bool GuiSpellchecker::checkAlive()
|
||||
{
|
||||
if (speller_->error().empty())
|
||||
return true;
|
||||
|
||||
docstring message;
|
||||
if (speller_->error().empty())
|
||||
message = _("The spellchecker has died for some reason.\n"
|
||||
"Maybe it has been killed.");
|
||||
else
|
||||
message = _("The spellchecker has failed.\n") + speller_->error();
|
||||
|
||||
slotClose();
|
||||
|
||||
Alert::error(_("The spellchecker has failed"), message);
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
void GuiSpellchecker::showSummary()
|
||||
{
|
||||
if (!checkAlive() || count_ == 0) {
|
||||
if (count_ == 0) {
|
||||
slotClose();
|
||||
return;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user