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:
Jean-Marc Lasgouttes 2018-01-03 18:28:55 +01:00
parent 016393a0dd
commit 76f0a3dd4e

View File

@ -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);