]> git.lyx.org Git - lyx.git/blobdiff - src/buffer.h
code cosmetics to the iterator fix
[lyx.git] / src / buffer.h
index 26ae13f928b9d2914202f56bb5a1d8f99331867e..ba3ec7c40c752569b620f5aad9b9cc11a6bd8aa4 100644 (file)
@@ -14,6 +14,8 @@
 
 #include "InsetList.h"
 
+#include "dociterator.h"
+
 #include "support/limited_stack.h"
 #include "support/types.h"
 
@@ -46,6 +48,7 @@ class ParIterator;
 class TeXErrors;
 class TexRow;
 class Undo;
+class StableDocIterator;
 
 
 /** The buffer object.
@@ -90,8 +93,6 @@ public:
        /// load a new file
        bool readFile(std::string const & filename);
 
-       bool readFile(std::string const & filename, lyx::pit_type pit);
-
        /// read the header, returns number of unknown tokens
        int readHeader(LyXLex & lex);
 
@@ -307,9 +308,10 @@ public:
        /// Set by buffer_funcs' newFile.
        void fully_loaded(bool);
 
-       ///
+       /// Our main text (inside the top InsetText)
        LyXText & text() const;
-       ///
+
+       /// Our top InsetText!
        InsetBase & inset() const;
 
        //
@@ -323,14 +325,20 @@ public:
        MacroData const & getMacro(std::string const & name) const;
        ///
        void insertMacro(std::string const & name, MacroData const & data);
+       ///
+       void saveCursor(StableDocIterator cursor, StableDocIterator anchor);
+       ///
+       StableDocIterator getCursor() const { return cursor_; }
+       ///
+       StableDocIterator getAnchor() const { return anchor_; }
+       ///
+       void changeRefsIfUnique(std::string const & from, std::string const & to);
 
 private:
        /** Inserts a file into a document
-           \param par if != 0 insert the file.
            \return \c false if method fails.
        */
-       bool readFile(LyXLex &, std::string const & filename,
-                     lyx::pit_type pit);
+       bool readFile(LyXLex &, std::string const & filename);
 
        bool do_writeFile(std::ostream & ofs) const;
 
@@ -338,6 +346,12 @@ private:
        class Impl;
        /// The pointer never changes although *pimpl_'s contents may.
        boost::scoped_ptr<Impl> const pimpl_;
+
+       /// Save the cursor Position on Buffer switch
+       /// this would not be needed if every Buffer would have
+       /// it's BufferView, this should be FIXED in future.
+       StableDocIterator cursor_;
+       StableDocIterator anchor_;
 };
 
 #endif