#include <unistd.h>
#include <fcntl.h>
#include <cstdlib>
-#include <cstring>
#include <csignal>
#include <sys/wait.h>
#include <sys/types.h>
#include "buffer.h"
#include "lyxrc.h"
#include "BufferView.h"
+#include "LyXView.h"
+#include "frontends/Dialogs.h"
#include "gettext.h"
#include "lyx_gui_misc.h"
#include "debug.h"
#include "support/lstrings.h"
#ifdef USE_PSPELL
+#define USE_ORIGINAL_MANAGER_FUNCS 1
# include <pspell/pspell.h>
#endif
using std::reverse;
using std::endl;
+namespace {
+
// Spellchecker status
enum {
ISP_OK = 1,
ISP_IGNORE
};
-static bool RunSpellChecker(BufferView * bv);
+bool RunSpellChecker(BufferView * bv);
#ifndef USE_PSPELL
-static FILE * in, * out; /* streams to communicate with ispell */
+FILE * in;
+FILE * out; /* streams to communicate with ispell */
pid_t isp_pid = -1; // pid for the `ispell' process. Also used (RO) in
// lyx_cb.C
// the true spell checker program being used
enum ActualSpellChecker {ASC_ISPELL, ASC_ASPELL};
-static ActualSpellChecker actual_spell_checker;
+ActualSpellChecker actual_spell_checker;
-static int isp_fd;
+int isp_fd;
#else
#endif
+} // namespace anon
+
+
// Non-static so that it can be redrawn if the xforms colors are re-mapped
-FD_form_spell_options *fd_form_spell_options = 0;
FD_form_spell_check *fd_form_spell_check = 0;
void sigchldhandler(pid_t pid, int *status);
#endif
+namespace {
+
const char * spell_error;
-
-/***** Spellchecker options *****/
-
-// Rewritten to use ordinary LyX xforms loop and OK, Apply and Cancel set,
-// now also string. Amazing, eh? (Asger)
-
-// Set (sane) values in form to current spellchecker options
-void SpellOptionsUpdate()
-{
- // Alternate language
- if (lyxrc.isp_alt_lang.empty()) {
- lyxrc.isp_use_alt_lang = false;
- } else {
- fl_set_input(fd_form_spell_options->altlang_input,
- lyxrc.isp_alt_lang.c_str());
- }
- if (lyxrc.isp_use_alt_lang) {
- fl_set_button(fd_form_spell_options->buflang, 0);
- fl_set_button(fd_form_spell_options->altlang, 1);
- } else {
- fl_set_button(fd_form_spell_options->buflang, 1);
- fl_set_button(fd_form_spell_options->altlang, 0);
- }
-
- // Personal dictionary
- if (lyxrc.isp_pers_dict.empty()) {
- lyxrc.isp_use_pers_dict = false;
- } else {
- fl_set_input(fd_form_spell_options->perdict_input,
- lyxrc.isp_pers_dict.c_str());
- }
- fl_set_button(fd_form_spell_options->perdict,
- lyxrc.isp_use_pers_dict ? 1:0);
-
- // Escape chars
- if (lyxrc.isp_esc_chars.empty()) {
- lyxrc.isp_use_esc_chars = false;
- } else {
- fl_set_input(fd_form_spell_options->esc_chars_input,
- lyxrc.isp_esc_chars.c_str());
- }
- fl_set_button(fd_form_spell_options->esc_chars,
- lyxrc.isp_use_esc_chars ? 1:0);
-
- // Options
- fl_set_button(fd_form_spell_options->compounds,
- lyxrc.isp_accept_compound ? 1 : 0);
- fl_set_button(fd_form_spell_options->inpenc,
- lyxrc.isp_use_input_encoding ? 1 : 0);
-}
-
-// Update spellchecker options
-void SpellOptionsApplyCB(FL_OBJECT *, long)
-{
- // Build new status from form data
- lyxrc.isp_use_alt_lang =
- fl_get_button(fd_form_spell_options->altlang);
- lyxrc.isp_use_pers_dict =
- fl_get_button(fd_form_spell_options->perdict);
- lyxrc.isp_accept_compound =
- fl_get_button(fd_form_spell_options->compounds);
- lyxrc.isp_use_esc_chars =
- fl_get_button(fd_form_spell_options->esc_chars);
- lyxrc.isp_use_input_encoding =
- fl_get_button(fd_form_spell_options->inpenc);
-
- // Update strings with data from input fields
- lyxrc.isp_alt_lang =
- fl_get_input(fd_form_spell_options->altlang_input);
- lyxrc.isp_pers_dict =
- fl_get_input(fd_form_spell_options->perdict_input);
- lyxrc.isp_esc_chars =
- fl_get_input(fd_form_spell_options->esc_chars_input);
-
- // Update form
- SpellOptionsUpdate();
-}
-
-
-void SpellOptionsCancelCB(FL_OBJECT *, long)
-{
- fl_hide_form(fd_form_spell_options->form_spell_options);
-}
-
-
-void SpellOptionsOKCB(FL_OBJECT * ob, long data)
-{
- SpellOptionsApplyCB(ob, data);
- SpellOptionsCancelCB(ob, data);
-}
-
-
-// Show spellchecker options form
-void SpellCheckerOptions()
-{
- // Create form if nescessary
- if (fd_form_spell_options == 0) {
- fd_form_spell_options = create_form_form_spell_options();
- // Make sure pressing the close box does not kill LyX. (RvdK)
- fl_set_form_atclose(fd_form_spell_options->form_spell_options,
- CancelCloseBoxCB, 0);
- }
-
- // Update form to current options
- SpellOptionsUpdate();
-
- // Focus in alternate language field
- fl_set_focus_object(fd_form_spell_options->form_spell_options,
- fd_form_spell_options->altlang_input);
-
- // Show form
- if (fd_form_spell_options->form_spell_options->visible) {
- fl_raise_form(fd_form_spell_options->form_spell_options);
- } else {
- fl_show_form(fd_form_spell_options->form_spell_options,
- FL_PLACE_MOUSE | FL_FREE_SIZE, FL_TRANSIENT,
- _("Spellchecker Options"));
- }
-}
-
#ifndef USE_PSPELL
/***** Spellchecker *****/
// Could also use a clean up. (Asger Alstrup)
-static
void init_spell_checker(BufferParams const & params, string const & lang)
{
static char o_buf[BUFSIZ]; // jc: it could be smaller
"could be that you do not have a dictionary file\n"
"for the language of this document installed.\n"
"Check /usr/lib/ispell or set another\n"
- "dictionary in the Spellchecker Options menu.";
+ "dictionary in the spellchecker preferences.";
} else {
spell_error = 0;
}
}
-static
+
bool sc_still_alive() {
return isp_pid != -1;
}
-static
+
void sc_clean_up_after_error()
{
::fclose(out);
}
+
// Send word to ispell and get reply
-static
isp_result * sc_check_word(string const & word)
{
//Please rewrite to use string.
}
-static inline
+inline
void close_spell_checker()
{
// Note: If you decide to optimize this out when it is not
}
-static inline
+inline
void sc_insert_word(string const & word)
{
::fputc('*', out); // Insert word in personal dictionary
}
-static inline
+inline
void sc_accept_word(string const & word)
{
::fputc('@', out); // Accept in this session
::fputc('\n', out);
}
-static inline
+
+inline
void sc_store_replacement(string const & mis, string const & cor) {
if (actual_spell_checker == ASC_ASPELL) {
::fputs("$$ra ", out);
PspellCanHaveError * spell_error_object;
-static
void init_spell_checker(BufferParams const &, string const & lang)
{
PspellConfig * config = new_pspell_config();
}
}
-static
+
bool sc_still_alive() {
return true;
}
-static
+
void sc_clean_up_after_error()
{
delete_pspell_can_have_error(spell_error_object);
// Send word to pspell and get reply
-static
isp_result * sc_check_word(string const & word)
{
isp_result * result = new isp_result;
+#ifdef WITH_WARNINGS
#warning Why isnt word_ok a bool? (Lgb)
+#endif
int word_ok = pspell_manager_check(sc, word.c_str());
- Assert(word_ok != -1);
+ lyx::Assert(word_ok != -1);
if (word_ok) {
result->flag = ISP_OK;
} else {
PspellWordList const * sugs =
pspell_manager_suggest(sc, word.c_str());
- Assert(sugs != 0);
+ lyx::Assert(sugs != 0);
result->els = pspell_word_list_elements(sugs);
if (pspell_word_list_empty(sugs))
result->flag = ISP_UNKNOWN;
}
-static inline
+inline
void close_spell_checker()
{
pspell_manager_save_all_word_lists(sc);
}
-static inline
+inline
void sc_insert_word(string const & word)
{
pspell_manager_add_to_personal(sc, word.c_str());
}
-static inline
+inline
void sc_accept_word(string const & word)
{
pspell_manager_add_to_session(sc, word.c_str());
}
-static inline
+inline
void sc_store_replacement(string const & mis, string const & cor)
{
pspell_manager_store_replacement(sc, mis.c_str(), cor.c_str());
#endif
+} // namespace anon
+
+
void ShowSpellChecker(BufferView * bv)
{
FL_OBJECT * obj;
while (true) {
obj = fl_do_forms();
if (obj == fd_form_spell_check->options) {
- SpellCheckerOptions();
+ bv->owner()->getDialogs()->showSpellcheckerPreferences();
}
if (obj == fd_form_spell_check->start) {
// activate insert, accept, and stop
// Perform a spell session
-static
+namespace {
+
bool RunSpellChecker(BufferView * bv)
{
isp_result * result;
int newvalue;
FL_OBJECT * obj;
-#ifndef NEW_INSETS
- // Open all floats
- bv->allFloats(1, 0);
- bv->allFloats(1, 1);
-#endif
-
#ifdef USE_PSPELL
string tmp = (lyxrc.isp_use_alt_lang) ?
lyxrc.isp_alt_lang : bv->buffer()->params.language->code();
}
}
+} // namespace anon
+
+#ifdef WITH_WARNINGS
#warning should go somewhere more sensible
+#endif
void sigchldhandler(pid_t pid, int * status)
-{
+{
+#ifndef USE_PSPELL
if (isp_pid > 0)
if (pid == isp_pid) {
isp_pid= -1;
to nonblocking so we can
continue */
}
+#endif
sigchldchecker(pid, status);
}
+
+