1818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com/* 2818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com * Copyright 2012 Google Inc. 3818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com * 4818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com * Use of this source code is governed by a BSD-style license that can be 5818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com * found in the LICENSE file. 6818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com */ 7818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 8818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include "PathOpsExtendedTest.h" 966089e4ec4f1702caf2154780471417872862148caryclark@google.com#include "PathOpsThreadedCommon.h" 10818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include "SkBitmap.h" 11818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include "SkCanvas.h" 12818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include "SkMatrix.h" 131b24933e52f50773de29332387a12721811f3012mtklein#include "SkMutex.h" 14e02c5dabbbfefca3e086b3653d71a7a4a9713277skia.committer@gmail.com#include "SkPaint.h" 15267be7fbc38174652c750ec69d8dc1feaa72db0cMike Reed#include "SkRegion.h" 16818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include "SkStream.h" 17818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 1860e0fee6d4acff638ccc9670c4055aced529a7a0bungeman#include <stdlib.h> 1960e0fee6d4acff638ccc9670c4055aced529a7a0bungeman 20818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#ifdef SK_BUILD_FOR_MAC 21818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include <sys/sysctl.h> 22818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 23818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 24389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark// std::to_string isn't implemented on android 25389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark#include <sstream> 26389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark 27389c557338afd82be5d87735b5ec1cf57e85b26cCary Clarktemplate <typename T> 28389c557338afd82be5d87735b5ec1cf57e85b26cCary Clarkstd::string std_to_string(T value) 29389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark{ 30389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark std::ostringstream os ; 31389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark os << value ; 32389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark return os.str() ; 33389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark} 34389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark 3555888e44171ffd48b591d19256884a969fe4da17caryclarkbool OpDebug(const SkPath& one, const SkPath& two, SkPathOp op, SkPath* result 3655888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(bool skipAssert) 3755888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(const char* testName)); 3855888e44171ffd48b591d19256884a969fe4da17caryclark 3955888e44171ffd48b591d19256884a969fe4da17caryclarkbool SimplifyDebug(const SkPath& one, SkPath* result 4055888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(bool skipAssert) 4155888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(const char* testName)); 4255888e44171ffd48b591d19256884a969fe4da17caryclark 43818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char marker[] = 44818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "</div>\n" 45818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "\n" 46818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "<script type=\"text/javascript\">\n" 47818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "\n" 48818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "var testDivs = [\n"; 49818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 50818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char* opStrs[] = { 5154359294a7c9dc54802d512a5d891a35c1663392caryclark "kDifference_SkPathOp", 5254359294a7c9dc54802d512a5d891a35c1663392caryclark "kIntersect_SkPathOp", 5354359294a7c9dc54802d512a5d891a35c1663392caryclark "kUnion_SkPathOp", 5455888e44171ffd48b591d19256884a969fe4da17caryclark "kXOR_PathOp", 5554359294a7c9dc54802d512a5d891a35c1663392caryclark "kReverseDifference_SkPathOp", 56818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com}; 57818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 58818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char* opSuffixes[] = { 59818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "d", 60818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "i", 61818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "u", 6266089e4ec4f1702caf2154780471417872862148caryclark@google.com "o", 6355888e44171ffd48b591d19256884a969fe4da17caryclark "r", 64818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com}; 65818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 66d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclarkenum class ExpectSuccess { 67d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kNo, 68d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kYes, 69d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kFlaky 70d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark}; 71d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 72d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclarkenum class SkipAssert { 73d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kNo, 74d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kYes 75d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark}; 76d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 77d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclarkenum class ExpectMatch { 78d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kNo, 79d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kYes, 80d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kFlaky 81d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark}; 82d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 83cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com#if DEBUG_SHOW_TEST_NAME 84cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.comstatic void showPathData(const SkPath& path) { 8507e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com SkPath::RawIter iter(path); 86818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint8_t verb; 87818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPoint pts[4]; 884431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkPoint firstPt = {0, 0}, lastPt = {0, 0}; 89fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com bool firstPtSet = false; 90fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com bool lastPtSet = true; 91818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com while ((verb = iter.next(pts)) != SkPath::kDone_Verb) { 92818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com switch (verb) { 93818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kMove_Verb: 94dac1d17027dcaa5596885a9f333979418b35001ccaryclark if (firstPtSet && lastPtSet && firstPt != lastPt) { 95dac1d17027dcaa5596885a9f333979418b35001ccaryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 96dac1d17027dcaa5596885a9f333979418b35001ccaryclark firstPt.fX, firstPt.fY); 97dac1d17027dcaa5596885a9f333979418b35001ccaryclark lastPtSet = false; 98dac1d17027dcaa5596885a9f333979418b35001ccaryclark } 99fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPt = pts[0]; 100fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPtSet = true; 101818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com continue; 102818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kLine_Verb: 10366089e4ec4f1702caf2154780471417872862148caryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", pts[0].fX, pts[0].fY, 10466089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[1].fX, pts[1].fY); 105fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[1]; 106fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 107818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 108818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kQuad_Verb: 109818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", 11066089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY); 111fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[2]; 112fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 113818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 11454359294a7c9dc54802d512a5d891a35c1663392caryclark case SkPath::kConic_Verb: 11554359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}}, //weight=%1.9g\n", 11654359294a7c9dc54802d512a5d891a35c1663392caryclark pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY, 11754359294a7c9dc54802d512a5d891a35c1663392caryclark iter.conicWeight()); 11854359294a7c9dc54802d512a5d891a35c1663392caryclark lastPt = pts[2]; 11954359294a7c9dc54802d512a5d891a35c1663392caryclark lastPtSet = true; 12054359294a7c9dc54802d512a5d891a35c1663392caryclark break; 121818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kCubic_Verb: 122818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", 12366089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY, 12466089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[3].fX, pts[3].fY); 125fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[3]; 126fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 127818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 128818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kClose_Verb: 129fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com if (firstPtSet && lastPtSet && firstPt != lastPt) { 130fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 131fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPt.fX, firstPt.fY); 132fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com } 133fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPtSet = lastPtSet = false; 134818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 135818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com default: 136818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDEBUGFAIL("bad verb"); 137818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return; 138818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 139818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 140dac1d17027dcaa5596885a9f333979418b35001ccaryclark if (firstPtSet && lastPtSet && firstPt != lastPt) { 141dac1d17027dcaa5596885a9f333979418b35001ccaryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 142dac1d17027dcaa5596885a9f333979418b35001ccaryclark firstPt.fX, firstPt.fY); 143dac1d17027dcaa5596885a9f333979418b35001ccaryclark } 144818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 145cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com#endif 146818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 147818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comvoid showOp(const SkPathOp op) { 148818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com switch (op) { 14954359294a7c9dc54802d512a5d891a35c1663392caryclark case kDifference_SkPathOp: 150818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op difference\n"); 151818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 15254359294a7c9dc54802d512a5d891a35c1663392caryclark case kIntersect_SkPathOp: 153818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op intersect\n"); 154818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 15554359294a7c9dc54802d512a5d891a35c1663392caryclark case kUnion_SkPathOp: 156818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op union\n"); 157818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 15854359294a7c9dc54802d512a5d891a35c1663392caryclark case kXOR_SkPathOp: 159818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op xor\n"); 160818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 16154359294a7c9dc54802d512a5d891a35c1663392caryclark case kReverseDifference_SkPathOp: 1626dc7df69ae6b24c90d231e0d6a4516bf4f1aee2ecaryclark@google.com SkDebugf("op reverse difference\n"); 1636dc7df69ae6b24c90d231e0d6a4516bf4f1aee2ecaryclark@google.com break; 164818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com default: 165818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkASSERT(0); 166818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 167818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 168818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 16907e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 1700361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.comstatic char hexorator(int x) { 1710361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com if (x < 10) { 1720361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com return x + '0'; 1730361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com } 1740361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com x -= 10; 1750361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkASSERT(x < 26); 1760361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com return x + 'A'; 1770361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com} 1780361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 1790361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com 1800361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.comvoid ShowTestName(PathOpsThreadState* state, int a, int b, int c, int d) { 1810361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 1820361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[0] = hexorator(state->fA); 1830361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[1] = hexorator(state->fB); 1840361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[2] = hexorator(state->fC); 1850361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[3] = hexorator(state->fD); 1860361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[4] = hexorator(a); 1870361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[5] = hexorator(b); 1880361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[6] = hexorator(c); 1890361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[7] = hexorator(d); 1900361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[8] = '\0'; 1910361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkDebugf("%s\n", state->fSerialNo); 1920361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com if (strcmp(state->fSerialNo, state->fKey) == 0) { 193389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark SkDebugf("%s\n", state->fPathStr.c_str()); 1940361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com } 1950361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 1960361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com} 1970361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com 198818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comconst int bitWidth = 64; 199818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comconst int bitHeight = 64; 200818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 201818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic void scaleMatrix(const SkPath& one, const SkPath& two, SkMatrix& scale) { 202818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRect larger = one.getBounds(); 203818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com larger.join(two.getBounds()); 204818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar largerWidth = larger.width(); 205818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (largerWidth < 4) { 206818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com largerWidth = 4; 207818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 208818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar largerHeight = larger.height(); 209818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (largerHeight < 4) { 210818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com largerHeight = 4; 211818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 212818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar hScale = (bitWidth - 2) / largerWidth; 213818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar vScale = (bitHeight - 2) / largerHeight; 214818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scale.reset(); 215818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scale.preScale(hScale, vScale); 21626ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fLeft *= hScale; 21726ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fRight *= hScale; 21826ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fTop *= vScale; 21926ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fBottom *= vScale; 22026ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark SkScalar dx = -16000 > larger.fLeft ? -16000 - larger.fLeft 22126ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark : 16000 < larger.fRight ? 16000 - larger.fRight : 0; 22226ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark SkScalar dy = -16000 > larger.fTop ? -16000 - larger.fTop 22326ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark : 16000 < larger.fBottom ? 16000 - larger.fBottom : 0; 22426ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark scale.postTranslate(dx, dy); 225818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 226818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 227818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic int pathsDrawTheSame(SkBitmap& bits, const SkPath& scaledOne, const SkPath& scaledTwo, 228818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int& error2x2) { 229818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bits.width() == 0) { 230deee496cd30070e52556dcb538c2e5eb39b66b81mike@reedtribe.org bits.allocN32Pixels(bitWidth * 2, bitHeight); 231818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 232818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkCanvas canvas(bits); 233818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawColor(SK_ColorWHITE); 234818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPaint paint; 235818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 236818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds1 = scaledOne.getBounds(); 237818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1, -bounds1.fTop + 1); 238818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(scaledOne, paint); 239818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 240818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 241818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1 + bitWidth, -bounds1.fTop + 1); 242818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(scaledTwo, paint); 243818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 244818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2 = 0; 245818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors = 0; 246818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int y = 0; y < bitHeight - 1; ++y) { 247818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr1 = bits.getAddr32(0, y); 248818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr2 = bits.getAddr32(0, y + 1); 249818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr3 = bits.getAddr32(bitWidth, y); 250818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr4 = bits.getAddr32(bitWidth, y + 1); 251818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int x = 0; x < bitWidth - 1; ++x) { 252818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com // count 2x2 blocks 253818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com bool err = addr1[x] != addr3[x]; 254818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (err) { 255818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com errors2 += addr1[x + 1] != addr3[x + 1] 256818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com && addr2[x] != addr4[x] && addr2[x + 1] != addr4[x + 1]; 257818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com errors++; 258818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 259818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 260818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 261818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com error2x2 = errors2; 262818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return errors; 263818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 264818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 265818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic int pathsDrawTheSame(const SkPath& one, const SkPath& two, SkBitmap& bits, SkPath& scaledOne, 266818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath& scaledTwo, int& error2x2) { 267818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMatrix scale; 268818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaleMatrix(one, two, scale); 269818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com one.transform(scale, &scaledOne); 270818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com two.transform(scale, &scaledTwo); 271818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return pathsDrawTheSame(bits, scaledOne, scaledTwo, error2x2); 272818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 273818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 274818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.combool drawAsciiPaths(const SkPath& one, const SkPath& two, bool drawPaths) { 275818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (!drawPaths) { 276818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 277818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 278818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds1 = one.getBounds(); 279818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds2 = two.getBounds(); 280818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRect larger = bounds1; 281818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com larger.join(bounds2); 282818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bits; 283818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char out[256]; 284e1ca705cac4b946993f6cbf798e2a0ba27e739f3reed@google.com int bitWidth = SkScalarCeilToInt(larger.width()) + 2; 285818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bitWidth * 2 + 1 >= (int) sizeof(out)) { 286818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return false; 287818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 288e1ca705cac4b946993f6cbf798e2a0ba27e739f3reed@google.com int bitHeight = SkScalarCeilToInt(larger.height()) + 2; 289818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bitHeight >= (int) sizeof(out)) { 290818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return false; 291818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 292deee496cd30070e52556dcb538c2e5eb39b66b81mike@reedtribe.org bits.allocN32Pixels(bitWidth * 2, bitHeight); 293818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkCanvas canvas(bits); 294818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawColor(SK_ColorWHITE); 295818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPaint paint; 296818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 297818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1, -bounds1.fTop + 1); 298818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(one, paint); 299818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 300818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 301818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1 + bitWidth, -bounds1.fTop + 1); 302818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(two, paint); 303818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 304818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int y = 0; y < bitHeight; ++y) { 305818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr1 = bits.getAddr32(0, y); 306818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int x; 307818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char* outPtr = out; 308818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (x = 0; x < bitWidth; ++x) { 309818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = addr1[x] == (uint32_t) -1 ? '_' : 'x'; 310818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 311818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = '|'; 312818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (x = bitWidth; x < bitWidth * 2; ++x) { 313818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = addr1[x] == (uint32_t) -1 ? '_' : 'x'; 314818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 315818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = '\0'; 316818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("%s\n", out); 317818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 318818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 319818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 320818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 32154359294a7c9dc54802d512a5d891a35c1663392caryclarkint comparePaths(skiatest::Reporter* reporter, const char* filename, const SkPath& one, 3224431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& two, SkBitmap& bitmap) { 323818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2x2; 324818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledOne, scaledTwo; 3254431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (void) pathsDrawTheSame(one, two, bitmap, scaledOne, scaledTwo, errors2x2); 326818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (errors2x2 == 0) { 327818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return 0; 328818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 329818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const int MAX_ERRORS = 9; 330818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return errors2x2 > MAX_ERRORS ? errors2x2 : 0; 331818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 332818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 3334431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic SkTDArray<SkPathOp> gTestOp; 3344431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 33559d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clarkstatic void showPathOpPath(const char* testName, const SkPath& one, const SkPath& two, 33659d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark const SkPath& a, const SkPath& b, const SkPath& scaledOne, const SkPath& scaledTwo, 33759d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark const SkPathOp shapeOp, const SkMatrix& scale) { 33859d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark SkASSERT((unsigned) shapeOp < SK_ARRAY_COUNT(opStrs)); 3394431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (!testName) { 3401049f1246e7be4ccb68001361efceb8933e6f81ccaryclark testName = "xOp"; 3414431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 3422bec26a71698105729c6a7cb0163f499b4361840caryclark SkDebugf("static void %s_%s(skiatest::Reporter* reporter, const char* filename) {\n", 3432bec26a71698105729c6a7cb0163f499b4361840caryclark testName, opSuffixes[shapeOp]); 34459d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark *gTestOp.append() = shapeOp; 345cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com SkDebugf(" SkPath path, pathB;\n"); 34619eb3b2f0aa6dce5c0335230a8930e90733e5d5dcaryclark SkPathOpsDebug::ShowOnePath(a, "path", false); 34719eb3b2f0aa6dce5c0335230a8930e90733e5d5dcaryclark SkPathOpsDebug::ShowOnePath(b, "pathB", false); 3484431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf(" testPathOp(reporter, path, pathB, %s, filename);\n", opStrs[shapeOp]); 349cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com SkDebugf("}\n"); 35026ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark drawAsciiPaths(scaledOne, scaledTwo, true); 3514431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 3524431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 353086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(compareDebugOut3); 35438a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark 3554431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic int comparePaths(skiatest::Reporter* reporter, const char* testName, const SkPath& one, 3564431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& scaledOne, const SkPath& two, const SkPath& scaledTwo, SkBitmap& bitmap, 35765f553182ab7069378ef863d30094d0327f178d0caryclark const SkPath& a, const SkPath& b, const SkPathOp shapeOp, const SkMatrix& scale, 358d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark ExpectMatch expectMatch) { 359818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2x2; 36065f553182ab7069378ef863d30094d0327f178d0caryclark const int MAX_ERRORS = 8; 3614431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (void) pathsDrawTheSame(bitmap, scaledOne, scaledTwo, errors2x2); 362d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark if (ExpectMatch::kNo == expectMatch) { 36338a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark if (errors2x2 < MAX_ERRORS) { 36465f553182ab7069378ef863d30094d0327f178d0caryclark REPORTER_ASSERT(reporter, 0); 36565f553182ab7069378ef863d30094d0327f178d0caryclark } 36665f553182ab7069378ef863d30094d0327f178d0caryclark return 0; 36765f553182ab7069378ef863d30094d0327f178d0caryclark } 368818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (errors2x2 == 0) { 369818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return 0; 370818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 371d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark if (ExpectMatch::kYes == expectMatch && errors2x2 >= MAX_ERRORS) { 3724431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkAutoMutexAcquire autoM(compareDebugOut3); 3734431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathOpPath(testName, one, two, a, b, scaledOne, scaledTwo, shapeOp, scale); 374aec251012542e971100e218bf463adbfb5d21d20caryclark SkDebugf("\n/*"); 375818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com REPORTER_ASSERT(reporter, 0); 376aec251012542e971100e218bf463adbfb5d21d20caryclark SkDebugf(" */\n"); 377818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 37838a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark return errors2x2 >= MAX_ERRORS ? errors2x2 : 0; 379818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 380818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 381409774e8accb8772765b376d3126209b198bc87ccommit-bot@chromium.org// Default values for when reporter->verbose() is false. 3824431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic int testNumber = 55; 383409774e8accb8772765b376d3126209b198bc87ccommit-bot@chromium.orgstatic const char* testName = "pathOpTest"; 38466089e4ec4f1702caf2154780471417872862148caryclark@google.com 385389c557338afd82be5d87735b5ec1cf57e85b26cCary Clarkstatic void appendTestName(const char* nameSuffix, std::string& out) { 386389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark out += testName; 387389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark out += std_to_string(testNumber); 3884431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org ++testNumber; 38966089e4ec4f1702caf2154780471417872862148caryclark@google.com if (nameSuffix) { 390561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(nameSuffix); 39166089e4ec4f1702caf2154780471417872862148caryclark@google.com } 39266089e4ec4f1702caf2154780471417872862148caryclark@google.com} 39366089e4ec4f1702caf2154780471417872862148caryclark@google.com 394561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagnerstatic void appendTest(const char* pathStr, const char* pathPrefix, const char* nameSuffix, 395389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark const char* testFunction, bool twoPaths, std::string& out) { 3964431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if 0 397561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("\n<div id=\""); 398561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTestName(nameSuffix, out); 399561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("\">\n"); 40066089e4ec4f1702caf2154780471417872862148caryclark@google.com if (pathPrefix) { 401561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(pathPrefix); 40266089e4ec4f1702caf2154780471417872862148caryclark@google.com } 403561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(pathStr); 404561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("</div>\n\n"); 40566089e4ec4f1702caf2154780471417872862148caryclark@google.com 406561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(marker); 407561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(" "); 408561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTestName(nameSuffix, out); 409561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(",\n\n\n"); 4104431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 411561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("static void "); 412561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTestName(nameSuffix, out); 413561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("(skiatest::Reporter* reporter) {\n SkPath path"); 41466089e4ec4f1702caf2154780471417872862148caryclark@google.com if (twoPaths) { 415561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(", pathB"); 41666089e4ec4f1702caf2154780471417872862148caryclark@google.com } 417561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(";\n"); 41866089e4ec4f1702caf2154780471417872862148caryclark@google.com if (pathPrefix) { 419561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(pathPrefix); 42066089e4ec4f1702caf2154780471417872862148caryclark@google.com } 421389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark out += pathStr; 422389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark out += " "; 423389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark out += testFunction; 4244431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if 0 425561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("static void (*firstTest)() = "); 426561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTestName(nameSuffix, out); 427561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(";\n\n"); 428561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner 429561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("static struct {\n"); 430561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(" void (*fun)();\n"); 431561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(" const char* str;\n"); 432561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("} tests[] = {\n"); 433561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append(" TEST("); 434561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTestName(nameSuffix, out); 435561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner out.append("),\n"); 4364431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 43766089e4ec4f1702caf2154780471417872862148caryclark@google.com} 43866089e4ec4f1702caf2154780471417872862148caryclark@google.com 439086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(simplifyDebugOut); 44054359294a7c9dc54802d512a5d891a35c1663392caryclark 44166089e4ec4f1702caf2154780471417872862148caryclark@google.combool testSimplify(SkPath& path, bool useXor, SkPath& out, PathOpsThreadState& state, 44266089e4ec4f1702caf2154780471417872862148caryclark@google.com const char* pathStr) { 443818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath::FillType fillType = useXor ? SkPath::kEvenOdd_FillType : SkPath::kWinding_FillType; 444818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com path.setFillType(fillType); 44554359294a7c9dc54802d512a5d891a35c1663392caryclark state.fReporter->bumpTestCount(); 44666560ca776773858abfffd59974eac32c942acc3caryclark@google.com if (!Simplify(path, &out)) { 44766560ca776773858abfffd59974eac32c942acc3caryclark@google.com SkDebugf("%s did not expect failure\n", __FUNCTION__); 44866560ca776773858abfffd59974eac32c942acc3caryclark@google.com REPORTER_ASSERT(state.fReporter, 0); 44966560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 45066560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 4518d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com if (!state.fReporter->verbose()) { 452818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 453818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 45496fcdcc219d2a0d3579719b84b28bede76efba64halcanary int result = comparePaths(state.fReporter, nullptr, path, out, *state.fBitmap); 45554359294a7c9dc54802d512a5d891a35c1663392caryclark if (result) { 4564431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkAutoMutexAcquire autoM(simplifyDebugOut); 457389c557338afd82be5d87735b5ec1cf57e85b26cCary Clark std::string str; 45896fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* pathPrefix = nullptr; 45996fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* nameSuffix = nullptr; 460818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (fillType == SkPath::kEvenOdd_FillType) { 461818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com pathPrefix = " path.setFillType(SkPath::kEvenOdd_FillType);\n"; 462818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com nameSuffix = "x"; 463818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 4644431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const char testFunction[] = "testSimplify(reporter, path);"; 465561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTest(pathStr, pathPrefix, nameSuffix, testFunction, false, str); 466ff80c2ab305a25434d17fbcbec02b20d69b05227Mike Reed SkDebugf("%s", str.c_str()); 46766089e4ec4f1702caf2154780471417872862148caryclark@google.com REPORTER_ASSERT(state.fReporter, 0); 468818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 46966089e4ec4f1702caf2154780471417872862148caryclark@google.com state.fReporter->bumpTestCount(); 470818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return result == 0; 471818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 472818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 47354359294a7c9dc54802d512a5d891a35c1663392caryclarkstatic bool inner_simplify(skiatest::Reporter* reporter, const SkPath& path, const char* filename, 47455888e44171ffd48b591d19256884a969fe4da17caryclark ExpectSuccess expectSuccess, SkipAssert skipAssert, ExpectMatch expectMatch) { 47554359294a7c9dc54802d512a5d891a35c1663392caryclark#if 0 && DEBUG_SHOW_TEST_NAME 4760361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com showPathData(path); 4770361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 478818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath out; 47955888e44171ffd48b591d19256884a969fe4da17caryclark if (!SimplifyDebug(path, &out SkDEBUGPARAMS(SkipAssert::kYes == skipAssert) 48055888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(testName))) { 48155888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kYes == expectSuccess) { 48255888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s did not expect %s failure\n", __FUNCTION__, filename); 48355888e44171ffd48b591d19256884a969fe4da17caryclark REPORTER_ASSERT(reporter, 0); 48455888e44171ffd48b591d19256884a969fe4da17caryclark } 48566560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 48655888e44171ffd48b591d19256884a969fe4da17caryclark } else { 48755888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kNo == expectSuccess) { 48855888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s %s unexpected success\n", __FUNCTION__, filename); 48955888e44171ffd48b591d19256884a969fe4da17caryclark REPORTER_ASSERT(reporter, 0); 49055888e44171ffd48b591d19256884a969fe4da17caryclark } 49166560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 492818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bitmap; 49354359294a7c9dc54802d512a5d891a35c1663392caryclark int errors = comparePaths(reporter, filename, path, out, bitmap); 49455888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectMatch::kNo == expectMatch) { 49554359294a7c9dc54802d512a5d891a35c1663392caryclark if (!errors) { 49654359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("%s failing test %s now succeeds\n", __FUNCTION__, filename); 49754359294a7c9dc54802d512a5d891a35c1663392caryclark REPORTER_ASSERT(reporter, 0); 49854359294a7c9dc54802d512a5d891a35c1663392caryclark return false; 49954359294a7c9dc54802d512a5d891a35c1663392caryclark } 500d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark } else if (ExpectMatch::kYes == expectMatch && errors) { 501818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com REPORTER_ASSERT(reporter, 0); 502818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 50366089e4ec4f1702caf2154780471417872862148caryclark@google.com reporter->bumpTestCount(); 50454359294a7c9dc54802d512a5d891a35c1663392caryclark return errors == 0; 50554359294a7c9dc54802d512a5d891a35c1663392caryclark} 50654359294a7c9dc54802d512a5d891a35c1663392caryclark 50754359294a7c9dc54802d512a5d891a35c1663392caryclarkbool testSimplify(skiatest::Reporter* reporter, const SkPath& path, const char* filename) { 50855888e44171ffd48b591d19256884a969fe4da17caryclark return inner_simplify(reporter, path, filename, ExpectSuccess::kYes, SkipAssert::kNo, 50955888e44171ffd48b591d19256884a969fe4da17caryclark ExpectMatch::kYes); 51055888e44171ffd48b591d19256884a969fe4da17caryclark} 51155888e44171ffd48b591d19256884a969fe4da17caryclark 51230b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclarkbool testSimplifyFuzz(skiatest::Reporter* reporter, const SkPath& path, const char* filename) { 51330b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclark return inner_simplify(reporter, path, filename, ExpectSuccess::kFlaky, SkipAssert::kYes, 51430b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclark ExpectMatch::kFlaky); 51554359294a7c9dc54802d512a5d891a35c1663392caryclark} 51654359294a7c9dc54802d512a5d891a35c1663392caryclark 51754359294a7c9dc54802d512a5d891a35c1663392caryclarkbool testSimplifyCheck(skiatest::Reporter* reporter, const SkPath& path, const char* filename, 51854359294a7c9dc54802d512a5d891a35c1663392caryclark bool checkFail) { 51955888e44171ffd48b591d19256884a969fe4da17caryclark return inner_simplify(reporter, path, filename, checkFail ? 52055888e44171ffd48b591d19256884a969fe4da17caryclark ExpectSuccess::kYes : ExpectSuccess::kNo, SkipAssert::kNo, ExpectMatch::kNo); 521818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 522818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 52307e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 5244431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic void showName(const SkPath& a, const SkPath& b, const SkPathOp shapeOp) { 5254431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf("\n"); 5264431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathData(a); 5274431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showOp(shapeOp); 5284431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathData(b); 5294431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 5304431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 5314431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 5328d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.comstatic bool innerPathOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 53355888e44171ffd48b591d19256884a969fe4da17caryclark const SkPathOp shapeOp, const char* testName, ExpectSuccess expectSuccess, 53455888e44171ffd48b591d19256884a969fe4da17caryclark SkipAssert skipAssert, ExpectMatch expectMatch) { 53554359294a7c9dc54802d512a5d891a35c1663392caryclark#if 0 && DEBUG_SHOW_TEST_NAME 5364431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showName(a, b, shapeOp); 537818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 538818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath out; 53955888e44171ffd48b591d19256884a969fe4da17caryclark if (!OpDebug(a, b, shapeOp, &out SkDEBUGPARAMS(SkipAssert::kYes == skipAssert) 540dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark SkDEBUGPARAMS(testName))) { 54155888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kYes == expectSuccess) { 54255888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s %s did not expect failure\n", __FUNCTION__, testName); 5433f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark REPORTER_ASSERT(reporter, 0); 5443f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark } 54566560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 54655888e44171ffd48b591d19256884a969fe4da17caryclark } else { 54755888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kNo == expectSuccess) { 54855888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s %s unexpected success\n", __FUNCTION__, testName); 54955888e44171ffd48b591d19256884a969fe4da17caryclark REPORTER_ASSERT(reporter, 0); 55055888e44171ffd48b591d19256884a969fe4da17caryclark } 55166560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 55254359294a7c9dc54802d512a5d891a35c1663392caryclark if (!reporter->verbose()) { 5538d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com return true; 5548d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com } 555818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath pathOut, scaledPathOut; 556818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRegion rgnA, rgnB, openClip, rgnOut; 557818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com openClip.setRect(-16000, -16000, 16000, 16000); 558818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnA.setPath(a, openClip); 559818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnB.setPath(b, openClip); 560818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnOut.op(rgnA, rgnB, (SkRegion::Op) shapeOp); 561818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnOut.getBoundaryPath(&pathOut); 562818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 563818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMatrix scale; 564818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaleMatrix(a, b, scale); 565818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRegion scaledRgnA, scaledRgnB, scaledRgnOut; 566818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledA, scaledB; 567818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledA.addPath(a, scale); 568818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledA.setFillType(a.getFillType()); 569818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledB.addPath(b, scale); 570818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledB.setFillType(b.getFillType()); 571818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnA.setPath(scaledA, openClip); 572818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnB.setPath(scaledB, openClip); 573818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnOut.op(scaledRgnA, scaledRgnB, (SkRegion::Op) shapeOp); 574818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnOut.getBoundaryPath(&scaledPathOut); 575818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bitmap; 576818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledOut; 577818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledOut.addPath(out, scale); 578818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledOut.setFillType(out.getFillType()); 5794431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org int result = comparePaths(reporter, testName, pathOut, scaledPathOut, out, scaledOut, bitmap, 580d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark a, b, shapeOp, scale, expectMatch); 58166089e4ec4f1702caf2154780471417872862148caryclark@google.com reporter->bumpTestCount(); 582818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return result == 0; 583818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 584818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 5858d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.combool testPathOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 58665f553182ab7069378ef863d30094d0327f178d0caryclark const SkPathOp shapeOp, const char* testName) { 58755888e44171ffd48b591d19256884a969fe4da17caryclark return innerPathOp(reporter, a, b, shapeOp, testName, ExpectSuccess::kYes, SkipAssert::kNo, 58855888e44171ffd48b591d19256884a969fe4da17caryclark ExpectMatch::kYes); 58965f553182ab7069378ef863d30094d0327f178d0caryclark} 59065f553182ab7069378ef863d30094d0327f178d0caryclark 59165f553182ab7069378ef863d30094d0327f178d0caryclarkbool testPathOpCheck(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 59265f553182ab7069378ef863d30094d0327f178d0caryclark const SkPathOp shapeOp, const char* testName, bool checkFail) { 59355888e44171ffd48b591d19256884a969fe4da17caryclark return innerPathOp(reporter, a, b, shapeOp, testName, checkFail ? 59455888e44171ffd48b591d19256884a969fe4da17caryclark ExpectSuccess::kYes : ExpectSuccess::kNo, SkipAssert::kNo, ExpectMatch::kNo); 5958d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com} 5968d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com 59730b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclarkbool testPathOpFuzz(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 598d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark const SkPathOp shapeOp, const char* testName) { 599d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark return innerPathOp(reporter, a, b, shapeOp, testName, ExpectSuccess::kFlaky, SkipAssert::kYes, 600d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark ExpectMatch::kFlaky); 601d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark} 602d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 60359d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clarkbool testPathOpFail(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 60459d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark const SkPathOp shapeOp, const char* testName) { 60559d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark#if DEBUG_SHOW_TEST_NAME 60659d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark showName(a, b, shapeOp); 60759d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark#endif 60859d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark SkPath orig; 60959d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark orig.lineTo(54, 43); 61059d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark SkPath out = orig; 61159d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark if (Op(a, b, shapeOp, &out) ) { 61259d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark SkDebugf("%s test is expected to fail\n", __FUNCTION__); 61359d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark REPORTER_ASSERT(reporter, 0); 61459d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark return false; 61559d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark } 61659d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark SkASSERT(out == orig); 61759d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark return true; 61859d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark} 61959d5a0e3f560da40e0ae7036a01d7d58ce3718d8Cary Clark 620086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(gMutex); 6217eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com 622406654be7a930b484159f5bca107d3b11d8a9edemtkleinvoid initializeTests(skiatest::Reporter* reporter, const char* test) { 6237eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (reporter->verbose()) { 6247eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkAutoMutexAcquire lock(gMutex); 6257eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com testName = test; 6267eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com size_t testNameSize = strlen(test); 6277eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkFILEStream inFile("../../experimental/Intersection/op.htm"); 6287eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (inFile.isValid()) { 6297eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkTDArray<char> inData; 6304431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org inData.setCount((int) inFile.getLength()); 6317eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com size_t inLen = inData.count(); 6327eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com inFile.read(inData.begin(), inLen); 6334d1955c43aaab045511b74a495dfbea4ef0057c5Ben Wagner inFile.close(); 6347eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com char* insert = strstr(inData.begin(), marker); 6357eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (insert) { 6367eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com insert += sizeof(marker) - 1; 6377eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com const char* numLoc = insert + 4 /* indent spaces */ + testNameSize - 1; 6387eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com testNumber = atoi(numLoc) + 1; 6397eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com } 640818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 641818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 642818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 643818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 644ff80c2ab305a25434d17fbcbec02b20d69b05227Mike Reedvoid PathOpsThreadState::outputProgress(const char* pathStr, SkPath::FillType pathFillType) { 64566089e4ec4f1702caf2154780471417872862148caryclark@google.com const char testFunction[] = "testSimplify(path);"; 64696fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* pathPrefix = nullptr; 64796fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* nameSuffix = nullptr; 648818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (pathFillType == SkPath::kEvenOdd_FillType) { 649818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com pathPrefix = " path.setFillType(SkPath::kEvenOdd_FillType);\n"; 650818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com nameSuffix = "x"; 651818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 652561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTest(pathStr, pathPrefix, nameSuffix, testFunction, false, fPathStr); 653818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 654818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 655ff80c2ab305a25434d17fbcbec02b20d69b05227Mike Reedvoid PathOpsThreadState::outputProgress(const char* pathStr, SkPathOp op) { 65666089e4ec4f1702caf2154780471417872862148caryclark@google.com const char testFunction[] = "testOp(path);"; 657ad65a3e5fb1f94699f183551b828efbcc6a133cecaryclark@google.com SkASSERT((size_t) op < SK_ARRAY_COUNT(opSuffixes)); 658818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const char* nameSuffix = opSuffixes[op]; 659561c1b07eff3263905b01d6dede359d08aa8f2f3Ben Wagner appendTest(pathStr, nullptr, nameSuffix, testFunction, true, fPathStr); 660818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 661818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 662818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comvoid RunTestSet(skiatest::Reporter* reporter, TestDesc tests[], size_t count, 6634431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org void (*firstTest)(skiatest::Reporter* , const char* filename), 66454359294a7c9dc54802d512a5d891a35c1663392caryclark void (*skipTest)(skiatest::Reporter* , const char* filename), 6654431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org void (*stopTest)(skiatest::Reporter* , const char* filename), bool reverse) { 666818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com size_t index; 667818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (firstTest) { 668818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index = count - 1; 669818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com while (index > 0 && tests[index].fun != firstTest) { 670818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com --index; 671818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 672a5e55925ea03e76885804bda77408a1d6f04c335caryclark@google.com#if DEBUG_SHOW_TEST_NAME 67354359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("\n<div id=\"%s\">\n", tests[index].str); 674818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 6754431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (*tests[index].fun)(reporter, tests[index].str); 6764431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (tests[index].fun == stopTest) { 6774431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org return; 6784431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 679818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 680818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index = reverse ? count - 1 : 0; 681818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com size_t last = reverse ? 0 : count - 1; 68254359294a7c9dc54802d512a5d891a35c1663392caryclark bool foundSkip = !skipTest; 683818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com do { 68454359294a7c9dc54802d512a5d891a35c1663392caryclark if (tests[index].fun == skipTest) { 68554359294a7c9dc54802d512a5d891a35c1663392caryclark foundSkip = true; 68654359294a7c9dc54802d512a5d891a35c1663392caryclark } 68754359294a7c9dc54802d512a5d891a35c1663392caryclark if (foundSkip && tests[index].fun != firstTest) { 688a5e55925ea03e76885804bda77408a1d6f04c335caryclark@google.com #if DEBUG_SHOW_TEST_NAME 68954359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("\n<div id=\"%s\">\n", tests[index].str); 690818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com #endif 69130b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclark (*tests[index].fun)(reporter, tests[index].str); 692818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 69303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == stopTest || index == last) { 6944431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org break; 695818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 69603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark index += reverse ? -1 : 1; 69703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } while (true); 69803b03cad01628146bbb8d4f33c073bd0c77ee558caryclark#if DEBUG_SHOW_TEST_NAME 69903b03cad01628146bbb8d4f33c073bd0c77ee558caryclark SkDebugf( 70003b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 70103b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "</div>\n" 70203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 70303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "<script type=\"text/javascript\">\n" 70403b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 70503b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "var testDivs = [\n" 70603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark ); 70703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark index = reverse ? count - 1 : 0; 70803b03cad01628146bbb8d4f33c073bd0c77ee558caryclark last = reverse ? 0 : count - 1; 70903b03cad01628146bbb8d4f33c073bd0c77ee558caryclark foundSkip = !skipTest; 71003b03cad01628146bbb8d4f33c073bd0c77ee558caryclark do { 71103b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == skipTest) { 71203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark foundSkip = true; 71303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } 71403b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (foundSkip && tests[index].fun != firstTest) { 71503b03cad01628146bbb8d4f33c073bd0c77ee558caryclark SkDebugf(" %s,\n", tests[index].str); 71603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } 71703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == stopTest || index == last) { 718818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 719818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 720818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index += reverse ? -1 : 1; 721818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } while (true); 72203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark#endif 723818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 724