-/* This file is part of
- * ======================================================
- *
- * LyX, The Document Processor
- *
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-2000 The LyX Team.
+/**
+ * \file lyxrc.C
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
- * ====================================================== */
+ * \author Lars Gullik Bjønnes
+ * \author Jean-Marc Lasgouttes
+ * \author Angus Leeming
+ * \author John Levon
+ * \author André Pönitz
+ * \author Allan Rae
+ * \author Dekel Tsur
+ *
+ * Full author contact details are available in file CREDITS.
+ */
#include <config.h>
-#ifdef __GNUG__
-#pragma implementation "lyxrc.h"
-#endif
-
#include <fstream>
-#include <iomanip>
#include <iostream>
+#include "lyxrc.h"
+
#include "debug.h"
+#include "converter.h"
+#include "format.h"
+#include "gettext.h"
+#include "lastfiles.h"
+#include "LColor.h"
+#include "lyxlex.h"
+#include "lyxfont.h"
+#include "mover.h"
+
+#include "graphics/GraphicsTypes.h"
-#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 "support/lstrings.h"
+#include "support/tostr.h"
+#include "support/userinfo.h"
+
+using lyx::support::ascii_lowercase;
+using lyx::support::bformat;
+using lyx::support::ExpandPath;
+using lyx::support::GetEnv;
+using lyx::support::LibFileSearch;
+using lyx::support::token;
-using std::ostream;
-using std::ofstream;
using std::cout;
-using std::ios;
using std::endl;
-using std::vector;
-extern LyXAction lyxaction;
-extern kb_keymap * toplevel_keymap;
+using std::ios;
+using std::ofstream;
+using std::ostream;
+using std::string;
-static
+namespace {
+
+// when adding something to this array keep it sorted!
keyword_item lyxrcTags[] = {
{ "\\accept_compound", LyXRC::RC_ACCEPT_COMPOUND },
{ "\\alternate_language", LyXRC::RC_ALT_LANG },
{ "\\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 },
+ { "\\bibtex_command", LyXRC::RC_BIBTEX_COMMAND },
{ "\\bind_file", LyXRC::RC_BINDFILE },
{ "\\check_lastfiles", LyXRC::RC_CHECKLASTFILES },
{ "\\chktex_command", LyXRC::RC_CHKTEX_COMMAND },
{ "\\converter", LyXRC::RC_CONVERTER },
+ { "\\copier", LyXRC::RC_COPIER },
{ "\\cursor_follows_scrollbar", LyXRC::RC_CURSOR_FOLLOWS_SCROLLBAR },
{ "\\custom_export_command", LyXRC::RC_CUSTOM_EXPORT_COMMAND },
{ "\\custom_export_format", LyXRC::RC_CUSTOM_EXPORT_FORMAT },
{ "\\date_insert_format", LyXRC::RC_DATE_INSERT_FORMAT },
{ "\\default_language", LyXRC::RC_DEFAULT_LANGUAGE },
{ "\\default_papersize", LyXRC::RC_DEFAULT_PAPERSIZE },
- { "\\display_shortcuts", LyXRC::RC_DISPLAY_SHORTCUTS },
+ { "\\dialogs_iconify_with_main", LyXRC::RC_DIALOGS_ICONIFY_WITH_MAIN },
+ { "\\display_graphics", LyXRC::RC_DISPLAY_GRAPHICS },
{ "\\document_path", LyXRC::RC_DOCUMENTPATH },
{ "\\escape_chars", LyXRC::RC_ESC_CHARS },
- { "\\exit_confirmation", LyXRC::RC_EXIT_CONFIRMATION },
{ "\\font_encoding", LyXRC::RC_FONT_ENCODING },
{ "\\format", LyXRC::RC_FORMAT },
+ { "\\index_command", LyXRC::RC_INDEX_COMMAND },
{ "\\input", LyXRC::RC_INPUT },
{ "\\kbmap", LyXRC::RC_KBMAP },
{ "\\kbmap_primary", LyXRC::RC_KBMAP_PRIMARY },
{ "\\language_auto_end", LyXRC::RC_LANGUAGE_AUTO_END },
{ "\\language_command_begin", LyXRC::RC_LANGUAGE_COMMAND_BEGIN },
{ "\\language_command_end", LyXRC::RC_LANGUAGE_COMMAND_END },
+ { "\\language_command_local", LyXRC::RC_LANGUAGE_COMMAND_LOCAL },
+ { "\\language_global_options", LyXRC::RC_LANGUAGE_GLOBAL_OPTIONS },
{ "\\language_package", LyXRC::RC_LANGUAGE_PACKAGE },
+ { "\\language_use_babel", LyXRC::RC_LANGUAGE_USE_BABEL },
{ "\\lastfiles", LyXRC::RC_LASTFILES },
{ "\\make_backup", LyXRC::RC_MAKE_BACKUP },
{ "\\mark_foreign_language", LyXRC::RC_MARK_FOREIGN_LANGUAGE },
- { "\\new_ask_filename", LyXRC::RC_NEW_ASK_FILENAME },
{ "\\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 },
+ { "\\preview", LyXRC::RC_PREVIEW },
+ { "\\preview_hashed_labels", LyXRC::RC_PREVIEW_HASHED_LABELS },
+ { "\\preview_scale_factor", LyXRC::RC_PREVIEW_SCALE_FACTOR },
{ "\\print_adapt_output", LyXRC::RC_PRINT_ADAPTOUTPUT },
{ "\\print_collcopies_flag", LyXRC::RC_PRINTCOLLCOPIESFLAG },
{ "\\print_command", LyXRC::RC_PRINT_COMMAND },
{ "\\print_landscape_flag", LyXRC::RC_PRINTLANDSCAPEFLAG },
{ "\\print_oddpage_flag", LyXRC::RC_PRINTODDPAGEFLAG },
{ "\\print_pagerange_flag", LyXRC::RC_PRINTPAGERANGEFLAG },
- { "\\print_paper_dimension_flag", LyXRC::RC_PRINTPAPERDIMENSIONFLAG },
- { "\\print_paper_flag", LyXRC::RC_PRINTPAPERFLAG },
+ { "\\print_paper_dimension_flag", LyXRC::RC_PRINTPAPERDIMENSIONFLAG },
+ { "\\print_paper_flag", LyXRC::RC_PRINTPAPERFLAG },
{ "\\print_reverse_flag", LyXRC::RC_PRINTREVERSEFLAG },
{ "\\print_spool_command", LyXRC::RC_PRINTSPOOL_COMMAND },
{ "\\print_spool_printerprefix", LyXRC::RC_PRINTSPOOL_PRINTERPREFIX },
{ "\\print_to_file", LyXRC::RC_PRINTTOFILE },
{ "\\print_to_printer", LyXRC::RC_PRINTTOPRINTER },
{ "\\printer", LyXRC::RC_PRINTER },
- { "\\ps_command", LyXRC::RC_PS_COMMAND },
{ "\\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_roman_foundry", LyXRC::RC_SCREEN_FONT_ROMAN_FOUNDRY },
{ "\\screen_font_sans", LyXRC::RC_SCREEN_FONT_SANS },
+ { "\\screen_font_sans_foundry", LyXRC::RC_SCREEN_FONT_SANS_FOUNDRY },
{ "\\screen_font_scalable", LyXRC::RC_SCREEN_FONT_SCALABLE },
{ "\\screen_font_sizes", LyXRC::RC_SCREEN_FONT_SIZES },
{ "\\screen_font_typewriter", LyXRC::RC_SCREEN_FONT_TYPEWRITER },
+ { "\\screen_font_typewriter_foundry", LyXRC::RC_SCREEN_FONT_TYPEWRITER_FOUNDRY },
{ "\\screen_zoom", LyXRC::RC_SCREEN_ZOOM },
{ "\\serverpipe", LyXRC::RC_SERVERPIPE },
{ "\\set_color", LyXRC::RC_SET_COLOR },
{ "\\use_escape_chars", LyXRC::RC_USE_ESC_CHARS },
{ "\\use_input_encoding", LyXRC::RC_USE_INP_ENC },
{ "\\use_personal_dictionary", LyXRC::RC_USE_PERS_DICT },
+ // compatibility with versions older than 1.4.0 only
+ { "\\use_pspell", LyXRC::RC_USE_SPELL_LIB },
+ { "\\use_spell_lib", LyXRC::RC_USE_SPELL_LIB },
+ // compatibility with versions older than 1.4.0 only
{ "\\use_tempdir", LyXRC::RC_USETEMPDIR },
+ { "\\user_email", LyXRC::RC_USER_EMAIL },
+ { "\\user_name", LyXRC::RC_USER_NAME },
{ "\\view_dvi_paper_option", LyXRC::RC_VIEWDVI_PAPEROPTION },
- { "\\viewer" ,LyXRC::RC_VIEWER},
+ // compatibility with versions older than 1.4.0 only
+ { "\\viewer" ,LyXRC::RC_VIEWER},
{ "\\wheel_jump", LyXRC::RC_WHEEL_JUMP }
};
-/* 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()
+LyXRC::LyXRC()
{
setDefaults();
}
void LyXRC::setDefaults() {
bind_file = "cua";
- hasBindFile = false;
ui_file = "default";
// Get printer from the environment. If fail, use default "",
// assuming that everything is set up correctly.
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";
- default_papersize = BufferParams::PAPER_USLETTER;
+ view_dvi_paper_option.erase();
+ default_papersize = PAPER_USLETTER;
custom_export_format = "ps";
chktex_command = "chktex -n1 -n3 -n6 -n9 -n22 -n25 -n30 -n38";
+ bibtex_command = "bibtex";
fontenc = "default";
+ index_command = "makeindex -c -q";
dpi = 75;
// Because a screen typically is wider than a piece of paper:
zoom = 150;
- wheel_jump = 100;
+ wheel_jump = 5;
// Default LaTeX font size:
font_sizes[LyXFont::SIZE_TINY] = 5.0;
font_sizes[LyXFont::SIZE_SCRIPT] = 7.0;
font_sizes[LyXFont::SIZE_HUGE] = 20.74;
font_sizes[LyXFont::SIZE_HUGER] = 24.88;
use_scalable_fonts = true;
- roman_font_name = "-*-times";
- sans_font_name = "-*-helvetica";
- typewriter_font_name = "-*-courier";
- menu_font_name = "-*-helvetica-bold-r";
- popup_font_name = "-*-helvetica-medium-r";
+ roman_font_name = "";
+ sans_font_name = "";
+ typewriter_font_name = "";
+ 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 = "";
- override_x_deadkeys = true;
+ popup_font_encoding.erase();
autosave = 300;
auto_region_delete = true;
+ auto_reset_options = false;
ascii_linelen = 65;
- num_lastfiles = 4;
+ num_lastfiles = maxlastfiles;
check_lastfiles = true;
make_backup = true;
- backupdir_path = "";
- exit_confirmation = true;
- display_shortcuts = true;
+ backupdir_path.erase();
+ display_graphics = lyx::graphics::ColorDisplay;
// Spellchecker settings:
+ use_spell_lib = true;
isp_command = "ispell";
isp_accept_compound = false;
isp_use_input_encoding = false;
rtl_support = false;
auto_number = true;
mark_foreign_language = true;
- language_package = "\\usepackage{babel}";
language_auto_begin = true;
language_auto_end = true;
+ language_global_options = true;
+ 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";
- //
- new_ask_filename = false;
+ show_banner = true;
//
date_insert_format = "%A, %e %B %Y";
- show_banner = true;
cursor_follows_scrollbar = false;
+ dialogs_iconify_with_main = false;
label_init_length = 3;
+ preview = PREVIEW_OFF;
+ preview_hashed_labels = false;
+ preview_scale_factor = 0.9;
+
+ user_name = lyx::support::user_name();
- /// These variables are not stored on disk (perhaps they
- // should be moved from the LyXRC class).
- use_gui = true;
- pdf_mode = false;
+ user_email = lyx::support::user_email();
}
-int LyXRC::ReadBindFile(string const & name)
-{
- hasBindFile = true;
- string const tmp = i18nLibFileSearch("bind", name, "bind");
- lyxerr[Debug::LYXRC] << "Reading bindfile:" << tmp << endl;
- int const result = read(tmp);
- if (result) {
- lyxerr << "Error reading bind file: " << tmp << endl;
- }
- return result;
-}
+namespace {
-void LyXRC::readBindFileIfNeeded()
+void oldFontFormat(string & family, string & foundry)
{
- if (!hasBindFile)
- ReadBindFile(bind_file);
+ if (family.empty() || family[0] != '-')
+ return;
+ foundry = token(family, '-', 1);
+ family = token(family, '-', 2);
+ if (foundry == "*")
+ foundry.erase();
}
+} // namespace anon
+
+
int LyXRC::read(string const & filename)
-{
+{
LyXLex lexrc(lyxrcTags, lyxrcCount);
if (lyxerr.debugging(Debug::PARSER))
lexrc.printTable(lyxerr);
-
+
lexrc.setFile(filename);
- if (!lexrc.IsOK()) return -2;
-
- lyxerr[Debug::INIT] << "Reading '" << filename << "'..." << endl;
-
- while (lexrc.IsOK()) {
+ if (!lexrc.isOK()) return -2;
+
+ lyxerr[Debug::LYXRC] << "Reading '" << filename << "'..." << endl;
+
+ return read(lexrc);
+}
+
+
+int LyXRC::read(std::istream & is)
+{
+ LyXLex lexrc(lyxrcTags, lyxrcCount);
+ if (lyxerr.debugging(Debug::PARSER))
+ lexrc.printTable(lyxerr);
+
+ lexrc.setStream(is);
+ if (!lexrc.isOK()) return -2;
+
+ lyxerr[Debug::LYXRC] << "Reading istream..." << endl;
+
+ return read(lexrc);
+}
+
+
+int LyXRC::read(LyXLex & lexrc)
+{
+ if (!lexrc.isOK()) return -2;
+
+ 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.
switch (le) {
case LyXLex::LEX_UNDEF:
lexrc.printError("Unknown tag `$$Token'");
- continue;
+ continue;
case LyXLex::LEX_FEOF:
- continue;
+ continue;
default: break;
}
switch (static_cast<LyXRCTags>(le)) {
case RC_INPUT: // Include file
- if (lexrc.next()) {
- string tmp = LibFileSearch(string(),
- lexrc.GetString());
+ if (lexrc.next()) {
+ string const tmp =
+ LibFileSearch(string(),
+ lexrc.getString());
if (read(tmp)) {
lexrc.printError("Error reading "
"included file: "+tmp);
break;
case RC_BINDFILE: // RVDK_PATCH_5
if (lexrc.next()) {
- string tmp(lexrc.GetString());
- if (hasBindFile)
- // We are already in the
- // "actually read bind file"
- // mode.
- ReadBindFile(tmp);
- else
- // We are still in the "just
- // remember the name of the
- // bind file" mode.
- bind_file = tmp;
+ bind_file = lexrc.getString();
}
break;
-
- case RC_UIFILE:
+
+ 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();
+
+ case RC_AUTORESET_OPTIONS:
+ if (lexrc.next()) {
+ auto_reset_options = lexrc.getBool();
+ }
break;
-
- case RC_DISPLAY_SHORTCUTS:
- if (lexrc.next())
- display_shortcuts = lexrc.GetBool();
+
+ case RC_DISPLAY_GRAPHICS:
+ if (lexrc.next()) {
+ display_graphics = lyx::graphics::displayTranslator().find(lexrc.getString());
+ }
break;
-
+
case RC_KBMAP:
- if (lexrc.next())
- use_kbmap = lexrc.GetBool();
+ if (lexrc.next()) {
+ 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,
- "kmap").empty())
+ } else if (!LibFileSearch("kbd", kmap,
+ "kmap").empty()) {
primary_kbmap = kmap;
- else
+ } else {
lexrc.printError("LyX: Keymap `$$Token' not found");
+ }
}
break;
-
+
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,
- "kmap").empty())
+ } else if (!LibFileSearch("kbd", kmap,
+ "kmap").empty()) {
secondary_kbmap = kmap;
- else
+ } else {
lexrc.printError("LyX: Keymap `$$Token' not found");
+ }
}
break;
-
+
case RC_FONT_ENCODING:
- if (lexrc.next())
- fontenc = lexrc.GetString();
+ if (lexrc.next()) {
+ fontenc = lexrc.getString();
+ }
break;
-
+
case RC_PRINTER:
- if (lexrc.next())
- printer = lexrc.GetString();
+ if (lexrc.next()) {
+ printer = lexrc.getString();
+ }
break;
-
+
case RC_PRINT_COMMAND:
- if (lexrc.next())
- print_command = lexrc.GetString();
+ if (lexrc.next()) {
+ print_command = lexrc.getString();
+ }
break;
-
+
case RC_PRINTEVENPAGEFLAG:
- if (lexrc.next())
- print_evenpage_flag = lexrc.GetString();
+ if (lexrc.next()) {
+ print_evenpage_flag = lexrc.getString();
+ }
break;
-
+
case RC_PRINTODDPAGEFLAG:
- if (lexrc.next())
- print_oddpage_flag = lexrc.GetString();
+ if (lexrc.next()) {
+ print_oddpage_flag = lexrc.getString();
+ }
break;
-
+
case RC_PRINTPAGERANGEFLAG:
- if (lexrc.next())
- print_pagerange_flag = lexrc.GetString();
+ if (lexrc.next()) {
+ print_pagerange_flag = lexrc.getString();
+ }
break;
-
+
case RC_PRINTCOPIESFLAG:
- if (lexrc.next())
- print_copies_flag = lexrc.GetString();
+ if (lexrc.next()) {
+ print_copies_flag = lexrc.getString();
+ }
break;
-
+
case RC_PRINTCOLLCOPIESFLAG:
- if (lexrc.next())
- print_collcopies_flag = lexrc.GetString();
+ if (lexrc.next()) {
+ print_collcopies_flag = lexrc.getString();
+ }
break;
-
+
case RC_PRINTREVERSEFLAG:
- if (lexrc.next())
- print_reverse_flag = lexrc.GetString();
+ if (lexrc.next()) {
+ print_reverse_flag = lexrc.getString();
+ }
break;
-
+
case RC_PRINTLANDSCAPEFLAG:
- if (lexrc.next())
- print_landscape_flag = lexrc.GetString();
+ if (lexrc.next()) {
+ print_landscape_flag = lexrc.getString();
+ }
break;
-
+
case RC_PRINTTOPRINTER:
- if (lexrc.next())
- print_to_printer = lexrc.GetString();
+ if (lexrc.next()) {
+ print_to_printer = lexrc.getString();
+ }
break;
-
+
case RC_PRINT_ADAPTOUTPUT:
- if (lexrc.next())
- print_adapt_output = lexrc.GetBool();
+ if (lexrc.next()) {
+ print_adapt_output = lexrc.getBool();
+ }
break;
-
+
case RC_PRINTTOFILE:
- if (lexrc.next())
- print_to_file = lexrc.GetString();
+ if (lexrc.next()) {
+ print_to_file = lexrc.getString();
+ }
break;
-
+
case RC_PRINTFILEEXTENSION:
- if (lexrc.next())
- print_file_extension = lexrc.GetString();
+ if (lexrc.next()) {
+ print_file_extension = lexrc.getString();
+ }
break;
-
+
case RC_PRINTEXSTRAOPTIONS:
- if (lexrc.next())
- print_extra_options = lexrc.GetString();
+ if (lexrc.next()) {
+ print_extra_options = lexrc.getString();
+ }
break;
-
+
case RC_PRINTSPOOL_COMMAND:
- if (lexrc.next())
- print_spool_command = lexrc.GetString();
+ if (lexrc.next()) {
+ print_spool_command = lexrc.getString();
+ }
break;
-
+
case RC_PRINTSPOOL_PRINTERPREFIX:
- if (lexrc.next())
- print_spool_printerprefix = lexrc.GetString();
+ if (lexrc.next()) {
+ print_spool_printerprefix = lexrc.getString();
+ }
break;
-
- case RC_PRINTPAPERDIMENSIONFLAG:
- if (lexrc.next())
- print_paper_dimension_flag = lexrc.GetString();
+
+ case RC_PRINTPAPERDIMENSIONFLAG:
+ if (lexrc.next()) {
+ print_paper_dimension_flag = lexrc.getString();
+ }
break;
-
- case RC_PRINTPAPERFLAG:
- if (lexrc.next())
- print_paper_flag = lexrc.GetString();
+
+ case RC_PRINTPAPERFLAG:
+ if (lexrc.next()) {
+ print_paper_flag = lexrc.getString();
+ }
break;
-
+
case RC_CUSTOM_EXPORT_COMMAND:
- if (lexrc.next())
- custom_export_command = lexrc.GetString();
+ if (lexrc.next()) {
+ custom_export_command = lexrc.getString();
+ }
break;
-
+
case RC_CUSTOM_EXPORT_FORMAT:
- if (lexrc.next())
- custom_export_format = lexrc.GetString();
+ if (lexrc.next()) {
+ custom_export_format = lexrc.getString();
+ }
break;
case RC_DEFAULT_PAPERSIZE:
- if (lexrc.next()) {
- string size = lowercase(lexrc.GetString());
+ if (lexrc.next()) {
+ string const size =
+ ascii_lowercase(lexrc.getString());
if (size == "usletter")
- default_papersize =
- BufferParams::PAPER_USLETTER;
+ default_papersize =
+ PAPER_USLETTER;
else if (size == "legal")
- default_papersize =
- BufferParams::PAPER_LEGALPAPER;
+ default_papersize =
+ PAPER_LEGALPAPER;
else if (size == "executive")
- default_papersize =
- BufferParams::PAPER_EXECUTIVEPAPER;
+ default_papersize =
+ PAPER_EXECUTIVEPAPER;
else if (size == "a3")
- default_papersize =
- BufferParams::PAPER_A3PAPER;
+ default_papersize =
+ PAPER_A3PAPER;
else if (size == "a4")
- default_papersize =
- BufferParams::PAPER_A4PAPER;
+ default_papersize =
+ PAPER_A4PAPER;
else if (size == "a5")
- default_papersize =
- BufferParams::PAPER_A5PAPER;
+ default_papersize =
+ PAPER_A5PAPER;
else if (size == "b5")
- default_papersize =
- BufferParams::PAPER_B5PAPER;
+ default_papersize =
+ PAPER_B5PAPER;
}
break;
case RC_VIEWDVI_PAPEROPTION:
- if (lexrc.next())
- view_dvi_paper_option = lexrc.GetString();
- else
- view_dvi_paper_option = "";
+ if (lexrc.next()) {
+ view_dvi_paper_option = lexrc.getString();
+ } else {
+ view_dvi_paper_option.erase();
+ }
break;
- case RC_PS_COMMAND:
- if (lexrc.next())
- ps_command = lexrc.GetString();
- break;
-
case RC_CHKTEX_COMMAND:
- if (lexrc.next())
- chktex_command = lexrc.GetString();
+ if (lexrc.next()) {
+ chktex_command = lexrc.getString();
+ }
+ break;
+
+ case RC_BIBTEX_COMMAND:
+ if (lexrc.next()) {
+ bibtex_command = lexrc.getString();
+ }
+ break;
+
+ case RC_INDEX_COMMAND:
+ if (lexrc.next()) {
+ index_command = lexrc.getString();
+ }
break;
-
+
case RC_SCREEN_DPI:
- if (lexrc.next())
- dpi = lexrc.GetInteger();
+ if (lexrc.next()) {
+ dpi = lexrc.getInteger();
+ }
break;
-
+
case RC_SCREEN_ZOOM:
- if (lexrc.next())
- zoom = lexrc.GetInteger();
+ if (lexrc.next()) {
+ zoom = lexrc.getInteger();
+ }
break;
case RC_WHEEL_JUMP:
- if (lexrc.next())
- wheel_jump = lexrc.GetInteger();
+ if (lexrc.next()) {
+ wheel_jump = lexrc.getInteger();
+ }
break;
-
+
case RC_SCREEN_FONT_SIZES:
- if (lexrc.next())
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_TINY] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_SCRIPT] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_FOOTNOTE] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_SMALL] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_NORMAL] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_LARGE] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_LARGER] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_LARGEST] =
- lexrc.GetFloat();
- if (lexrc.next())
+ lexrc.getFloat();
+ }
+ if (lexrc.next()) {
font_sizes[LyXFont::SIZE_HUGE] =
- lexrc.GetFloat();
- if (lexrc.next())
+ 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();
+
+ case RC_SCREEN_FONT_SCALABLE:
+ if (lexrc.next()) {
+ use_scalable_fonts = lexrc.getBool();
+ }
break;
-
+
case RC_AUTOSAVE:
- if (lexrc.next())
- autosave = lexrc.GetInteger();
+ if (lexrc.next()) {
+ 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());
+ if (lexrc.next()) {
+ template_path = ExpandPath(lexrc.getString());
+ }
break;
-
+
case RC_TEMPDIRPATH:
- if (lexrc.next())
- tempdir_path = ExpandPath(lexrc.GetString());
+ if (lexrc.next()) {
+ tempdir_path = ExpandPath(lexrc.getString());
+ }
break;
-
+
case RC_USETEMPDIR:
- if (lexrc.next())
- use_tempdir = lexrc.GetBool();
+ if (lexrc.next()) {
+ lyxerr << "Ignoring obsolete use_tempdir flag." << endl;
+ }
break;
-
+
case RC_LASTFILES:
- if (lexrc.next())
- lastfiles = ExpandPath(lexrc.GetString());
+ if (lexrc.next()) {
+ lastfiles = ExpandPath(lexrc.getString());
+ }
break;
-
- case RC_NUMLASTFILES:
- if (lexrc.next())
- num_lastfiles = lexrc.GetInteger();
+
+ case RC_NUMLASTFILES:
+ if (lexrc.next()) {
+ num_lastfiles = lexrc.getInteger();
+ }
break;
-
- case RC_CHECKLASTFILES:
- if (lexrc.next())
- check_lastfiles = lexrc.GetBool();
+
+ case RC_CHECKLASTFILES:
+ if (lexrc.next()) {
+ check_lastfiles = lexrc.getBool();
+ }
break;
-
+
case RC_SCREEN_FONT_ROMAN:
- if (lexrc.next())
- roman_font_name = lexrc.GetString();
+ if (lexrc.next()) {
+ roman_font_name = lexrc.getString();
+ oldFontFormat(roman_font_name,
+ roman_font_foundry);
+ }
break;
-
+
case RC_SCREEN_FONT_SANS:
- if (lexrc.next())
- sans_font_name = lexrc.GetString();
+ if (lexrc.next()) {
+ sans_font_name = lexrc.getString();
+ oldFontFormat(sans_font_name, sans_font_foundry);
+ }
break;
-
+
case RC_SCREEN_FONT_TYPEWRITER:
- if (lexrc.next())
- typewriter_font_name = lexrc.GetString();
+ if (lexrc.next()) {
+ typewriter_font_name = lexrc.getString();
+ oldFontFormat(typewriter_font_name,
+ typewriter_font_foundry);
+ }
break;
-
- case RC_SCREEN_FONT_MENU:
- if (lexrc.next())
- menu_font_name = lexrc.GetString();
+
+ case RC_SCREEN_FONT_ROMAN_FOUNDRY:
+ if (lexrc.next()) {
+ roman_font_foundry = lexrc.getString();
+ }
break;
-
- case RC_SCREEN_FONT_POPUP:
- if (lexrc.next())
- popup_font_name = lexrc.GetString();
+
+ case RC_SCREEN_FONT_SANS_FOUNDRY:
+ if (lexrc.next()) {
+ sans_font_foundry = lexrc.getString();
+ }
+ break;
+
+ case RC_SCREEN_FONT_TYPEWRITER_FOUNDRY:
+ if (lexrc.next()) {
+ typewriter_font_foundry = 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:
- if (lexrc.next())
- font_norm_menu = lexrc.GetString();
+ 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()) {
+ popup_font_encoding = lexrc.getString();
+ }
break;
case RC_SET_COLOR:
{
string lyx_name, x11_name;
- if (lexrc.next()) {
- lyx_name = lexrc.GetString();
+ if (lexrc.next()) {
+ 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'");
+ lexrc.printError("Missing color name for color: `$$Token'");
break;
}
- if (!lcolor.setColor(lyx_name, x11_name))
+ LColor::color const col =
+ lcolor.getFromLyXName(lyx_name);
+ if (col == LColor::none ||
+ col == LColor::inherit ||
+ col == LColor::ignore)
+ break;
+
+ if (!lcolor.setColor(col, x11_name)) {
lyxerr << "Bad lyxrc set_color for "
<< lyx_name << endl;
+ }
break;
}
case RC_AUTOREGIONDELETE:
// Auto region delete defaults to true
- if (lexrc.next())
- auto_region_delete = lexrc.GetBool();
- break;
-
- case RC_BIND:
- {
- // we should not do an explicit binding before
- // loading a bind file. So, in this case, load
- // the default bind file.
- readBindFileIfNeeded();
-
- // !!!chb, dynamic key binding...
- int action, res = 0;
- string seq, cmd;
-
- if (lexrc.lex() == LyXLex::LEX_DATA) {
- seq = lexrc.GetString();
- } else {
- lexrc.printError("Bad key sequence: `$$Token'");
- break;
- }
-
- if (lexrc.lex() == LyXLex::LEX_DATA) {
- cmd = lexrc.GetString();
- } else {
- lexrc.printError("Bad command: `$$Token'");
- break;
- }
-
- if ((action = lyxaction.LookupFunc(cmd))>= 0) {
- if (lyxerr.debugging(Debug::KBMAP)) {
- lyxerr << "RC_BIND: Sequence `"
- << seq << "' Command `"
- << cmd << "' Action `"
- << action << '\'' << endl;
- }
- res = toplevel_keymap->bind(seq, action);
- if (res != 0) {
- lexrc.printError(
- "Invalid key sequence `"
- + seq + '\'');
- }
- } else {// cmd is the last token read.
- lexrc.printError(
- "Unknown LyX function `$$Token'");
+ if (lexrc.next()) {
+ auto_region_delete = lexrc.getBool();
}
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());
+ if (lexrc.next()) {
+ lyxpipes = ExpandPath(lexrc.getString());
+ }
break;
-
+
case RC_CURSOR_FOLLOWS_SCROLLBAR:
- if (lexrc.next())
- cursor_follows_scrollbar = lexrc.GetBool();
+ if (lexrc.next()) {
+ 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();
+ if (lexrc.next()) {
+ ascii_roff_command = lexrc.getString();
+ }
break;
case RC_ASCII_LINELEN:
- if (lexrc.next())
- ascii_linelen = lexrc.GetInteger();
+ if (lexrc.next()) {
+ ascii_linelen = lexrc.getInteger();
+ }
break;
// Spellchecker settings:
+ case RC_USE_SPELL_LIB:
+ if (lexrc.next()) {
+ use_spell_lib = lexrc.getBool();
+ }
+ break;
case RC_SPELL_COMMAND:
- if (lexrc.next())
- isp_command = lexrc.GetString();
+ if (lexrc.next()) {
+ isp_command = lexrc.getString();
+ }
break;
case RC_ACCEPT_COMPOUND:
- if (lexrc.next())
- isp_accept_compound = lexrc.GetBool();
+ if (lexrc.next()) {
+ isp_accept_compound = lexrc.getBool();
+ }
break;
case RC_USE_INP_ENC:
- if (lexrc.next())
- isp_use_input_encoding = lexrc.GetBool();
+ if (lexrc.next()) {
+ isp_use_input_encoding = lexrc.getBool();
+ }
break;
case RC_USE_ALT_LANG:
- if (lexrc.next())
- isp_use_alt_lang = lexrc.GetBool();
+ if (lexrc.next()) {
+ isp_use_alt_lang = lexrc.getBool();
+ }
break;
case RC_USE_PERS_DICT:
- if (lexrc.next())
- isp_use_pers_dict = lexrc.GetBool();
+ if (lexrc.next()) {
+ isp_use_pers_dict = lexrc.getBool();
+ }
break;
case RC_USE_ESC_CHARS:
- if (lexrc.next())
- isp_use_esc_chars = lexrc.GetBool();
+ if (lexrc.next()) {
+ isp_use_esc_chars = lexrc.getBool();
+ }
break;
case RC_ALT_LANG:
- if (lexrc.next())
- isp_alt_lang = lexrc.GetString();
+ if (lexrc.next()) {
+ isp_alt_lang = lexrc.getString();
+ }
break;
case RC_PERS_DICT:
- if (lexrc.next())
- isp_pers_dict = lexrc.GetString();
+ if (lexrc.next()) {
+ isp_pers_dict = lexrc.getString();
+ }
break;
case RC_ESC_CHARS:
- if (lexrc.next())
- isp_esc_chars = lexrc.GetString();
+ if (lexrc.next()) {
+ isp_esc_chars = lexrc.getString();
+ }
break;
case RC_MAKE_BACKUP:
- if (lexrc.next())
- make_backup = lexrc.GetBool();
+ if (lexrc.next()) {
+ make_backup = lexrc.getBool();
+ }
break;
case RC_BACKUPDIR_PATH:
- if (lexrc.next())
- backupdir_path = ExpandPath(lexrc.GetString());
+ if (lexrc.next()) {
+ backupdir_path = ExpandPath(lexrc.getString());
+ }
break;
case RC_DATE_INSERT_FORMAT:
- if (lexrc.next())
- date_insert_format = lexrc.GetString();
+ if (lexrc.next()) {
+ date_insert_format = lexrc.getString();
+ }
break;
case RC_LANGUAGE_PACKAGE:
- if (lexrc.next())
- language_package = lexrc.GetString();
+ if (lexrc.next()) {
+ language_package = lexrc.getString();
+ }
break;
case RC_LANGUAGE_AUTO_BEGIN:
- if (lexrc.next())
- language_auto_begin = lexrc.GetBool();
+ if (lexrc.next()) {
+ language_auto_begin = lexrc.getBool();
+ }
break;
case RC_LANGUAGE_AUTO_END:
- if (lexrc.next())
- language_auto_end = lexrc.GetBool();
+ if (lexrc.next()) {
+ language_auto_end = lexrc.getBool();
+ }
+ break;
+ case RC_LANGUAGE_GLOBAL_OPTIONS:
+ if (lexrc.next()) {
+ language_global_options = lexrc.getBool();
+ }
+ break;
+ case RC_LANGUAGE_USE_BABEL:
+ if (lexrc.next()) {
+ language_use_babel = lexrc.getBool();
+ }
break;
case RC_LANGUAGE_COMMAND_BEGIN:
- if (lexrc.next())
- language_command_begin = lexrc.GetString();
+ if (lexrc.next()) {
+ language_command_begin = lexrc.getString();
+ }
break;
case RC_LANGUAGE_COMMAND_END:
- if (lexrc.next())
- language_command_end = lexrc.GetString();
+ if (lexrc.next()) {
+ language_command_end = lexrc.getString();
+ }
+ break;
+ case RC_LANGUAGE_COMMAND_LOCAL:
+ if (lexrc.next()) {
+ language_command_local = lexrc.getString();
+ }
break;
case RC_RTL_SUPPORT:
- if (lexrc.next())
- rtl_support = lexrc.GetBool();
+ if (lexrc.next()) {
+ rtl_support = lexrc.getBool();
+ }
break;
case RC_AUTO_NUMBER:
- if (lexrc.next())
- auto_number = lexrc.GetBool();
+ 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();
+ if (lexrc.next()) {
+ mark_foreign_language = lexrc.getBool();
+ }
break;
-
- case RC_NEW_ASK_FILENAME:
- if (lexrc.next())
- new_ask_filename = lexrc.GetBool();
+
+ case RC_COPIER: {
+ string fmt, command;
+ if (lexrc.next()) {
+ fmt = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ command = lexrc.getString();
+ }
+ movers.set(fmt, command);
break;
+ }
+
case RC_CONVERTER: {
string from, to, command, flags;
- if (lexrc.next())
- from = lexrc.GetString();
- if (lexrc.next())
- to = lexrc.GetString();
- if (lexrc.next())
- command = lexrc.GetString();
- if (lexrc.next())
- flags = lexrc.GetString();
- if (command.empty() || command == "none")
- converters.Delete(from, to);
- else
- converters.Add(from, to, command, flags);
+ if (lexrc.next()) {
+ from = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ to = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ command = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ flags = lexrc.getString();
+ }
+ if (command.empty()
+ || token(command, ' ', 0) == "none") {
+ converters.erase(from, to);
+ } else {
+ converters.add(from, to, command, flags);
+ }
break;
}
+ // compatibility with versions older than 1.4.0 only
case RC_VIEWER: {
string format, command;
- if (lexrc.next())
- format = lexrc.GetString();
- if (lexrc.next())
- command = lexrc.GetString();
- formats.SetViewer(format, command);
+ if (lexrc.next()) {
+ format = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ command = lexrc.getString();
+ if (token(command, ' ', 0) == "none")
+ command.erase();
+ }
+ formats.setViewer(format, command);
break;
}
case RC_FORMAT: {
string format, extension, prettyname, shortcut;
- if (lexrc.next())
- format = lexrc.GetString();
- if (lexrc.next())
- extension = lexrc.GetString();
- if (lexrc.next())
- prettyname = lexrc.GetString();
- if (lexrc.next())
- shortcut = lexrc.GetString();
+ if (lexrc.next()) {
+ format = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ extension = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ prettyname = lexrc.getString();
+ }
+ if (lexrc.next()) {
+ shortcut = lexrc.getString();
+ }
+ string viewer, editor;
+ // Hack to ensure compatibility with versions older
+ // than 1.4.0
+ int le = lexrc.lex();
+ if (le != LyXLex::LEX_FEOF && le != LyXLex::LEX_UNDEF) {
+ viewer = lexrc.getString();
+ if (le == LyXLex::LEX_DATA) {
+ if (token(viewer, ' ', 0) == "none")
+ viewer.erase();
+ if (lexrc.next()) {
+ editor = lexrc.getString();
+ if (token(editor, ' ', 0) == "none")
+ editor.erase();
+ }
+ } else {
+ // We have got a known token.
+ // Therefore this is an old style
+ // format definition without
+ // viewer and editor.
+ lexrc.pushToken(viewer);
+ viewer.erase();
+ }
+ }
if (prettyname.empty()) {
- if (converters.FormatIsUsed(format))
+ if (converters.formatIsUsed(format)) {
lyxerr << "Can't delete format "
<< format << endl;
- else
- formats.Delete(format);
-
- } else
- formats.Add(format, extension, prettyname,
- shortcut);
+ } else {
+ formats.erase(format);
+ }
+ } else {
+ formats.add(format, extension, prettyname,
+ shortcut, viewer, editor);
+ }
break;
}
case RC_DEFAULT_LANGUAGE:
- if (lexrc.next())
- default_language = lexrc.GetString();
+ if (lexrc.next()) {
+ default_language = lexrc.getString();
+ }
break;
case RC_LABEL_INIT_LENGTH:
+ if (lexrc.next()) {
+ label_init_length = lexrc.getInteger();
+ }
+ break;
+
+ case RC_SHOW_BANNER:
+ if (lexrc.next()) {
+ show_banner = lexrc.getBool();
+ }
+ break;
+
+ case RC_PREVIEW:
+ if (lexrc.next()) {
+ string const tmp = lexrc.getString();
+ if (tmp == "true" || tmp == "on")
+ preview = PREVIEW_ON;
+ else if (tmp == "no_math")
+ preview = PREVIEW_NO_MATH;
+ else {
+ preview = PREVIEW_OFF;
+ if (tmp != "false" && tmp != "off")
+ lyxerr << "Unrecognized "
+ "preview status \""
+ << tmp << '\n' << endl;
+ }
+ }
+ break;
+
+ case RC_PREVIEW_HASHED_LABELS:
+ if (lexrc.next()) {
+ preview_hashed_labels = lexrc.getBool();
+ }
+ break;
+
+ case RC_PREVIEW_SCALE_FACTOR:
+ if (lexrc.next()) {
+ preview_scale_factor = lexrc.getFloat();
+ }
+ break;
+
+ case RC_USER_NAME:
+ if (lexrc.next())
+ user_name = lexrc.getString();
+ break;
+
+ case RC_USER_EMAIL:
if (lexrc.next())
- label_init_length = lexrc.GetInteger();
+ user_email = lexrc.getString();
break;
case RC_LAST: break; // this is just a dummy
}
/// Update converters data-structures
- converters.Update(formats);
- converters.BuildGraph();
+ converters.update(formats);
+ converters.buildGraph();
return 0;
}
-void LyXRC::write(string const & filename) const
+void LyXRC::write(string const & filename, bool ignore_system_lyxrc) const
{
ofstream ofs(filename.c_str());
if (ofs)
- output(ofs);
+ write(ofs, ignore_system_lyxrc);
}
void LyXRC::print() const
{
if (lyxerr.debugging())
- output(lyxerr);
+ write(lyxerr, false);
else
- output(cout);
+ write(cout, false);
}
-void LyXRC::output(ostream & os) const
+struct SameMover {
+ typedef std::pair<std::string, SpecialisedMover> Data;
+
+ SameMover(Data const & comparison)
+ : comparison_(comparison) {}
+
+ bool operator()(Data const & data) const
+ {
+ return data.first == comparison_.first &&
+ data.second.command() == comparison_.second.command();
+ }
+
+private:
+ Data comparison_;
+};
+
+
+void LyXRC::write(ostream & os, bool ignore_system_lyxrc) const
{
os << "### This file is part of\n"
<< "### ========================================================\n"
<< "### 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"
<< "# This file is written by LyX, if you want to make your own\n"
<< "# modifications you should do them from inside LyX and save\n"
<< "\n";
-
+
// Why the switch you might ask. It is a trick to ensure that all
// the elements in the LyXRCTags enum is handled. As you can see
// there are no breaks at all. So it is just a huge fall-through.
case RC_LAST:
case RC_INPUT:
// input/include files are not done here
- case RC_BIND:
- // bindings is not written to the preferences file.
case RC_BINDFILE:
- if (bind_file != system_lyxrc.bind_file) {
+ if (ignore_system_lyxrc ||
+ bind_file != system_lyxrc.bind_file) {
os << "\\bind_file " << bind_file << "\n";
}
//
os << "\n#\n"
<< "# MISC SECTION ######################################\n"
<< "#\n\n";
-
- case RC_SHOW_BANNER:
- if (show_banner != system_lyxrc.show_banner) {
- os << "# Set to false to inhibit the startup banner.\n"
- << "\\show_banner " << tostr(show_banner) << "\n";
- }
+
// bind files are not done here.
case RC_UIFILE:
- if (ui_file != system_lyxrc.ui_file) {
+ if (ignore_system_lyxrc ||
+ ui_file != system_lyxrc.ui_file) {
os << "\\ui_file \"" << ui_file << "\"\n";
}
case RC_AUTOREGIONDELETE:
- if (auto_region_delete != system_lyxrc.auto_region_delete) {
+ if (ignore_system_lyxrc ||
+ auto_region_delete != system_lyxrc.auto_region_delete) {
os << "# Set to false to inhibit automatic replacement of\n"
<< "# the current selection.\n"
<< "\\auto_region_delete " << tostr(auto_region_delete)
- << "\n";
+ << '\n';
+ }
+ case RC_AUTORESET_OPTIONS:
+ if (ignore_system_lyxrc ||
+ 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) {
+ if (ignore_system_lyxrc ||
+ autosave != system_lyxrc.autosave) {
os << "# The time interval between auto-saves in seconds.\n"
- << "\\autosave " << autosave << "\n";
- }
- case RC_EXIT_CONFIRMATION:
- if (exit_confirmation != system_lyxrc.exit_confirmation) {
- os << "# Ask for confirmation before exit if there are\n"
- << "# unsaved changed documents.\n"
- << "\\exit_confirmation " << tostr(exit_confirmation)
- << "\n";
- }
- case RC_DISPLAY_SHORTCUTS:
- if (display_shortcuts != system_lyxrc.display_shortcuts) {
- os << "# Display name of the last command executed,\n"
- << "# with a list of short-cuts in the minibuffer.\n"
- << "\\display_shortcuts " << tostr(display_shortcuts)
- << "\n";
+ << "\\autosave " << autosave << '\n';
+ }
+ case RC_DISPLAY_GRAPHICS:
+ if (ignore_system_lyxrc ||
+ display_graphics != system_lyxrc.display_graphics) {
+ os << "# Display graphics within LyX\n"
+ << "# monochrome|grayscale|color|none\n"
+ << "\\display_graphics "
+ << lyx::graphics::displayTranslator().find(display_graphics)
+ << '\n';
}
+
case RC_VIEWDVI_PAPEROPTION:
- if (view_dvi_paper_option
+ if (ignore_system_lyxrc ||
+ 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";
}
case RC_DEFAULT_PAPERSIZE:
- if (default_papersize != system_lyxrc.default_papersize) {
+ if (ignore_system_lyxrc ||
+ default_papersize != system_lyxrc.default_papersize) {
os << "# The default papersize to use.\n"
<< "\\default_papersize \"";
switch (default_papersize) {
- case BufferParams::PAPER_USLETTER:
+ case PAPER_USLETTER:
os << "usletter"; break;
- case BufferParams::PAPER_LEGALPAPER:
+ case PAPER_LEGALPAPER:
os << "legal"; break;
- case BufferParams::PAPER_EXECUTIVEPAPER:
+ case PAPER_EXECUTIVEPAPER:
os << "executive"; break;
- case BufferParams::PAPER_A3PAPER:
+ case PAPER_A3PAPER:
os << "a3"; break;
- case BufferParams::PAPER_A4PAPER:
+ case PAPER_A4PAPER:
os << "a4"; break;
- case BufferParams::PAPER_A5PAPER:
+ case PAPER_A5PAPER:
os << "a5"; break;
- case BufferParams::PAPER_B5PAPER:
+ case PAPER_B5PAPER:
os << "b5"; break;
- case BufferParams::PAPER_DEFAULT: break;
+ case PAPER_DEFAULT: break;
}
os << "\"\n";
}
- case RC_PS_COMMAND:
- if (ps_command != system_lyxrc.ps_command) {
- os << "# Program used for interpreting postscript.\n"
- << "\\ps_command \"" << ps_command << "\"\n";
- }
case RC_CHKTEX_COMMAND:
- if (chktex_command != system_lyxrc.chktex_command) {
+ if (ignore_system_lyxrc ||
+ chktex_command != system_lyxrc.chktex_command) {
os << "\\chktex_command \"" << chktex_command << "\"\n";
}
+ case RC_BIBTEX_COMMAND:
+ if (ignore_system_lyxrc ||
+ bibtex_command != system_lyxrc.bibtex_command) {
+ os << "\\bibtex_command \"" << bibtex_command << "\"\n";
+ }
+ case RC_INDEX_COMMAND:
+ if (ignore_system_lyxrc ||
+ index_command != system_lyxrc.index_command) {
+ os << "\\index_command \"" << index_command << "\"\n";
+ }
case RC_KBMAP:
- if (use_kbmap != system_lyxrc.use_kbmap) {
- os << "\\kbmap " << tostr(use_kbmap) << "\n";
+ if (ignore_system_lyxrc ||
+ use_kbmap != system_lyxrc.use_kbmap) {
+ os << "\\kbmap " << tostr(use_kbmap) << '\n';
}
case RC_KBMAP_PRIMARY:
- if (primary_kbmap != system_lyxrc.primary_kbmap) {
+ if (ignore_system_lyxrc ||
+ primary_kbmap != system_lyxrc.primary_kbmap) {
os << "\\kbmap_primary \"" << primary_kbmap << "\"\n";
}
case RC_KBMAP_SECONDARY:
- if (secondary_kbmap != system_lyxrc.secondary_kbmap) {
+ if (ignore_system_lyxrc ||
+ secondary_kbmap != system_lyxrc.secondary_kbmap) {
os << "\\kbmap_secondary \"" << secondary_kbmap
<< "\"\n";
}
case RC_SERVERPIPE:
- if (lyxpipes != system_lyxrc.lyxpipes) {
+ if (ignore_system_lyxrc ||
+ lyxpipes != system_lyxrc.lyxpipes) {
os << "\\serverpipe \"" << lyxpipes << "\"\n";
}
case RC_DATE_INSERT_FORMAT:
- if (date_insert_format != system_lyxrc.date_insert_format) {
+ if (ignore_system_lyxrc ||
+ date_insert_format != system_lyxrc.date_insert_format) {
os << "\\date_insert_format \"" << date_insert_format
<< "\"\n";
}
case RC_LABEL_INIT_LENGTH:
- if (label_init_length != system_lyxrc.label_init_length) {
+ if (ignore_system_lyxrc ||
+ label_init_length != system_lyxrc.label_init_length) {
os << "\\label_init_length " << label_init_length
- << "\n";
+ << '\n';
+ }
+
+ case RC_USER_NAME:
+ os << "\\user_name \"" << user_name << "\"\n";
+
+ case RC_USER_EMAIL:
+ os << "\\user_email \"" << user_email << "\"\n";
+
+ case RC_SHOW_BANNER:
+ if (ignore_system_lyxrc ||
+ show_banner != system_lyxrc.show_banner) {
+ os << "\\show_banner " << tostr(show_banner) << '\n';
+ }
+
+ case RC_PREVIEW:
+ if (ignore_system_lyxrc ||
+ preview != system_lyxrc.preview) {
+ string status;
+ switch (preview) {
+ case PREVIEW_ON:
+ status = "on";
+ break;
+ case PREVIEW_NO_MATH:
+ status = "no_math";
+ break;
+ case PREVIEW_OFF:
+ status = "off";
+ break;
+ }
+ os << "\\preview " << status << '\n';
+ }
+
+ case RC_PREVIEW_HASHED_LABELS:
+ if (ignore_system_lyxrc ||
+ preview_hashed_labels !=
+ system_lyxrc.preview_hashed_labels) {
+ os << "\\preview_hashed_labels "
+ << tostr(preview_hashed_labels) << '\n';
+ }
+
+ case RC_PREVIEW_SCALE_FACTOR:
+ if (ignore_system_lyxrc ||
+ preview_scale_factor != system_lyxrc.preview_scale_factor) {
+ os << "\\preview_scale_factor "
+ << preview_scale_factor << '\n';
}
os << "\n#\n"
<< "# SCREEN & FONTS SECTION ############################\n"
<< "#\n\n";
-
+
+ case RC_POPUP_NORMAL_FONT:
+ if (ignore_system_lyxrc ||
+ popup_normal_font != system_lyxrc.popup_normal_font) {
+ os << "\\popup_normal_font \"" << popup_normal_font
+ << "\"\n";
+ }
+ case RC_POPUP_BOLD_FONT:
+ if (ignore_system_lyxrc ||
+ popup_bold_font != system_lyxrc.popup_bold_font) {
+ os << "\\popup_bold_font \"" << popup_bold_font
+ << "\"\n";
+ }
+ case RC_POPUP_FONT_ENCODING:
+ if (ignore_system_lyxrc ||
+ 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";
+ if (ignore_system_lyxrc ||
+ dpi != system_lyxrc.dpi) {
+ os << "\\screen_dpi " << dpi << '\n';
}
case RC_SCREEN_ZOOM:
- if (zoom != system_lyxrc.zoom) {
- os << "\\screen_zoom " << zoom << "\n";
+ if (ignore_system_lyxrc ||
+ zoom != system_lyxrc.zoom) {
+ os << "\\screen_zoom " << zoom << '\n';
}
case RC_WHEEL_JUMP:
- if (wheel_jump != system_lyxrc.wheel_jump) {
- os << "\\wheel_jump " << wheel_jump << "\n";
+ if (ignore_system_lyxrc ||
+ wheel_jump != system_lyxrc.wheel_jump) {
+ os << "\\wheel_jump " << wheel_jump << '\n';
}
case RC_CURSOR_FOLLOWS_SCROLLBAR:
- if (cursor_follows_scrollbar
+ if (ignore_system_lyxrc ||
+ cursor_follows_scrollbar
!= system_lyxrc.cursor_follows_scrollbar) {
os << "\\cursor_follows_scrollbar "
- << tostr(cursor_follows_scrollbar) << "\n";
+ << tostr(cursor_follows_scrollbar) << '\n';
+ }
+ case RC_DIALOGS_ICONIFY_WITH_MAIN:
+ if (ignore_system_lyxrc ||
+ 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) {
+ if (ignore_system_lyxrc ||
+ roman_font_name != system_lyxrc.roman_font_name) {
os << "\\screen_font_roman \"" << roman_font_name
<< "\"\n";
}
+ case RC_SCREEN_FONT_ROMAN_FOUNDRY:
+ if (ignore_system_lyxrc ||
+ roman_font_foundry != system_lyxrc.roman_font_foundry) {
+ os << "\\screen_font_roman_foundry \"" << roman_font_foundry
+ << "\"\n";
+ }
case RC_SCREEN_FONT_SANS:
- if (sans_font_name != system_lyxrc.sans_font_name) {
+ if (ignore_system_lyxrc ||
+ sans_font_name != system_lyxrc.sans_font_name) {
os << "\\screen_font_sans \"" << sans_font_name
<< "\"\n";
}
+ case RC_SCREEN_FONT_SANS_FOUNDRY:
+ if (ignore_system_lyxrc ||
+ sans_font_foundry != system_lyxrc.sans_font_foundry) {
+ os << "\\screen_font_sans_foundry \"" << sans_font_foundry
+ << "\"\n";
+ }
case RC_SCREEN_FONT_TYPEWRITER:
- if (typewriter_font_name != system_lyxrc.typewriter_font_name) {
+ if (ignore_system_lyxrc ||
+ typewriter_font_name != system_lyxrc.typewriter_font_name) {
os << "\\screen_font_typewriter \""
<< typewriter_font_name << "\"\n";
}
+ case RC_SCREEN_FONT_TYPEWRITER_FOUNDRY:
+ if (ignore_system_lyxrc ||
+ typewriter_font_foundry != system_lyxrc.typewriter_font_foundry) {
+ os << "\\screen_font_typewriter_foundry \""
+ << typewriter_font_foundry << "\"\n";
+ }
+
case RC_SCREEN_FONT_SCALABLE:
- if (use_scalable_fonts != system_lyxrc.use_scalable_fonts) {
+ if (ignore_system_lyxrc ||
+ use_scalable_fonts != system_lyxrc.use_scalable_fonts) {
os << "\\screen_font_scalable "
<< tostr(use_scalable_fonts)
- << "\n";
+ << '\n';
}
case RC_SCREEN_FONT_ENCODING:
- if (font_norm != system_lyxrc.font_norm) {
+ if (ignore_system_lyxrc ||
+ font_norm != system_lyxrc.font_norm) {
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]
+ if (ignore_system_lyxrc ||
+ font_sizes[LyXFont::SIZE_TINY]
!= system_lyxrc.font_sizes[LyXFont::SIZE_TINY] ||
font_sizes[LyXFont::SIZE_SCRIPT]
!= system_lyxrc.font_sizes[LyXFont::SIZE_SCRIPT] ||
os.setf(ios::fixed);
os.precision(2);
os << "\\screen_font_sizes"
- << " " << font_sizes[LyXFont::SIZE_TINY]
- << " " << font_sizes[LyXFont::SIZE_SCRIPT]
- << " " << font_sizes[LyXFont::SIZE_FOOTNOTE]
- << " " << font_sizes[LyXFont::SIZE_SMALL]
- << " " << font_sizes[LyXFont::SIZE_NORMAL]
- << " " << font_sizes[LyXFont::SIZE_LARGE]
- << " " << font_sizes[LyXFont::SIZE_LARGER]
- << " " << font_sizes[LyXFont::SIZE_LARGEST]
- << " " << font_sizes[LyXFont::SIZE_HUGE]
- << " " << font_sizes[LyXFont::SIZE_HUGER]
- << "\n";
- }
-
+ << ' ' << font_sizes[LyXFont::SIZE_TINY]
+ << ' ' << font_sizes[LyXFont::SIZE_SCRIPT]
+ << ' ' << font_sizes[LyXFont::SIZE_FOOTNOTE]
+ << ' ' << font_sizes[LyXFont::SIZE_SMALL]
+ << ' ' << font_sizes[LyXFont::SIZE_NORMAL]
+ << ' ' << font_sizes[LyXFont::SIZE_LARGE]
+ << ' ' << font_sizes[LyXFont::SIZE_LARGER]
+ << ' ' << font_sizes[LyXFont::SIZE_LARGEST]
+ << ' ' << font_sizes[LyXFont::SIZE_HUGE]
+ << ' ' << font_sizes[LyXFont::SIZE_HUGER]
+ << '\n';
+ }
+
os << "\n#\n"
<< "# COLOR SECTION ###################################\n"
<< "#\n\n";
-
+
case RC_SET_COLOR:
- for (int i = 0; i < LColor::ignore; ++i ) {
+ for (int i = 0; i < LColor::ignore; ++i) {
LColor::color lc = static_cast<LColor::color>(i);
-
+
string const col(lcolor.getX11Name(lc));
- if (col != system_lcolor.getX11Name(lc)) {
+ if (ignore_system_lyxrc ||
+ col != system_lcolor.getX11Name(lc)) {
os << "\\set_color \""
<< lcolor.getLyXName(lc) << "\" \""
<< col << "\"\n";
}
}
-
+
os << "\n#\n"
<< "# PRINTER SECTION ###################################\n"
<< "#\n\n";
-
+
case RC_PRINTER:
- if (printer != system_lyxrc.printer) {
+ if (ignore_system_lyxrc ||
+ printer != system_lyxrc.printer) {
os << "\\printer \"" << printer << "\"\n";
}
case RC_PRINT_ADAPTOUTPUT:
- if (print_adapt_output != system_lyxrc.print_adapt_output) {
+ if (ignore_system_lyxrc ||
+ print_adapt_output != system_lyxrc.print_adapt_output) {
os << "\\print_adapt_output "
<< tostr(print_adapt_output)
- << "\n";
+ << '\n';
}
case RC_PRINT_COMMAND:
- if (print_command != system_lyxrc.print_command) {
+ if (ignore_system_lyxrc ||
+ print_command != system_lyxrc.print_command) {
os << "\\print_command \"" << print_command << "\"\n";
}
case RC_PRINTEXSTRAOPTIONS:
- if (print_extra_options != system_lyxrc.print_extra_options) {
+ if (ignore_system_lyxrc ||
+ print_extra_options != system_lyxrc.print_extra_options) {
os << "\\print_extra_options \"" << print_extra_options
<< "\"\n";
}
case RC_PRINTSPOOL_COMMAND:
- if (print_spool_command != system_lyxrc.print_spool_command) {
+ if (ignore_system_lyxrc ||
+ print_spool_command != system_lyxrc.print_spool_command) {
os << "\\print_spool_command \"" << print_spool_command
<< "\"\n";
}
case RC_PRINTSPOOL_PRINTERPREFIX:
- if (print_spool_printerprefix
+ if (ignore_system_lyxrc ||
+ print_spool_printerprefix
!= system_lyxrc.print_spool_printerprefix) {
os << "\\print_spool_printerprefix \""
<< print_spool_printerprefix << "\"\n";
}
case RC_PRINTEVENPAGEFLAG:
- if (print_evenpage_flag != system_lyxrc.print_evenpage_flag) {
+ if (ignore_system_lyxrc ||
+ print_evenpage_flag != system_lyxrc.print_evenpage_flag) {
os << "\\print_evenpage_flag \"" << print_evenpage_flag
<< "\"\n";
}
case RC_PRINTODDPAGEFLAG:
- if (print_oddpage_flag != system_lyxrc.print_oddpage_flag) {
+ if (ignore_system_lyxrc ||
+ print_oddpage_flag != system_lyxrc.print_oddpage_flag) {
os << "\\print_oddpage_flag \"" << print_oddpage_flag
<< "\"\n";
}
case RC_PRINTREVERSEFLAG:
- if (print_reverse_flag != system_lyxrc.print_reverse_flag) {
+ if (ignore_system_lyxrc ||
+ print_reverse_flag != system_lyxrc.print_reverse_flag) {
os << "\\print_reverse_flag \"" << print_reverse_flag
<< "\"\n";
}
case RC_PRINTLANDSCAPEFLAG:
- if (print_landscape_flag != system_lyxrc.print_landscape_flag) {
+ if (ignore_system_lyxrc ||
+ print_landscape_flag != system_lyxrc.print_landscape_flag) {
os << "\\print_landscape_flag \"" << print_landscape_flag
<< "\"\n";
}
case RC_PRINTPAGERANGEFLAG:
- if (print_pagerange_flag != system_lyxrc.print_pagerange_flag) {
+ if (ignore_system_lyxrc ||
+ print_pagerange_flag != system_lyxrc.print_pagerange_flag) {
os << "\\print_pagerange_flag \"" << print_pagerange_flag
<< "\"\n";
}
case RC_PRINTCOPIESFLAG:
- if (print_copies_flag != system_lyxrc.print_copies_flag) {
- os << "\\print_copies_flag \"" << print_copies_flag
+ if (ignore_system_lyxrc ||
+ print_copies_flag != system_lyxrc.print_copies_flag) {
+ os << "\\print_copies_flag \"" << print_copies_flag
<< "\"\n";
}
case RC_PRINTCOLLCOPIESFLAG:
- if (print_collcopies_flag
+ if (ignore_system_lyxrc ||
+ print_collcopies_flag
!= system_lyxrc.print_collcopies_flag) {
os << "\\print_collcopies_flag \""
<< print_collcopies_flag
<< "\"\n";
}
case RC_PRINTPAPERFLAG:
- if (print_paper_flag != system_lyxrc.print_paper_flag) {
+ if (ignore_system_lyxrc ||
+ print_paper_flag != system_lyxrc.print_paper_flag) {
os << "\\print_paper_flag \"" << print_paper_flag
<< "\"\n";
}
case RC_PRINTPAPERDIMENSIONFLAG:
- if (print_paper_dimension_flag
+ if (ignore_system_lyxrc ||
+ print_paper_dimension_flag
!= system_lyxrc.print_paper_dimension_flag) {
os << "\\print_paper_dimension_flag \""
<< print_paper_dimension_flag << "\"\n";
}
case RC_PRINTTOPRINTER:
- if (print_to_printer != system_lyxrc.print_to_printer) {
+ if (ignore_system_lyxrc ||
+ print_to_printer != system_lyxrc.print_to_printer) {
os << "\\print_to_printer \"" << print_to_printer
<< "\"\n";
}
case RC_PRINTTOFILE:
- if (print_to_file != system_lyxrc.print_to_file) {
+ if (ignore_system_lyxrc ||
+ print_to_file != system_lyxrc.print_to_file) {
os << "\\print_to_file \"" << print_to_file << "\"\n";
}
case RC_PRINTFILEEXTENSION:
- if (print_file_extension != system_lyxrc.print_file_extension) {
+ if (ignore_system_lyxrc ||
+ print_file_extension != system_lyxrc.print_file_extension) {
os << "\\print_file_extension \""
<< print_file_extension
<< "\"\n";
os << "\n#\n"
<< "# EXPORT SECTION ####################################\n"
<< "#\n\n";
-
+
case RC_CUSTOM_EXPORT_COMMAND:
- if (custom_export_command
+ if (ignore_system_lyxrc ||
+ custom_export_command
!= system_lyxrc.custom_export_command) {
os << "\\custom_export_command \""
<< custom_export_command
<< "\"\n";
}
case RC_CUSTOM_EXPORT_FORMAT:
- if (custom_export_format
+ if (ignore_system_lyxrc ||
+ custom_export_format
!= system_lyxrc.custom_export_format) {
os << "\\custom_export_format \"" << custom_export_format
<< "\"\n";
os << "\n#\n"
<< "# TEX SECTION #######################################\n"
<< "#\n\n";
-
+
case RC_FONT_ENCODING:
- if (fontenc != system_lyxrc.fontenc) {
+ if (ignore_system_lyxrc ||
+ fontenc != system_lyxrc.fontenc) {
os << "\\font_encoding \"" << fontenc << "\"\n";
}
<< "#\n\n";
case RC_DOCUMENTPATH:
- if (document_path != system_lyxrc.document_path) {
+ if (ignore_system_lyxrc ||
+ document_path != system_lyxrc.document_path) {
os << "\\document_path \"" << document_path << "\"\n";
}
case RC_LASTFILES:
- if (lastfiles != system_lyxrc.lastfiles) {
+ if (ignore_system_lyxrc ||
+ lastfiles != system_lyxrc.lastfiles) {
os << "\\lastfiles \"" << lastfiles << "\"\n";
}
case RC_NUMLASTFILES:
- if (num_lastfiles != system_lyxrc.num_lastfiles) {
- os << "\\num_lastfiles " << num_lastfiles << "\n";
+ if (ignore_system_lyxrc ||
+ num_lastfiles != system_lyxrc.num_lastfiles) {
+ os << "\\num_lastfiles " << num_lastfiles << '\n';
}
case RC_CHECKLASTFILES:
- if (check_lastfiles != system_lyxrc.check_lastfiles) {
+ if (ignore_system_lyxrc ||
+ check_lastfiles != system_lyxrc.check_lastfiles) {
os << "\\check_lastfiles " << tostr(check_lastfiles)
- << "\n";
+ << '\n';
}
case RC_TEMPLATEPATH:
- if (template_path != system_lyxrc.template_path) {
+ if (ignore_system_lyxrc ||
+ template_path != system_lyxrc.template_path) {
os << "\\template_path \"" << template_path << "\"\n";
}
case RC_TEMPDIRPATH:
- if (tempdir_path != system_lyxrc.tempdir_path) {
+ if (ignore_system_lyxrc ||
+ tempdir_path != system_lyxrc.tempdir_path) {
os << "\\tempdir_path \"" << tempdir_path << "\"\n";
}
case RC_USETEMPDIR:
- if (use_tempdir != system_lyxrc.use_tempdir) {
- os << "\\use_tempdir " << tostr(use_tempdir) << "\n";
- }
+ // Ignore it
case RC_ASCII_LINELEN:
- if (ascii_linelen != system_lyxrc.ascii_linelen) {
- os << "\\ascii_linelen " << ascii_linelen << "\n";
+ if (ignore_system_lyxrc ||
+ ascii_linelen != system_lyxrc.ascii_linelen) {
+ os << "\\ascii_linelen " << ascii_linelen << '\n';
}
case RC_MAKE_BACKUP:
- if (make_backup != system_lyxrc.make_backup) {
- os << "\\make_backup " << tostr(make_backup) << "\n";
+ if (ignore_system_lyxrc ||
+ make_backup != system_lyxrc.make_backup) {
+ os << "\\make_backup " << tostr(make_backup) << '\n';
}
case RC_BACKUPDIR_PATH:
- if (backupdir_path != system_lyxrc.backupdir_path) {
+ if (ignore_system_lyxrc ||
+ backupdir_path != system_lyxrc.backupdir_path) {
os << "\\backupdir_path \"" << backupdir_path << "\"\n";
}
<< "#\n\n";
case RC_ASCIIROFF_COMMAND:
- if (ascii_roff_command != system_lyxrc.ascii_roff_command) {
+ if (ignore_system_lyxrc ||
+ ascii_roff_command != system_lyxrc.ascii_roff_command) {
os << "\\ascii_roff_command \"" << ascii_roff_command
<< "\"\n";
}
os << "\n#\n"
<< "# SPELLCHECKER SECTION ##############################\n"
<< "#\n\n";
-
+ case RC_USE_SPELL_LIB:
+ if (ignore_system_lyxrc ||
+ use_spell_lib != system_lyxrc.use_spell_lib) {
+ os << "\\use_spell_lib " << tostr(use_spell_lib) << '\n';
+ }
case RC_SPELL_COMMAND:
- if (isp_command != system_lyxrc.isp_command) {
+ if (ignore_system_lyxrc ||
+ isp_command != system_lyxrc.isp_command) {
os << "\\spell_command \"" << isp_command << "\"\n";
}
case RC_ACCEPT_COMPOUND:
- if (isp_accept_compound != system_lyxrc.isp_accept_compound) {
+ if (ignore_system_lyxrc ||
+ isp_accept_compound != system_lyxrc.isp_accept_compound) {
os << "\\accept_compound " << tostr(isp_accept_compound)
- << "\n";
+ << '\n';
}
case RC_USE_ALT_LANG:
- if (isp_use_alt_lang != system_lyxrc.isp_use_alt_lang) {
+ if (ignore_system_lyxrc ||
+ isp_use_alt_lang != system_lyxrc.isp_use_alt_lang) {
os << "\\use_alt_language " << tostr(isp_use_alt_lang)
- << "\n";
+ << '\n';
}
case RC_ALT_LANG:
- if (isp_alt_lang != system_lyxrc.isp_alt_lang) {
+ if (ignore_system_lyxrc ||
+ isp_alt_lang != system_lyxrc.isp_alt_lang) {
os << "\\alternate_language \"" << isp_alt_lang
<< "\"\n";
}
case RC_USE_ESC_CHARS:
- if (isp_use_esc_chars != system_lyxrc.isp_use_esc_chars) {
+ if (ignore_system_lyxrc ||
+ isp_use_esc_chars != system_lyxrc.isp_use_esc_chars) {
os << "\\use_escape_chars " << tostr(isp_use_esc_chars)
- << "\n";
+ << '\n';
}
case RC_ESC_CHARS:
- if (isp_esc_chars != system_lyxrc.isp_esc_chars) {
+ if (ignore_system_lyxrc ||
+ isp_esc_chars != system_lyxrc.isp_esc_chars) {
os << "\\escape_chars \"" << isp_esc_chars << "\"\n";
}
case RC_USE_PERS_DICT:
- if (isp_use_pers_dict != system_lyxrc.isp_use_pers_dict) {
+ if (ignore_system_lyxrc ||
+ isp_use_pers_dict != system_lyxrc.isp_use_pers_dict) {
os << "\\use_personal_dictionary "
<< tostr(isp_use_pers_dict)
- << "\n";
+ << '\n';
}
case RC_PERS_DICT:
if (isp_pers_dict != system_lyxrc.isp_pers_dict) {
<< "\"\n";
}
case RC_USE_INP_ENC:
- if (isp_use_input_encoding
+ if (ignore_system_lyxrc ||
+ isp_use_input_encoding
!= system_lyxrc.isp_use_input_encoding) {
os << "\\use_input_encoding "
<< tostr(isp_use_input_encoding)
- << "\n";
+ << '\n';
}
os << "\n#\n"
<< "#\n\n";
case RC_RTL_SUPPORT:
- if (rtl_support != system_lyxrc.rtl_support) {
- os << "\\rtl " << tostr(rtl_support) << "\n";
+ if (ignore_system_lyxrc ||
+ rtl_support != system_lyxrc.rtl_support) {
+ os << "\\rtl " << tostr(rtl_support) << '\n';
}
case RC_LANGUAGE_PACKAGE:
- if (language_package != system_lyxrc.language_package) {
+ if (ignore_system_lyxrc ||
+ language_package != system_lyxrc.language_package) {
os << "\\language_package \"" << language_package
<< "\"\n";
}
+ case RC_LANGUAGE_GLOBAL_OPTIONS:
+ if (ignore_system_lyxrc ||
+ language_global_options
+ != system_lyxrc.language_global_options) {
+ os << "\\language_global_options \""
+ << tostr(language_global_options)
+ << "\"\n";
+ }
+ case RC_LANGUAGE_USE_BABEL:
+ if (ignore_system_lyxrc ||
+ language_use_babel != system_lyxrc.language_use_babel) {
+ os << "\\language_use_babel \""
+ << tostr(language_use_babel)
+ << "\"\n";
+ }
case RC_LANGUAGE_COMMAND_BEGIN:
- if (language_command_begin
+ if (ignore_system_lyxrc ||
+ language_command_begin
!= system_lyxrc.language_command_begin) {
os << "\\language_command_begin \""
<< language_command_begin
<< "\"\n";
}
case RC_LANGUAGE_COMMAND_END:
- if (language_command_end
+ if (ignore_system_lyxrc ||
+ language_command_end
!= system_lyxrc.language_command_end) {
os << "\\language_command_end \"" << language_command_end
<< "\"\n";
}
+ case RC_LANGUAGE_COMMAND_LOCAL:
+ if (ignore_system_lyxrc ||
+ language_command_local
+ != system_lyxrc.language_command_local) {
+ os << "\\language_command_local \""
+ << language_command_local
+ << "\"\n";
+ }
case RC_LANGUAGE_AUTO_BEGIN:
- if (language_auto_begin != system_lyxrc.language_auto_begin) {
- os << "\\language_auto_begin "
- << tostr(language_auto_begin) << "\n";
+ if (ignore_system_lyxrc ||
+ language_auto_begin != system_lyxrc.language_auto_begin) {
+ os << "\\language_auto_begin "
+ << tostr(language_auto_begin) << '\n';
}
case RC_LANGUAGE_AUTO_END:
- if (language_auto_end != system_lyxrc.language_auto_end) {
- os << "\\language_auto_end "
- << tostr(language_auto_end) << "\n";
+ if (ignore_system_lyxrc ||
+ language_auto_end != system_lyxrc.language_auto_end) {
+ os << "\\language_auto_end "
+ << tostr(language_auto_end) << '\n';
}
case RC_MARK_FOREIGN_LANGUAGE:
- if (mark_foreign_language
+ if (ignore_system_lyxrc ||
+ mark_foreign_language
!= system_lyxrc.mark_foreign_language) {
os << "\\mark_foreign_language " <<
- tostr(mark_foreign_language) << "\n";
+ tostr(mark_foreign_language) << '\n';
}
os << "\n#\n"
<< "# 2nd MISC SUPPORT SECTION ##########################\n"
<< "#\n\n";
- case RC_OVERRIDE_X_DEADKEYS:
- if (override_x_deadkeys != system_lyxrc.override_x_deadkeys) {
- 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";
- }
- case RC_NEW_ASK_FILENAME:
- if (new_ask_filename != system_lyxrc.new_ask_filename) {
- os << "\\new_ask_filename " << tostr(new_ask_filename)
- << "\n";
+ if (ignore_system_lyxrc ||
+ auto_number != system_lyxrc.auto_number) {
+ os << "\\auto_number " << tostr(auto_number) << '\n';
}
case RC_DEFAULT_LANGUAGE:
- if (default_language != system_lyxrc.default_language) {
- os << "\\default_language " << default_language << "\n";
+ if (ignore_system_lyxrc ||
+ default_language != system_lyxrc.default_language) {
+ os << "\\default_language " << default_language << '\n';
}
os << "\n#\n"
<< "#\n\n";
case RC_FORMAT:
- // Look for deleted formats
+ // New/modifed formats
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() ||
- format->shortcut() != cit->shortcut())
+ format->shortcut() != cit->shortcut() ||
+ format->viewer() != cit->viewer() ||
+ format->editor() != cit->editor())
os << "\\format \"" << cit->name() << "\" \""
<< cit->extension() << "\" \""
<< cit->prettyname() << "\" \""
- << cit->shortcut() << "\"\n";
+ << cit->shortcut() << "\" \""
+ << cit->viewer() << "\" \""
+ << cit->editor() << "\"\n";
}
- // New/modifed formats
+ // Look for deleted formats
for (Formats::const_iterator cit = system_formats.begin();
cit != system_formats.end(); ++cit)
- if (!formats.GetFormat(cit->name()))
- os << "\\format \"" << cit->name()
- << "\" \"\" \"\" \"\"\n";
+ 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());
- if ((!format || format->viewer() != cit->viewer()) &&
- (format || !cit->viewer().empty()))
- os << "\\viewer \"" << cit->name() << "\" \""
- << cit->viewer() << "\"\n";
- }
+ // Ignore it
os << "\n#\n"
<< "# CONVERTERS SECTION ##########################\n"
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 ||
// New/modifed converters
for (Converters::const_iterator cit = system_converters.begin();
cit != system_converters.end(); ++cit)
- if (!converters.GetConverter(cit->from, cit->to))
- os << "\\converter \"" << cit->from
+ if (!converters.getConverter(cit->from, cit->to))
+ os << "\\converter \"" << cit->from
<< "\" \"" << cit->to << "\" \"\" \"\"\n";
+
+ case RC_COPIER:
+ os << "\n#\n"
+ << "# COPIERS SECTION ##########################\n"
+ << "#\n\n";
+
+ // Look for new movers
+ Movers::iterator const sysbegin = system_movers.begin();
+ Movers::iterator const sysend = system_movers.end();
+
+ for (Movers::iterator it = movers.begin(), end = movers.end();
+ it != end; ++it) {
+ Movers::iterator const sysit =
+ std::find_if(sysbegin, sysend, SameMover(*it));
+ if (sysit == sysend) {
+ std::string const & fmt = it->first;
+ std::string const & command =
+ it->second.command();
+
+ os << "\\copier " << fmt
+ << " \"" << command << "\"\n";
+ }
+ }
+
+ // We don't actually delete SpecialisedMover(s) from the
+ // map, just clear their 'command', so there's no need
+ // to test for anything else.
}
+
os.flush();
}
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;
}
-string const LyXRC::getDescription(LyXRCTags tag)
+string const LyXRC::getDescription(LyXRCTags tag)
{
string str;
-
+
switch (tag) {
case RC_FONT_ENCODING:
- str = N_("The font encoding used for the LaTeX2e fontenc package. T1 is highly recommended for non-English languages.");
+ str = _("The font encoding used for the LaTeX2e fontenc package. T1 is highly recommended for non-English languages.");
break;
-
+
case RC_PRINTER:
- str = N_("The default printer to print on. If none is specified, LyX will use the environment variable PRINTER.");
+ str = _("The default printer to print on. If none is specified, LyX will use the environment variable PRINTER.");
break;
-
+
case RC_PRINT_COMMAND:
- str = N_("Your favorite print program, e.g. \"dvips\", \"dvilj4\".");
+ str = _("Your favorite print program, e.g. \"dvips\", \"dvilj4\".");
break;
-
+
case RC_PRINTEVENPAGEFLAG:
- str = N_("The option to print only even pages.");
+ str = _("The option to print only even pages.");
break;
case RC_PRINTODDPAGEFLAG:
- str = N_("The option to print only odd pages.");
+ str = _("The option to print only odd pages.");
break;
case RC_PRINTPAGERANGEFLAG:
- str = N_("The option for specifying a comma-separated list of pages to print.");
+ str = _("The option for specifying a comma-separated list of pages to print.");
break;
case RC_PRINTCOPIESFLAG:
- str = N_("The option for specifying the number of copies to print.");
+ str = _("The option for specifying the number of copies to print.");
break;
case RC_PRINTCOLLCOPIESFLAG:
- str = N_("The option for specifying whether the copies should be collated.");
+ str = _("The option for specifying whether the copies should be collated.");
break;
case RC_PRINTREVERSEFLAG:
- str = N_("The option to reverse the order of the pages printed.");
+ str = _("The option to reverse the order of the pages printed.");
break;
case RC_PRINTLANDSCAPEFLAG:
- str = N_("The option to print out in landscape.");
+ str = _("The option to print out in landscape.");
break;
- case RC_PRINTPAPERFLAG:
- str = N_("The option to specify paper type.");
+ case RC_PRINTPAPERFLAG:
+ str = _("The option to specify paper type.");
break;
case RC_PRINTPAPERDIMENSIONFLAG:
- str = N_("Option to specify the dimensions of the print paper.");
+ str = _("Option to specify the dimensions of the print paper.");
break;
-
+
case RC_PRINTTOPRINTER:
- str = N_("Option to pass to the print program to print on a specific printer.");
+ str = _("Option to pass to the print program to print on a specific printer.");
break;
-
+
case RC_PRINT_ADAPTOUTPUT:
- str = N_("Select for LyX to pass the name of the destination printer to your print command.");
+ str = _("Select for LyX to pass the name of the destination printer to your print command.");
break;
-
+
case RC_PRINTTOFILE:
- str = N_("Option to pass to the print program to print to a file.");
+ str = _("Option to pass to the print program to print to a file.");
break;
-
+
case RC_PRINTFILEEXTENSION:
- str = N_("Extension of printer program output file. Usually \".ps\".");
+ str = _("Extension of printer program output file. Usually \".ps\".");
break;
-
+
case RC_PRINTEXSTRAOPTIONS:
- str = N_("Extra options to pass to printing program after everything else, but before the filename of the DVI file to be printed.");
+ str = _("Extra options to pass to printing program after everything else, but before the filename of the DVI file to be printed.");
break;
-
+
case RC_PRINTSPOOL_COMMAND:
- str = N_("When set, this printer option automatically prints to a file and then calls a separate print spooling program on that file with the given name and arguments.");
+ str = _("When set, this printer option automatically prints to a file and then calls a separate print spooling program on that file with the given name and arguments.");
break;
-
+
case RC_PRINTSPOOL_PRINTERPREFIX:
- str = N_("If you specify a printer name in the print dialog, the following argument is prepended along with the printer name after the spool command.");
+ str = _("If you specify a printer name in the print dialog, the following argument is prepended along with the printer name after the spool command.");
break;
-
+
case RC_SCREEN_DPI:
- str = N_("DPI (dots per inch) of your monitor is auto-detected by LyX. If that goes wrong, override the setting here.");
+ str = _("DPI (dots per inch) of your monitor is auto-detected by LyX. If that goes wrong, override the setting here.");
break;
-
+
case RC_SCREEN_ZOOM:
//xgettext:no-c-format
- str = N_("The zoom percentage for screen fonts. A setting of 100% will make the fonts roughly the same size as on paper.");
+ str = _("The zoom percentage for screen fonts. A setting of 100% will make the fonts roughly the same size as on paper.");
break;
-
+
case RC_SCREEN_FONT_SIZES:
- str = N_("The font sizes used for calculating the scaling of the screen fonts.");
+ str = _("The font sizes used for calculating the scaling of the screen fonts.");
break;
-
+
case RC_SCREEN_FONT_ROMAN:
case RC_SCREEN_FONT_SANS:
case RC_SCREEN_FONT_TYPEWRITER:
- str = N_("The screen fonts used to display the text while editing.");
+ str = _("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 = _("The bold font in the dialogs.");
break;
-
- case RC_SCREEN_FONT_POPUP:
- str = N_("The font for popups.");
+
+ case RC_POPUP_NORMAL_FONT:
+ str = _("The normal font in the dialogs.");
break;
-
+
case RC_SCREEN_FONT_ENCODING:
- str = N_("The encoding for the screen fonts.");
+ str = _("The encoding for the screen fonts.");
break;
-
- case RC_SCREEN_FONT_ENCODING_MENU:
- str = N_("The encoding for the menu/popups fonts.");
+
+ case RC_POPUP_FONT_ENCODING:
+ str = _("The encoding for the menu/popups fonts.");
break;
-
+
case RC_SET_COLOR:
break;
-
+
case RC_AUTOSAVE:
- str = N_("The time interval between auto-saves (in seconds). 0 means no auto-save.");
+ str = _("The time interval between auto-saves (in seconds). 0 means no auto-save.");
break;
-
+
case RC_DOCUMENTPATH:
- str = N_("The default path for your documents.");
+ str = _("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 = _("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:
- str = N_("LyX will place its temporary directories in this path. They will be deleted when you quit LyX.");
- break;
-
- case RC_USETEMPDIR:
- str = N_("Select if you wish to use a temporary directory structure to store temporary TeX output.");
+ str = _("LyX will place its temporary directories in this path. They will be deleted when you quit LyX.");
break;
-
+
case RC_LASTFILES:
- str = N_("The file where the last-files information should be stored.");
+ str = _("The file where the last-files information should be stored.");
break;
-
+
case RC_AUTOREGIONDELETE:
- str = N_("De-select if you don't want the current selection to be replaced automatically by what you type.");
+ str = _("De-select if you don't want the current selection to be replaced automatically by what you type.");
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.");
+
+ case RC_AUTORESET_OPTIONS:
+ str = _("De-select if you don't want the class options to be reset to defaults after class change.");
break;
-
case RC_SERVERPIPE:
- str = N_("This starts the lyxserver. The pipes get an additional extension \".in\" and \".out\". Only for advanced users.");
+ str = _("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.");
+ str = _("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.");
+ str = _("The UI (user interface) file. Can either specify an absolute path, or LyX will look in its global and local ui/ directories.");
break;
-
+
case RC_KBMAP:
case RC_KBMAP_PRIMARY:
case RC_KBMAP_SECONDARY:
- str = N_("Use this to set the correct mapping file for your keyboard. You'll need this if you for instance want to type German documents on an American keyboard.");
+ str = _("Use this to set the correct mapping file for your keyboard. You'll need this if you for instance want to type German documents on an American keyboard.");
break;
case RC_ASCIIROFF_COMMAND:
- str = N_("Use to define an external program to render tables in the ASCII output. E.g. \"groff -t -Tlatin1 $$FName\" where $$FName is the input file. If \"none\" is specified, an internal routine is used.");
+ str = _("Use to define an external program to render tables in the ASCII output. E.g. \"groff -t -Tlatin1 $$FName\" where $$FName is the input file. If \"none\" is specified, an internal routine is used.");
break;
-
+
case RC_ASCII_LINELEN:
- str = N_("This is the maximum line length of an exported ASCII file (LaTeX, SGML or plain text).");
+ str = _("This is the maximum line length of an exported ASCII file (LaTeX, SGML or plain text).");
break;
-
+
case RC_NUMLASTFILES:
- str = N_("Maximal number of lastfiles. Up to 9 can appear in the file menu.");
+ str = bformat(_("Maximal number of lastfiles. Up to %1$s can appear in the file menu."), tostr(maxlastfiles));
break;
-
+
case RC_CHECKLASTFILES:
- str = N_("Select to check whether the lastfiles still exist.");
+ str = _("Select to check whether the lastfiles still exist.");
break;
-
+
case RC_VIEWDVI_PAPEROPTION:
+ str = _("Specify the paper command to DVI viewer (leave empty or use \"-paper\")");
break;
-
+
case RC_DEFAULT_PAPERSIZE:
- str = N_("Specify the default paper size.");
- break;
-
- case RC_PS_COMMAND:
+ str = _("Specify the default paper size.");
break;
-
+
case RC_ACCEPT_COMPOUND:
- str = N_("Consider run-together words, such as \"diskdrive\" for \"disk drive\", as legal words?");
+ str = _("Consider run-together words, such as \"diskdrive\" for \"disk drive\", as legal words?");
break;
-
+
case RC_SPELL_COMMAND:
- str = N_("What command runs the spell checker?");
+ str = _("What command runs the spell checker?");
break;
-
+
case RC_USE_INP_ENC:
- str = N_("Specify whether to pass the -T input encoding option to ispell. Enable this if you can't spellcheck words with international letters in them. This may not work with all dictionaries.");
+ str = _("Specify whether to pass the -T input encoding option to ispell. Enable this if you can't spellcheck words with international letters in them. This may not work with all dictionaries.");
break;
-
+
case RC_USE_ALT_LANG:
case RC_ALT_LANG:
- str = N_("Specify an alternate language. The default is to use the language of the document.");
+ str = _("Specify an alternate language. The default is to use the language of the document.");
break;
-
+
case RC_USE_PERS_DICT:
case RC_PERS_DICT:
- str = N_("Specify an alternate personal dictionary file. E.g. \".ispell_english\".");
+ str = _("Specify an alternate personal dictionary file. E.g. \".ispell_english\".");
break;
-
+
case RC_USE_ESC_CHARS:
case RC_ESC_CHARS:
- str = N_("Specify additional chars that can be part of a word.");
+ str = _("Specify additional chars that can be part of a word.");
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 = _("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:
- str = N_("Define how to run chktex. E.g. \"chktex -n11 -n1 -n3 -n6 -n9 -22 -n25 -n30 -n38\" Refer to the ChkTeX documentation.");
+ str = _("Define how to run chktex. E.g. \"chktex -n11 -n1 -n3 -n6 -n9 -22 -n25 -n30 -n38\" Refer to the ChkTeX documentation.");
+ break;
+
+ case RC_BIBTEX_COMMAND:
+ str = _("Define the options of bibtex (cf. man bibtex) or select an alternative compiler (e.g. mlbibtex or bibulus).");
+ break;
+
+ case RC_INDEX_COMMAND:
+ str = _("Define the options of makeindex (cf. man makeindex) or select an alternative compiler. E.g., using xindy/make-rules, the command string would be \"makeindex.sh -m $$lang\".");
break;
-
+
case RC_CURSOR_FOLLOWS_SCROLLBAR:
- 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.");
+ str = _("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_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.)");
+
+ case RC_DIALOGS_ICONIFY_WITH_MAIN:
+ str = _("Iconify the dialogs when the main window is iconified. (Affects only dialogs shown after the change has been made.)");
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.");
+
+ case RC_DISPLAY_GRAPHICS:
+ str = _("Select how LyX will display any graphics.");
break;
-
+
case RC_MAKE_BACKUP:
- str = N_("De-select if you don't want LyX to create backup files.");
+ str = _("De-select if you don't want LyX to create backup files.");
break;
-
+
case RC_BACKUPDIR_PATH:
- str = N_("The path for storing backup files. If it is an empty string, LyX will store the backup file in the same directory as the original file.");
+ str = _("The path for storing backup files. If it is an empty string, LyX will store the backup file in the same directory as the original file.");
break;
case RC_RTL_SUPPORT:
- str = N_("Select to enable support of right-to-left languages (e.g. Hebrew, Arabic).");
+ str = _("Select to enable support of right-to-left languages (e.g. Hebrew, Arabic).");
break;
-
+
case RC_MARK_FOREIGN_LANGUAGE:
- str = N_("Select to control the highlighting of words with a language foreign to that of the document.");
+ str = _("Select to control the highlighting of words with a language foreign to that of the document.");
break;
-
+
case RC_LANGUAGE_PACKAGE:
- str = N_("The latex command for loading the language package. E.g. \"\\usepackage{babel}\", \"\\usepackage{omega}\".");
+ str = _("The LaTeX command for loading the language package. E.g. \"\\usepackage{babel}\", \"\\usepackage{omega}\".");
+ break;
+
+ case RC_LANGUAGE_GLOBAL_OPTIONS:
+ str = _("De-select if you don't want the language(s) used as an argument to \\documentclass.");
+ break;
+
+ case RC_LANGUAGE_USE_BABEL:
+ str = _("De-select if you don't want babel to be used when the language of the document is the default language.");
break;
-
+
case RC_LANGUAGE_AUTO_BEGIN:
- str = N_("Select if a language switching command is needed at the beginning of the document.");
+ str = _("Select if a language switching command is needed at the beginning of the document.");
break;
-
+
case RC_LANGUAGE_AUTO_END:
- str = N_("Select if a language switching command is needed at the end of the document.");
+ str = _("Select if a language switching command is needed at the end of the document.");
break;
-
+
case RC_LANGUAGE_COMMAND_BEGIN:
- str = N_("The latex command for changing from the language of the document to another language. E.g. \\selectlanguage{$$lang} where $$lang is substituted by the name of the second language.");
+ str = _("The LaTeX command for changing from the language of the document to another language. E.g. \\selectlanguage{$$lang} where $$lang is substituted by the name of the second language.");
break;
-
+
case RC_LANGUAGE_COMMAND_END:
- str = N_("The latex command for changing back to the language of the document.");
+ str = _("The LaTeX command for changing back to the language of the document.");
+ break;
+
+ case RC_LANGUAGE_COMMAND_LOCAL:
+ str = _("The LaTeX command for local changing of the language.");
break;
-
+
case RC_DATE_INSERT_FORMAT:
//xgettext:no-c-format
- str = N_("This accepts the normal strftime formats; see man strftime for full details. E.g.\"%A, %e. %B %Y\".");
+ str = _("This accepts the normal strftime formats; see man strftime for full details. E.g.\"%A, %e. %B %Y\".");
break;
-
+
case RC_SHOW_BANNER:
- str = N_("De-select if you don't want the startup banner.");
+ str = _("De-select if you don't want the startup banner.");
break;
-
+
case RC_WHEEL_JUMP:
- str = N_("The wheel movement factor (for mice with wheels or five button mice).");
+ str = _("The number of lines that are scrolled by mice with wheels or five button mice.");
break;
-
+
case RC_CONVERTER:
break;
-
+
case RC_VIEWER:
break;
-
+
case RC_FORMAT:
break;
-
- case RC_NEW_ASK_FILENAME:
- str = N_("This sets the behaviour if you want to be asked for a filename when creating a new document or wait until you save it and be asked then.");
- break;
-
+
case RC_DEFAULT_LANGUAGE:
- str = N_("New documents will be assigned this language.");
+ str = _("New documents will be assigned this language.");
break;
case RC_LABEL_INIT_LENGTH:
- str = N_("Maximum number of words in the initialization string for a new label");
+ str = _("Maximum number of words in the initialization string for a new label");
+ break;
+
+ case RC_PREVIEW:
+ str = _("Shows a typeset preview of things such as math");
+ break;
+
+ case RC_PREVIEW_HASHED_LABELS:
+ str = _("Previewed equations will have \"(#)\" labels rather than numbered ones");
+ break;
+
+ case RC_PREVIEW_SCALE_FACTOR:
+ str = _("Scale the preview size to suit.");
break;
-
+
default:
break;
}