mirror of
https://git.lyx.org/repos/lyx.git
synced 2025-01-18 13:40:19 +00:00
Remove 'premature optimization' that proved buggy
At some time it seemed like a good idea in breakRow() to return early when the row was bound to be empty. It turns out that this creates two symptoms: * empty paragraphs will not have an end of paragraph marker * since row width is not correctly computed in this case, caret ghosts can appear in master. This commit removes the oprimization and replace the do {} while() construct to a straightforward while() {}. Related to bug #10952.
This commit is contained in:
parent
016393a0dd
commit
76f0a3dd4e
@ -844,11 +844,6 @@ bool TextMetrics::breakRow(Row & row, int const right_margin) const
|
|||||||
// the width available for the row.
|
// the width available for the row.
|
||||||
int const width = max_width_ - row.right_margin;
|
int const width = max_width_ - row.right_margin;
|
||||||
|
|
||||||
if (pos >= end || row.width() > width) {
|
|
||||||
row.endpos(end);
|
|
||||||
return need_new_row;
|
|
||||||
}
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
//FIXME: As long as leftMargin() is not correctly implemented for
|
//FIXME: As long as leftMargin() is not correctly implemented for
|
||||||
// MARGIN_RIGHT_ADDRESS_BOX, we should also not do this here.
|
// MARGIN_RIGHT_ADDRESS_BOX, we should also not do this here.
|
||||||
@ -867,10 +862,7 @@ bool TextMetrics::breakRow(Row & row, int const right_margin) const
|
|||||||
// or the end of the par, then build a representation of the row.
|
// or the end of the par, then build a representation of the row.
|
||||||
pos_type i = pos;
|
pos_type i = pos;
|
||||||
FontIterator fi = FontIterator(*this, par, row.pit(), pos);
|
FontIterator fi = FontIterator(*this, par, row.pit(), pos);
|
||||||
do {
|
while (i < end && row.width() <= width) {
|
||||||
// this can happen for an empty row after a newline
|
|
||||||
if (i >= end)
|
|
||||||
break;
|
|
||||||
char_type c = par.getChar(i);
|
char_type c = par.getChar(i);
|
||||||
// The most special cases are handled first.
|
// The most special cases are handled first.
|
||||||
if (par.isInset(i)) {
|
if (par.isInset(i)) {
|
||||||
@ -952,7 +944,7 @@ bool TextMetrics::breakRow(Row & row, int const right_margin) const
|
|||||||
|
|
||||||
++i;
|
++i;
|
||||||
++fi;
|
++fi;
|
||||||
} while (i < end && row.width() <= width);
|
}
|
||||||
row.finalizeLast();
|
row.finalizeLast();
|
||||||
row.endpos(i);
|
row.endpos(i);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user