namespace {
// when adding something to this array keep it sorted!
-keyword_item lyxrcTags[] = {
+LexerKeyword lyxrcTags[] = {
{ "\\accept_compound", LyXRC::RC_ACCEPT_COMPOUND },
{ "\\allow_geometry_session", LyXRC::RC_GEOMETRY_SESSION },
{ "\\alternate_language", LyXRC::RC_ALT_LANG },
{ "\\tex_expects_windows_paths", LyXRC::RC_TEX_EXPECTS_WINDOWS_PATHS },
{ "\\ui_file", LyXRC::RC_UIFILE },
{ "\\use_alt_language", LyXRC::RC_USE_ALT_LANG },
- { "\\use_bundled_format", LyXRC::RC_USE_BUNDLED_FORMAT },
{ "\\use_converter_cache", LyXRC::RC_USE_CONVERTER_CACHE },
{ "\\use_escape_chars", LyXRC::RC_USE_ESC_CHARS },
{ "\\use_input_encoding", LyXRC::RC_USE_INP_ENC },
{ "\\visual_cursor" ,LyXRC::RC_VISUAL_CURSOR}
};
-const int lyxrcCount = sizeof(lyxrcTags) / sizeof(keyword_item);
+const int lyxrcCount = sizeof(lyxrcTags) / sizeof(lyxrcTags[0]);
} // namespace anon
}
-void LyXRC::setDefaults() {
+void LyXRC::setDefaults()
+{
bind_file = "cua";
def_file = "default";
ui_file = "default";
user_name = to_utf8(support::user_name());
user_email = to_utf8(support::user_email());
open_buffers_in_tabs = true;
- use_bundled_format = false;
// Fullscreen settings
full_screen_limit = false;
int LyXRC::read(FileName const & filename)
{
- Lexer lexrc(lyxrcTags, lyxrcCount);
+ Lexer lexrc(lyxrcTags);
if (lyxerr.debugging(Debug::PARSER))
lexrc.printTable(lyxerr);
lexrc.setFile(filename);
- if (!lexrc.isOK()) return -2;
+ if (!lexrc.isOK())
+ return -2;
LYXERR(Debug::LYXRC, "Reading '" << filename << "'...");
int LyXRC::read(istream & is)
{
- Lexer lexrc(lyxrcTags, lyxrcCount);
+ Lexer lexrc(lyxrcTags);
if (lyxerr.debugging(Debug::PARSER))
lexrc.printTable(lyxerr);
break;
case RC_AUTORESET_OPTIONS:
- if (lexrc.next()) {
- auto_reset_options = lexrc.getBool();
- }
+ lexrc >> auto_reset_options;
break;
case RC_DISPLAY_GRAPHICS:
- if (lexrc.next()) {
+ if (lexrc.next())
display_graphics = graphics::displayTranslator().find(lexrc.getString());
- }
break;
case RC_TEX_EXPECTS_WINDOWS_PATHS:
- if (lexrc.next()) {
- windows_style_tex_paths = lexrc.getBool();
- }
+ lexrc >> windows_style_tex_paths;
break;
case RC_TEX_ALLOWS_SPACES:
- if (lexrc.next()) {
- tex_allows_spaces = lexrc.getBool();
- }
+ lexrc >> tex_allows_spaces;
break;
case RC_KBMAP:
- if (lexrc.next()) {
- use_kbmap = lexrc.getBool();
- }
+ lexrc >> use_kbmap;
break;
case RC_KBMAP_PRIMARY:
break;
case RC_FONT_ENCODING:
- if (lexrc.next()) {
- fontenc = lexrc.getString();
- }
+ lexrc >> fontenc;
break;
case RC_PRINTER:
- if (lexrc.next()) {
- printer = lexrc.getString();
- }
+ lexrc >> printer;
break;
case RC_PRINT_COMMAND:
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
print_command = lexrc.getString();
}
break;
case RC_PRINTEVENPAGEFLAG:
- if (lexrc.next()) {
- print_evenpage_flag = lexrc.getString();
- }
+ lexrc >> print_evenpage_flag;
break;
case RC_PRINTODDPAGEFLAG:
- if (lexrc.next()) {
- print_oddpage_flag = lexrc.getString();
- }
+ lexrc >> print_oddpage_flag;
break;
case RC_PRINTPAGERANGEFLAG:
- if (lexrc.next()) {
- print_pagerange_flag = lexrc.getString();
- }
+ lexrc >> print_pagerange_flag;
break;
case RC_PRINTCOPIESFLAG:
- if (lexrc.next()) {
- print_copies_flag = lexrc.getString();
- }
+ lexrc >> print_copies_flag;
break;
case RC_PRINTCOLLCOPIESFLAG:
- if (lexrc.next()) {
- print_collcopies_flag = lexrc.getString();
- }
+ lexrc >> print_collcopies_flag;
break;
case RC_PRINTREVERSEFLAG:
- if (lexrc.next()) {
- print_reverse_flag = lexrc.getString();
- }
+ lexrc >> print_reverse_flag;
break;
case RC_PRINTLANDSCAPEFLAG:
- if (lexrc.next()) {
- print_landscape_flag = lexrc.getString();
- }
+ lexrc >> print_landscape_flag;
break;
case RC_PRINTTOPRINTER:
- if (lexrc.next()) {
- print_to_printer = lexrc.getString();
- }
+ lexrc >> print_to_printer;
break;
case RC_PRINT_ADAPTOUTPUT:
- if (lexrc.next()) {
- print_adapt_output = lexrc.getBool();
- }
+ lexrc >> print_adapt_output;
break;
case RC_PRINTTOFILE:
break;
case RC_PRINTFILEEXTENSION:
- if (lexrc.next()) {
- print_file_extension = lexrc.getString();
- }
+ lexrc >> print_file_extension;
break;
case RC_PRINTEXSTRAOPTIONS:
- if (lexrc.next()) {
- print_extra_options = lexrc.getString();
- }
+ lexrc >> print_extra_options;
break;
case RC_PRINTSPOOL_COMMAND:
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
print_spool_command = lexrc.getString();
}
break;
case RC_PRINTSPOOL_PRINTERPREFIX:
- if (lexrc.next()) {
- print_spool_printerprefix = lexrc.getString();
- }
+ lexrc >> print_spool_printerprefix;
break;
case RC_PRINTPAPERDIMENSIONFLAG:
- if (lexrc.next()) {
- print_paper_dimension_flag = lexrc.getString();
- }
+ lexrc >> print_paper_dimension_flag;
break;
case RC_PRINTPAPERFLAG:
- if (lexrc.next()) {
- print_paper_flag = lexrc.getString();
- }
+ lexrc >> print_paper_flag;
break;
case RC_CUSTOM_EXPORT_COMMAND:
- if (lexrc.next()) {
- custom_export_command = lexrc.getString();
- }
+ lexrc >> custom_export_command;
break;
case RC_CUSTOM_EXPORT_FORMAT:
- if (lexrc.next()) {
- custom_export_format = lexrc.getString();
- }
+ lexrc >> custom_export_format;
break;
case RC_DEFAULT_PAPERSIZE:
if (lexrc.next()) {
- string const size =
- ascii_lowercase(lexrc.getString());
+ string const size = ascii_lowercase(lexrc.getString());
if (size == "usletter")
- default_papersize =
- PAPER_USLETTER;
+ default_papersize = PAPER_USLETTER;
else if (size == "legal")
- default_papersize =
- PAPER_USLEGAL;
+ default_papersize = PAPER_USLEGAL;
else if (size == "executive")
- default_papersize =
- PAPER_USEXECUTIVE;
+ default_papersize = PAPER_USEXECUTIVE;
else if (size == "a3")
- default_papersize =
- PAPER_A3;
+ default_papersize = PAPER_A3;
else if (size == "a4")
- default_papersize =
- PAPER_A4;
+ default_papersize = PAPER_A4;
else if (size == "a5")
- default_papersize =
- PAPER_A5;
+ default_papersize = PAPER_A5;
else if (size == "b5")
- default_papersize =
- PAPER_B5;
+ default_papersize = PAPER_B5;
else if (size == "default")
- default_papersize =
- PAPER_DEFAULT;
+ default_papersize = PAPER_DEFAULT;
}
break;
case RC_VIEWDVI_PAPEROPTION:
- if (lexrc.next()) {
+ if (lexrc.next())
view_dvi_paper_option = lexrc.getString();
- } else {
+ else
view_dvi_paper_option.erase();
- }
break;
case RC_CHKTEX_COMMAND:
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
chktex_command = lexrc.getString();
}
break;
case RC_BIBTEX_COMMAND:
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
bibtex_command = lexrc.getString();
}
break;
case RC_INDEX_COMMAND:
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
index_command = lexrc.getString();
}
break;
case RC_SCREEN_DPI:
- if (lexrc.next()) {
- dpi = lexrc.getInteger();
- }
+ lexrc >> dpi;
break;
case RC_SCREEN_ZOOM:
- if (lexrc.next()) {
- zoom = lexrc.getInteger();
- }
+ lexrc >> zoom;
break;
case RC_GEOMETRY_SESSION:
- if (lexrc.next()) {
- allow_geometry_session = lexrc.getBool();
- }
+ lexrc >> allow_geometry_session;
break;
case RC_SCREEN_FONT_SIZES:
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_TINY] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_SCRIPT] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_FOOTNOTE] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_SMALL] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_NORMAL] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_LARGE] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_LARGER] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_LARGEST] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_HUGE] =
- lexrc.getString();
- }
- if (lexrc.next()) {
- font_sizes[FONT_SIZE_HUGER] =
- lexrc.getString();
- }
+ lexrc >> font_sizes[FONT_SIZE_TINY];
+ lexrc >> font_sizes[FONT_SIZE_SCRIPT];
+ lexrc >> font_sizes[FONT_SIZE_FOOTNOTE];
+ lexrc >> font_sizes[FONT_SIZE_SMALL];
+ lexrc >> font_sizes[FONT_SIZE_NORMAL];
+ lexrc >> font_sizes[FONT_SIZE_LARGE];
+ lexrc >> font_sizes[FONT_SIZE_LARGER];
+ lexrc >> font_sizes[FONT_SIZE_LARGEST];
+ lexrc >> font_sizes[FONT_SIZE_HUGE];
+ lexrc >> font_sizes[FONT_SIZE_HUGER];
break;
case RC_SCREEN_FONT_SCALABLE:
- if (lexrc.next()) {
- use_scalable_fonts = lexrc.getBool();
- }
+ lexrc >> use_scalable_fonts;
break;
case RC_AUTOSAVE:
- if (lexrc.next()) {
- autosave = lexrc.getInteger();
- }
+ lexrc >> autosave;
break;
case RC_DOCUMENTPATH:
break;
case RC_USETEMPDIR:
- if (lexrc.next()) {
+ if (lexrc.next())
lyxerr << "Ignoring obsolete use_tempdir flag." << endl;
- }
break;
case RC_USELASTFILEPOS:
- if (lexrc.next()) {
- use_lastfilepos = lexrc.getBool();
- }
+ lexrc >> use_lastfilepos;
break;
case RC_LOADSESSION:
- if (lexrc.next()) {
- load_session = lexrc.getBool();
- }
+ lexrc >> load_session;
break;
case RC_MOUSE_WHEEL_SPEED:
- if (lexrc.next()) {
- mouse_wheel_speed = lexrc.getFloat();
- }
+ lexrc >> mouse_wheel_speed;
break;
case RC_COMPLETION_INLINE_DELAY:
- if (lexrc.next()) {
- completion_inline_delay = lexrc.getFloat();
- }
+ lexrc >> completion_inline_delay;
break;
case RC_COMPLETION_INLINE_MATH:
- if (lexrc.next()) {
- completion_inline_math = lexrc.getBool();
- }
+ lexrc >> completion_inline_math;
break;
case RC_COMPLETION_INLINE_TEXT:
- if (lexrc.next()) {
- completion_inline_text = lexrc.getBool();
- }
+ lexrc >> completion_inline_text;
break;
case RC_COMPLETION_INLINE_DOTS:
- if (lexrc.next()) {
- completion_inline_dots = lexrc.getInteger();
- }
+ lexrc >> completion_inline_dots;
break;
case RC_COMPLETION_POPUP_DELAY:
- if (lexrc.next()) {
- completion_popup_delay = lexrc.getFloat();
- }
+ lexrc >> completion_popup_delay;
break;
case RC_COMPLETION_POPUP_MATH:
- if (lexrc.next()) {
- completion_popup_math = lexrc.getBool();
- }
+ lexrc >> completion_popup_math;
break;
case RC_COMPLETION_POPUP_TEXT:
- if (lexrc.next()) {
- completion_popup_text = lexrc.getBool();
- }
+ lexrc >> completion_popup_text;
break;
case RC_COMPLETION_CURSOR_TEXT:
- if (lexrc.next()) {
- completion_cursor_text = lexrc.getBool();
- }
+ lexrc >> completion_cursor_text;
break;
case RC_COMPLETION_POPUP_AFTER_COMPLETE:
- if (lexrc.next()) {
- completion_popup_after_complete = lexrc.getBool();
- }
+ lexrc >> completion_popup_after_complete;
break;
case RC_NUMLASTFILES:
- if (lexrc.next()) {
- num_lastfiles = lexrc.getInteger();
- }
+ lexrc >> num_lastfiles;
break;
case RC_CHECKLASTFILES:
- if (lexrc.next()) {
- check_lastfiles = lexrc.getBool();
- }
+ lexrc >> check_lastfiles;
break;
case RC_SCREEN_FONT_ROMAN:
break;
case RC_SCREEN_FONT_ROMAN_FOUNDRY:
- if (lexrc.next()) {
- roman_font_foundry = lexrc.getString();
- }
+ lexrc >> roman_font_foundry;
break;
case RC_SCREEN_FONT_SANS_FOUNDRY:
- if (lexrc.next()) {
- sans_font_foundry = lexrc.getString();
- }
+ lexrc >> sans_font_foundry;
break;
case RC_SCREEN_FONT_TYPEWRITER_FOUNDRY:
- if (lexrc.next()) {
- typewriter_font_foundry = lexrc.getString();
- }
+ lexrc >> typewriter_font_foundry;
break;
case RC_SET_COLOR:
}
case RC_AUTOREGIONDELETE:
// Auto region delete defaults to true
- if (lexrc.next()) {
- auto_region_delete = lexrc.getBool();
- }
+ lexrc >> auto_region_delete;
break;
case RC_SERVERPIPE:
break;
case RC_CURSOR_FOLLOWS_SCROLLBAR:
- if (lexrc.next()) {
- cursor_follows_scrollbar = lexrc.getBool();
- }
+ lexrc >> cursor_follows_scrollbar;
break;
case RC_MACRO_EDIT_STYLE:
break;
case RC_DIALOGS_ICONIFY_WITH_MAIN:
- if (lexrc.next()) {
- dialogs_iconify_with_main = lexrc.getBool();
- }
+ lexrc >> dialogs_iconify_with_main;
break;
case RC_PLAINTEXT_ROFF_COMMAND:
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
plaintext_roff_command = lexrc.getString();
}
break;
case RC_PLAINTEXT_LINELEN:
- if (lexrc.next()) {
- plaintext_linelen = lexrc.getInteger();
- }
+ lexrc >> plaintext_linelen;
break;
// Spellchecker settings:
case RC_USE_SPELL_LIB:
- if (lexrc.next()) {
- use_spell_lib = lexrc.getBool();
- }
+ lexrc >> use_spell_lib;
break;
case RC_SPELL_COMMAND:
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
isp_command = lexrc.getString();
}
break;
case RC_ACCEPT_COMPOUND:
- if (lexrc.next()) {
- isp_accept_compound = lexrc.getBool();
- }
+ lexrc >> isp_accept_compound;
break;
case RC_USE_INP_ENC:
- if (lexrc.next()) {
- isp_use_input_encoding = lexrc.getBool();
- }
+ lexrc >> isp_use_input_encoding;
break;
case RC_USE_ALT_LANG:
- if (lexrc.next()) {
- isp_use_alt_lang = lexrc.getBool();
- }
+ lexrc >> isp_use_alt_lang;
break;
case RC_USE_PERS_DICT:
- if (lexrc.next()) {
- isp_use_pers_dict = lexrc.getBool();
- }
+ lexrc >> isp_use_pers_dict;
break;
case RC_USE_TOOLTIP:
- if (lexrc.next()) {
- use_tooltip = lexrc.getBool();
- }
+ lexrc >> use_tooltip;
break;
case RC_USE_PIXMAP_CACHE:
- if (lexrc.next()) {
- use_pixmap_cache = lexrc.getBool();
- }
+ lexrc >> use_pixmap_cache;
break;
case RC_USE_ESC_CHARS:
- if (lexrc.next()) {
- isp_use_esc_chars = lexrc.getBool();
- }
+ lexrc >> isp_use_esc_chars;
break;
case RC_ALT_LANG:
- if (lexrc.next()) {
- isp_alt_lang = lexrc.getString();
- }
+ lexrc >> isp_alt_lang;
break;
case RC_PERS_DICT:
- if (lexrc.next()) {
+ if (lexrc.next())
isp_pers_dict = os::internal_path(lexrc.getString());
- }
break;
case RC_ESC_CHARS:
- if (lexrc.next()) {
- isp_esc_chars = lexrc.getString();
- }
+ lexrc >> isp_esc_chars;
break;
case RC_MAKE_BACKUP:
- if (lexrc.next()) {
- make_backup = lexrc.getBool();
- }
+ lexrc >> make_backup;
break;
case RC_BACKUPDIR_PATH:
if (lexrc.next()) {
}
break;
case RC_DATE_INSERT_FORMAT:
- if (lexrc.next()) {
- date_insert_format = lexrc.getString();
- }
+ lexrc >> date_insert_format;
break;
case RC_LANGUAGE_PACKAGE:
- if (lexrc.next()) {
- language_package = lexrc.getString();
- }
+ lexrc >> language_package;
break;
case RC_LANGUAGE_AUTO_BEGIN:
- if (lexrc.next()) {
- language_auto_begin = lexrc.getBool();
- }
+ lexrc >> language_auto_begin;
break;
case RC_LANGUAGE_AUTO_END:
- if (lexrc.next()) {
- language_auto_end = lexrc.getBool();
- }
+ lexrc >> language_auto_end;
break;
case RC_LANGUAGE_GLOBAL_OPTIONS:
- if (lexrc.next()) {
- language_global_options = lexrc.getBool();
- }
+ lexrc >> language_global_options;
break;
case RC_LANGUAGE_USE_BABEL:
- if (lexrc.next()) {
- language_use_babel = lexrc.getBool();
- }
+ lexrc >> language_use_babel;
break;
case RC_LANGUAGE_COMMAND_BEGIN:
- if (lexrc.next()) {
- language_command_begin = lexrc.getString();
- }
+ lexrc >> language_command_begin;
break;
case RC_LANGUAGE_COMMAND_END:
- if (lexrc.next()) {
- language_command_end = lexrc.getString();
- }
+ lexrc >> language_command_end;
break;
case RC_LANGUAGE_COMMAND_LOCAL:
- if (lexrc.next()) {
- language_command_local = lexrc.getString();
- }
+ lexrc >> language_command_local;
break;
case RC_RTL_SUPPORT:
- if (lexrc.next()) {
- rtl_support = lexrc.getBool();
- }
+ lexrc >> rtl_support;
break;
case RC_VISUAL_CURSOR:
- if (lexrc.next()) {
- visual_cursor = lexrc.getBool();
- }
+ lexrc >> visual_cursor;
break;
case RC_AUTO_NUMBER:
- if (lexrc.next()) {
- auto_number = lexrc.getBool();
- }
+ lexrc >> auto_number;
break;
case RC_MARK_FOREIGN_LANGUAGE:
- if (lexrc.next()) {
- mark_foreign_language = lexrc.getBool();
- }
+ lexrc >> mark_foreign_language;
break;
case RC_COPIER: {
if (lexrc.next()) {
fmt = lexrc.getString();
}
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
command = lexrc.getString();
}
setMover(fmt, command);
if (lexrc.next()) {
to = lexrc.getString();
}
- if (lexrc.next()) {
+ if (lexrc.next(true)) {
command = lexrc.getString();
}
if (lexrc.next()) {
flags = lexrc.getString();
}
- if (command.empty()) {
+ if (command.empty())
theConverters().erase(from, to);
- } else {
+ else
theConverters().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();
- }
+ lexrc >> format >> command;
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();
- }
+ lexrc >> format >> extension >> prettyname >> shortcut;
string viewer, editor;
- if (lexrc.next())
+ if (lexrc.next(true))
viewer = lexrc.getString();
- if (lexrc.next())
+ if (lexrc.next(true))
editor = lexrc.getString();
string flags;
// Hack to ensure compatibility with versions older
<< format << "'." << endl;
}
if (prettyname.empty()) {
- if (theConverters().formatIsUsed(format)) {
- lyxerr << "Can't delete format "
- << format << endl;
- } else {
+ if (theConverters().formatIsUsed(format))
+ LYXERR0( "Can't delete format " << format);
+ else
formats.erase(format);
- }
} else {
formats.add(format, extension, prettyname,
shortcut, viewer, editor, flgs);
break;
}
case RC_DEFAULT_LANGUAGE:
- if (lexrc.next()) {
- default_language = lexrc.getString();
- }
+ lexrc >> default_language;
break;
case RC_LABEL_INIT_LENGTH:
- if (lexrc.next()) {
- label_init_length = lexrc.getInteger();
- }
+ lexrc >> label_init_length;
break;
case RC_SHOW_BANNER:
- if (lexrc.next()) {
- show_banner = lexrc.getBool();
- }
+ lexrc >> show_banner;
break;
case RC_PREVIEW:
break;
case RC_PREVIEW_HASHED_LABELS:
- if (lexrc.next()) {
- preview_hashed_labels = lexrc.getBool();
- }
+ lexrc >> preview_hashed_labels;
break;
case RC_PREVIEW_SCALE_FACTOR:
- if (lexrc.next()) {
- preview_scale_factor = lexrc.getString();
- }
+ lexrc >> preview_scale_factor;
break;
case RC_USER_NAME:
- if (lexrc.next())
- user_name = lexrc.getString();
+ lexrc >> user_name;
break;
-
case RC_USER_EMAIL:
- if (lexrc.next())
- user_email = lexrc.getString();
+ lexrc >> user_email;
break;
case RC_PATH_PREFIX:
- if (lexrc.next())
- path_prefix = lexrc.getString();
+ lexrc >> path_prefix;
break;
case RC_USE_CONVERTER_CACHE:
- if (lexrc.next())
- use_converter_cache = lexrc.getBool();
+ lexrc >> use_converter_cache;
break;
-
case RC_CONVERTER_CACHE_MAXAGE:
- if (lexrc.next())
- converter_cache_maxage =
- convert<unsigned int>(lexrc.getString());
+ lexrc >> converter_cache_maxage;
break;
case RC_SORT_LAYOUTS:
- if (lexrc.next())
- sort_layouts = lexrc.getBool();
+ lexrc >> sort_layouts;
break;
case RC_GROUP_LAYOUTS:
- if (lexrc.next())
- group_layouts = lexrc.getBool();
+ lexrc >> group_layouts;
break;
case RC_FULL_SCREEN_LIMIT:
- if (lexrc.next())
- full_screen_limit = lexrc.getBool();
+ lexrc >> full_screen_limit;
break;
case RC_FULL_SCREEN_TOOLBARS:
- if (lexrc.next())
- full_screen_toolbars = lexrc.getBool();
+ lexrc >> full_screen_toolbars;
break;
case RC_FULL_SCREEN_SCROLLBAR:
- if (lexrc.next())
- full_screen_scrollbar = lexrc.getBool();
+ lexrc >> full_screen_scrollbar;
break;
case RC_FULL_SCREEN_TABBAR:
- if (lexrc.next())
- full_screen_tabbar = lexrc.getBool();
+ lexrc >> full_screen_tabbar;
break;
case RC_FULL_SCREEN_WIDTH:
- if (lexrc.next())
- full_screen_width = lexrc.getInteger();
+ lexrc >> full_screen_width;
break;
case RC_OPEN_BUFFERS_IN_TABS:
- if (lexrc.next())
- open_buffers_in_tabs = lexrc.getBool();
- break;
- case RC_USE_BUNDLED_FORMAT:
- if (lexrc.next())
- use_bundled_format = lexrc.getBool();
- break;
+ lexrc >> open_buffers_in_tabs;
+ break;
- case RC_LAST: break; // this is just a dummy
+ case RC_LAST:
+ break; // this is just a dummy
}
}
};
+namespace {
+
+ // Escape \ and " so that LyXLex can read the string later
+ string escapeCommand(string const & str) {
+ return subst(subst(str , "\\", "\\\\"),
+ "\"", "\\\"");
+ }
+
+}
+
+
void LyXRC::write(ostream & os, bool ignore_system_lyxrc, string const & name) const
{
LyXRCTags tag = RC_LAST;
}
if (tag == RC_LAST)
- os << "### This file is part of\n"
- << "### ========================================================\n"
- << "### LyX, The Document Processor\n"
- << "###\n"
- << "### Copyright 1995 Matthias Ettrich\n"
- << "### Copyright 1995-2007 The LyX Team.\n"
- << "###\n"
- << "### ========================================================\n"
- << "\n"
- << "# This file is written by LyX, if you want to make your own\n"
+ os << "# 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
+ // the elements in the LyXRCTags enum are handled. As you can see
// there are no breaks at all. So it is just a huge fall-through.
// The nice thing is that we will get a warning from the compiler
// if we forget an element.
case RC_CHKTEX_COMMAND:
if (ignore_system_lyxrc ||
chktex_command != system_lyxrc.chktex_command) {
- os << "\\chktex_command \"" << chktex_command << "\"\n";
+ os << "\\chktex_command \"" << escapeCommand(chktex_command) << "\"\n";
}
if (tag != RC_LAST)
break;
case RC_BIBTEX_COMMAND:
if (ignore_system_lyxrc ||
bibtex_command != system_lyxrc.bibtex_command) {
- os << "\\bibtex_command \"" << bibtex_command << "\"\n";
+ os << "\\bibtex_command \"" << escapeCommand(bibtex_command) << "\"\n";
}
if (tag != RC_LAST)
break;
case RC_INDEX_COMMAND:
if (ignore_system_lyxrc ||
index_command != system_lyxrc.index_command) {
- os << "\\index_command \"" << index_command << "\"\n";
+ os << "\\index_command \"" << escapeCommand(index_command) << "\"\n";
}
if (tag != RC_LAST)
break;
}
if (tag != RC_LAST)
break;
- case RC_USE_BUNDLED_FORMAT:
- if (ignore_system_lyxrc ||
- use_bundled_format != system_lyxrc.use_bundled_format) {
- os << "\\use_bundled_format "
- << convert<string>(use_bundled_format)
- << '\n';
- }
- if (tag != RC_LAST)
- break;
- os << "\n#\n"
- << "# COLOR SECTION ###################################\n"
- << "#\n\n";
+ os << "\n#\n"
+ << "# COLOR SECTION ###################################\n"
+ << "#\n\n";
case RC_SET_COLOR:
for (int i = 0; i < Color_ignore; ++i) {
case RC_PRINT_COMMAND:
if (ignore_system_lyxrc ||
print_command != system_lyxrc.print_command) {
- os << "\\print_command \"" << print_command << "\"\n";
+ os << "\\print_command \"" << escapeCommand(print_command) << "\"\n";
}
if (tag != RC_LAST)
break;
case RC_PRINTSPOOL_COMMAND:
if (ignore_system_lyxrc ||
print_spool_command != system_lyxrc.print_spool_command) {
- os << "\\print_spool_command \"" << print_spool_command
+ os << "\\print_spool_command \"" << escapeCommand(print_spool_command)
<< "\"\n";
}
if (tag != RC_LAST)
case RC_PLAINTEXT_ROFF_COMMAND:
if (ignore_system_lyxrc ||
plaintext_roff_command != system_lyxrc.plaintext_roff_command) {
- os << "\\plaintext_roff_command \"" << plaintext_roff_command
+ os << "\\plaintext_roff_command \"" << escapeCommand(plaintext_roff_command)
<< "\"\n";
}
if (tag != RC_LAST)
case RC_SPELL_COMMAND:
if (ignore_system_lyxrc ||
isp_command != system_lyxrc.isp_command) {
- os << "\\spell_command \"" << isp_command << "\"\n";
+ os << "\\spell_command \"" << escapeCommand(isp_command) << "\"\n";
}
if (tag != RC_LAST)
break;
<< cit->extension() << "\" \""
<< cit->prettyname() << "\" \""
<< cit->shortcut() << "\" \""
- << cit->viewer() << "\" \""
- << cit->editor() << "\" \"";
+ << escapeCommand(cit->viewer()) << "\" \""
+ << escapeCommand(cit->editor()) << "\" \"";
vector<string> flags;
if (cit->documentFormat())
flags.push_back("document");
converter->flags != cit->flags)
os << "\\converter \"" << cit->from << "\" \""
<< cit->to << "\" \""
- << cit->command << "\" \""
+ << escapeCommand(cit->command) << "\" \""
<< cit->flags << "\"\n";
}
it->second.command();
os << "\\copier " << fmt
- << " \"" << command << "\"\n";
+ << " \"" << escapeCommand(command) << "\"\n";
}
}
if (tag != RC_LAST)