X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FBufferView_pimpl.h;h=b55cf924e27bcc0e73c52ba1ef0e44f893a0da0e;hb=e7ef29fa2d516b8593aa3cccb6548de5686e8a9a;hp=1c291ca8d74231ab899659e1fd94ac0e5a461171;hpb=97901b5d513ea3fc43eb0896ef6e448891c3f097;p=lyx.git diff --git a/src/BufferView_pimpl.h b/src/BufferView_pimpl.h index 1c291ca8d7..b55cf924e2 100644 --- a/src/BufferView_pimpl.h +++ b/src/BufferView_pimpl.h @@ -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 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 screen_; /// boost::scoped_ptr 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,19 +170,26 @@ private: }; /// std::vector 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 { - LyXCursor cursor; - LyXCursor anchor; + 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