X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FRow.h;h=f69eeca9f17ae9b83e4d24fafbafdbb105d1a133;hb=670efa8f646218f2a378f0cc614c4c37a9f6b89a;hp=92521ef4baa9ffb8a9e3ffed346cfb560c71c293;hpb=b63421b7dc65e0c721f8928d1330b9bb2cff43d8;p=lyx.git diff --git a/src/Row.h b/src/Row.h index 92521ef4ba..f69eeca9f1 100644 --- a/src/Row.h +++ b/src/Row.h @@ -62,7 +62,8 @@ public: extra(0), font(f), change(ch), final(false) {} // Return total width of element, including separator overhead - double full_width() const { return dim.wid + extra * countSeparators(); }; + // FIXME: Cache this value or the number of separators? + double full_width() const { return dim.wid + extra * countSeparators(); } // Return the number of separator in the element (only STRING type) int countSeparators() const; @@ -87,6 +88,13 @@ public: // Returns the position on right side of the element. pos_type right_pos() const; + // + bool isRTL() const { return font.isVisibleRightToLeft(); } + // This is true for virtual elements. + // Note that we do not use the type here. The two definitions + // should be equivalent + bool isVirtual() const { return pos == endpos; } + // The kind of row element Type type; // position of the element in the paragraph @@ -137,6 +145,10 @@ public: void setSelectionAndMargins(DocIterator const & beg, DocIterator const & end) const; + /// + void pit(pit_type p) { pit_ = p; } + /// + pit_type pit() const { return pit_; } /// void pos(pos_type p) { pos_ = p; } /// @@ -163,6 +175,11 @@ public: /// int descent() const { return dim_.des; } + /// The offset of the left-most cursor position on the row + int left_x() const; + /// The offset of the right-most cursor position on the row + int right_x() const; + // Return the number of separators in the row int countSeparators() const; // Set the extra spacing for every separator in STRING elements @@ -215,8 +232,9 @@ public: * remains is a large word, cut it to \param width. * \param body_pos minimum amount of text to keep. * \param width maximum width of the row + * \return true if the row has been shortened. */ - void shortenIfNeeded(pos_type const body_pos, int const width); + bool shortenIfNeeded(pos_type const body_pos, int const width); /** * If last element of the row is a string, compute its width @@ -273,6 +291,8 @@ private: mutable bool changed_; /// CRC of row contents. mutable size_type crc_; + /// Index of the paragraph that contains this row + pit_type pit_; /// first pos covered by this row pos_type pos_; /// one behind last pos covered by this row