X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2FBufferView.h;h=5b277c4edc8e7dab79584040e114f90cfb3ecdc7;hb=2098f1d8c20d51e63e670bcdc9da8996068975bf;hp=fcf58544a72dd533997a7dcaec9c190e8c1167fa;hpb=1bbcd403fc1c0e64416371610ab18e0b6df5bf36;p=lyx.git diff --git a/src/BufferView.h b/src/BufferView.h index fcf58544a7..5b277c4edc 100644 --- a/src/BufferView.h +++ b/src/BufferView.h @@ -32,6 +32,7 @@ class Change; class CoordCache; class Cursor; class DocIterator; +class DocumentClass; class FuncRequest; class FuncStatus; class Intl; @@ -195,8 +196,8 @@ public: /// translate and insert a character, using the correct keymap. void translateAndInsert(char_type c, Text * t, Cursor & cur); - /// return true for events that will handle. - FuncStatus getStatus(FuncRequest const & cmd); + /// \return true if we've made a decision + bool getStatus(FuncRequest const & cmd, FuncStatus & flag); /// execute the given function. /// \return true if the function has been processed. bool dispatch(FuncRequest const & argument); @@ -261,6 +262,10 @@ public: Point getPos(DocIterator const & dit, bool boundary) const; /// is the paragraph of the cursor visible ? bool paragraphVisible(DocIterator const & dit) const; + /// is the cursor currently visible in the view + bool cursorInView(Point const & p, int h) const; + /// get the position and height of the cursor + void cursorPosAndHeight(Point & p, int & h) const; /// @@ -299,6 +304,10 @@ public: void insertLyXFile(support::FileName const & f); /// save temporary bookmark for jump back navigation void bookmarkEditPosition(); + /// Find and return the inset associated with given dialog name. + Inset * editedInset(std::string const & name) const; + /// Associate an inset associated with given dialog name. + void editInset(std::string const & name, Inset * inset); private: /// noncopyable @@ -311,6 +320,10 @@ private: /// \return true if no further update is needed. bool singleParUpdate(); + /// The minimal size of the document that is visible. Used + /// when it is allowed to scroll below the document. + int minVisiblePart(); + /// Search recursively for the the innermost inset that covers (x, y) position. /// \retval 0 if no inset is found. Inset const * getCoveringInset( @@ -319,6 +332,8 @@ private: int y //< y-coordinate on screen ) const; + /// + void updateLayout(DocumentClass const * const oldlayout); /// int width_; ///