]> git.lyx.org Git - lyx.git/blobdiff - src/BufferView_pimpl.h
Rewording in GTK document dialog
[lyx.git] / src / BufferView_pimpl.h
index 776888c2d9f3e36637f42c3059ffb5cd8f8815d8..b55cf924e27bcc0e73c52ba1ef0e44f893a0da0e 100644 (file)
@@ -40,32 +40,29 @@ class LyXView;
 class WorkArea;
 class LyXScreen;
 class FuncRequest;
+class FuncStatus;
+class ViewMetricsInfo;
+
 
 ///
-struct BufferView::Pimpl : public boost::signals::trackable {
+class BufferView::Pimpl : public boost::signals::trackable {
+public:
        ///
-       Pimpl(BufferView * bv, LyXView * owner,
-             int xpos, int ypos, int width, int height);
+       Pimpl(BufferView & bv, LyXView * owner, int width, int height);
        ///
        Painter & painter() const;
        /// return the screen for this bview
        LyXScreen & screen() const;
        ///
-       void buffer(Buffer *);
-       /// Return true if the cursor was fitted.
-       bool fitCursor();
-       ///
-       void redoCurrentBuffer();
+       void setBuffer(Buffer * buf);
        ///
        void resizeCurrentBuffer();
+       //
+       bool fitCursor();
        ///
-       void update();
-       /**
-        * Repaint pixmap. Used for when we've made a visible
-        * change but don't need the full update() logic
-        */
+       void update(Update::flags flags = Update::Force);
        ///
-       bool newFile(std::string const &, std::string const &, bool);
+       void newFile(std::string const &, std::string const &, bool);
        ///
        bool loadLyXFile(std::string const &, bool);
        ///
@@ -74,9 +71,7 @@ struct BufferView::Pimpl : public boost::signals::trackable {
        void updateScrollbar();
        ///
        void scrollDocView(int value);
-       /**
-        * Wheel mouse scroll, move by multiples of text->defaultRowHeight().
-        */
+       /// Wheel mouse scroll, move by multiples of text->defaultRowHeight().
        void scroll(int lines);
        ///
        typedef boost::shared_ptr<LyXKeySym> LyXKeySymPtr;
@@ -102,21 +97,13 @@ struct BufferView::Pimpl : public boost::signals::trackable {
        void switchKeyMap();
        ///
        void center();
-       ///
-       bool insertInset(InsetOld * inset, std::string const & lout = std::string());
        /// a function should be executed from the workarea
        bool workAreaDispatch(FuncRequest const & ev);
+       /// return true for events that will handle
+       FuncStatus getStatus(FuncRequest const & cmd);
        /// a function should be executed
        bool dispatch(FuncRequest const & ev);
-       ///
-       int top_y() const;
-       ///
-       void top_y(int y);
-       /// update paragraph dialogs
-       void updateParagraphDialog();
 private:
-       /// the y coordinate of the top of the screen
-       int top_y_;
        /// An error list (replaces the error insets)
        ErrorList errorlist_;
        /// add an error to the list
@@ -144,13 +131,6 @@ private:
        /// notify readonly status
        void showReadonly(bool);
 
-       /**
-        * Change all insets with the given code's contents to a new
-        * string. May only be used with InsetCommand-derived insets
-        * Returns true if a screen update is needed.
-        */
-       bool ChangeInsets(InsetOld::Code code, std::string const & from,
-                         std::string const & to);
 
        ///
        friend class BufferView;
@@ -165,6 +145,8 @@ private:
        boost::scoped_ptr<LyXScreen> screen_;
        ///
        boost::scoped_ptr<WorkArea> workarea_;
+       /// Estimated average par height for scrollbar
+       int wh_;
        ///
        Timeout cursor_timeout;
        ///
@@ -172,7 +154,8 @@ private:
        ///
        bool using_xterm_cursor;
        ///
-       struct Position {
+       class Position {
+       public:
                /// Filename
                std::string filename;
                /// Cursor paragraph Id
@@ -187,14 +170,26 @@ private:
        };
        ///
        std::vector<Position> saved_positions;
-       /// Get next inset of this class from current cursor position
-       InsetOld * getInsetByCode(InsetOld::Code code);
        ///
        void MenuInsertLyXFile(std::string const & filen);
        /// our workarea
        WorkArea & workarea() const;
-
+       /// this is used to handle XSelection events in the right manner
+       struct {
+               CursorSlice cursor;
+               CursorSlice anchor;
+               bool set;
+       } xsel_cache_;
        ///
        LCursor cursor_;
+       ///
+       ///
+       lyx::pit_type anchor_ref_;
+       ///
+       int offset_ref_;
+       ///
+       ViewMetricsInfo metrics(bool singlepar = false);
+
+
 };
 #endif // BUFFERVIEW_PIMPL_H