commit 254b2b0bfa68420b612a1be7b2a59ec38cf7888f
Author: Jean-Marc Lasgouttes <[email protected]>
Date: Thu Jun 9 21:27:43 2022 +0200
Implement CanBreakBefore row flag
This is used for elements that allow to break a row before them
(similar to CanBreakAfter).
---
src/Row.cpp | 12 +++++++++++-
src/RowFlags.h | 29 +++++++++++++++--------------
2 files changed, 26 insertions(+), 15 deletions(-)
diff --git a/src/Row.cpp b/src/Row.cpp
index 3d5ab90..68ab984 100644
--- a/src/Row.cpp
+++ b/src/Row.cpp
@@ -562,7 +562,7 @@ Row::Elements Row::shortenIfNeeded(int const w, int const
next_width)
Element brk = *cit_brk;
/* If the current element is an inset that allows breaking row
* after itself, and if the row is already short enough after
- * this inset, then cut right after this element.
+ * this element, then cut right after it.
*/
if (wid_brk <= w && brk.row_flags & CanBreakAfter) {
end_ = brk.endpos;
@@ -572,6 +572,16 @@ Row::Elements Row::shortenIfNeeded(int const w, int const
next_width)
}
// assume now that the current element is not there
wid_brk -= brk.dim.wid;
+ /* If the current element is an inset that allows breaking row
+ * before itself, and if the row is already short enough before
+ * this element, then cut right before it.
+ */
+ if (wid_brk <= w && brk.row_flags & CanBreakBefore && cit_brk
!= beg) {
+ end_ = (cit_brk -1)->endpos;
+ dim_.wid = wid_brk;
+ moveElements(elements_, cit_brk, tail);
+ return tail;
+ }
/* We have found a suitable separable element. This is the
common case.
* Try to break it cleanly at a length that is both
* - less than the available space on the row
diff --git a/src/RowFlags.h b/src/RowFlags.h
index 01c4dd2..953d7f9 100644
--- a/src/RowFlags.h
+++ b/src/RowFlags.h
@@ -16,10 +16,9 @@
namespace lyx {
-/* The list of possible flags, that can be combined.
- * Some flags that should logically be here (e.g.,
- * CanBreakBefore), do not exist. This is because the need has not
- * been identitfied yet.
+/* The list of possible flags, that can be combined. Some flags that
+ * should logically be here (e.g., AlwaysBreakBefore), do not exist.
+ * This is because the need has not been identitfied yet.
*
* Priorities when before/after disagree:
* AlwaysBreak* > NoBreak* > Break* or CanBreak*.
@@ -30,26 +29,28 @@ enum RowFlags {
Inline = 0,
// break row before this element if the row is not empty
BreakBefore = 1 << 0,
+ // break row whenever needed before this element
+ CanBreakBefore = 1 << 1,
// Avoid breaking row before this element
- NoBreakBefore = 1 << 1,
+ NoBreakBefore = 1 << 2,
// flush the row before this element (useful with BreakBefore)
- FlushBefore = 1 << 2,
+ FlushBefore = 1 << 3,
// force new (maybe empty) row after this element
- AlwaysBreakAfter = 1 << 3,
+ AlwaysBreakAfter = 1 << 4,
// break row after this element if there are more elements
- BreakAfter = 1 << 4,
+ BreakAfter = 1 << 5,
// break row whenever needed after this element
- CanBreakAfter = 1 << 5,
+ CanBreakAfter = 1 << 6,
// Avoid breaking row after this element
- NoBreakAfter = 1 << 6,
+ NoBreakAfter = 1 << 7,
// The contents of the row may be broken in two (e.g. string)
- CanBreakInside = 1 << 7,
+ CanBreakInside = 1 << 8,
// Flush the row that ends with this element
- Flush = 1 << 8,
+ Flush = 1 << 9,
// specify an alignment (left, right) for a display element
// (default is center)
- AlignLeft = 1 << 9,
- AlignRight = 1 << 10,
+ AlignLeft = 1 << 10,
+ AlignRight = 1 << 11,
// A display element breaks row at both ends
Display = FlushBefore | BreakBefore | BreakAfter,
// Flags that concern breaking after element
--
lyx-cvs mailing list
[email protected]
http://lists.lyx.org/mailman/listinfo/lyx-cvs