]> git.lyx.org Git - lyx.git/blobdiff - src/lyxrc.h
remove unneeded functions
[lyx.git] / src / lyxrc.h
index 9d70eacee8e6bb2d9cb2836e93a0da6ca0f9fa9e..e948e6489fcf8ec6ae1b56988da30fe1b677f23b 100644 (file)
@@ -4,16 +4,27 @@
  * This file is part of LyX, the document processor.
  * Licence details can be found in the file COPYING.
  *
- * Full author contact details are available in file CREDITS
+ * \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.
  */
 
 #ifndef LYXRC_H
 #define LYXRC_H
 
-#include "bufferparams.h" // Just to get the enum BufferParams::PAPER_SIZE (sic)
+#include "paper.h"
 #include "graphics/GraphicsTypes.h"
 
-// #include <boost/utility.hpp>
+#include <iosfwd>
+#include <string>
+
+class LyXLex;
 
 /// This contains the runtime configuration of LyX
 class LyXRC //: public noncopyable {
@@ -65,7 +76,6 @@ enum LyXRCTags {
        RC_LASTFILES,
        RC_AUTOREGIONDELETE,
        RC_AUTORESET_OPTIONS,
-       RC_BIND,
        RC_SERVERPIPE,
        RC_INPUT,
        RC_BINDFILE,
@@ -79,7 +89,6 @@ enum LyXRCTags {
        RC_CHECKLASTFILES,
        RC_VIEWDVI_PAPEROPTION,
        RC_DEFAULT_PAPERSIZE,
-       RC_PS_COMMAND,
        RC_ACCEPT_COMPOUND,
        RC_SPELL_COMMAND,
        RC_USE_INP_ENC,
@@ -91,6 +100,7 @@ enum LyXRCTags {
        RC_PERS_DICT,
        RC_ESC_CHARS,
        RC_CHKTEX_COMMAND,
+       RC_BIBTEX_COMMAND,
        RC_CURSOR_FOLLOWS_SCROLLBAR,
        RC_DIALOGS_ICONIFY_WITH_MAIN,
        RC_MAKE_BACKUP,
@@ -130,77 +140,81 @@ enum LyXRCTags {
        ///
        void setDefaults();
        ///
-       int read(string const & filename);
+       int read(std::string const & filename);
        ///
-       void readBindFileIfNeeded();
+       int read(std::istream &);
+private:
        ///
-       void write(string const & filename) const;
+       int read(LyXLex &);
+public:
        ///
-       void print() const;
+       void write(std::string const & filename,
+                  bool ignore_system_lyxrc) const;
        ///
-       void output(std::ostream & os) const;
+       void write(std::ostream & os,
+                  bool ignore_system_lyxrc) const;
        ///
-       static string const getDescription(LyXRCTags);
+       void print() const;
+       ///
+       static std::string const getDescription(LyXRCTags);
        ///
-       string bind_file;
+       std::string bind_file;
        ///
-       string ui_file;
+       std::string ui_file;
        ///
-       string printer;
+       std::string printer;
        ///
-       string print_command;
+       std::string print_command;
        ///
-       string print_evenpage_flag;
+       std::string print_evenpage_flag;
        ///
-       string print_oddpage_flag;
+       std::string print_oddpage_flag;
        ///
-       string print_pagerange_flag;
+       std::string print_pagerange_flag;
        ///
-       string print_copies_flag;
+       std::string print_copies_flag;
        ///
-       string print_collcopies_flag;
+       std::string print_collcopies_flag;
        ///
-       string print_reverse_flag;
+       std::string print_reverse_flag;
        ///
-       string print_landscape_flag;
+       std::string print_landscape_flag;
        ///
-       string print_to_printer;
+       std::string print_to_printer;
        ///
        bool print_adapt_output;
        ///
-       string print_to_file;
+       std::string print_to_file;
        ///
-       string print_file_extension;
+       std::string print_file_extension;
        ///
-       string print_extra_options;
+       std::string print_extra_options;
        ///
-       string print_spool_command;
+       std::string print_spool_command;
        ///
-       string print_spool_printerprefix;
+       std::string print_spool_printerprefix;
        ///
-       string print_paper_flag;
+       std::string print_paper_flag;
        ///
-       string print_paper_dimension_flag;
+       std::string print_paper_dimension_flag;
        ///
-       string custom_export_command;
+       std::string custom_export_command;
        ///
-       string custom_export_format;
-       /// postscript interpreter (in general "gs", if it is installed)
-       string ps_command;
+       std::string custom_export_format;
        /// option for telling the dvi viewer about the paper size
-       string view_dvi_paper_option;
+       std::string view_dvi_paper_option;
        /// default paper size for local xdvi/dvips/ghostview/whatever
-       BufferParams::PAPER_SIZE default_papersize;
+       PAPER_SIZE default_papersize;
        /// command to run chktex incl. options
-       string chktex_command;
+       std::string chktex_command;
+       /// command to run bibtex incl. options
+       std::string bibtex_command;
        ///
-       string document_path;
+       std::string document_path;
        ///
-       string template_path;
+       std::string template_path;
        ///
-       string tempdir_path;
-       ///
-       bool use_tempdir;
+       std::string tempdir_path;
        ///
        bool auto_region_delete;
        /// flag telling whether lastfiles should be checked for existance
@@ -208,13 +222,13 @@ enum LyXRCTags {
        ///
        bool check_lastfiles;
        /// filename for lastfiles file
-       string lastfiles;
+       std::string lastfiles;
        /// maximal number of lastfiles
        unsigned int num_lastfiles;
        /// shall a backup file be created
        bool make_backup;
        /// A directory for storing backup files
-       string backupdir_path;
+       std::string backupdir_path;
        /// Zoom factor for screen fonts
        unsigned int zoom;
        /// parameter for button_4 and button_5 (scrollwheel)
@@ -226,25 +240,25 @@ enum LyXRCTags {
        /// DPI of monitor
        float dpi;
        ///
-       string fontenc;
+       std::string fontenc;
        ///
-       string roman_font_name;
+       std::string roman_font_name;
        ///
-       string sans_font_name;
+       std::string sans_font_name;
        ///
-       string typewriter_font_name;
+       std::string typewriter_font_name;
        ///
-       string roman_font_foundry;
+       std::string roman_font_foundry;
        ///
-       string sans_font_foundry;
+       std::string sans_font_foundry;
        ///
-       string typewriter_font_foundry;
+       std::string typewriter_font_foundry;
        ///
-       string popup_bold_font;
+       std::string popup_bold_font;
        ///
-       string popup_normal_font;
+       std::string popup_normal_font;
        ///
-       string font_norm;
+       std::string font_norm;
        ///
        enum FontEncoding {
                ///
@@ -269,17 +283,17 @@ enum LyXRCTags {
        ///
        void set_font_norm_type();
        ///
-       string popup_font_encoding;
+       std::string popup_font_encoding;
        ///
        unsigned int autosave;
        ///
-       string ascii_roff_command;
+       std::string ascii_roff_command;
        ///
        unsigned int ascii_linelen;
        /// use library instead of process
        bool use_spell_lib;
        /// Ispell command
-       string isp_command;
+       std::string isp_command;
        /// Accept compound words in spellchecker?
        bool isp_accept_compound;
        /// Pass input encoding switch to ispell?
@@ -291,33 +305,33 @@ enum LyXRCTags {
        /// Use escape chars?
        bool isp_use_esc_chars;
        /// Alternate language for ispell
-       string isp_alt_lang;
+       std::string isp_alt_lang;
        /// Alternate personal dictionary file for ispell
-       string isp_pers_dict;
+       std::string isp_pers_dict;
        /// Escape characters
-       string isp_esc_chars;
+       std::string isp_esc_chars;
        ///
        bool use_kbmap;
        ///
-       string primary_kbmap;
+       std::string primary_kbmap;
        ///
-       string secondary_kbmap;
+       std::string secondary_kbmap;
        ///
-       string lyxpipes;
+       std::string lyxpipes;
        ///
-       string date_insert_format;
+       std::string date_insert_format;
        ///
-       string language_package;
+       std::string language_package;
        ///
        bool language_auto_begin;
        ///
        bool language_auto_end;
        ///
-       string language_command_begin;
+       std::string language_command_begin;
        ///
-       string language_command_end;
+       std::string language_command_end;
        ///
-       string language_command_local;
+       std::string language_command_local;
        ///
        bool language_global_options;
        ///
@@ -329,7 +343,7 @@ enum LyXRCTags {
        ///
        bool mark_foreign_language;
        ///
-       string default_language;
+       std::string default_language;
        ///
        bool cursor_follows_scrollbar;
        ///
@@ -341,23 +355,36 @@ enum LyXRCTags {
        ///
        bool show_banner;
        ///
-       bool preview;
+       enum PreviewStatus {
+               PREVIEW_OFF,
+               PREVIEW_NO_MATH,
+               PREVIEW_ON
+       };
+       ///
+       PreviewStatus preview;
        ///
        bool preview_hashed_labels;
        ///
        float preview_scale_factor;
        /// user name
-       string user_name;
+       std::string user_name;
        /// user email
-       string user_email;
+       std::string user_email;
+};
 
-private:
-       /// Is a bind file already (or currently) read?
-       bool hasBindFile;
-       ///
-       int ReadBindFile(string const & name);
+
+/** \c LyXRC_PreviewStatus is a wrapper for LyXRC::PreviewStatus.
+ *  It can be forward-declared and passed as a function argument without
+ *  having to expose lyxrc.h.
+ */
+class LyXRC_PreviewStatus {
+        LyXRC::PreviewStatus val_;
+public:
+       LyXRC_PreviewStatus(LyXRC::PreviewStatus val) : val_(val) {}
+        operator LyXRC::PreviewStatus() const{ return val_; }
 };
 
+
 ///
 extern LyXRC lyxrc;
 ///