]> git.lyx.org Git - lyx.git/blobdiff - src/lyxrc.C
more changes, read the Changelog
[lyx.git] / src / lyxrc.C
index 0a2ac6e5c5af983100a2f4f708cfbe958ac7458d..2b81b0d0c3ce94933737d1fffa88de4493a961ad 100644 (file)
@@ -41,8 +41,6 @@ using std::endl;
 // not in lyxrc?? (Matthias) 
 // Because nobody put them there. (Asger)
 
-extern string background_color;
-extern char selection_color[];
 extern bool cursor_follows_scrollbar;
 extern LyXAction lyxaction;
 extern kb_keymap * toplevel_keymap;
@@ -87,6 +85,7 @@ enum LyXRCTags {
        RC_SCREEN_FONT_POPUP,
        RC_SCREEN_FONT_ENCODING,
        RC_SCREEN_FONT_ENCODING_MENU,
+       RC_SET_COLOR,
        RC_AUTOSAVE,
        RC_DOCUMENTPATH,
        RC_TEMPLATEPATH,
@@ -95,14 +94,13 @@ enum LyXRCTags {
        RC_LASTFILES,
        RC_AUTOREGIONDELETE,
        RC_BIND,
+       RC_OVERRIDE_X_DEADKEYS,
        RC_SERVERPIPE,
        RC_INPUT,
        RC_BINDFILE,
        RC_KBMAP,
        RC_KBMAP_PRIMARY,
        RC_KBMAP_SECONDARY,
-       RC_SELECTION_COLOR,
-       RC_BACKGROUND_COLOR,
        RC_FAX_COMMAND,
        RC_PHONEBOOK,
        RC_FAXPROGRAM,
@@ -136,6 +134,7 @@ enum LyXRCTags {
        RC_BACKUPDIR_PATH,
        RC_RTL_SUPPORT,
        RC_AUTO_NUMBER,
+       RC_MARK_FOREIGN_LANGUAGE,
        RC_LANGUAGE_PACKAGE,
        RC_LANGUAGE_AUTO_BEGIN,
        RC_LANGUAGE_AUTO_END,
@@ -168,7 +167,6 @@ keyword_item lyxrcTags[] = {
        { "\\auto_number", RC_AUTO_NUMBER },
        { "\\auto_region_delete", RC_AUTOREGIONDELETE },
        { "\\autosave", RC_AUTOSAVE },
-       { "\\background_color", RC_BACKGROUND_COLOR },
        { "\\backupdir_path", RC_BACKUPDIR_PATH },
        { "\\begin_toolbar", RC_BEGINTOOLBAR },
        { "\\bind", RC_BIND },
@@ -212,7 +210,9 @@ keyword_item lyxrcTags[] = {
         { "\\literate_error_filter", RC_LITERATE_ERROR_FILTER },
         { "\\literate_extension", RC_LITERATE_EXTENSION },
        { "\\make_backup", RC_MAKE_BACKUP },
+       { "\\mark_foreign_language", RC_MARK_FOREIGN_LANGUAGE },
        { "\\num_lastfiles", RC_NUMLASTFILES },
+       { "\\override_x_deadkeys", RC_OVERRIDE_X_DEADKEYS },
        { "\\pdf_mode", RC_PDF_MODE },
        { "\\pdf_to_ps_command", RC_PDF_TO_PS_COMMAND },
        { "\\pdflatex_command", RC_PDFLATEX_COMMAND },
@@ -250,8 +250,8 @@ keyword_item lyxrcTags[] = {
        { "\\screen_font_sizes", RC_SCREEN_FONT_SIZES },
        { "\\screen_font_typewriter", RC_SCREEN_FONT_TYPEWRITER },
        { "\\screen_zoom", RC_SCREEN_ZOOM },
-       { "\\selection_color", RC_SELECTION_COLOR },
        { "\\serverpipe", RC_SERVERPIPE },
+       { "\\set_color", RC_SET_COLOR },
        { "\\show_banner", RC_SHOW_BANNER },
        { "\\spell_command", RC_SPELL_COMMAND },
        { "\\tempdir_path", RC_TEMPDIRPATH },
@@ -344,9 +344,10 @@ void LyXRC::setDefaults() {
        popup_font_name = "-*-helvetica-medium-r";
        font_norm = "iso8859-1";
        font_norm_menu = "";
+       override_x_deadkeys = true;
        autosave = 300;
        auto_region_delete = true;
-       ascii_linelen = 75;
+       ascii_linelen = 65;
        num_lastfiles = 4;
        check_lastfiles = true;
        make_backup = true;
@@ -364,6 +365,7 @@ void LyXRC::setDefaults() {
        hasBindFile = false;
        rtl_support = false;
        auto_number = true;
+       mark_foreign_language = true;
        language_package = "\\usepackage{babel}";
        language_auto_begin = true;
        language_auto_end = true;
@@ -383,9 +385,6 @@ void LyXRC::setDefaults() {
        docbook_to_dvi_command="none";
        docbook_to_html_command="none";
        docbook_to_pdf_command="none";
-
-       //
-       defaultKeyBindings();
 }
 
 
@@ -446,7 +445,14 @@ int LyXRC::read(string const & filename)
                        break;
                case RC_BINDFILE:                     // RVDK_PATCH_5
                        if (lexrc.next()) {
-                               ReadBindFile(lexrc.GetString());
+                               string tmp(lexrc.GetString());
+                               if (bind_file.empty()) {
+                                       // we only need the name of the first
+                                       // bind file since that (usually)
+                                       // includes several others.
+                                       bind_file = tmp;
+                               }
+                               ReadBindFile(tmp);
                        }
                        break;
                        
@@ -472,13 +478,21 @@ int LyXRC::read(string const & filename)
                        break;
                        
                case RC_KBMAP_PRIMARY:
-                       if (lexrc.next())
-                               primary_kbmap = lexrc.GetString();
+                       if (lexrc.next()) 
+                               if (!LibFileSearch("kbd", lexrc.GetString(), 
+                                                  "kmap").empty()) 
+                                       primary_kbmap = lexrc.GetString();
+                               else 
+                                       lexrc.printError("LyX: Keymap `$$Token' not found");
                        break;
                        
                case RC_KBMAP_SECONDARY:
-                       if (lexrc.next())
-                               secondary_kbmap = lexrc.GetString();
+                       if (lexrc.next()) 
+                               if (!LibFileSearch("kbd", lexrc.GetString(), 
+                                                  "kmap").empty()) 
+                                       secondary_kbmap = lexrc.GetString();
+                               else 
+                                       lexrc.printError("LyX: Keymap `$$Token' not found");
                        break;
                        
                case RC_FONT_ENCODING:
@@ -833,6 +847,30 @@ int LyXRC::read(string const & filename)
                                font_norm_menu = lexrc.GetString();
                        break;
 
+               case RC_SET_COLOR:
+               {
+                       string lyx_name, x11_name;
+
+                       if (lexrc.lex() == LyXLex::LEX_DATA)  {
+                               lyx_name = lexrc.GetString();
+                       } else {
+                               lexrc.printError("Bad color tag: `$$Token'");
+                               break;
+                       }
+                       
+                       if (lexrc.lex() == LyXLex::LEX_DATA) {
+                               x11_name = lexrc.GetString();
+                       } else {
+                               lexrc.printError("Bad color name: `$$Token'");
+                               break;
+                       }
+
+                       if (!lcolor.setColor(lyx_name, x11_name))
+                               lyxerr << "Bad lyxrc set_color for "
+                                       << lyx_name << endl;
+
+                       break;
+               }
                case RC_AUTOREGIONDELETE:
                        // Auto region delete defaults to true
                        if (lexrc.next())
@@ -844,9 +882,10 @@ int LyXRC::read(string const & filename)
                        // we should not do an explicit binding before
                        // loading a bind file. So, in this case, load
                        // the default bind file.
-                       if (!hasBindFile)
+                       if (!hasBindFile) {
                                ReadBindFile();
-                       
+                               bind_file = bindFile;
+                       }
                        // !!!chb, dynamic key binding...
                        int action, res = 0;
                        string seq, cmd;
@@ -885,6 +924,11 @@ int LyXRC::read(string const & filename)
                        }
                        break;
                }
+               case RC_OVERRIDE_X_DEADKEYS:
+                       if (lexrc.next())
+                               override_x_deadkeys = lexrc.GetBool();
+                       break;
+
                case RC_SERVERPIPE:
                        if (lexrc.next())
                                lyxpipes = ExpandPath(lexrc.GetString());
@@ -895,15 +939,6 @@ int LyXRC::read(string const & filename)
                                cursor_follows_scrollbar = lexrc.GetBool();
                        break;
 
-               case RC_BACKGROUND_COLOR:
-                       if (lexrc.next())
-                               background_color = lexrc.GetString();
-                       break;
-               case RC_SELECTION_COLOR:
-                       if (lexrc.next())
-                               strncpy(selection_color,
-                                       lexrc.GetString().c_str(), 31);
-                       break;
                case RC_FAX_COMMAND:
                        if (lexrc.next())
                                fax_command = lexrc.GetString();
@@ -1006,6 +1041,10 @@ int LyXRC::read(string const & filename)
                        if (lexrc.next())
                                auto_number = lexrc.GetBool();
                        break;
+               case RC_MARK_FOREIGN_LANGUAGE:
+                       if (lexrc.next())
+                               mark_foreign_language = lexrc.GetBool();
+                       break;
                case RC_SHOW_BANNER:
                        if (lexrc.next())
                                show_banner = lexrc.GetBool();
@@ -1038,6 +1077,7 @@ int LyXRC::read(string const & filename)
                        if ( lexrc.next())
                                docbook_to_pdf_command = lexrc.GetString();
                        break;
+
                case RC_LAST: break; // this is just a dummy
                }
        }
@@ -1096,6 +1136,9 @@ void LyXRC::output(ostream & os) const
                // bind files are not done here.
        case RC_BEGINTOOLBAR:
                // Toolbar is not written here (yet).
+       //case RC_SET_COLOR:
+               // color bindings not written to preference file.
+               // And we want to be warned about that. (Lgb)
        case RC_FONT_ENCODING:
                os << "\\font_encoding \"" << fontenc << "\"\n";
        case RC_PRINTER:
@@ -1194,6 +1237,9 @@ void LyXRC::output(ostream & os) const
                os << " " << font_sizes[LyXFont::SIZE_HUGE];
                os << " " << font_sizes[LyXFont::SIZE_HUGER];
                os << "\n";
+       case RC_OVERRIDE_X_DEADKEYS:
+               os << "\\override_x_deadkeys " 
+                  << override_x_deadkeys << "\n";
        case RC_AUTOREGIONDELETE:
                os << "\\auto_region_delete " << tostr(auto_region_delete)
                   << "\n";
@@ -1288,10 +1334,6 @@ void LyXRC::output(ostream & os) const
        case RC_CURSOR_FOLLOWS_SCROLLBAR:
                os << "\\cursor_follows_scrollbar "
                   << tostr(cursor_follows_scrollbar) << "\n";
-       case RC_BACKGROUND_COLOR:
-               os << "\\background_color \"" << background_color << "\"\n";
-       case RC_SELECTION_COLOR:
-               os << "\\selection_color \"" << selection_color << "\"\n";
        case RC_FAX_COMMAND:
                os << "\\fax_command \"" << fax_command << "\"\n";
        case RC_FAXPROGRAM:
@@ -1328,7 +1370,10 @@ void LyXRC::output(ostream & os) const
        case RC_RTL_SUPPORT:
                os << "\\rtl " << tostr(rtl_support) << "\n";
        case RC_AUTO_NUMBER:
-               os << "\\auto_number" << tostr(auto_number) << "\n";
+               os << "\\auto_number " << tostr(auto_number) << "\n";
+       case RC_MARK_FOREIGN_LANGUAGE:
+               os << "\\mark_foreign_language " << 
+                       tostr(mark_foreign_language) << "\n";
        case RC_LANGUAGE_AUTO_BEGIN:
                os << "\\language_auto_begin " 
                   << tostr(language_auto_begin) << "\n";
@@ -1346,7 +1391,7 @@ void LyXRC::output(ostream & os) const
        case RC_MAKE_BACKUP:
                os << "\\make_backup " << tostr(make_backup) << "\n";
        case RC_BACKUPDIR_PATH:
-               os << "\\backupdir_path" << backupdir_path << "\n";
+               os << "\\backupdir_path \"" << backupdir_path << "\"\n";
        case RC_DATE_INSERT_FORMAT:
                os << "\\date_insert_format \"" << date_insert_format
                   << "\"\n";
@@ -1377,74 +1422,5 @@ void LyXRC::output(ostream & os) const
 }
 
 
-/// define the default key bindings for LyX.
-void LyXRC::defaultKeyBindings()
-{
-       bindings["Right"] =   LFUN_RIGHT;
-       bindings["Left"] =    LFUN_LEFT;
-       bindings["Up"] =      LFUN_UP;
-       bindings["Down"] =    LFUN_DOWN;
-       
-       bindings["Tab"] =  LFUN_TAB;
-       
-       bindings["Home"] =    LFUN_HOME;
-       bindings["End"] =     LFUN_END;
-       bindings["Prior"] =   LFUN_PRIOR;
-       bindings["Next"] =    LFUN_NEXT;
-       
-       bindings["Return"] =  LFUN_BREAKPARAGRAPH;
-       bindings["~C-~S-~M-nobreakspace"] = LFUN_PROTECTEDSPACE;
-       
-       bindings["Delete"] =  LFUN_DELETE;
-       bindings["BackSpace"] =    LFUN_BACKSPACE;
-       // bindKeyings for transparent handling of deadkeys
-       // The keysyms are gotten from XFree86 X11R6
-       bindings["~C-~S-~M-dead_acute"] =           LFUN_ACUTE;
-       bindings["~C-~S-~M-dead_breve"] =           LFUN_BREVE;
-       bindings["~C-~S-~M-dead_caron"] =           LFUN_CARON;
-       bindings["~C-~S-~M-dead_cedilla"] =         LFUN_CEDILLA;
-       bindings["~C-~S-~M-dead_abovering"] =          LFUN_CIRCLE;
-       bindings["~C-~S-~M-dead_circumflex"] =      LFUN_CIRCUMFLEX;
-       bindings["~C-~S-~M-dead_abovedot"] =             LFUN_DOT;
-       bindings["~C-~S-~M-dead_grave"] =           LFUN_GRAVE;
-       bindings["~C-~S-~M-dead_doubleacute"] =     LFUN_HUNG_UMLAUT;
-       bindings["~C-~S-~M-dead_macron"] =          LFUN_MACRON;
-       // nothing with this name
-       // bindings["~C-~S-~M-dead_special_caron"] =   LFUN_SPECIAL_CARON;
-       bindings["~C-~S-~M-dead_tilde"] =           LFUN_TILDE;
-       bindings["~C-~S-~M-dead_diaeresis"] =       LFUN_UMLAUT;
-       // nothing with this name either...
-       //bindings["~C-~S-~M-dead_underbar"] =        LFUN_UNDERBAR;
-       bindings["~C-~S-~M-dead_belowdot"] =        LFUN_UNDERDOT;
-       bindings["~C-~S-~M-dead_tie"] =             LFUN_TIE;
-       bindings["~C-~S-~M-dead_ogonek"] =           LFUN_OGONEK;
-       
-       // bindings to utilize the use of the numeric keypad
-       // e.g. Num Lock set
-       bindings["KP_0"] =        LFUN_SELFINSERT;
-       bindings["KP_Decimal"] =  LFUN_SELFINSERT;
-       bindings["KP_Enter"] =    LFUN_SELFINSERT;
-       bindings["KP_1"] =        LFUN_SELFINSERT;
-       bindings["KP_2"] =        LFUN_SELFINSERT;
-       bindings["KP_3"] =        LFUN_SELFINSERT;
-       bindings["KP_4"] =        LFUN_SELFINSERT;
-       bindings["KP_5"] =        LFUN_SELFINSERT;
-       bindings["KP_6"] =        LFUN_SELFINSERT;
-       bindings["KP_Add"] =      LFUN_SELFINSERT;
-       bindings["KP_7"] =        LFUN_SELFINSERT;
-       bindings["KP_8"] =        LFUN_SELFINSERT;
-       bindings["KP_9"] =        LFUN_SELFINSERT;
-       bindings["KP_Divide"] =   LFUN_SELFINSERT;
-       bindings["KP_Multiply"] = LFUN_SELFINSERT;
-       bindings["KP_Subtract"] = LFUN_SELFINSERT;
-       
-       /* Most self-insert keys are handled in the 'default:' section of
-        * WorkAreaKeyPress - so we don't have to define them all.
-        * However keys explicit decleared as self-insert are
-        * handled seperatly (LFUN_SELFINSERT.) Lgb. */
-       
-        bindings["C-Tab"] =  LFUN_TABINSERT;  // ale970515
-}
-
 // The global instance
 LyXRC lyxrc;