]> git.lyx.org Git - lyx.git/commitdiff
Make pit_type unsigned (in particular, size_t).
authorRichard Kimberly Heck <rikiheck@lyx.org>
Sun, 26 Apr 2020 02:50:03 +0000 (22:50 -0400)
committerRichard Kimberly Heck <rikiheck@lyx.org>
Sun, 26 Apr 2020 02:50:48 +0000 (22:50 -0400)
This involves not just changing the type but checking that downward
loops and similar tricks don't break.

src/BufferView.cpp
src/Compare.cpp
src/RowPainter.cpp
src/support/types.h

index 621b58ef26fc74fdeeb6b0242bc39ab92c61e9f7..ca59fcb4db9f3c0878bd43641b614a181c4fe22a 100644 (file)
@@ -2860,7 +2860,7 @@ void BufferView::updateMetrics(Update::flags & update_flags)
        int y1 = d->anchor_ypos_ - anchor_pm.ascent();
        // We are now just above the anchor paragraph.
        pit_type pit1 = d->anchor_pit_ - 1;
-       for (; pit1 >= 0 && y1 >= 0; --pit1) {
+       while (y1 >= 0) {
                tm.redoParagraph(pit1);
                ParagraphMetrics & pm = tm.par_metrics_[pit1];
                y1 -= pm.descent();
@@ -2868,6 +2868,9 @@ void BufferView::updateMetrics(Update::flags & update_flags)
                pm.setPosition(y1);
                tm.updatePosCache(pit1);
                y1 -= pm.ascent();
+               if (pit1 == 0)
+                       break;
+               --pit1;
        }
 
        // Redo paragraphs below the anchor if necessary.
index 60a0b65bb14538d630ceda87873543b406b6d973..931fe76fafe2ea81091d38e848bb469ae32c2f16 100644 (file)
@@ -881,10 +881,10 @@ void Compare::Impl::writeToDestBuffer(DocRange const & range,
 
 void Compare::Impl::writeToDestBuffer(ParagraphList const & pars) const
 {
-       pit_type const pit = dest_pars_->size() - 1;
        dest_pars_->insert(dest_pars_->end(), pars.begin(), pars.end());
-       if (pit >= 0)
-               mergeParagraph(dest_buf_->params(), *dest_pars_, pit);
+       pit_type pit = dest_pars_->size();
+       if (pit > 0)
+               mergeParagraph(dest_buf_->params(), *dest_pars_, pit - 1);
 }
 
 
index 6e4cf31ac10eed23dd7016d30067091ec4fd27b1..a392c027fadc85c72ab8fab6df5fbac412686e68 100644 (file)
@@ -60,8 +60,7 @@ RowPainter::RowPainter(PainterInfo & pi,
        //lyxerr << "RowPainter: x: " << x_ << " xo: " << xo_ << " yo: " << yo_ << endl;
        //row_.dump();
 
-       LBUFERR(row.pit() >= 0);
-       LBUFERR(row.pit() < int(text.paragraphs().size()));
+       LBUFERR(row.pit() < text.paragraphs().size());
 }
 
 
index c9cf349592d5ee61c58961f744ab631cbd965849..4b08d7aef07186c2d162113c58bebc31bd91d6e3 100644 (file)
@@ -40,7 +40,7 @@ namespace lyx {
         */
        // FIXME: should be unsigned as well.
        // however, simply changing it breaks a downward loop somewhere...
-       typedef ptrdiff_t  pit_type;
+       typedef size_t  pit_type;
 
        /// a type for the nesting depth of a paragraph
        typedef size_t     depth_type;