]> git.lyx.org Git - lyx.git/blobdiff - src/lyx_main.h
* GuiView.C (updateTab): do not update early if current tab has
[lyx.git] / src / lyx_main.h
index ab1619f97e7372a30b189ec50a4817141ad1ee43..6c53bc6a01dd8ee1c2f853a0cf2b9c1c8b572c53 100644 (file)
 #include <boost/utility.hpp>
 
 #include <string>
-#include <vector>
 
 namespace lyx {
 
 class Buffer;
 class BufferList;
+class Converters;
 class ErrorItem;
 class IconvProcessor;
 class InsetBase;
@@ -31,6 +31,9 @@ class LyXFunc;
 class LyXServer;
 class LyXServerSocket;
 class LyXView;
+class Messages;
+class Mover;
+class Movers;
 class Session;
 class kb_keymap;
 
@@ -45,17 +48,7 @@ public:
        LyX();
        ~LyX();
 
-       /**
-        * Execute LyX. The startup sequence is as follows:
-        * -# LyX::exec()
-        * -# LyX::priv_exec()
-        * -# lyx::createApplication()
-        * Step 3 is omitted if no gui is wanted. We need lyx::createApplication()
-        * only to create the QApplication object in the qt frontend. All
-        * attempts with static and dynamically allocated QApplication
-        * objects lead either to harmless error messages on exit
-        * ("Mutex destroy failure") or crashes (OS X).
-        */
+       /// Execute LyX.
        int exec(int & argc, char * argv[]);
 
        static LyX & ref();
@@ -64,13 +57,6 @@ public:
        /// in the case of failure
        void emergencyCleanup() const;
 
-       /// Ask the LyX class to exit.
-       /**
-       In GUI mode, after this function has been called, application_ leaves
-       the main event loop and returns from the call to Application::start().
-       */
-       void quit();
-
        ///
        BufferList & bufferList();
        BufferList const & bufferList() const;
@@ -94,6 +80,17 @@ public:
        ///
        kb_keymap & topLevelKeymap();
        kb_keymap const & topLevelKeymap() const;
+       
+       ///
+       Converters & converters();
+       Converters & systemConverters();
+
+       ///
+       Messages & getMessages(std::string const & language);
+       ///
+       Messages & getGuiMessages();
+       ///
+       void setGuiLanguage(std::string const & language);
 
        ///
        IconvProcessor & iconvProcessor();
@@ -105,6 +102,9 @@ public:
         */
        Buffer const * const updateInset(InsetBase const *) const;
 
+       /// Execute batch commands if available.
+       void execBatchCommands();
+
 private:
        /// Do some cleanup in preparation of an exit.
        void prepareExit();
@@ -112,16 +112,20 @@ private:
        /// Early exit during the initialisation process.
        void earlyExit(int status);
 
-       /// Initialise LyX and execute batch commands if available.
+       /// Initialise LyX and fills-in the vector of files to be loaded.
        /**
-       \param files is filled in with the command-line file names.
        \return exit code failure if any.
        */
-       int execBatchCommands(int & argc, char * argv[],
-               std::vector<std::string> & files);
+       int init(int & argc, char * argv[]);
 
-       /// Create a View and restore GUI Session.
-       void restoreGuiSession(std::vector<std::string> const & files);
+       /// Load files passed at command-line.
+       /**
+       This method is used only in non-GUI mode.
+       */
+       void loadFiles();
+
+       /// Create a View, load files and restore GUI Session.
+       void restoreGuiSession();
 
        /// Initialize RC font for the GUI.
        void initGuiFont();
@@ -142,11 +146,14 @@ private:
        /// read lyxrc/preferences
        bool readRcFile(std::string const & name);
        /// read the given ui (menu/toolbar) file
-       bool readUIFile(std::string const & name);
+       bool readUIFile(std::string const & name, bool include = false);
        /// read the given languages file
        bool readLanguagesFile(std::string const & name);
-       /// read the given encodings file
-       bool readEncodingsFile(std::string const & name);
+       /// read the encodings.
+       /// \param enc_name encodings definition file
+       /// \param symbols_name unicode->LaTeX mapping file
+       bool readEncodingsFile(std::string const & enc_name,
+                              std::string const & symbols_name);
        /// parsing of non-gui LyX options.
        void easyParse(int & argc, char * argv[]);
        /// shows up a parsing error on screen
@@ -161,8 +168,11 @@ private:
        struct Singletons;
        boost::scoped_ptr<Singletons> pimpl_;
 
-       ///
-       bool geometryOption_;
+       friend Movers & theMovers();
+       friend Mover const & getMover(std::string  const & fmt);
+       friend void setMover(std::string const & fmt, std::string const & command);
+       friend Movers & theSystemMovers();
+       friend frontend::Application * theApp();
 };
 
 } // namespace lyx