commit 7bb08f10b1567a1a5bd87ba213c13a40d6a70cfc
Author: Jean-Marc Lasgouttes <[email protected]>
Date: Thu Apr 18 17:09:12 2019 +0200
Move initial values of LyXRC members to the header
We use a C++11 construct that puts initial values of members along
with their definition. It is a good construct and now the out of line
constructor and the setDefaults() method can go.
This removes the need to define a dummy constructor in tex2lyx and
client.
The only needed change to the rest of code is a change of signature
for the user_(name|email) to return std::string. They are now called
explicitely from the constructor. We now have to include userinfo.h in
LyXRC.h, but this should not be too expensive.
---
src/LyXRC.cpp | 154 -----------------------------
src/LyXRC.h | 229 +++++++++++++++++++++++--------------------
src/client/client.cpp | 5 +-
src/support/userinfo.cpp | 14 ++--
src/support/userinfo.h | 4 +-
src/tex2lyx/dummy_impl.cpp | 10 +--
6 files changed, 133 insertions(+), 283 deletions(-)
diff --git a/src/LyXRC.cpp b/src/LyXRC.cpp
index d7e83c2..99289aa 100644
--- a/src/LyXRC.cpp
+++ b/src/LyXRC.cpp
@@ -211,160 +211,6 @@ LexerKeyword lyxrcTags[] = {
const int lyxrcCount = sizeof(lyxrcTags) / sizeof(lyxrcTags[0]);
-} // namespace
-
-
-LyXRC::LyXRC()
-{
- setDefaults();
-}
-
-
-void LyXRC::setDefaults()
-{
- icon_set = string();
- use_system_theme_icons = false;
- bind_file = "cua";
- def_file = "default";
- ui_file = "default";
- // The current document directory
- texinputs_prefix = ".";
- print_landscape_flag = "-t landscape";
- print_paper_flag = "-t";
- print_paper_dimension_flag = "-T";
- document_path.erase();
- view_dvi_paper_option.erase();
- default_view_format = "pdf2";
- default_otf_view_format = "pdf4";
- default_platex_view_format = "pdf3";
- chktex_command = "chktex -n1 -n3 -n6 -n9 -n22 -n25 -n30 -n38";
- bibtex_command = "automatic";
- index_command = "makeindex -c -q";
- nomencl_command = "makeindex -s nomencl.ist";
- pygmentize_command = string();
- dpi = 75;
- // Because a screen is typically wider than a piece of paper:
- defaultZoom = 150;
- currentZoom = defaultZoom;
- allow_geometry_session = true;
- // Default LaTeX font size:
- font_sizes[FONT_SIZE_TINY] = "5.0";
- font_sizes[FONT_SIZE_SCRIPT] = "7.0";
- font_sizes[FONT_SIZE_FOOTNOTE] = "8.0";
- font_sizes[FONT_SIZE_SMALL] = "9.0";
- font_sizes[FONT_SIZE_NORMAL] = "10.0";
- font_sizes[FONT_SIZE_LARGE] = "12.0";
- font_sizes[FONT_SIZE_LARGER] = "14.4";
- font_sizes[FONT_SIZE_LARGEST] = "17.26";
- font_sizes[FONT_SIZE_HUGE] = "20.74";
- font_sizes[FONT_SIZE_HUGER] = "24.88";
- use_scalable_fonts = true;
- roman_font_name = "";
- sans_font_name = "";
- typewriter_font_name = "";
- autosave = 300;
- auto_region_delete = true;
- auto_reset_options = false;
- plaintext_linelen = 65;
- mouse_wheel_speed = 1.0;
- num_lastfiles = 20;
- check_lastfiles = true;
- use_lastfilepos = true;
- use_native_filedialog = true;
- load_session = false;
- make_backup = true;
- save_compressed = false;
- save_origin = false;
- backupdir_path.erase();
- display_graphics = true;
- // Spellchecker settings:
-// FIXME: this check should test the target platform (darwin)
-#if defined(USE_MACOSX_PACKAGING)
- spellchecker = "native";
-#elif defined(USE_ENCHANT)
- spellchecker = "enchant";
-#elif defined(USE_ASPELL)
- spellchecker = "aspell";
-#elif defined(USE_HUNSPELL)
- spellchecker = "hunspell";
-#else
- spellchecker = "aspell";
-#endif
- spellchecker_accept_compound = false;
- spellcheck_continuously = false;
- completion_minlength = 6;
- spellcheck_notes = true;
- use_kbmap = false;
- visual_cursor = false;
- auto_number = true;
- mark_foreign_language = true;
- language_auto_begin = true;
- language_auto_end = true;
- language_global_options = true;
- language_package_selection = LP_AUTO;
- language_custom_package = "\\usepackage{babel}";
- language_command_begin = "\\selectlanguage{$$lang}";
- language_command_local = "\\foreignlanguage{$$lang}{";
- sort_layouts = false;
- group_layouts = true;
- gui_language = "auto";
- show_banner = true;
- windows_style_tex_paths = false;
- tex_allows_spaces = false;
- cursor_follows_scrollbar = false;
- scroll_below_document = false;
- scroll_wheel_zoom = SCROLL_WHEEL_ZOOM_CTRL;
- paragraph_markers = false;
- mac_dontswap_ctrl_meta = false;
- mac_like_cursor_movement = false;
- macro_edit_style = MACRO_EDIT_INLINE_BOX;
- dialogs_iconify_with_main = false;
- preview = PREVIEW_OFF;
- preview_hashed_labels = false;
- preview_scale_factor = 1.0;
- use_converter_cache = true;
- use_converter_needauth_forbidden = true;
- use_converter_needauth = true;
- use_system_colors = false;
- use_tooltip = true;
- converter_cache_maxage = 6 * 30 * 24 * 3600; // 6 months
- user_name = to_utf8(support::user_name());
- user_email = to_utf8(support::user_email());
- open_buffers_in_tabs = true;
- single_close_tab_button = false;
- single_instance = true;
- forward_search_dvi = string();
- forward_search_pdf = string();
- export_overwrite = NO_FILES;
-
- // Fullscreen settings
- full_screen_limit = false;
- full_screen_toolbars = true;
- full_screen_tabbar = true;
- full_screen_menubar = true;
- full_screen_statusbar = true;
- full_screen_scrollbar = true;
- full_screen_width = 700;
-
- completion_cursor_text = true;
- completion_popup_math = true;
- completion_popup_text = false;
- completion_popup_delay = 2.0;
- completion_popup_after_complete = true;
- autocorrection_math = false;
- completion_inline_math = true;
- completion_inline_text = false;
- completion_inline_dots = -1;
- completion_inline_delay = 0.2;
- default_decimal_point = ".";
- default_length_unit = Length::CM;
- cursor_width = 1;
- close_buffer_with_last_view = "yes";
- mouse_middlebutton_paste = true;
-}
-
-
-namespace {
void oldFontFormat(string & family, string & foundry)
{
diff --git a/src/LyXRC.h b/src/LyXRC.h
index 6e1ccfd..ab6a590 100644
--- a/src/LyXRC.h
+++ b/src/LyXRC.h
@@ -19,8 +19,10 @@
#define LYXRC_H
#include "Length.h"
+#include "LyX.h"
#include "support/strfwd.h"
+#include "support/userinfo.h"
#include <map>
#include <set>
@@ -183,9 +185,10 @@ public:
};
///
- LyXRC();
- ///
- void setDefaults();
+ LyXRC() : user_name(support::user_name()),
+ user_email(support::user_email()) // always empty
+ {};
+
/// \param check_format: whether to try to convert the file format,
/// if it is not current. this should only be true, really, for the
/// user's own preferences file.
@@ -220,26 +223,26 @@ public:
// FIXME unused (was used for xforms. Do we still need this?)
//static docstring const getDescription(LyXRCTags);
///
- std::string bind_file;
+ std::string bind_file = "cua";
///
- std::string def_file;
+ std::string def_file = "default";
///
- std::string ui_file;
+ std::string ui_file = "default";
///
- std::string print_landscape_flag;
+ std::string print_landscape_flag = "-t landscape";
///
- std::string print_paper_flag;
+ std::string print_paper_flag = "-t";
///
- std::string print_paper_dimension_flag;
+ std::string print_paper_dimension_flag = "-T";
/// option for telling the dvi viewer about the paper size
std::string view_dvi_paper_option;
/// default paper size for local xdvi/dvips/ghostview/whatever
/// command to run chktex incl. options
- std::string chktex_command;
+ std::string chktex_command = "chktex -n1 -n3 -n6 -n9 -n22 -n25 -n30
-n38";
/// all available commands to run bibtex incl. options
CommandSet bibtex_alternatives;
/// command to run bibtex incl. options
- std::string bibtex_command;
+ std::string bibtex_command = "automatic";
/// command to run japanese bibtex incl. options
std::string jbibtex_command;
/// all available commands to run japanese bibtex incl. options
@@ -247,13 +250,13 @@ public:
/// all available index commands incl. options
CommandSet index_alternatives;
/// command to run makeindex incl. options or other index programs
- std::string index_command;
+ std::string index_command = "makeindex -c -q";
/// command to run japanese index program incl. options
std::string jindex_command;
/// command to generate multiple indices
std::string splitindex_command;
/// command to run makeindex incl. options for nomencl
- std::string nomencl_command;
+ std::string nomencl_command = "makeindex -s nomencl.ist";
/// command to run the python pygments syntax highlighter
std::string pygmentize_command;
///
@@ -269,43 +272,44 @@ public:
///
std::string hunspelldir_path;
///
- bool auto_region_delete;
+ bool auto_region_delete = true;
/// enable middle-mouse-button paste
- bool mouse_middlebutton_paste;
- /// flag telling whether lastfiles should be checked for existance
- bool auto_reset_options;
+ bool mouse_middlebutton_paste = true;
///
- bool check_lastfiles;
+ bool auto_reset_options = false;
+ /// flag telling whether lastfiles should be checked for existance
+ bool check_lastfiles = true;
/// maximal number of lastfiles
- unsigned int num_lastfiles;
+ unsigned int num_lastfiles = 20;
/// whether or not go to saved position when opening a file
- bool use_lastfilepos;
+ bool use_lastfilepos = true;
/// load files from last session automatically
- bool load_session;
+ bool load_session = false;
/// do we save new documents as compressed by default
- bool save_compressed;
+ bool save_compressed = false;
/// whether or not to save the document dir in the file
- bool save_origin;
+ bool save_origin = false;
/// shall a backup file be created
- bool make_backup;
+ bool make_backup = true;
/// A directory for storing backup files
std::string backupdir_path;
/// Whether or not save/restore session information
/// like windows position and geometry.
- bool allow_geometry_session;
+ bool allow_geometry_session = true;
/// Scrolling speed of the mouse wheel
- double mouse_wheel_speed;
+ double mouse_wheel_speed = 1.0;
/// Default zoom factor for screen fonts
- int defaultZoom;
+ int defaultZoom = 150;
/// Actual zoom factor for screen fonts
/// (default zoom plus buffer zoom factor)
- int currentZoom;
+ int currentZoom = 150;
/// Screen font sizes in points for each font size
- std::string font_sizes[10];
+ std::string font_sizes[10] = { "5.0", "7.0", "8.0", "9.0", "10.0",
+ "12.0", "14.4", "17.26", "20.74",
"24.88"};
/// Allow the use of scalable fonts? Default is yes.
- bool use_scalable_fonts;
+ bool use_scalable_fonts = true;
/// DPI of monitor
- unsigned int dpi;
+ unsigned int dpi = 75;
///
std::string roman_font_name;
///
@@ -319,33 +323,44 @@ public:
///
std::string typewriter_font_foundry;
///
- unsigned int autosave;
+ unsigned int autosave = 300;
///
- unsigned int plaintext_linelen;
- /// Accept compound words in spellchecker?
- bool spellchecker_accept_compound;
+ unsigned int plaintext_linelen = 65;
/// End of paragraph markers?
- bool paragraph_markers;
+ bool paragraph_markers = false;
/// Use tooltips?
- bool use_tooltip;
+ bool use_tooltip = true;
/// Use the colors from current system theme?
- bool use_system_colors;
+ bool use_system_colors = false;
/// use native file dialog or our own ?
- bool use_native_filedialog;
+ bool use_native_filedialog = true;
/// Spellchecker engine: aspell, hunspell, etc
- std::string spellchecker;
+ std::string spellchecker
+#if defined(USE_MACOSX_PACKAGING)
+ = "native";
+#elif defined(USE_ENCHANT)
+ = "enchant";
+#elif defined(USE_ASPELL)
+ = "aspell";
+#elif defined(USE_HUNSPELL)
+ = "hunspell";
+#else
+ = "aspell";
+#endif
/// Alternate language for spellchecker
std::string spellchecker_alt_lang;
/// Escape characters
std::string spellchecker_esc_chars;
+ /// Accept compound words in spellchecker?
+ bool spellchecker_accept_compound = false;
/// spellcheck continuously?
- bool spellcheck_continuously;
+ bool spellcheck_continuously = false;
/// spellcheck notes and comments?
- bool spellcheck_notes;
+ bool spellcheck_notes = true;
/// minimum length of words to complete
- unsigned int completion_minlength;
+ unsigned int completion_minlength = 6;
///
- bool use_kbmap;
+ bool use_kbmap = false;
///
std::string primary_kbmap;
///
@@ -353,19 +368,19 @@ public:
///
std::string lyxpipes;
///
- std::string language_custom_package;
+ std::string language_custom_package = "\\usepackage{babel}";
///
- bool language_auto_begin;
+ bool language_auto_begin = true;
///
- bool language_auto_end;
+ bool language_auto_end = true;
///
- std::string language_command_begin;
+ std::string language_command_begin = "\\selectlanguage{$$lang}";
///
std::string language_command_end;
///
- std::string language_command_local;
+ std::string language_command_local = "\\foreignlanguage{$$lang}{";
///
- bool language_global_options;
+ bool language_global_options = true;
///
enum LangPackageSelection {
LP_AUTO = 0,
@@ -374,33 +389,33 @@ public:
LP_NONE
};
///
- LangPackageSelection language_package_selection;
+ LangPackageSelection language_package_selection = LP_AUTO;
/// bidi cursor movement: true = visual, false = logical
- bool visual_cursor;
+ bool visual_cursor = false;
///
- bool auto_number;
+ bool auto_number = true;
///
- bool mark_foreign_language;
+ bool mark_foreign_language = true;
///
- std::string gui_language;
+ std::string gui_language = "auto";
///
- std::string default_otf_view_format;
+ std::string default_otf_view_format = "pdf4";
///
- std::string default_platex_view_format;
+ std::string default_platex_view_format = "pdf3";
///
- std::string default_view_format;
+ std::string default_view_format = "pdf2";
/// all available viewers
Alternatives viewer_alternatives;
/// all available editors
Alternatives editor_alternatives;
///
- bool mac_dontswap_ctrl_meta;
+ bool mac_dontswap_ctrl_meta = false;
///
- bool mac_like_cursor_movement;
+ bool mac_like_cursor_movement = false;
///
- bool cursor_follows_scrollbar;
+ bool cursor_follows_scrollbar = false;
///
- bool scroll_below_document;
+ bool scroll_below_document = false;
///
enum MacroEditStyle {
MACRO_EDIT_INLINE_BOX = 0,
@@ -408,13 +423,13 @@ public:
MACRO_EDIT_LIST
};
///
- MacroEditStyle macro_edit_style;
+ MacroEditStyle macro_edit_style = MACRO_EDIT_INLINE_BOX;
///
- bool dialogs_iconify_with_main;
+ bool dialogs_iconify_with_main = false;
///
- bool display_graphics;
+ bool display_graphics = true;
///
- bool show_banner;
+ bool show_banner = true;
///
enum PreviewStatus {
PREVIEW_OFF,
@@ -422,23 +437,23 @@ public:
PREVIEW_ON
};
///
- PreviewStatus preview;
+ PreviewStatus preview = PREVIEW_OFF;
///
- bool preview_hashed_labels;
+ bool preview_hashed_labels = false;
///
- double preview_scale_factor;
+ double preview_scale_factor = 1.0;
/// user name
- std::string user_name;
+ std::string user_name; // set in constructor
/// user email
- std::string user_email;
+ std::string user_email; // set in constructor (empty for now)
/// icon set name
std::string icon_set;
/// whether to use the icons from the theme
- bool use_system_theme_icons;
+ bool use_system_theme_icons = false;
/// True if the TeX engine cannot handle posix paths
- bool windows_style_tex_paths;
+ bool windows_style_tex_paths = false;
/// True if the TeX engine can handle file names containing spaces
- bool tex_allows_spaces;
+ bool tex_allows_spaces = false;
/** Prepend paths to the PATH environment variable.
* The string is input, stored and output in native format.
*/
@@ -447,69 +462,69 @@ public:
* The string is input, stored and output in native format.
* A '.' here stands for the current document directory.
*/
- std::string texinputs_prefix;
+ std::string texinputs_prefix = ".";
/// Use the cache for file converters?
- bool use_converter_cache;
+ bool use_converter_cache = true;
/// Forbid use of external converters with 'needauth' option
- bool use_converter_needauth_forbidden;
+ bool use_converter_needauth_forbidden = true;
/// Ask user before calling external converters with 'needauth' option
- bool use_converter_needauth;
+ bool use_converter_needauth = true;
/// The maximum age of cache files in seconds
- unsigned int converter_cache_maxage;
+ unsigned int converter_cache_maxage = 6 * 30 * 24 * 3600; // 6 months;
/// Sort layouts alphabetically
- bool sort_layouts;
+ bool sort_layouts = false;
/// Group layout by their category
- bool group_layouts;
+ bool group_layouts = true;
/// Toggle toolbars in fullscreen mode?
- bool full_screen_toolbars;
+ bool full_screen_toolbars = true;
/// Toggle scrollbar in fullscreen mode?
- bool full_screen_scrollbar;
+ bool full_screen_scrollbar = true;
/// Toggle tabbar in fullscreen mode?
- bool full_screen_tabbar;
+ bool full_screen_tabbar = true;
/// Toggle menubar in fullscreen mode?
- bool full_screen_menubar;
+ bool full_screen_menubar = true;
/// Toggle statusbar in fullscreen mode?
- bool full_screen_statusbar;
+ bool full_screen_statusbar = true;
/// Limit the text width?
- bool full_screen_limit;
+ bool full_screen_limit = false;
/// Width of limited screen (in pixels) in fullscreen mode
- int full_screen_width;
+ int full_screen_width = 700;
///
- bool completion_cursor_text;
+ bool completion_cursor_text = true;
///
- double completion_inline_delay;
+ double completion_inline_delay = 0.2;
///
- bool completion_inline_math;
+ bool completion_inline_math = true;
///
- bool completion_inline_text;
+ bool completion_inline_text = false;
///
- int completion_inline_dots;
+ int completion_inline_dots = -1;
///
- bool autocorrection_math;
+ double completion_popup_delay = 2.0;
///
- double completion_popup_delay;
+ bool completion_popup_math = true;
///
- bool completion_popup_math;
+ bool completion_popup_text = false;
///
- bool completion_popup_text;
+ bool completion_popup_after_complete = true;
///
- bool completion_popup_after_complete;
+ bool autocorrection_math = false;
///
- bool open_buffers_in_tabs;
+ bool open_buffers_in_tabs = true;
///
- bool single_close_tab_button;
+ bool single_close_tab_button = false;
///
- bool single_instance;
+ bool single_instance = true;
///
std::string forward_search_dvi;
///
std::string forward_search_pdf;
///
- int export_overwrite;
+ int export_overwrite = NO_FILES;
/// Default decimal point when aligning table columns on decimal
- std::string default_decimal_point;
+ std::string default_decimal_point = ".";
///
- Length::UNIT default_length_unit;
+ Length::UNIT default_length_unit = Length::CM;
///
enum ScrollWheelZoom {
SCROLL_WHEEL_ZOOM_OFF,
@@ -518,11 +533,11 @@ public:
SCROLL_WHEEL_ZOOM_ALT
};
///
- ScrollWheelZoom scroll_wheel_zoom;
+ ScrollWheelZoom scroll_wheel_zoom = SCROLL_WHEEL_ZOOM_CTRL;
///
- int cursor_width;
+ int cursor_width = 1;
/// One of: yes, no, ask
- std::string close_buffer_with_last_view;
+ std::string close_buffer_with_last_view = "yes";
};
diff --git a/src/client/client.cpp b/src/client/client.cpp
index ceea5d1..17338a6 100644
--- a/src/client/client.cpp
+++ b/src/client/client.cpp
@@ -68,11 +68,8 @@ using namespace lyx::support;
namespace lyx {
-// Dummy verbose support
+// Required global variables
bool verbose = false;
-
-// Dummy LyXRC support
-LyXRC::LyXRC() {}
LyXRC lyxrc;
// Keep the linker happy on Windows
diff --git a/src/support/userinfo.cpp b/src/support/userinfo.cpp
index 97c458c..30a7c54 100644
--- a/src/support/userinfo.cpp
+++ b/src/support/userinfo.cpp
@@ -35,7 +35,7 @@ using namespace std;
namespace lyx {
namespace support {
-docstring const user_name()
+string const user_name()
{
#if defined (_WIN32)
@@ -43,32 +43,32 @@ docstring const user_name()
DWORD size = UNLEN + 1;
if (!GetUserName(name, &size))
return _("Unknown user");
- return from_local8bit(name);
+ return to_utf8(from_local8bit(name));
#else
struct passwd * pw = getpwuid(geteuid());
- LASSERT(pw, return docstring());
+ LASSERT(pw, return string());
const string gecos = pw->pw_gecos;
const size_t pos = gecos.find(",");
string name = gecos.substr(0, pos);
if (name.empty())
name = pw->pw_name;
- return from_local8bit(name);
+ return to_utf8(from_local8bit(name));
#endif
}
-docstring const user_email()
+string const user_email()
{
//FIXME: quick fix wrt bug #3764; only Anonymous is detected now.
//The code after should be used only after user approval.
- return docstring();
+ return string();
#if 0
string email = getEnv("EMAIL_ADDRESS");
if (email.empty())
email = getEnv("EMAIL");
- return from_local8bit(email);
+ return to_utf8(from_local8bit(email));
#endif
}
diff --git a/src/support/userinfo.h b/src/support/userinfo.h
index 6232a2b..096e8ff 100644
--- a/src/support/userinfo.h
+++ b/src/support/userinfo.h
@@ -19,10 +19,10 @@ namespace lyx {
namespace support {
/// return the current user's real name or user name
-docstring const user_name();
+std::string const user_name();
/// return the current user's e-mail address
-docstring const user_email();
+std::string const user_email();
} // namespace support
} // namespace lyx
diff --git a/src/tex2lyx/dummy_impl.cpp b/src/tex2lyx/dummy_impl.cpp
index f38526f..c850cd9 100644
--- a/src/tex2lyx/dummy_impl.cpp
+++ b/src/tex2lyx/dummy_impl.cpp
@@ -48,18 +48,10 @@ namespace Alert {
//
-// Dummy verbose support
+// Required global variables
//
bool verbose = false;
-
-
-//
-// Dummy LyXRC support
-//
-
-
-LyXRC::LyXRC() {}
LyXRC lyxrc;