diff --git a/src/Row.cpp b/src/Row.cpp index 9df572441c..16ce90d473 100644 --- a/src/Row.cpp +++ b/src/Row.cpp @@ -126,7 +126,6 @@ pos_type Row::Element::x2pos(int &x) const } //lyxerr << "=> p=" << pos + i << " x=" << x << endl; return pos + i; - } @@ -446,7 +445,7 @@ void Row::pop_back() } -bool Row::shortenIfNeeded(pos_type const keep, int const w) +bool Row::shortenIfNeeded(pos_type const keep, int const w, int const next_width) { if (empty() || width() <= w) return false; @@ -493,7 +492,7 @@ bool Row::shortenIfNeeded(pos_type const keep, int const w) * next row. Thus breaking does not help. */ if (wid_brk + cit_brk->dim.wid < w - && dim_.wid - (wid_brk + brk.dim.wid) >= w) { + && dim_.wid - (wid_brk + brk.dim.wid) >= next_width) { break; } end_ = brk.endpos; diff --git a/src/Row.h b/src/Row.h index 7ae9c11b1e..220449947a 100644 --- a/src/Row.h +++ b/src/Row.h @@ -243,10 +243,11 @@ public: * separator and update endpos if necessary. If all that * 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 + * \param width maximum width of the row. + * \param available width on next row. * \return true if the row has been shortened. */ - bool shortenIfNeeded(pos_type const body_pos, int const width); + bool shortenIfNeeded(pos_type const body_pos, int const width, int const next_width); /** * If last element of the row is a string, compute its width diff --git a/src/TextMetrics.cpp b/src/TextMetrics.cpp index 3f6457e49c..96c2fb52bd 100644 --- a/src/TextMetrics.cpp +++ b/src/TextMetrics.cpp @@ -941,7 +941,9 @@ bool TextMetrics::breakRow(Row & row, int const right_margin) const // if the row is too large, try to cut at last separator. In case // of success, reset indication that the row was broken abruptly. - if (row.shortenIfNeeded(body_pos, width)) + int const next_width = max_width_ - leftMargin(max_width_, row.pit(), row.endpos()) + - rightMargin(row.pit()); + if (row.shortenIfNeeded(body_pos, width, next_width)) row.right_boundary(!row.empty() && row.back().endpos == row.endpos()); // make sure that the RTL elements are in reverse ordering