PathOpsExtendedTest.cpp revision 30b9fdd6a1d607bde20c793af65b5e2e8a1737ca
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" 127eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com#include "SkForceLinking.h" 13818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include "SkMatrix.h" 141b24933e52f50773de29332387a12721811f3012mtklein#include "SkMutex.h" 15e02c5dabbbfefca3e086b3653d71a7a4a9713277skia.committer@gmail.com#include "SkPaint.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 2455888e44171ffd48b591d19256884a969fe4da17caryclarkbool OpDebug(const SkPath& one, const SkPath& two, SkPathOp op, SkPath* result 2555888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(bool skipAssert) 2655888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(const char* testName)); 2755888e44171ffd48b591d19256884a969fe4da17caryclark 2855888e44171ffd48b591d19256884a969fe4da17caryclarkbool SimplifyDebug(const SkPath& one, SkPath* result 2955888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(bool skipAssert) 3055888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(const char* testName)); 3155888e44171ffd48b591d19256884a969fe4da17caryclark 3255888e44171ffd48b591d19256884a969fe4da17caryclark 337eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com__SK_FORCE_IMAGE_DECODER_LINKING; 347eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com 3565b427cff9cd34a06ff060d65d00cc3615d8fd94caryclarkDEFINE_bool2(runFail, f, false, "run tests known to fail."); 3654359294a7c9dc54802d512a5d891a35c1663392caryclarkDEFINE_bool2(runBinary, f, false, "run tests known to fail binary sect."); 3765b427cff9cd34a06ff060d65d00cc3615d8fd94caryclark 38818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char marker[] = 39818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "</div>\n" 40818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "\n" 41818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "<script type=\"text/javascript\">\n" 42818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "\n" 43818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "var testDivs = [\n"; 44818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 45818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char* opStrs[] = { 4654359294a7c9dc54802d512a5d891a35c1663392caryclark "kDifference_SkPathOp", 4754359294a7c9dc54802d512a5d891a35c1663392caryclark "kIntersect_SkPathOp", 4854359294a7c9dc54802d512a5d891a35c1663392caryclark "kUnion_SkPathOp", 4955888e44171ffd48b591d19256884a969fe4da17caryclark "kXOR_PathOp", 5054359294a7c9dc54802d512a5d891a35c1663392caryclark "kReverseDifference_SkPathOp", 51818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com}; 52818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 53818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char* opSuffixes[] = { 54818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "d", 55818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "i", 56818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "u", 5766089e4ec4f1702caf2154780471417872862148caryclark@google.com "o", 5855888e44171ffd48b591d19256884a969fe4da17caryclark "r", 59818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com}; 60818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 61d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclarkenum class ExpectSuccess { 62d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kNo, 63d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kYes, 64d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kFlaky 65d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark}; 66d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 67d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclarkenum class SkipAssert { 68d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kNo, 69d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kYes 70d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark}; 71d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 72d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclarkenum class ExpectMatch { 73d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kNo, 74d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kYes, 75d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark kFlaky 76d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark}; 77d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 78cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com#if DEBUG_SHOW_TEST_NAME 79cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.comstatic void showPathData(const SkPath& path) { 8007e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com SkPath::RawIter iter(path); 81818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint8_t verb; 82818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPoint pts[4]; 834431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkPoint firstPt = {0, 0}, lastPt = {0, 0}; 84fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com bool firstPtSet = false; 85fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com bool lastPtSet = true; 86818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com while ((verb = iter.next(pts)) != SkPath::kDone_Verb) { 87818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com switch (verb) { 88818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kMove_Verb: 89dac1d17027dcaa5596885a9f333979418b35001ccaryclark if (firstPtSet && lastPtSet && firstPt != lastPt) { 90dac1d17027dcaa5596885a9f333979418b35001ccaryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 91dac1d17027dcaa5596885a9f333979418b35001ccaryclark firstPt.fX, firstPt.fY); 92dac1d17027dcaa5596885a9f333979418b35001ccaryclark lastPtSet = false; 93dac1d17027dcaa5596885a9f333979418b35001ccaryclark } 94fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPt = pts[0]; 95fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPtSet = true; 96818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com continue; 97818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kLine_Verb: 9866089e4ec4f1702caf2154780471417872862148caryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", pts[0].fX, pts[0].fY, 9966089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[1].fX, pts[1].fY); 100fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[1]; 101fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 102818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 103818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kQuad_Verb: 104818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", 10566089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY); 106fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[2]; 107fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 108818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 10954359294a7c9dc54802d512a5d891a35c1663392caryclark case SkPath::kConic_Verb: 11054359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}}, //weight=%1.9g\n", 11154359294a7c9dc54802d512a5d891a35c1663392caryclark pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY, 11254359294a7c9dc54802d512a5d891a35c1663392caryclark iter.conicWeight()); 11354359294a7c9dc54802d512a5d891a35c1663392caryclark lastPt = pts[2]; 11454359294a7c9dc54802d512a5d891a35c1663392caryclark lastPtSet = true; 11554359294a7c9dc54802d512a5d891a35c1663392caryclark break; 116818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kCubic_Verb: 117818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", 11866089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY, 11966089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[3].fX, pts[3].fY); 120fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[3]; 121fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 122818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 123818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kClose_Verb: 124fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com if (firstPtSet && lastPtSet && firstPt != lastPt) { 125fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 126fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPt.fX, firstPt.fY); 127fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com } 128fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPtSet = lastPtSet = false; 129818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 130818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com default: 131818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDEBUGFAIL("bad verb"); 132818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return; 133818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 134818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 135dac1d17027dcaa5596885a9f333979418b35001ccaryclark if (firstPtSet && lastPtSet && firstPt != lastPt) { 136dac1d17027dcaa5596885a9f333979418b35001ccaryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 137dac1d17027dcaa5596885a9f333979418b35001ccaryclark firstPt.fX, firstPt.fY); 138dac1d17027dcaa5596885a9f333979418b35001ccaryclark } 139818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 140cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com#endif 141818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 142818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comvoid showOp(const SkPathOp op) { 143818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com switch (op) { 14454359294a7c9dc54802d512a5d891a35c1663392caryclark case kDifference_SkPathOp: 145818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op difference\n"); 146818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 14754359294a7c9dc54802d512a5d891a35c1663392caryclark case kIntersect_SkPathOp: 148818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op intersect\n"); 149818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 15054359294a7c9dc54802d512a5d891a35c1663392caryclark case kUnion_SkPathOp: 151818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op union\n"); 152818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 15354359294a7c9dc54802d512a5d891a35c1663392caryclark case kXOR_SkPathOp: 154818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op xor\n"); 155818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 15654359294a7c9dc54802d512a5d891a35c1663392caryclark case kReverseDifference_SkPathOp: 1576dc7df69ae6b24c90d231e0d6a4516bf4f1aee2ecaryclark@google.com SkDebugf("op reverse difference\n"); 1586dc7df69ae6b24c90d231e0d6a4516bf4f1aee2ecaryclark@google.com break; 159818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com default: 160818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkASSERT(0); 161818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 162818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 163818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 16407e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 1650361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.comstatic char hexorator(int x) { 1660361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com if (x < 10) { 1670361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com return x + '0'; 1680361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com } 1690361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com x -= 10; 1700361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkASSERT(x < 26); 1710361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com return x + 'A'; 1720361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com} 1730361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 1740361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com 1750361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.comvoid ShowTestName(PathOpsThreadState* state, int a, int b, int c, int d) { 1760361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 1770361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[0] = hexorator(state->fA); 1780361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[1] = hexorator(state->fB); 1790361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[2] = hexorator(state->fC); 1800361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[3] = hexorator(state->fD); 1810361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[4] = hexorator(a); 1820361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[5] = hexorator(b); 1830361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[6] = hexorator(c); 1840361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[7] = hexorator(d); 1850361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[8] = '\0'; 1860361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkDebugf("%s\n", state->fSerialNo); 1870361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com if (strcmp(state->fSerialNo, state->fKey) == 0) { 1880361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkDebugf("%s\n", state->fPathStr); 1890361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com } 1900361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 1910361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com} 1920361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com 193818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comconst int bitWidth = 64; 194818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comconst int bitHeight = 64; 195818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 196818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic void scaleMatrix(const SkPath& one, const SkPath& two, SkMatrix& scale) { 197818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRect larger = one.getBounds(); 198818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com larger.join(two.getBounds()); 199818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar largerWidth = larger.width(); 200818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (largerWidth < 4) { 201818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com largerWidth = 4; 202818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 203818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar largerHeight = larger.height(); 204818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (largerHeight < 4) { 205818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com largerHeight = 4; 206818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 207818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar hScale = (bitWidth - 2) / largerWidth; 208818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar vScale = (bitHeight - 2) / largerHeight; 209818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scale.reset(); 210818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scale.preScale(hScale, vScale); 21126ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fLeft *= hScale; 21226ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fRight *= hScale; 21326ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fTop *= vScale; 21426ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fBottom *= vScale; 21526ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark SkScalar dx = -16000 > larger.fLeft ? -16000 - larger.fLeft 21626ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark : 16000 < larger.fRight ? 16000 - larger.fRight : 0; 21726ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark SkScalar dy = -16000 > larger.fTop ? -16000 - larger.fTop 21826ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark : 16000 < larger.fBottom ? 16000 - larger.fBottom : 0; 21926ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark scale.postTranslate(dx, dy); 220818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 221818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 222818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic int pathsDrawTheSame(SkBitmap& bits, const SkPath& scaledOne, const SkPath& scaledTwo, 223818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int& error2x2) { 224818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bits.width() == 0) { 225deee496cd30070e52556dcb538c2e5eb39b66b81mike@reedtribe.org bits.allocN32Pixels(bitWidth * 2, bitHeight); 226818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 227818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkCanvas canvas(bits); 228818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawColor(SK_ColorWHITE); 229818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPaint paint; 230818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 231818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds1 = scaledOne.getBounds(); 232818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1, -bounds1.fTop + 1); 233818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(scaledOne, paint); 234818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 235818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 236818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1 + bitWidth, -bounds1.fTop + 1); 237818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(scaledTwo, paint); 238818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 239818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2 = 0; 240818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors = 0; 241818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int y = 0; y < bitHeight - 1; ++y) { 242818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr1 = bits.getAddr32(0, y); 243818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr2 = bits.getAddr32(0, y + 1); 244818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr3 = bits.getAddr32(bitWidth, y); 245818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr4 = bits.getAddr32(bitWidth, y + 1); 246818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int x = 0; x < bitWidth - 1; ++x) { 247818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com // count 2x2 blocks 248818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com bool err = addr1[x] != addr3[x]; 249818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (err) { 250818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com errors2 += addr1[x + 1] != addr3[x + 1] 251818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com && addr2[x] != addr4[x] && addr2[x + 1] != addr4[x + 1]; 252818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com errors++; 253818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 254818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 255818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 256818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com error2x2 = errors2; 257818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return errors; 258818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 259818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 260818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic int pathsDrawTheSame(const SkPath& one, const SkPath& two, SkBitmap& bits, SkPath& scaledOne, 261818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath& scaledTwo, int& error2x2) { 262818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMatrix scale; 263818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaleMatrix(one, two, scale); 264818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com one.transform(scale, &scaledOne); 265818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com two.transform(scale, &scaledTwo); 266818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return pathsDrawTheSame(bits, scaledOne, scaledTwo, error2x2); 267818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 268818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 269818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.combool drawAsciiPaths(const SkPath& one, const SkPath& two, bool drawPaths) { 270818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (!drawPaths) { 271818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 272818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 273818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds1 = one.getBounds(); 274818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds2 = two.getBounds(); 275818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRect larger = bounds1; 276818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com larger.join(bounds2); 277818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bits; 278818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char out[256]; 279e1ca705cac4b946993f6cbf798e2a0ba27e739f3reed@google.com int bitWidth = SkScalarCeilToInt(larger.width()) + 2; 280818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bitWidth * 2 + 1 >= (int) sizeof(out)) { 281818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return false; 282818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 283e1ca705cac4b946993f6cbf798e2a0ba27e739f3reed@google.com int bitHeight = SkScalarCeilToInt(larger.height()) + 2; 284818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bitHeight >= (int) sizeof(out)) { 285818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return false; 286818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 287deee496cd30070e52556dcb538c2e5eb39b66b81mike@reedtribe.org bits.allocN32Pixels(bitWidth * 2, bitHeight); 288818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkCanvas canvas(bits); 289818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawColor(SK_ColorWHITE); 290818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPaint paint; 291818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 292818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1, -bounds1.fTop + 1); 293818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(one, paint); 294818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 295818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 296818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1 + bitWidth, -bounds1.fTop + 1); 297818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(two, paint); 298818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 299818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int y = 0; y < bitHeight; ++y) { 300818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr1 = bits.getAddr32(0, y); 301818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int x; 302818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char* outPtr = out; 303818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (x = 0; x < bitWidth; ++x) { 304818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = addr1[x] == (uint32_t) -1 ? '_' : 'x'; 305818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 306818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = '|'; 307818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (x = bitWidth; x < bitWidth * 2; ++x) { 308818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = addr1[x] == (uint32_t) -1 ? '_' : 'x'; 309818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 310818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = '\0'; 311818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("%s\n", out); 312818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 313818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 314818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 315818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 31654359294a7c9dc54802d512a5d891a35c1663392caryclarkint comparePaths(skiatest::Reporter* reporter, const char* filename, const SkPath& one, 3174431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& two, SkBitmap& bitmap) { 318818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2x2; 319818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledOne, scaledTwo; 3204431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (void) pathsDrawTheSame(one, two, bitmap, scaledOne, scaledTwo, errors2x2); 321818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (errors2x2 == 0) { 322818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return 0; 323818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 324818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const int MAX_ERRORS = 9; 325818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return errors2x2 > MAX_ERRORS ? errors2x2 : 0; 326818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 327818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 3284431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic SkTDArray<SkPathOp> gTestOp; 3294431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 3304431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic void showPathOpPath(const char* testName, const SkPath& one, const SkPath& two, 3314431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& a, const SkPath& b, const SkPath& scaledOne, const SkPath& scaledTwo, 3324431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPathOp shapeOp, const SkMatrix& scale) { 333ad65a3e5fb1f94699f183551b828efbcc6a133cecaryclark@google.com SkASSERT((unsigned) shapeOp < SK_ARRAY_COUNT(opStrs)); 3344431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (!testName) { 3351049f1246e7be4ccb68001361efceb8933e6f81ccaryclark testName = "xOp"; 3364431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 3372bec26a71698105729c6a7cb0163f499b4361840caryclark SkDebugf("static void %s_%s(skiatest::Reporter* reporter, const char* filename) {\n", 3382bec26a71698105729c6a7cb0163f499b4361840caryclark testName, opSuffixes[shapeOp]); 3394431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org *gTestOp.append() = shapeOp; 340cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com SkDebugf(" SkPath path, pathB;\n"); 34119eb3b2f0aa6dce5c0335230a8930e90733e5d5dcaryclark SkPathOpsDebug::ShowOnePath(a, "path", false); 34219eb3b2f0aa6dce5c0335230a8930e90733e5d5dcaryclark SkPathOpsDebug::ShowOnePath(b, "pathB", false); 3434431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf(" testPathOp(reporter, path, pathB, %s, filename);\n", opStrs[shapeOp]); 344cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com SkDebugf("}\n"); 34526ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark drawAsciiPaths(scaledOne, scaledTwo, true); 3464431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 3474431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 348086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(compareDebugOut3); 34938a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark 3504431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic int comparePaths(skiatest::Reporter* reporter, const char* testName, const SkPath& one, 3514431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& scaledOne, const SkPath& two, const SkPath& scaledTwo, SkBitmap& bitmap, 35265f553182ab7069378ef863d30094d0327f178d0caryclark const SkPath& a, const SkPath& b, const SkPathOp shapeOp, const SkMatrix& scale, 353d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark ExpectMatch expectMatch) { 354818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2x2; 35565f553182ab7069378ef863d30094d0327f178d0caryclark const int MAX_ERRORS = 8; 3564431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (void) pathsDrawTheSame(bitmap, scaledOne, scaledTwo, errors2x2); 357d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark if (ExpectMatch::kNo == expectMatch) { 35838a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark if (errors2x2 < MAX_ERRORS) { 35965f553182ab7069378ef863d30094d0327f178d0caryclark REPORTER_ASSERT(reporter, 0); 36065f553182ab7069378ef863d30094d0327f178d0caryclark } 36165f553182ab7069378ef863d30094d0327f178d0caryclark return 0; 36265f553182ab7069378ef863d30094d0327f178d0caryclark } 363818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (errors2x2 == 0) { 364818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return 0; 365818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 366d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark if (ExpectMatch::kYes == expectMatch && errors2x2 >= MAX_ERRORS) { 3674431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkAutoMutexAcquire autoM(compareDebugOut3); 3684431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathOpPath(testName, one, two, a, b, scaledOne, scaledTwo, shapeOp, scale); 369aec251012542e971100e218bf463adbfb5d21d20caryclark SkDebugf("\n/*"); 370818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com REPORTER_ASSERT(reporter, 0); 371aec251012542e971100e218bf463adbfb5d21d20caryclark SkDebugf(" */\n"); 372818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 37338a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark return errors2x2 >= MAX_ERRORS ? errors2x2 : 0; 374818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 375818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 376409774e8accb8772765b376d3126209b198bc87ccommit-bot@chromium.org// Default values for when reporter->verbose() is false. 3774431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic int testNumber = 55; 378409774e8accb8772765b376d3126209b198bc87ccommit-bot@chromium.orgstatic const char* testName = "pathOpTest"; 37966089e4ec4f1702caf2154780471417872862148caryclark@google.com 38066089e4ec4f1702caf2154780471417872862148caryclark@google.comstatic void writeTestName(const char* nameSuffix, SkMemoryWStream& outFile) { 38166089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(testName); 38266089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeDecAsText(testNumber); 3834431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org ++testNumber; 38466089e4ec4f1702caf2154780471417872862148caryclark@google.com if (nameSuffix) { 38566089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(nameSuffix); 38666089e4ec4f1702caf2154780471417872862148caryclark@google.com } 38766089e4ec4f1702caf2154780471417872862148caryclark@google.com} 38866089e4ec4f1702caf2154780471417872862148caryclark@google.com 38966089e4ec4f1702caf2154780471417872862148caryclark@google.comstatic void outputToStream(const char* pathStr, const char* pathPrefix, const char* nameSuffix, 39066089e4ec4f1702caf2154780471417872862148caryclark@google.com const char* testFunction, bool twoPaths, SkMemoryWStream& outFile) { 3914431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if 0 39254359294a7c9dc54802d512a5d891a35c1663392caryclark outFile.writeText("\n<div id=\""); 39366089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 39466089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("\">\n"); 39566089e4ec4f1702caf2154780471417872862148caryclark@google.com if (pathPrefix) { 39666089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathPrefix); 39766089e4ec4f1702caf2154780471417872862148caryclark@google.com } 39866089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathStr); 39966089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("</div>\n\n"); 40066089e4ec4f1702caf2154780471417872862148caryclark@google.com 40166089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(marker); 40266089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" "); 40366089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 40466089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(",\n\n\n"); 4054431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 40666089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("static void "); 40766089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 4084431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org outFile.writeText("(skiatest::Reporter* reporter) {\n SkPath path"); 40966089e4ec4f1702caf2154780471417872862148caryclark@google.com if (twoPaths) { 41066089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(", pathB"); 41166089e4ec4f1702caf2154780471417872862148caryclark@google.com } 41266089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(";\n"); 41366089e4ec4f1702caf2154780471417872862148caryclark@google.com if (pathPrefix) { 41466089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathPrefix); 41566089e4ec4f1702caf2154780471417872862148caryclark@google.com } 41666089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathStr); 41766089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" "); 41866089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(testFunction); 41966089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("\n}\n\n"); 4204431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if 0 42166089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("static void (*firstTest)() = "); 42266089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 42366089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(";\n\n"); 42466089e4ec4f1702caf2154780471417872862148caryclark@google.com 42566089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("static struct {\n"); 42666089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" void (*fun)();\n"); 42766089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" const char* str;\n"); 42866089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("} tests[] = {\n"); 42966089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" TEST("); 43066089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 43166089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("),\n"); 4324431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 43366089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.flush(); 43466089e4ec4f1702caf2154780471417872862148caryclark@google.com} 43566089e4ec4f1702caf2154780471417872862148caryclark@google.com 436086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(simplifyDebugOut); 43754359294a7c9dc54802d512a5d891a35c1663392caryclark 43866089e4ec4f1702caf2154780471417872862148caryclark@google.combool testSimplify(SkPath& path, bool useXor, SkPath& out, PathOpsThreadState& state, 43966089e4ec4f1702caf2154780471417872862148caryclark@google.com const char* pathStr) { 440818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath::FillType fillType = useXor ? SkPath::kEvenOdd_FillType : SkPath::kWinding_FillType; 441818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com path.setFillType(fillType); 44254359294a7c9dc54802d512a5d891a35c1663392caryclark state.fReporter->bumpTestCount(); 44366560ca776773858abfffd59974eac32c942acc3caryclark@google.com if (!Simplify(path, &out)) { 44466560ca776773858abfffd59974eac32c942acc3caryclark@google.com SkDebugf("%s did not expect failure\n", __FUNCTION__); 44566560ca776773858abfffd59974eac32c942acc3caryclark@google.com REPORTER_ASSERT(state.fReporter, 0); 44666560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 44766560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 4488d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com if (!state.fReporter->verbose()) { 449818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 450818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 45196fcdcc219d2a0d3579719b84b28bede76efba64halcanary int result = comparePaths(state.fReporter, nullptr, path, out, *state.fBitmap); 45254359294a7c9dc54802d512a5d891a35c1663392caryclark if (result) { 4534431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkAutoMutexAcquire autoM(simplifyDebugOut); 454818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char temp[8192]; 455818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com sk_bzero(temp, sizeof(temp)); 456818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMemoryWStream stream(temp, sizeof(temp)); 45796fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* pathPrefix = nullptr; 45896fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* nameSuffix = nullptr; 459818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (fillType == SkPath::kEvenOdd_FillType) { 460818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com pathPrefix = " path.setFillType(SkPath::kEvenOdd_FillType);\n"; 461818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com nameSuffix = "x"; 462818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 4634431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const char testFunction[] = "testSimplify(reporter, path);"; 46466089e4ec4f1702caf2154780471417872862148caryclark@google.com outputToStream(pathStr, pathPrefix, nameSuffix, testFunction, false, stream); 465297aaf97a32ac16a2bc3f4bbc231d5de859ac02dkkinnunen SkDebugf("%s", temp); 46666089e4ec4f1702caf2154780471417872862148caryclark@google.com REPORTER_ASSERT(state.fReporter, 0); 467818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 46866089e4ec4f1702caf2154780471417872862148caryclark@google.com state.fReporter->bumpTestCount(); 469818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return result == 0; 470818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 471818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 47254359294a7c9dc54802d512a5d891a35c1663392caryclarkstatic bool inner_simplify(skiatest::Reporter* reporter, const SkPath& path, const char* filename, 47355888e44171ffd48b591d19256884a969fe4da17caryclark ExpectSuccess expectSuccess, SkipAssert skipAssert, ExpectMatch expectMatch) { 47454359294a7c9dc54802d512a5d891a35c1663392caryclark#if 0 && DEBUG_SHOW_TEST_NAME 4750361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com showPathData(path); 4760361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 477818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath out; 47855888e44171ffd48b591d19256884a969fe4da17caryclark if (!SimplifyDebug(path, &out SkDEBUGPARAMS(SkipAssert::kYes == skipAssert) 47955888e44171ffd48b591d19256884a969fe4da17caryclark SkDEBUGPARAMS(testName))) { 48055888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kYes == expectSuccess) { 48155888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s did not expect %s failure\n", __FUNCTION__, filename); 48255888e44171ffd48b591d19256884a969fe4da17caryclark REPORTER_ASSERT(reporter, 0); 48355888e44171ffd48b591d19256884a969fe4da17caryclark } 48466560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 48555888e44171ffd48b591d19256884a969fe4da17caryclark } else { 48655888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kNo == expectSuccess) { 48755888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s %s unexpected success\n", __FUNCTION__, filename); 48855888e44171ffd48b591d19256884a969fe4da17caryclark REPORTER_ASSERT(reporter, 0); 48955888e44171ffd48b591d19256884a969fe4da17caryclark } 49066560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 491818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bitmap; 49254359294a7c9dc54802d512a5d891a35c1663392caryclark int errors = comparePaths(reporter, filename, path, out, bitmap); 49355888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectMatch::kNo == expectMatch) { 49454359294a7c9dc54802d512a5d891a35c1663392caryclark if (!errors) { 49554359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("%s failing test %s now succeeds\n", __FUNCTION__, filename); 49654359294a7c9dc54802d512a5d891a35c1663392caryclark REPORTER_ASSERT(reporter, 0); 49754359294a7c9dc54802d512a5d891a35c1663392caryclark return false; 49854359294a7c9dc54802d512a5d891a35c1663392caryclark } 499d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark } else if (ExpectMatch::kYes == expectMatch && errors) { 500818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com REPORTER_ASSERT(reporter, 0); 501818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 50266089e4ec4f1702caf2154780471417872862148caryclark@google.com reporter->bumpTestCount(); 50354359294a7c9dc54802d512a5d891a35c1663392caryclark return errors == 0; 50454359294a7c9dc54802d512a5d891a35c1663392caryclark} 50554359294a7c9dc54802d512a5d891a35c1663392caryclark 50654359294a7c9dc54802d512a5d891a35c1663392caryclarkbool testSimplify(skiatest::Reporter* reporter, const SkPath& path, const char* filename) { 50755888e44171ffd48b591d19256884a969fe4da17caryclark return inner_simplify(reporter, path, filename, ExpectSuccess::kYes, SkipAssert::kNo, 50855888e44171ffd48b591d19256884a969fe4da17caryclark ExpectMatch::kYes); 50955888e44171ffd48b591d19256884a969fe4da17caryclark} 51055888e44171ffd48b591d19256884a969fe4da17caryclark 51130b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclarkbool testSimplifyFuzz(skiatest::Reporter* reporter, const SkPath& path, const char* filename) { 51230b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclark return inner_simplify(reporter, path, filename, ExpectSuccess::kFlaky, SkipAssert::kYes, 51330b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclark ExpectMatch::kFlaky); 51454359294a7c9dc54802d512a5d891a35c1663392caryclark} 51554359294a7c9dc54802d512a5d891a35c1663392caryclark 51654359294a7c9dc54802d512a5d891a35c1663392caryclarkbool testSimplifyCheck(skiatest::Reporter* reporter, const SkPath& path, const char* filename, 51754359294a7c9dc54802d512a5d891a35c1663392caryclark bool checkFail) { 51855888e44171ffd48b591d19256884a969fe4da17caryclark return inner_simplify(reporter, path, filename, checkFail ? 51955888e44171ffd48b591d19256884a969fe4da17caryclark ExpectSuccess::kYes : ExpectSuccess::kNo, SkipAssert::kNo, ExpectMatch::kNo); 520818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 521818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 52207e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 5234431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic void showName(const SkPath& a, const SkPath& b, const SkPathOp shapeOp) { 5244431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf("\n"); 5254431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathData(a); 5264431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showOp(shapeOp); 5274431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathData(b); 5284431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 5294431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 5304431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 5318d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.comstatic bool innerPathOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 53255888e44171ffd48b591d19256884a969fe4da17caryclark const SkPathOp shapeOp, const char* testName, ExpectSuccess expectSuccess, 53355888e44171ffd48b591d19256884a969fe4da17caryclark SkipAssert skipAssert, ExpectMatch expectMatch) { 53454359294a7c9dc54802d512a5d891a35c1663392caryclark#if 0 && DEBUG_SHOW_TEST_NAME 5354431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showName(a, b, shapeOp); 536818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 537818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath out; 53855888e44171ffd48b591d19256884a969fe4da17caryclark if (!OpDebug(a, b, shapeOp, &out SkDEBUGPARAMS(SkipAssert::kYes == skipAssert) 539dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark SkDEBUGPARAMS(testName))) { 54055888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kYes == expectSuccess) { 54155888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s %s did not expect failure\n", __FUNCTION__, testName); 5423f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark REPORTER_ASSERT(reporter, 0); 5433f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark } 54466560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 54555888e44171ffd48b591d19256884a969fe4da17caryclark } else { 54655888e44171ffd48b591d19256884a969fe4da17caryclark if (ExpectSuccess::kNo == expectSuccess) { 54755888e44171ffd48b591d19256884a969fe4da17caryclark SkDebugf("%s %s unexpected success\n", __FUNCTION__, testName); 54855888e44171ffd48b591d19256884a969fe4da17caryclark REPORTER_ASSERT(reporter, 0); 54955888e44171ffd48b591d19256884a969fe4da17caryclark } 55066560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 55154359294a7c9dc54802d512a5d891a35c1663392caryclark if (!reporter->verbose()) { 5528d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com return true; 5538d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com } 554818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath pathOut, scaledPathOut; 555818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRegion rgnA, rgnB, openClip, rgnOut; 556818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com openClip.setRect(-16000, -16000, 16000, 16000); 557818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnA.setPath(a, openClip); 558818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnB.setPath(b, openClip); 559818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnOut.op(rgnA, rgnB, (SkRegion::Op) shapeOp); 560818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnOut.getBoundaryPath(&pathOut); 561818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 562818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMatrix scale; 563818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaleMatrix(a, b, scale); 564818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRegion scaledRgnA, scaledRgnB, scaledRgnOut; 565818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledA, scaledB; 566818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledA.addPath(a, scale); 567818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledA.setFillType(a.getFillType()); 568818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledB.addPath(b, scale); 569818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledB.setFillType(b.getFillType()); 570818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnA.setPath(scaledA, openClip); 571818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnB.setPath(scaledB, openClip); 572818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnOut.op(scaledRgnA, scaledRgnB, (SkRegion::Op) shapeOp); 573818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnOut.getBoundaryPath(&scaledPathOut); 574818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bitmap; 575818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledOut; 576818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledOut.addPath(out, scale); 577818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledOut.setFillType(out.getFillType()); 5784431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org int result = comparePaths(reporter, testName, pathOut, scaledPathOut, out, scaledOut, bitmap, 579d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark a, b, shapeOp, scale, expectMatch); 58066089e4ec4f1702caf2154780471417872862148caryclark@google.com reporter->bumpTestCount(); 581818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return result == 0; 582818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 583818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 5848d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.combool testPathOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 58565f553182ab7069378ef863d30094d0327f178d0caryclark const SkPathOp shapeOp, const char* testName) { 58655888e44171ffd48b591d19256884a969fe4da17caryclark return innerPathOp(reporter, a, b, shapeOp, testName, ExpectSuccess::kYes, SkipAssert::kNo, 58755888e44171ffd48b591d19256884a969fe4da17caryclark ExpectMatch::kYes); 58865f553182ab7069378ef863d30094d0327f178d0caryclark} 58965f553182ab7069378ef863d30094d0327f178d0caryclark 59065f553182ab7069378ef863d30094d0327f178d0caryclarkbool testPathOpCheck(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 59165f553182ab7069378ef863d30094d0327f178d0caryclark const SkPathOp shapeOp, const char* testName, bool checkFail) { 59255888e44171ffd48b591d19256884a969fe4da17caryclark return innerPathOp(reporter, a, b, shapeOp, testName, checkFail ? 59355888e44171ffd48b591d19256884a969fe4da17caryclark ExpectSuccess::kYes : ExpectSuccess::kNo, SkipAssert::kNo, ExpectMatch::kNo); 5948d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com} 5958d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com 59630b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclarkbool testPathOpFuzz(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 597d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark const SkPathOp shapeOp, const char* testName) { 598d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark return innerPathOp(reporter, a, b, shapeOp, testName, ExpectSuccess::kFlaky, SkipAssert::kYes, 599d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark ExpectMatch::kFlaky); 600d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark} 601d5b9173fe869584f01f0e8c468ad0daf03fbc958caryclark 60255888e44171ffd48b591d19256884a969fe4da17caryclarkbool testPathOpFail(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 6034431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPathOp shapeOp, const char* testName) { 6044431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if DEBUG_SHOW_TEST_NAME 6054431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showName(a, b, shapeOp); 6064431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 6071049f1246e7be4ccb68001361efceb8933e6f81ccaryclark SkPath orig; 6081049f1246e7be4ccb68001361efceb8933e6f81ccaryclark orig.lineTo(54, 43); 6091049f1246e7be4ccb68001361efceb8933e6f81ccaryclark SkPath out = orig; 6104431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (Op(a, b, shapeOp, &out) ) { 6114431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf("%s test is expected to fail\n", __FUNCTION__); 6124431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org REPORTER_ASSERT(reporter, 0); 6134431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org return false; 6144431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 6151049f1246e7be4ccb68001361efceb8933e6f81ccaryclark SkASSERT(out == orig); 6164431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org return true; 6174431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 6184431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 619086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(gMutex); 6207eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com 621406654be7a930b484159f5bca107d3b11d8a9edemtkleinvoid initializeTests(skiatest::Reporter* reporter, const char* test) { 6227eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (reporter->verbose()) { 6237eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkAutoMutexAcquire lock(gMutex); 6247eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com testName = test; 6257eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com size_t testNameSize = strlen(test); 6267eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkFILEStream inFile("../../experimental/Intersection/op.htm"); 6277eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (inFile.isValid()) { 6287eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkTDArray<char> inData; 6294431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org inData.setCount((int) inFile.getLength()); 6307eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com size_t inLen = inData.count(); 6317eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com inFile.read(inData.begin(), inLen); 63296fcdcc219d2a0d3579719b84b28bede76efba64halcanary inFile.setPath(nullptr); 6337eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com char* insert = strstr(inData.begin(), marker); 6347eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (insert) { 6357eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com insert += sizeof(marker) - 1; 6367eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com const char* numLoc = insert + 4 /* indent spaces */ + testNameSize - 1; 6377eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com testNumber = atoi(numLoc) + 1; 6387eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com } 639818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 640818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 641818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 642818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 64366089e4ec4f1702caf2154780471417872862148caryclark@google.comvoid outputProgress(char* ramStr, const char* pathStr, SkPath::FillType pathFillType) { 64466089e4ec4f1702caf2154780471417872862148caryclark@google.com const char testFunction[] = "testSimplify(path);"; 64596fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* pathPrefix = nullptr; 64696fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* nameSuffix = nullptr; 647818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (pathFillType == SkPath::kEvenOdd_FillType) { 648818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com pathPrefix = " path.setFillType(SkPath::kEvenOdd_FillType);\n"; 649818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com nameSuffix = "x"; 650818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 65166089e4ec4f1702caf2154780471417872862148caryclark@google.com SkMemoryWStream rRamStream(ramStr, PATH_STR_SIZE); 65266089e4ec4f1702caf2154780471417872862148caryclark@google.com outputToStream(pathStr, pathPrefix, nameSuffix, testFunction, false, rRamStream); 653818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 654818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 65566089e4ec4f1702caf2154780471417872862148caryclark@google.comvoid outputProgress(char* ramStr, 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]; 65966089e4ec4f1702caf2154780471417872862148caryclark@google.com SkMemoryWStream rRamStream(ramStr, PATH_STR_SIZE); 66096fcdcc219d2a0d3579719b84b28bede76efba64halcanary outputToStream(pathStr, nullptr, nameSuffix, testFunction, true, rRamStream); 661818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 662818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 663818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comvoid RunTestSet(skiatest::Reporter* reporter, TestDesc tests[], size_t count, 6644431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org void (*firstTest)(skiatest::Reporter* , const char* filename), 66554359294a7c9dc54802d512a5d891a35c1663392caryclark void (*skipTest)(skiatest::Reporter* , const char* filename), 6664431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org void (*stopTest)(skiatest::Reporter* , const char* filename), bool reverse) { 667818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com size_t index; 668818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (firstTest) { 669818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index = count - 1; 670818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com while (index > 0 && tests[index].fun != firstTest) { 671818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com --index; 672818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 673a5e55925ea03e76885804bda77408a1d6f04c335caryclark@google.com#if DEBUG_SHOW_TEST_NAME 67454359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("\n<div id=\"%s\">\n", tests[index].str); 675818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 6764431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (*tests[index].fun)(reporter, tests[index].str); 6774431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (tests[index].fun == stopTest) { 6784431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org return; 6794431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 680818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 681818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index = reverse ? count - 1 : 0; 682818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com size_t last = reverse ? 0 : count - 1; 68354359294a7c9dc54802d512a5d891a35c1663392caryclark bool foundSkip = !skipTest; 684818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com do { 68554359294a7c9dc54802d512a5d891a35c1663392caryclark if (tests[index].fun == skipTest) { 68654359294a7c9dc54802d512a5d891a35c1663392caryclark foundSkip = true; 68754359294a7c9dc54802d512a5d891a35c1663392caryclark } 68854359294a7c9dc54802d512a5d891a35c1663392caryclark if (foundSkip && tests[index].fun != firstTest) { 689a5e55925ea03e76885804bda77408a1d6f04c335caryclark@google.com #if DEBUG_SHOW_TEST_NAME 69054359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("\n<div id=\"%s\">\n", tests[index].str); 691818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com #endif 69230b9fdd6a1d607bde20c793af65b5e2e8a1737cacaryclark (*tests[index].fun)(reporter, tests[index].str); 693818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 69403b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == stopTest || index == last) { 6954431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org break; 696818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 69703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark index += reverse ? -1 : 1; 69803b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } while (true); 69903b03cad01628146bbb8d4f33c073bd0c77ee558caryclark#if DEBUG_SHOW_TEST_NAME 70003b03cad01628146bbb8d4f33c073bd0c77ee558caryclark SkDebugf( 70103b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 70203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "</div>\n" 70303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 70403b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "<script type=\"text/javascript\">\n" 70503b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 70603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "var testDivs = [\n" 70703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark ); 70803b03cad01628146bbb8d4f33c073bd0c77ee558caryclark index = reverse ? count - 1 : 0; 70903b03cad01628146bbb8d4f33c073bd0c77ee558caryclark last = reverse ? 0 : count - 1; 71003b03cad01628146bbb8d4f33c073bd0c77ee558caryclark foundSkip = !skipTest; 71103b03cad01628146bbb8d4f33c073bd0c77ee558caryclark do { 71203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == skipTest) { 71303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark foundSkip = true; 71403b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } 71503b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (foundSkip && tests[index].fun != firstTest) { 71603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark SkDebugf(" %s,\n", tests[index].str); 71703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } 71803b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == stopTest || index == last) { 719818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 720818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 721818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index += reverse ? -1 : 1; 722818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } while (true); 72303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark#endif 724818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 725