Fix bound returned by SkPath::isRect when the path contains a trailing moveTo

Oddly enough this was fixed in:

https://codereview.chromium.org/16950021/ (add rect-output parameter to isRect, allowing us to return the correct bounds even if a rectagular path has a trailing moveTo)

but was reverted here:

https://skia.googlesource.com/skia/+/8fd160350ca5f57fbb1b2e03383c5778414a9b48

since it appeared to be crashing Chrome's trybots. I think it just fell through the cracks after that.

If this sticks I will land a follow on patch for the stroke issue reported in the original bug (crbug.com/247770).

BUG=247770,445368

Review URL: https://codereview.chromium.org/834483002
This commit is contained in:
robertphillips 2014-12-29 11:36:39 -08:00 committed by Commit bot
parent 40d4bd8daf
commit fe7c427e3d
2 changed files with 27 additions and 4 deletions

View File

@ -538,11 +538,20 @@ bool SkPath::isRect(SkRect* rect) const {
SkDEBUGCODE(this->validate();) SkDEBUGCODE(this->validate();)
int currVerb = 0; int currVerb = 0;
const SkPoint* pts = fPathRef->points(); const SkPoint* pts = fPathRef->points();
bool result = isRectContour(false, &currVerb, &pts, NULL, NULL); const SkPoint* first = pts;
if (result && rect) { bool isClosed;
*rect = getBounds(); if (!this->isRectContour(false, &currVerb, &pts, &isClosed, NULL)) {
return false;
} }
return result; if (rect) {
if (isClosed) {
rect->set(first, SkToS32(pts - first));
} else {
// 'pts' isn't updated for open rects
*rect = this->getBounds();
}
}
return true;
} }
bool SkPath::isRect(bool* isClosed, Direction* direction) const { bool SkPath::isRect(bool* isClosed, Direction* direction) const {

View File

@ -3712,6 +3712,20 @@ DEF_TEST(Paths, reporter) {
p.addRect(bounds); p.addRect(bounds);
REPORTER_ASSERT(reporter, !p.isRect(NULL)); REPORTER_ASSERT(reporter, !p.isRect(NULL));
// Test an edge case w.r.t. the bound returned by isRect (i.e., the
// path has a trailing moveTo. Please see crbug.com\445368)
{
SkRect r;
p.reset();
p.addRect(bounds);
REPORTER_ASSERT(reporter, p.isRect(&r));
REPORTER_ASSERT(reporter, r == bounds);
// add a moveTo outside of our bounds
p.moveTo(bounds.fLeft + 10, bounds.fBottom + 10);
REPORTER_ASSERT(reporter, p.isRect(&r));
REPORTER_ASSERT(reporter, r == bounds);
}
test_operatorEqual(reporter); test_operatorEqual(reporter);
test_isLine(reporter); test_isLine(reporter);
test_isRect(reporter); test_isRect(reporter);