]> git.lyx.org Git - lyx.git/blobdiff - src/lyxrc.C
Fix fuer #209
[lyx.git] / src / lyxrc.C
index bfdb1ad4ce123c694f666ba390a765823440774c..b0dc77ff74a9c404fece2430b68249de1c4b2e4c 100644 (file)
@@ -4,7 +4,7 @@
  *           LyX, The Document Processor
  *      
  *         Copyright 1995 Matthias Ettrich
- *          Copyright 1995-2000 The LyX Team.
+ *          Copyright 1995-2001 The LyX Team.
  *
  * ====================================================== */
 
 #include "lyxrc.h"
 #include "kbmap.h"
 #include "LyXAction.h"
-#include "lyxserver.h"
 #include "lyx_main.h"
 #include "intl.h"
-#include "tex-strings.h"
 #include "support/path.h"
 #include "support/filetools.h"
 #include "lyxtext.h"
 #include "converter.h"
+#include "gettext.h"
 
 using std::ostream;
 using std::ofstream;
@@ -40,10 +39,10 @@ using std::endl;
 using std::vector;
 
 extern LyXAction lyxaction;
-extern kb_keymap * toplevel_keymap;
+extern boost::scoped_ptr<kb_keymap> toplevel_keymap;
 
+namespace {
 
-static
 keyword_item lyxrcTags[] = {
        { "\\accept_compound", LyXRC::RC_ACCEPT_COMPOUND },
        { "\\alternate_language", LyXRC::RC_ALT_LANG },
@@ -51,6 +50,7 @@ keyword_item lyxrcTags[] = {
        { "\\ascii_roff_command", LyXRC::RC_ASCIIROFF_COMMAND },
        { "\\auto_number", LyXRC::RC_AUTO_NUMBER },
        { "\\auto_region_delete", LyXRC::RC_AUTOREGIONDELETE },
+       { "\\auto_reset_options", LyXRC::RC_AUTORESET_OPTIONS },
        { "\\autosave", LyXRC::RC_AUTOSAVE },
        { "\\backupdir_path", LyXRC::RC_BACKUPDIR_PATH },
        { "\\bind", LyXRC::RC_BIND },
@@ -64,6 +64,8 @@ keyword_item lyxrcTags[] = {
        { "\\date_insert_format", LyXRC::RC_DATE_INSERT_FORMAT },
        { "\\default_language", LyXRC::RC_DEFAULT_LANGUAGE },
        { "\\default_papersize", LyXRC::RC_DEFAULT_PAPERSIZE },
+       { "\\dialogs_iconify_with_main", LyXRC::RC_DIALOGS_ICONIFY_WITH_MAIN },
+       { "\\display_graphics", LyXRC::RC_DISPLAY_GRAPHICS },
        { "\\display_shortcuts", LyXRC::RC_DISPLAY_SHORTCUTS },
        { "\\document_path", LyXRC::RC_DOCUMENTPATH },
        { "\\escape_chars", LyXRC::RC_ESC_CHARS },
@@ -90,6 +92,9 @@ keyword_item lyxrcTags[] = {
        { "\\num_lastfiles", LyXRC::RC_NUMLASTFILES },
        { "\\override_x_deadkeys", LyXRC::RC_OVERRIDE_X_DEADKEYS },
        { "\\personal_dictionary", LyXRC::RC_PERS_DICT },
+       { "\\popup_bold_font", LyXRC::RC_POPUP_BOLD_FONT },
+       { "\\popup_font_encoding", LyXRC::RC_POPUP_FONT_ENCODING },
+       { "\\popup_normal_font", LyXRC::RC_POPUP_NORMAL_FONT },
        { "\\print_adapt_output", LyXRC::RC_PRINT_ADAPTOUTPUT },
        { "\\print_collcopies_flag", LyXRC::RC_PRINTCOLLCOPIESFLAG },
        { "\\print_command", LyXRC::RC_PRINT_COMMAND },
@@ -112,9 +117,12 @@ keyword_item lyxrcTags[] = {
        { "\\rtl", LyXRC::RC_RTL_SUPPORT },
        { "\\screen_dpi", LyXRC::RC_SCREEN_DPI },
        { "\\screen_font_encoding", LyXRC::RC_SCREEN_FONT_ENCODING },
-       { "\\screen_font_encoding_menu", LyXRC::RC_SCREEN_FONT_ENCODING_MENU },
-       { "\\screen_font_menu", LyXRC::RC_SCREEN_FONT_MENU },
-       { "\\screen_font_popup", LyXRC::RC_SCREEN_FONT_POPUP },
+       // compatibility with versions older than 1.2.0 only Angus 10 Jan 2002
+       { "\\screen_font_encoding_menu", LyXRC::RC_POPUP_FONT_ENCODING },
+       // compatibility with versions older than 1.2.0 only Angus 10 Jan 2002
+       { "\\screen_font_menu", LyXRC::RC_POPUP_BOLD_FONT },
+       // compatibility with versions older than 1.2.0 only Angus 10 Jan 2002
+       { "\\screen_font_popup", LyXRC::RC_POPUP_NORMAL_FONT },
        { "\\screen_font_roman", LyXRC::RC_SCREEN_FONT_ROMAN },
        { "\\screen_font_sans", LyXRC::RC_SCREEN_FONT_SANS },
        { "\\screen_font_scalable", LyXRC::RC_SCREEN_FONT_SCALABLE },
@@ -132,6 +140,9 @@ keyword_item lyxrcTags[] = {
        { "\\use_escape_chars", LyXRC::RC_USE_ESC_CHARS },
        { "\\use_input_encoding", LyXRC::RC_USE_INP_ENC },
        { "\\use_personal_dictionary", LyXRC::RC_USE_PERS_DICT },
+#ifdef USE_PSPELL
+       { "\\use_pspell", LyXRC::RC_USE_PSPELL },
+#endif
        { "\\use_tempdir", LyXRC::RC_USETEMPDIR },
        { "\\view_dvi_paper_option", LyXRC::RC_VIEWDVI_PAPEROPTION },
        { "\\viewer" ,LyXRC::RC_VIEWER}, 
@@ -139,7 +150,9 @@ keyword_item lyxrcTags[] = {
 };
 
 /* Let the range depend of the size of lyxrcTags.  Alejandro 240596 */
-static const int lyxrcCount = sizeof(lyxrcTags) / sizeof(keyword_item);
+const int lyxrcCount = sizeof(lyxrcTags) / sizeof(keyword_item);
+
+} // namespace anon
 
 
 LyXRC::LyXRC() 
@@ -169,11 +182,11 @@ void LyXRC::setDefaults() {
        print_file_extension = ".ps";
        print_paper_flag = "-t";
        print_paper_dimension_flag = "-T";
-       document_path = GetEnvPath("HOME");
+       document_path.erase();
        tempdir_path = "/tmp";
        use_tempdir = true;
        ps_command = "gs";
-       view_dvi_paper_option = "-paper";
+       view_dvi_paper_option.erase();
        default_papersize = BufferParams::PAPER_USLETTER;
        custom_export_format = "ps";
        chktex_command = "chktex -n1 -n3 -n6 -n9 -n22 -n25 -n30 -n38";
@@ -197,22 +210,27 @@ void LyXRC::setDefaults() {
        roman_font_name = "-*-times";
        sans_font_name = "-*-helvetica";
        typewriter_font_name = "-*-courier";
-       menu_font_name = "-*-helvetica-bold-r";
-       popup_font_name = "-*-helvetica-medium-r";
+       popup_bold_font = "-*-helvetica-bold-r";
+       popup_normal_font = "-*-helvetica-medium-r";
        font_norm = "iso8859-1";
        font_norm_type = ISO_8859_1;
-       font_norm_menu = "";
+       popup_font_encoding.erase();
        override_x_deadkeys = true;
        autosave = 300;
        auto_region_delete = true;
+       auto_reset_options = false;
        ascii_linelen = 65;
        num_lastfiles = 4;
        check_lastfiles = true;
        make_backup = true;
-       backupdir_path = "";
+       backupdir_path.erase();
        exit_confirmation = true;
+       display_graphics = "mono";
        display_shortcuts = true;
        // Spellchecker settings:
+#ifdef USE_PSPELL      
+       use_pspell = true;
+#endif
        isp_command = "ispell";
        isp_accept_compound = false;
        isp_use_input_encoding = false;
@@ -229,7 +247,6 @@ void LyXRC::setDefaults() {
        language_use_babel = true;
        language_package = "\\usepackage{babel}";
        language_command_begin = "\\selectlanguage{$$lang}";
-       language_command_end = "\\selectlanguage{$$lang}";
        language_command_local = "\\foreignlanguage{$$lang}{";
        default_language = "english";
        //
@@ -239,6 +256,7 @@ void LyXRC::setDefaults() {
        date_insert_format = "%A, %e %B %Y";
        show_banner = true;
        cursor_follows_scrollbar = false;
+       dialogs_iconify_with_main = false;
        label_init_length = 3;
 
        /// These variables are not stored on disk (perhaps they
@@ -266,6 +284,7 @@ void LyXRC::readBindFileIfNeeded()
                ReadBindFile(bind_file);
 }
 
+
 int LyXRC::read(string const & filename)
 {      
        LyXLex lexrc(lyxrcTags, lyxrcCount);
@@ -273,11 +292,11 @@ int LyXRC::read(string const & filename)
                lexrc.printTable(lyxerr);
        
        lexrc.setFile(filename);
-       if (!lexrc.IsOK()) return -2;
+       if (!lexrc.isOK()) return -2;
        
-       lyxerr[Debug::INIT] << "Reading '" << filename << "'..." << endl;
+       lyxerr[Debug::LYXRC] << "Reading '" << filename << "'..." << endl;
        
-       while (lexrc.IsOK()) {
+       while (lexrc.isOK()) {
                // By using two switches we take advantage of the compiler
                // telling us if we have missed a LyXRCTags element in
                // the second switch.
@@ -297,8 +316,9 @@ int LyXRC::read(string const & filename)
                switch (static_cast<LyXRCTags>(le)) {
                case RC_INPUT: // Include file
                        if (lexrc.next()) {
-                               string tmp = LibFileSearch(string(),
-                                                          lexrc.GetString()); 
+                               string const tmp =
+                                       LibFileSearch(string(),
+                                                     lexrc.getString()); 
                                if (read(tmp)) {
                                        lexrc.printError("Error reading "
                                                         "included file: "+tmp);
@@ -307,7 +327,7 @@ int LyXRC::read(string const & filename)
                        break;
                case RC_BINDFILE:                     // RVDK_PATCH_5
                        if (lexrc.next()) {
-                               string tmp(lexrc.GetString());
+                               string const tmp(lexrc.getString());
                                if (hasBindFile)
                                        // We are already in the
                                        // "actually read bind file"
@@ -323,28 +343,38 @@ int LyXRC::read(string const & filename)
                        
                case RC_UIFILE: 
                        if (lexrc.next()) {
-                               ui_file = lexrc.GetString();
+                               ui_file = lexrc.getString();
                        }
                        break;
                        
                case RC_EXIT_CONFIRMATION:
                        if (lexrc.next())
-                               exit_confirmation = lexrc.GetBool();
+                               exit_confirmation = lexrc.getBool();
                        break;
                        
+               case RC_AUTORESET_OPTIONS:
+                       if (lexrc.next())
+                               auto_reset_options = lexrc.getBool();
+                       break;
+
+               case RC_DISPLAY_GRAPHICS:
+                       if (lexrc.next())
+                               display_graphics = lexrc.getString();
+                       break;
+
                case RC_DISPLAY_SHORTCUTS:
                        if (lexrc.next())
-                               display_shortcuts = lexrc.GetBool();
+                               display_shortcuts = lexrc.getBool();
                        break;
-                       
+
                case RC_KBMAP:
                        if (lexrc.next())
-                               use_kbmap = lexrc.GetBool();
+                               use_kbmap = lexrc.getBool();
                        break;
                        
                case RC_KBMAP_PRIMARY:
                        if (lexrc.next()) {
-                               string kmap(lexrc.GetString());
+                               string const kmap(lexrc.getString());
                                if (kmap.empty()) {
                                        // nothing
                                } else if (!LibFileSearch("kbd", kmap, 
@@ -357,7 +387,7 @@ int LyXRC::read(string const & filename)
                        
                case RC_KBMAP_SECONDARY:
                        if (lexrc.next()) {
-                               string kmap(lexrc.GetString());
+                               string const kmap(lexrc.getString());
                                if (kmap.empty()) {
                                        // nothing
                                } else if (!LibFileSearch("kbd", kmap, 
@@ -370,112 +400,113 @@ int LyXRC::read(string const & filename)
                        
                case RC_FONT_ENCODING:
                        if (lexrc.next())
-                               fontenc = lexrc.GetString();
+                               fontenc = lexrc.getString();
                        break;
                        
                case RC_PRINTER:
                        if (lexrc.next())
-                               printer = lexrc.GetString();
+                               printer = lexrc.getString();
                        break;
                        
                case RC_PRINT_COMMAND:
                        if (lexrc.next())
-                               print_command = lexrc.GetString();
+                               print_command = lexrc.getString();
                        break;
                        
                case RC_PRINTEVENPAGEFLAG:
                        if (lexrc.next())
-                               print_evenpage_flag = lexrc.GetString();
+                               print_evenpage_flag = lexrc.getString();
                        break;
                        
                case RC_PRINTODDPAGEFLAG:
                        if (lexrc.next())
-                               print_oddpage_flag = lexrc.GetString();
+                               print_oddpage_flag = lexrc.getString();
                        break;
                        
                case RC_PRINTPAGERANGEFLAG:
                        if (lexrc.next())
-                               print_pagerange_flag = lexrc.GetString();
+                               print_pagerange_flag = lexrc.getString();
                        break;
                        
                case RC_PRINTCOPIESFLAG:
                        if (lexrc.next())
-                               print_copies_flag = lexrc.GetString();
+                               print_copies_flag = lexrc.getString();
                        break;
                        
                case RC_PRINTCOLLCOPIESFLAG:
                        if (lexrc.next())
-                               print_collcopies_flag = lexrc.GetString();
+                               print_collcopies_flag = lexrc.getString();
                        break;
                        
                case RC_PRINTREVERSEFLAG:
                        if (lexrc.next())
-                               print_reverse_flag = lexrc.GetString();
+                               print_reverse_flag = lexrc.getString();
                        break;
                        
                case RC_PRINTLANDSCAPEFLAG:
                        if (lexrc.next())
-                               print_landscape_flag = lexrc.GetString();
+                               print_landscape_flag = lexrc.getString();
                        break;
                        
                case RC_PRINTTOPRINTER:
                        if (lexrc.next())
-                               print_to_printer = lexrc.GetString();
+                               print_to_printer = lexrc.getString();
                        break;
                        
                case RC_PRINT_ADAPTOUTPUT:
                        if (lexrc.next())
-                               print_adapt_output = lexrc.GetBool();
+                               print_adapt_output = lexrc.getBool();
                        break;
                        
                case RC_PRINTTOFILE:
                        if (lexrc.next())
-                               print_to_file = lexrc.GetString();
+                               print_to_file = lexrc.getString();
                        break;
                        
                case RC_PRINTFILEEXTENSION:
                        if (lexrc.next())
-                               print_file_extension = lexrc.GetString();
+                               print_file_extension = lexrc.getString();
                        break;
                        
                case RC_PRINTEXSTRAOPTIONS:
                        if (lexrc.next())
-                               print_extra_options = lexrc.GetString();
+                               print_extra_options = lexrc.getString();
                        break;
                        
                case RC_PRINTSPOOL_COMMAND:
                        if (lexrc.next())
-                               print_spool_command = lexrc.GetString();
+                               print_spool_command = lexrc.getString();
                        break;
                        
                case RC_PRINTSPOOL_PRINTERPREFIX:
                        if (lexrc.next())
-                               print_spool_printerprefix = lexrc.GetString();
+                               print_spool_printerprefix = lexrc.getString();
                        break;
                        
                 case RC_PRINTPAPERDIMENSIONFLAG:
                        if (lexrc.next())
-                               print_paper_dimension_flag = lexrc.GetString();
+                               print_paper_dimension_flag = lexrc.getString();
                        break;
                        
                 case RC_PRINTPAPERFLAG:
                        if (lexrc.next())
-                               print_paper_flag = lexrc.GetString();
+                               print_paper_flag = lexrc.getString();
                        break;
                        
                case RC_CUSTOM_EXPORT_COMMAND:
                        if (lexrc.next())
-                               custom_export_command = lexrc.GetString();
+                               custom_export_command = lexrc.getString();
                        break;
                        
                case RC_CUSTOM_EXPORT_FORMAT:
                        if (lexrc.next())
-                               custom_export_format = lexrc.GetString();
+                               custom_export_format = lexrc.getString();
                        break;
 
                case RC_DEFAULT_PAPERSIZE:
                         if (lexrc.next()) {
-                               string size = lowercase(lexrc.GetString());
+                               string const size =
+                                       lowercase(lexrc.getString());
                                if (size == "usletter")
                                        default_papersize =
                                                BufferParams::PAPER_USLETTER;
@@ -502,150 +533,150 @@ int LyXRC::read(string const & filename)
 
                case RC_VIEWDVI_PAPEROPTION:
                        if (lexrc.next())
-                               view_dvi_paper_option = lexrc.GetString();
+                               view_dvi_paper_option = lexrc.getString();
                        else 
-                               view_dvi_paper_option = "";
+                               view_dvi_paper_option.erase();
                        break;
 
                case RC_PS_COMMAND:
                        if (lexrc.next())
-                               ps_command = lexrc.GetString();
+                               ps_command = lexrc.getString();
                        break;
                        
                case RC_CHKTEX_COMMAND:
                        if (lexrc.next())
-                               chktex_command = lexrc.GetString();
+                               chktex_command = lexrc.getString();
                        break;
                        
                case RC_SCREEN_DPI:
                        if (lexrc.next())
-                               dpi = lexrc.GetInteger();
+                               dpi = lexrc.getInteger();
                        break;
                        
                case RC_SCREEN_ZOOM:
                        if (lexrc.next())
-                               zoom = lexrc.GetInteger();
+                               zoom = lexrc.getInteger();
                        break;
 
                case RC_WHEEL_JUMP:
                        if (lexrc.next())
-                               wheel_jump = lexrc.GetInteger();
+                               wheel_jump = lexrc.getInteger();
                        break;
                        
                case RC_SCREEN_FONT_SIZES:
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_TINY] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_SCRIPT] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_FOOTNOTE] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_SMALL] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_NORMAL] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_LARGE] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_LARGER] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_LARGEST] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_HUGE] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        if (lexrc.next())
                                font_sizes[LyXFont::SIZE_HUGER] =
-                                       lexrc.GetFloat();
+                                       lexrc.getFloat();
                        break;
                        
                 case RC_SCREEN_FONT_SCALABLE:
                         if (lexrc.next())
-                                use_scalable_fonts = lexrc.GetBool();
+                                use_scalable_fonts = lexrc.getBool();
                        break;
                        
                case RC_AUTOSAVE:
                        if (lexrc.next())
-                               autosave = lexrc.GetInteger();
+                               autosave = lexrc.getInteger();
                        break;
                        
                case RC_DOCUMENTPATH:
                        if (lexrc.next()) {
-                               document_path = ExpandPath(lexrc.GetString());
+                               document_path = ExpandPath(lexrc.getString());
                        }
                        break;
                        
                case RC_TEMPLATEPATH:
                        if (lexrc.next())
-                               template_path = ExpandPath(lexrc.GetString());
+                               template_path = ExpandPath(lexrc.getString());
                        break;
                        
                case RC_TEMPDIRPATH:
                        if (lexrc.next())
-                               tempdir_path = ExpandPath(lexrc.GetString());
+                               tempdir_path = ExpandPath(lexrc.getString());
                        break;
                        
                case RC_USETEMPDIR:
                        if (lexrc.next())
-                               use_tempdir = lexrc.GetBool();
+                               use_tempdir = lexrc.getBool();
                        break;
                        
                case RC_LASTFILES:
                        if (lexrc.next())
-                               lastfiles = ExpandPath(lexrc.GetString());
+                               lastfiles = ExpandPath(lexrc.getString());
                        break;
                        
                 case RC_NUMLASTFILES:
                         if (lexrc.next())
-                                num_lastfiles = lexrc.GetInteger();
+                                num_lastfiles = lexrc.getInteger();
                        break;
                        
                 case RC_CHECKLASTFILES:
                         if (lexrc.next())
-                                check_lastfiles = lexrc.GetBool();
+                                check_lastfiles = lexrc.getBool();
                        break;
                        
                case RC_SCREEN_FONT_ROMAN:
                        if (lexrc.next())
-                               roman_font_name = lexrc.GetString();
+                               roman_font_name = lexrc.getString();
                        break;
                        
                case RC_SCREEN_FONT_SANS:
                        if (lexrc.next())
-                               sans_font_name = lexrc.GetString();
+                               sans_font_name = lexrc.getString();
                        break;
                        
                case RC_SCREEN_FONT_TYPEWRITER:
                        if (lexrc.next())
-                               typewriter_font_name = lexrc.GetString();
-                       break;
-                       
-               case RC_SCREEN_FONT_MENU:
-                       if (lexrc.next())
-                               menu_font_name = lexrc.GetString();
-                       break;
-                       
-               case RC_SCREEN_FONT_POPUP:
-                       if (lexrc.next())
-                               popup_font_name = lexrc.GetString();
+                               typewriter_font_name = lexrc.getString();
                        break;
                        
                case RC_SCREEN_FONT_ENCODING:
                        if (lexrc.next()) {
-                               font_norm = lexrc.GetString();
+                               font_norm = lexrc.getString();
                                set_font_norm_type();
                        }
                        break;
 
-               case RC_SCREEN_FONT_ENCODING_MENU:
+               case RC_POPUP_BOLD_FONT:
+                       if (lexrc.next())
+                               popup_bold_font = lexrc.getString();
+                       break;
+                       
+               case RC_POPUP_NORMAL_FONT:
+                       if (lexrc.next())
+                               popup_normal_font = lexrc.getString();
+                       break;
+                       
+               case RC_POPUP_FONT_ENCODING:
                        if (lexrc.next())
-                               font_norm_menu = lexrc.GetString();
+                               popup_font_encoding = lexrc.getString();
                        break;
 
                case RC_SET_COLOR:
@@ -653,14 +684,14 @@ int LyXRC::read(string const & filename)
                        string lyx_name, x11_name;
 
                        if (lexrc.next())  {
-                               lyx_name = lexrc.GetString();
+                               lyx_name = lexrc.getString();
                        } else {
                                lexrc.printError("Missing color tag.");
                                break;
                        }
                        
                        if (lexrc.next()) {
-                               x11_name = lexrc.GetString();
+                               x11_name = lexrc.getString();
                        } else {
                                lexrc.printError("Missing color name for color : `$$Token'");
                                break;
@@ -675,7 +706,7 @@ int LyXRC::read(string const & filename)
                case RC_AUTOREGIONDELETE:
                        // Auto region delete defaults to true
                        if (lexrc.next())
-                               auto_region_delete = lexrc.GetBool();
+                               auto_region_delete = lexrc.getBool();
                        break;
                        
                case RC_BIND:
@@ -686,33 +717,36 @@ int LyXRC::read(string const & filename)
                        readBindFileIfNeeded();
 
                        // !!!chb, dynamic key binding...
-                       int action, res = 0;
+                       int action = 0;
+                       string::size_type res = 0;
                        string seq, cmd;
                        
-                       if (lexrc.lex() == LyXLex::LEX_DATA)  {
-                               seq = lexrc.GetString();
+                       if (lexrc.next()) {
+                               seq = lexrc.getString();
                        } else {
-                               lexrc.printError("Bad key sequence: `$$Token'");
+                               lexrc.printError("RC_BIND: Missing key sequence");
                                break;
                        }
                        
-                       if (lexrc.lex() == LyXLex::LEX_DATA) {
-                               cmd = lexrc.GetString();
+                       if (lexrc.next(true)) {
+                               cmd = lexrc.getString();
                        } else {
-                               lexrc.printError("Bad command: `$$Token'");
+                               lexrc.printError("RC_BIND: missing command");
                                break;
                        }
                        
                        if ((action = lyxaction.LookupFunc(cmd))>= 0) {
-                               if (lyxerr.debugging(Debug::KBMAP)) {
+                               if (lyxerr.debugging(Debug::LYXRC)) {
                                        lyxerr << "RC_BIND: Sequence `"
                                               << seq << "' Command `"
                                               << cmd << "' Action `"
                                               << action << '\'' << endl;
                                }
-                               res = toplevel_keymap->bind(seq, action);
-                               if (res != 0) {
+                               res = toplevel_keymap->bind(seq, kb_action(action));
+                               if (res != string::npos
+                                   && lyxerr.debugging(Debug::LYXRC)) {
                                        lexrc.printError(
+                                               "RC_BIND: "
                                                "Invalid key sequence `"
                                                + seq + '\''); 
                                }
@@ -724,184 +758,195 @@ int LyXRC::read(string const & filename)
                }
                case RC_OVERRIDE_X_DEADKEYS:
                        if (lexrc.next())
-                               override_x_deadkeys = lexrc.GetBool();
+                               override_x_deadkeys = lexrc.getBool();
                        break;
 
                case RC_SERVERPIPE:
                        if (lexrc.next())
-                               lyxpipes = ExpandPath(lexrc.GetString());
+                               lyxpipes = ExpandPath(lexrc.getString());
                        break;
                        
                case RC_CURSOR_FOLLOWS_SCROLLBAR:
                        if (lexrc.next())
-                               cursor_follows_scrollbar = lexrc.GetBool();
+                               cursor_follows_scrollbar = lexrc.getBool();
+                       break;
+
+               case RC_DIALOGS_ICONIFY_WITH_MAIN:
+                       if (lexrc.next())
+                               dialogs_iconify_with_main = lexrc.getBool();
                        break;
 
                case RC_ASCIIROFF_COMMAND:
                        if (lexrc.next())
-                               ascii_roff_command = lexrc.GetString();
+                               ascii_roff_command = lexrc.getString();
                        break;
                case RC_ASCII_LINELEN:
                        if (lexrc.next())
-                               ascii_linelen = lexrc.GetInteger();
+                               ascii_linelen = lexrc.getInteger();
                        break;
                        // Spellchecker settings:
+#ifdef USE_PSPELL
+               case RC_USE_PSPELL:
+                       if (lexrc.next())
+                               use_pspell = lexrc.getBool();
+                       break;
+#endif
                case RC_SPELL_COMMAND:
                        if (lexrc.next())
-                               isp_command = lexrc.GetString();
+                               isp_command = lexrc.getString();
                        break;
                case RC_ACCEPT_COMPOUND:
                        if (lexrc.next())
-                               isp_accept_compound = lexrc.GetBool();
+                               isp_accept_compound = lexrc.getBool();
                        break;
                case RC_USE_INP_ENC:
                        if (lexrc.next())
-                               isp_use_input_encoding = lexrc.GetBool();
+                               isp_use_input_encoding = lexrc.getBool();
                        break;
                case RC_USE_ALT_LANG:
                        if (lexrc.next())
-                               isp_use_alt_lang = lexrc.GetBool();
+                               isp_use_alt_lang = lexrc.getBool();
                        break;
                case RC_USE_PERS_DICT:
                        if (lexrc.next())
-                               isp_use_pers_dict = lexrc.GetBool();
+                               isp_use_pers_dict = lexrc.getBool();
                        break;
                case RC_USE_ESC_CHARS:
                        if (lexrc.next())
-                               isp_use_esc_chars = lexrc.GetBool();
+                               isp_use_esc_chars = lexrc.getBool();
                        break;
                case RC_ALT_LANG:
                        if (lexrc.next())
-                               isp_alt_lang = lexrc.GetString();
+                               isp_alt_lang = lexrc.getString();
                        break;
                case RC_PERS_DICT:
                        if (lexrc.next())
-                               isp_pers_dict = lexrc.GetString();
+                               isp_pers_dict = lexrc.getString();
                        break;
                case RC_ESC_CHARS:
                        if (lexrc.next())
-                               isp_esc_chars = lexrc.GetString();
+                               isp_esc_chars = lexrc.getString();
                        break;
                case RC_MAKE_BACKUP:
                        if (lexrc.next())
-                               make_backup = lexrc.GetBool();
+                               make_backup = lexrc.getBool();
                        break;
                case RC_BACKUPDIR_PATH:
                        if (lexrc.next())
-                               backupdir_path = ExpandPath(lexrc.GetString());
+                               backupdir_path = ExpandPath(lexrc.getString());
                        break;
                case RC_DATE_INSERT_FORMAT:
                        if (lexrc.next())
-                               date_insert_format = lexrc.GetString();
+                               date_insert_format = lexrc.getString();
                        break;
                case RC_LANGUAGE_PACKAGE:
                        if (lexrc.next())
-                               language_package = lexrc.GetString();
+                               language_package = lexrc.getString();
                        break;
                case RC_LANGUAGE_AUTO_BEGIN:
                        if (lexrc.next())
-                               language_auto_begin = lexrc.GetBool();
+                               language_auto_begin = lexrc.getBool();
                        break;
                case RC_LANGUAGE_AUTO_END:
                        if (lexrc.next())
-                               language_auto_end = lexrc.GetBool();
+                               language_auto_end = lexrc.getBool();
                        break;
                case RC_LANGUAGE_GLOBAL_OPTIONS:
                        if (lexrc.next())
-                               language_global_options = lexrc.GetBool();
+                               language_global_options = lexrc.getBool();
                        break;
                case RC_LANGUAGE_USE_BABEL:
                        if (lexrc.next())
-                               language_use_babel = lexrc.GetBool();
+                               language_use_babel = lexrc.getBool();
                        break;
                case RC_LANGUAGE_COMMAND_BEGIN:
                        if (lexrc.next())
-                               language_command_begin = lexrc.GetString();
+                               language_command_begin = lexrc.getString();
                        break;
                case RC_LANGUAGE_COMMAND_END:
                        if (lexrc.next())
-                               language_command_end = lexrc.GetString();
+                               language_command_end = lexrc.getString();
                        break;
                case RC_LANGUAGE_COMMAND_LOCAL:
                        if (lexrc.next())
-                               language_command_local = lexrc.GetString();
+                               language_command_local = lexrc.getString();
                        break;
                case RC_RTL_SUPPORT:
                        if (lexrc.next())
-                               rtl_support = lexrc.GetBool();
+                               rtl_support = lexrc.getBool();
                        break;
                case RC_AUTO_NUMBER:
                        if (lexrc.next())
-                               auto_number = lexrc.GetBool();
+                               auto_number = lexrc.getBool();
                        break;
                case RC_MARK_FOREIGN_LANGUAGE:
                        if (lexrc.next())
-                               mark_foreign_language = lexrc.GetBool();
+                               mark_foreign_language = lexrc.getBool();
                        break;
                case RC_SHOW_BANNER:
                        if (lexrc.next())
-                               show_banner = lexrc.GetBool();
+                               show_banner = lexrc.getBool();
                        break;
                        
                case RC_NEW_ASK_FILENAME:
                        if (lexrc.next())
-                               new_ask_filename = lexrc.GetBool();
+                               new_ask_filename = lexrc.getBool();
                        break;
                case RC_CONVERTER: {
                        string from, to, command, flags;
                        if (lexrc.next())
-                               from = lexrc.GetString();
+                               from = lexrc.getString();
                        if (lexrc.next())
-                               to = lexrc.GetString();
+                               to = lexrc.getString();
                        if (lexrc.next())
-                               command = lexrc.GetString();
+                               command = lexrc.getString();
                        if (lexrc.next())
-                               flags = lexrc.GetString();
+                               flags = lexrc.getString();
                        if (command.empty() || command == "none")
-                               converters.Delete(from, to);
+                               converters.erase(from, to);
                        else
-                               converters.Add(from, to, command, flags);
+                               converters.add(from, to, command, flags);
                        break;
                }
                case RC_VIEWER: {
                        string format, command;
                        if (lexrc.next())
-                               format = lexrc.GetString();
+                               format = lexrc.getString();
                        if (lexrc.next())
-                               command = lexrc.GetString();
-                       formats.SetViewer(format, command);
+                               command = lexrc.getString();
+                       formats.setViewer(format, command);
                        break;
                }
                case RC_FORMAT: {
                        string format, extension, prettyname, shortcut;
                        if (lexrc.next())
-                               format = lexrc.GetString();
+                               format = lexrc.getString();
                        if (lexrc.next())
-                               extension = lexrc.GetString();
+                               extension = lexrc.getString();
                        if (lexrc.next())
-                               prettyname = lexrc.GetString();
+                               prettyname = lexrc.getString();
                        if (lexrc.next())
-                               shortcut = lexrc.GetString();
+                               shortcut = lexrc.getString();
                        if (prettyname.empty()) {
-                               if (converters.FormatIsUsed(format))
+                               if (converters.formatIsUsed(format))
                                        lyxerr << "Can't delete format "
                                               << format << endl;
                                else
-                                       formats.Delete(format);
+                                       formats.erase(format);
 
                        } else
-                               formats.Add(format, extension, prettyname,
+                               formats.add(format, extension, prettyname,
                                            shortcut);
                        break;
                }
                case RC_DEFAULT_LANGUAGE:
                        if (lexrc.next())
-                               default_language = lexrc.GetString();
+                               default_language = lexrc.getString();
                        break;
 
                case RC_LABEL_INIT_LENGTH:
                        if (lexrc.next())
-                               label_init_length = lexrc.GetInteger();
+                               label_init_length = lexrc.getInteger();
                        break;
 
                case RC_LAST: break; // this is just a dummy
@@ -909,8 +954,8 @@ int LyXRC::read(string const & filename)
        }
 
        /// Update converters data-structures
-       converters.Update(formats);
-       converters.BuildGraph();
+       converters.update(formats);
+       converters.buildGraph();
 
        return 0;
 }
@@ -940,7 +985,7 @@ void LyXRC::output(ostream & os) const
           << "###          LyX, The Document Processor\n"
           << "###\n"
           << "###          Copyright 1995 Matthias Ettrich\n"
-          << "###          Copyright 1995-2000 The LyX Team.\n"
+          << "###          Copyright 1995-2001 The LyX Team.\n"
           << "###\n"
           << "### ========================================================\n"
           << "\n"
@@ -988,6 +1033,13 @@ void LyXRC::output(ostream & os) const
                           << "\\auto_region_delete " << tostr(auto_region_delete)
                           << "\n";
                }
+       case RC_AUTORESET_OPTIONS:
+               if (auto_reset_options != system_lyxrc.auto_reset_options) {
+                       os << "# Set to false to inhibit automatic reset of\n"
+                          << "# the class options to defaults on class change.\n"
+                          << "\\auto_reset_options " << tostr(auto_reset_options)
+                          << "\n";
+               }
        case RC_AUTOSAVE:
                if (autosave != system_lyxrc.autosave) {
                        os << "# The time interval between auto-saves in seconds.\n"
@@ -1000,6 +1052,14 @@ void LyXRC::output(ostream & os) const
                           << "\\exit_confirmation " << tostr(exit_confirmation)
                           << "\n";
                }
+       case RC_DISPLAY_GRAPHICS:
+               if (display_graphics != system_lyxrc.display_graphics) {
+                       os << "# Display graphics within LyX\n"
+                          << "# no|mono|gray|color\n"
+                          << "\\display_graphics " << display_graphics
+                          << "\n";
+               }
+                       
        case RC_DISPLAY_SHORTCUTS:
                if (display_shortcuts != system_lyxrc.display_shortcuts) {
                        os << "# Display name of the last command executed,\n"
@@ -1011,7 +1071,7 @@ void LyXRC::output(ostream & os) const
                if (view_dvi_paper_option 
                    != system_lyxrc.view_dvi_paper_option) {
                        os << "# Options used to specify paper size to the\n"
-                          << "# view_dvi_command\n"
+                          << "# view_dvi_command (e.g. -paper)\n"
                           << "\\view_dvi_paper_option \""
                           << view_dvi_paper_option << "\"\n";
                }
@@ -1079,6 +1139,21 @@ void LyXRC::output(ostream & os) const
                   << "# SCREEN & FONTS SECTION ############################\n"
                   << "#\n\n";
                
+       case RC_POPUP_NORMAL_FONT:
+               if (popup_normal_font != system_lyxrc.popup_normal_font) {
+                       os << "\\popup_normal_font \"" << popup_normal_font
+                          << "\"\n";
+               }
+       case RC_POPUP_BOLD_FONT:
+               if (popup_bold_font != system_lyxrc.popup_bold_font) {
+                       os << "\\popup_bold_font \"" << popup_bold_font
+                          << "\"\n";
+               }
+       case RC_POPUP_FONT_ENCODING:
+               if (popup_font_encoding != system_lyxrc.popup_font_encoding) {
+                       os << "\\popup_font_encoding \"" << popup_font_encoding
+                          << "\"\n";
+               }
        case RC_SCREEN_DPI:
                if (dpi != system_lyxrc.dpi) {
                        os << "\\screen_dpi " << dpi << "\n";
@@ -1097,6 +1172,12 @@ void LyXRC::output(ostream & os) const
                        os << "\\cursor_follows_scrollbar "
                           << tostr(cursor_follows_scrollbar) << "\n";
                }
+       case RC_DIALOGS_ICONIFY_WITH_MAIN:
+               if (dialogs_iconify_with_main
+                  != system_lyxrc.dialogs_iconify_with_main) {
+                       os << "\\dialogs_iconify_with_main "
+                         <<  tostr(dialogs_iconify_with_main) << "\n";
+               }
        case RC_SCREEN_FONT_ROMAN:
                if (roman_font_name != system_lyxrc.roman_font_name) {
                        os << "\\screen_font_roman \"" << roman_font_name
@@ -1123,16 +1204,6 @@ void LyXRC::output(ostream & os) const
                        os << "\\screen_font_encoding \"" << font_norm
                           << "\"\n";
                }
-       case RC_SCREEN_FONT_POPUP:
-               if (popup_font_name != system_lyxrc.popup_font_name) {
-                       os << "\\screen_font_popup \"" << popup_font_name
-                          << "\"\n";
-               }
-       case RC_SCREEN_FONT_MENU:
-               if (menu_font_name != system_lyxrc.menu_font_name) {
-                       os << "\\screen_font_menu \"" << menu_font_name
-                          << "\"\n";
-               }
        case RC_SCREEN_FONT_SIZES:
                if (font_sizes[LyXFont::SIZE_TINY]
                    != system_lyxrc.font_sizes[LyXFont::SIZE_TINY] ||
@@ -1370,7 +1441,12 @@ void LyXRC::output(ostream & os) const
                os << "\n#\n"
                   << "# SPELLCHECKER SECTION ##############################\n"
                   << "#\n\n";
-
+#ifdef USE_PSPELL
+       case RC_USE_PSPELL:
+               if (use_pspell != system_lyxrc.use_pspell) {
+                       os << "\\use_pspell " << tostr(use_pspell) << "\n";
+               }
+#endif
        case RC_SPELL_COMMAND:
                if (isp_command != system_lyxrc.isp_command) {
                        os << "\\spell_command \"" << isp_command << "\"\n";
@@ -1490,11 +1566,6 @@ void LyXRC::output(ostream & os) const
                        os << "\\override_x_deadkeys "
                           << tostr(override_x_deadkeys) << "\n";
                }
-       case RC_SCREEN_FONT_ENCODING_MENU:
-               if (font_norm_menu != system_lyxrc.font_norm_menu) {
-                       os << "\\screen_font_encoding_menu \"" << font_norm_menu
-                          << "\"\n";
-               }
        case RC_AUTO_NUMBER:
                if (auto_number != system_lyxrc.auto_number) {
                        os << "\\auto_number " << tostr(auto_number) << "\n";
@@ -1518,7 +1589,7 @@ void LyXRC::output(ostream & os) const
                for (Formats::const_iterator cit = formats.begin();
                     cit != formats.end(); ++cit) {
                        Format const * format =
-                               system_formats.GetFormat(cit->name());
+                               system_formats.getFormat(cit->name());
                        if (!format ||
                            format->extension() != cit->extension() ||
                            format->prettyname() != cit->prettyname() ||
@@ -1532,14 +1603,14 @@ void LyXRC::output(ostream & os) const
                // New/modifed formats
                for (Formats::const_iterator cit = system_formats.begin();
                     cit != system_formats.end(); ++cit)
-                       if (!formats.GetFormat(cit->name()))
+                       if (!formats.getFormat(cit->name()))
                                os << "\\format \"" << cit->name() 
                                   << "\" \"\" \"\" \"\"\n";
        case RC_VIEWER:
                for (Formats::const_iterator cit = formats.begin();
                     cit != formats.end(); ++cit) {
                        Format const * format = 
-                               system_formats.GetFormat(cit->name());
+                               system_formats.getFormat(cit->name());
                        if ((!format || format->viewer() != cit->viewer()) &&
                            (format || !cit->viewer().empty()))
                                os << "\\viewer \"" << cit->name() << "\" \""
@@ -1555,7 +1626,7 @@ void LyXRC::output(ostream & os) const
                for (Converters::const_iterator cit = converters.begin();
                     cit != converters.end(); ++cit) {
                        Converter const * converter =
-                               system_converters.GetConverter(cit->from,
+                               system_converters.getConverter(cit->from,
                                                               cit->to);
                        if (!converter ||
                            converter->command != cit->command ||
@@ -1569,7 +1640,7 @@ void LyXRC::output(ostream & os) const
                // New/modifed converters
                for (Converters::const_iterator cit = system_converters.begin();
                     cit != system_converters.end(); ++cit)
-                       if (!converters.GetConverter(cit->from, cit->to))
+                       if (!converters.getConverter(cit->from, cit->to))
                                os << "\\converter \"" << cit->from 
                                   << "\" \"" << cit->to << "\" \"\" \"\"\n";
        }
@@ -1582,10 +1653,16 @@ void LyXRC::set_font_norm_type()
                font_norm_type = ISO_10646_1;
        else if (font_norm == "iso8859-1")
                font_norm_type = ISO_8859_1;
+       else if (font_norm == "iso8859-3")
+               font_norm_type = ISO_8859_3;
+       else if (font_norm == "iso8859-4")
+               font_norm_type = ISO_8859_4;
        else if (font_norm == "iso8859-6.8x")
                font_norm_type = ISO_8859_6_8;
        else if (font_norm == "iso8859-9")
                font_norm_type = ISO_8859_9;
+       else if (font_norm == "iso8859-15")
+               font_norm_type = ISO_8859_15;
        else
                font_norm_type = OTHER_ENCODING;
 }
@@ -1691,19 +1768,19 @@ string const LyXRC::getDescription(LyXRCTags tag)
                str = N_("The screen fonts used to display the text while editing.");
                break;
                
-       case RC_SCREEN_FONT_MENU:
-               str = N_("The font for menus (and groups titles in popups).");
+       case RC_POPUP_BOLD_FONT:
+               str = N_("The bold font in the dialogs.");
                break;
                
-       case RC_SCREEN_FONT_POPUP:
-               str = N_("The font for popups.");
+       case RC_POPUP_NORMAL_FONT:
+               str = N_("The normal font in the dialogs.");
                break;
                
        case RC_SCREEN_FONT_ENCODING:
                str = N_("The encoding for the screen fonts.");
                break;
                
-       case RC_SCREEN_FONT_ENCODING_MENU:
+       case RC_POPUP_FONT_ENCODING:
                str = N_("The encoding for the menu/popups fonts.");
                break;
                
@@ -1715,11 +1792,11 @@ string const LyXRC::getDescription(LyXRCTags tag)
                break;
                
        case RC_DOCUMENTPATH:
-               str = N_("The default path for your documents.");
+               str = N_("The default path for your documents.  An empty value selects the directory LyX was started from.");
                break;
                
        case RC_TEMPLATEPATH:
-               str = N_("The path that LyX will set when offering to choose a template.");
+               str = N_("The path that LyX will set when offering to choose a template.  An empty value selects the directory LyX was started from.");
                break;
                
        case RC_TEMPDIRPATH:
@@ -1737,20 +1814,24 @@ string const LyXRC::getDescription(LyXRCTags tag)
        case RC_AUTOREGIONDELETE:
                str = N_("De-select if you don't want the current selection to be replaced automatically by what you type.");
                break;
+
+       case RC_AUTORESET_OPTIONS:
+               str = N_("De-select if you don't want the class options to be reset to defaults after class change.");
+               break;
                
        case RC_OVERRIDE_X_DEADKEYS:
                str = N_("Select if LyX is to take over the handling of the dead keys (a.k.a. accent keys) that may be defined for your keyboard.");
                break;
-               
+
 
        case RC_SERVERPIPE:
                str = N_("This starts the lyxserver. The pipes get an additional extension \".in\" and \".out\". Only for advanced users.");
                break;
-               
+
        case RC_BINDFILE:
                str = N_("Keybindings file. Can either specify an absolute path, or LyX will look in its global and local bind/ directories.");
                break;
-               
+
        case RC_UIFILE:
                str = N_("The  UI (user interface) file. Can either specify an absolute path, or LyX will look in its global and local ui/ directories.");
                break;
@@ -1778,6 +1859,7 @@ string const LyXRC::getDescription(LyXRCTags tag)
                break;
                
        case RC_VIEWDVI_PAPEROPTION:
+               str = N_("Specify the paper command to DVI viewer (leave empty or use \"-paper\")");
                break;
                
        case RC_DEFAULT_PAPERSIZE:
@@ -1815,7 +1897,7 @@ string const LyXRC::getDescription(LyXRCTags tag)
                break;
                
        case RC_SCREEN_FONT_SCALABLE:
-               str = N_("Allow the use of scalable screen fonts? If false, LyX will use the closest existing size for a match. Use this if the scalable fonts look bad and you have many fixed size fonts.");
+               str = N_("Allow bitmap fonts to be resized. If you are using a bitmap font, selecting this option may make some fonts look blocky in LyX. Deselecting this option makes LyX use the nearest bitmap font size available, instead of scaling.");
                break;
                
        case RC_CHKTEX_COMMAND:
@@ -1826,10 +1908,18 @@ string const LyXRC::getDescription(LyXRCTags tag)
                str = N_("LyX normally doesn't update the cursor position if you move the scrollbar. Set to true if you'd prefer to always have the cursor on screen.");
                break;
                
+       case RC_DIALOGS_ICONIFY_WITH_MAIN:
+               str = N_("Iconify the dialogs when the main window is iconified. (Affects only dialogs shown after the change has been made.)");
+               break;
+               
        case RC_EXIT_CONFIRMATION:
                str = N_("Sets whether LyX asks for a second confirmation to exit when you have changed documents. (LyX will still ask to save changed documents.)");
                break;
                
+       case RC_DISPLAY_GRAPHICS:
+               str = N_("Select how LyX will display any graphics.");
+               break;
+               
        case RC_DISPLAY_SHORTCUTS:
                str = N_("LyX continously displays names of last command executed, along with a list of defined short-cuts for it in the minibuffer. Set to false if LyX seems slow.");
                break;