PathOpsExtendedTest.cpp revision 3f0753d3eccece8ac7f02f6af36d66a96c3dfb26
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" 16a2bbc6e19d5332e81784e582c290cc060f40c4c7caryclark@google.com#include "SkRTConf.h" 17818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include "SkStream.h" 18818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 1960e0fee6d4acff638ccc9670c4055aced529a7a0bungeman#include <stdlib.h> 2060e0fee6d4acff638ccc9670c4055aced529a7a0bungeman 21818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#ifdef SK_BUILD_FOR_MAC 22818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#include <sys/sysctl.h> 23818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 24818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 257eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com__SK_FORCE_IMAGE_DECODER_LINKING; 267eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com 2765b427cff9cd34a06ff060d65d00cc3615d8fd94caryclarkDEFINE_bool2(runFail, f, false, "run tests known to fail."); 2854359294a7c9dc54802d512a5d891a35c1663392caryclarkDEFINE_bool2(runBinary, f, false, "run tests known to fail binary sect."); 2965b427cff9cd34a06ff060d65d00cc3615d8fd94caryclark 30818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char marker[] = 31818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "</div>\n" 32818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "\n" 33818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "<script type=\"text/javascript\">\n" 34818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "\n" 35818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "var testDivs = [\n"; 36818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 37818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char* opStrs[] = { 3854359294a7c9dc54802d512a5d891a35c1663392caryclark "kDifference_SkPathOp", 3954359294a7c9dc54802d512a5d891a35c1663392caryclark "kIntersect_SkPathOp", 4054359294a7c9dc54802d512a5d891a35c1663392caryclark "kUnion_SkPathOp", 41818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "kXor_PathOp", 4254359294a7c9dc54802d512a5d891a35c1663392caryclark "kReverseDifference_SkPathOp", 43818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com}; 44818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 45818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic const char* opSuffixes[] = { 46818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "d", 47818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "i", 48818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com "u", 4966089e4ec4f1702caf2154780471417872862148caryclark@google.com "o", 50818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com}; 51818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 52cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com#if DEBUG_SHOW_TEST_NAME 53cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.comstatic void showPathData(const SkPath& path) { 5407e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com SkPath::RawIter iter(path); 55818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint8_t verb; 56818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPoint pts[4]; 574431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkPoint firstPt = {0, 0}, lastPt = {0, 0}; 58fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com bool firstPtSet = false; 59fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com bool lastPtSet = true; 60818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com while ((verb = iter.next(pts)) != SkPath::kDone_Verb) { 61818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com switch (verb) { 62818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kMove_Verb: 63dac1d17027dcaa5596885a9f333979418b35001ccaryclark if (firstPtSet && lastPtSet && firstPt != lastPt) { 64dac1d17027dcaa5596885a9f333979418b35001ccaryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 65dac1d17027dcaa5596885a9f333979418b35001ccaryclark firstPt.fX, firstPt.fY); 66dac1d17027dcaa5596885a9f333979418b35001ccaryclark lastPtSet = false; 67dac1d17027dcaa5596885a9f333979418b35001ccaryclark } 68fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPt = pts[0]; 69fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPtSet = true; 70818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com continue; 71818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kLine_Verb: 7266089e4ec4f1702caf2154780471417872862148caryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", pts[0].fX, pts[0].fY, 7366089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[1].fX, pts[1].fY); 74fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[1]; 75fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 76818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 77818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kQuad_Verb: 78818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", 7966089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY); 80fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[2]; 81fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 82818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 8354359294a7c9dc54802d512a5d891a35c1663392caryclark case SkPath::kConic_Verb: 8454359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}}, //weight=%1.9g\n", 8554359294a7c9dc54802d512a5d891a35c1663392caryclark pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY, 8654359294a7c9dc54802d512a5d891a35c1663392caryclark iter.conicWeight()); 8754359294a7c9dc54802d512a5d891a35c1663392caryclark lastPt = pts[2]; 8854359294a7c9dc54802d512a5d891a35c1663392caryclark lastPtSet = true; 8954359294a7c9dc54802d512a5d891a35c1663392caryclark break; 90818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kCubic_Verb: 91818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", 9266089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[0].fX, pts[0].fY, pts[1].fX, pts[1].fY, pts[2].fX, pts[2].fY, 9366089e4ec4f1702caf2154780471417872862148caryclark@google.com pts[3].fX, pts[3].fY); 94fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPt = pts[3]; 95fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com lastPtSet = true; 96818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 97818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com case SkPath::kClose_Verb: 98fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com if (firstPtSet && lastPtSet && firstPt != lastPt) { 99fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 100fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPt.fX, firstPt.fY); 101fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com } 102fa2aeee27af27f2934ee52a9732148f66481fb03caryclark@google.com firstPtSet = lastPtSet = false; 103818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 104818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com default: 105818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDEBUGFAIL("bad verb"); 106818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return; 107818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 108818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 109dac1d17027dcaa5596885a9f333979418b35001ccaryclark if (firstPtSet && lastPtSet && firstPt != lastPt) { 110dac1d17027dcaa5596885a9f333979418b35001ccaryclark SkDebugf("{{%1.9g,%1.9g}, {%1.9g,%1.9g}},\n", lastPt.fX, lastPt.fY, 111dac1d17027dcaa5596885a9f333979418b35001ccaryclark firstPt.fX, firstPt.fY); 112dac1d17027dcaa5596885a9f333979418b35001ccaryclark } 113818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 114cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com#endif 115818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 116818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comvoid showOp(const SkPathOp op) { 117818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com switch (op) { 11854359294a7c9dc54802d512a5d891a35c1663392caryclark case kDifference_SkPathOp: 119818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op difference\n"); 120818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 12154359294a7c9dc54802d512a5d891a35c1663392caryclark case kIntersect_SkPathOp: 122818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op intersect\n"); 123818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 12454359294a7c9dc54802d512a5d891a35c1663392caryclark case kUnion_SkPathOp: 125818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op union\n"); 126818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 12754359294a7c9dc54802d512a5d891a35c1663392caryclark case kXOR_SkPathOp: 128818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("op xor\n"); 129818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 13054359294a7c9dc54802d512a5d891a35c1663392caryclark case kReverseDifference_SkPathOp: 1316dc7df69ae6b24c90d231e0d6a4516bf4f1aee2ecaryclark@google.com SkDebugf("op reverse difference\n"); 1326dc7df69ae6b24c90d231e0d6a4516bf4f1aee2ecaryclark@google.com break; 133818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com default: 134818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkASSERT(0); 135818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 136818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 137818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 13807e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 1390361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.comstatic char hexorator(int x) { 1400361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com if (x < 10) { 1410361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com return x + '0'; 1420361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com } 1430361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com x -= 10; 1440361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkASSERT(x < 26); 1450361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com return x + 'A'; 1460361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com} 1470361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 1480361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com 1490361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.comvoid ShowTestName(PathOpsThreadState* state, int a, int b, int c, int d) { 1500361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 1510361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[0] = hexorator(state->fA); 1520361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[1] = hexorator(state->fB); 1530361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[2] = hexorator(state->fC); 1540361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[3] = hexorator(state->fD); 1550361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[4] = hexorator(a); 1560361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[5] = hexorator(b); 1570361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[6] = hexorator(c); 1580361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[7] = hexorator(d); 1590361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com state->fSerialNo[8] = '\0'; 1600361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkDebugf("%s\n", state->fSerialNo); 1610361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com if (strcmp(state->fSerialNo, state->fKey) == 0) { 1620361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com SkDebugf("%s\n", state->fPathStr); 1630361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com } 1640361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 1650361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com} 1660361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com 167818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comconst int bitWidth = 64; 168818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comconst int bitHeight = 64; 169818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 170818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic void scaleMatrix(const SkPath& one, const SkPath& two, SkMatrix& scale) { 171818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRect larger = one.getBounds(); 172818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com larger.join(two.getBounds()); 173818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar largerWidth = larger.width(); 174818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (largerWidth < 4) { 175818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com largerWidth = 4; 176818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 177818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar largerHeight = larger.height(); 178818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (largerHeight < 4) { 179818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com largerHeight = 4; 180818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 181818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar hScale = (bitWidth - 2) / largerWidth; 182818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkScalar vScale = (bitHeight - 2) / largerHeight; 183818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scale.reset(); 184818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scale.preScale(hScale, vScale); 18526ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fLeft *= hScale; 18626ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fRight *= hScale; 18726ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fTop *= vScale; 18826ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark larger.fBottom *= vScale; 18926ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark SkScalar dx = -16000 > larger.fLeft ? -16000 - larger.fLeft 19026ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark : 16000 < larger.fRight ? 16000 - larger.fRight : 0; 19126ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark SkScalar dy = -16000 > larger.fTop ? -16000 - larger.fTop 19226ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark : 16000 < larger.fBottom ? 16000 - larger.fBottom : 0; 19326ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark scale.postTranslate(dx, dy); 194818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 195818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 196818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic int pathsDrawTheSame(SkBitmap& bits, const SkPath& scaledOne, const SkPath& scaledTwo, 197818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int& error2x2) { 198818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bits.width() == 0) { 199deee496cd30070e52556dcb538c2e5eb39b66b81mike@reedtribe.org bits.allocN32Pixels(bitWidth * 2, bitHeight); 200818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 201818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkCanvas canvas(bits); 202818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawColor(SK_ColorWHITE); 203818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPaint paint; 204818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 205818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds1 = scaledOne.getBounds(); 206818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1, -bounds1.fTop + 1); 207818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(scaledOne, paint); 208818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 209818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 210818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1 + bitWidth, -bounds1.fTop + 1); 211818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(scaledTwo, paint); 212818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 213818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2 = 0; 214818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors = 0; 215818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int y = 0; y < bitHeight - 1; ++y) { 216818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr1 = bits.getAddr32(0, y); 217818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr2 = bits.getAddr32(0, y + 1); 218818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr3 = bits.getAddr32(bitWidth, y); 219818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr4 = bits.getAddr32(bitWidth, y + 1); 220818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int x = 0; x < bitWidth - 1; ++x) { 221818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com // count 2x2 blocks 222818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com bool err = addr1[x] != addr3[x]; 223818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (err) { 224818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com errors2 += addr1[x + 1] != addr3[x + 1] 225818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com && addr2[x] != addr4[x] && addr2[x + 1] != addr4[x + 1]; 226818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com errors++; 227818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 228818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 229818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 230818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com error2x2 = errors2; 231818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return errors; 232818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 233818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 234818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comstatic int pathsDrawTheSame(const SkPath& one, const SkPath& two, SkBitmap& bits, SkPath& scaledOne, 235818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath& scaledTwo, int& error2x2) { 236818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMatrix scale; 237818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaleMatrix(one, two, scale); 238818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com one.transform(scale, &scaledOne); 239818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com two.transform(scale, &scaledTwo); 240818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return pathsDrawTheSame(bits, scaledOne, scaledTwo, error2x2); 241818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 242818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 243818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.combool drawAsciiPaths(const SkPath& one, const SkPath& two, bool drawPaths) { 244818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (!drawPaths) { 245818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 246818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 247818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds1 = one.getBounds(); 248818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const SkRect& bounds2 = two.getBounds(); 249818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRect larger = bounds1; 250818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com larger.join(bounds2); 251818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bits; 252818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char out[256]; 253e1ca705cac4b946993f6cbf798e2a0ba27e739f3reed@google.com int bitWidth = SkScalarCeilToInt(larger.width()) + 2; 254818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bitWidth * 2 + 1 >= (int) sizeof(out)) { 255818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return false; 256818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 257e1ca705cac4b946993f6cbf798e2a0ba27e739f3reed@google.com int bitHeight = SkScalarCeilToInt(larger.height()) + 2; 258818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (bitHeight >= (int) sizeof(out)) { 259818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return false; 260818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 261deee496cd30070e52556dcb538c2e5eb39b66b81mike@reedtribe.org bits.allocN32Pixels(bitWidth * 2, bitHeight); 262818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkCanvas canvas(bits); 263818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawColor(SK_ColorWHITE); 264818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPaint paint; 265818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 266818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1, -bounds1.fTop + 1); 267818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(one, paint); 268818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 269818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.save(); 270818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.translate(-bounds1.fLeft + 1 + bitWidth, -bounds1.fTop + 1); 271818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.drawPath(two, paint); 272818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com canvas.restore(); 273818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (int y = 0; y < bitHeight; ++y) { 274818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com uint32_t* addr1 = bits.getAddr32(0, y); 275818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int x; 276818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char* outPtr = out; 277818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (x = 0; x < bitWidth; ++x) { 278818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = addr1[x] == (uint32_t) -1 ? '_' : 'x'; 279818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 280818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = '|'; 281818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com for (x = bitWidth; x < bitWidth * 2; ++x) { 282818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = addr1[x] == (uint32_t) -1 ? '_' : 'x'; 283818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 284818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com *outPtr++ = '\0'; 285818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkDebugf("%s\n", out); 286818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 287818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 288818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 289818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 29054359294a7c9dc54802d512a5d891a35c1663392caryclarkint comparePaths(skiatest::Reporter* reporter, const char* filename, const SkPath& one, 2914431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& two, SkBitmap& bitmap) { 292818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2x2; 293818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledOne, scaledTwo; 2944431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (void) pathsDrawTheSame(one, two, bitmap, scaledOne, scaledTwo, errors2x2); 295818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (errors2x2 == 0) { 296818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return 0; 297818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 298818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const int MAX_ERRORS = 9; 299818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return errors2x2 > MAX_ERRORS ? errors2x2 : 0; 300818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 301818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 3024431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic SkTDArray<SkPathOp> gTestOp; 3034431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 3044431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic void showPathOpPath(const char* testName, const SkPath& one, const SkPath& two, 3054431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& a, const SkPath& b, const SkPath& scaledOne, const SkPath& scaledTwo, 3064431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPathOp shapeOp, const SkMatrix& scale) { 307ad65a3e5fb1f94699f183551b828efbcc6a133cecaryclark@google.com SkASSERT((unsigned) shapeOp < SK_ARRAY_COUNT(opStrs)); 3084431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (!testName) { 3091049f1246e7be4ccb68001361efceb8933e6f81ccaryclark testName = "xOp"; 3104431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 3112bec26a71698105729c6a7cb0163f499b4361840caryclark SkDebugf("static void %s_%s(skiatest::Reporter* reporter, const char* filename) {\n", 3122bec26a71698105729c6a7cb0163f499b4361840caryclark testName, opSuffixes[shapeOp]); 3134431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org *gTestOp.append() = shapeOp; 314cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com SkDebugf(" SkPath path, pathB;\n"); 31519eb3b2f0aa6dce5c0335230a8930e90733e5d5dcaryclark SkPathOpsDebug::ShowOnePath(a, "path", false); 31619eb3b2f0aa6dce5c0335230a8930e90733e5d5dcaryclark SkPathOpsDebug::ShowOnePath(b, "pathB", false); 3174431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf(" testPathOp(reporter, path, pathB, %s, filename);\n", opStrs[shapeOp]); 318cffbcc3b9665f2c928544b6fc6b8a0e22a4210fbcaryclark@google.com SkDebugf("}\n"); 31926ad22ab61539e3d3b6bc5e0da8dcebbd52a53decaryclark drawAsciiPaths(scaledOne, scaledTwo, true); 3204431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 3214431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 322086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(compareDebugOut3); 32338a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark 3244431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic int comparePaths(skiatest::Reporter* reporter, const char* testName, const SkPath& one, 3254431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPath& scaledOne, const SkPath& two, const SkPath& scaledTwo, SkBitmap& bitmap, 32665f553182ab7069378ef863d30094d0327f178d0caryclark const SkPath& a, const SkPath& b, const SkPathOp shapeOp, const SkMatrix& scale, 32738a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark bool expectSuccess) { 328818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com int errors2x2; 32965f553182ab7069378ef863d30094d0327f178d0caryclark const int MAX_ERRORS = 8; 3304431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (void) pathsDrawTheSame(bitmap, scaledOne, scaledTwo, errors2x2); 33165f553182ab7069378ef863d30094d0327f178d0caryclark if (!expectSuccess) { 33238a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark if (errors2x2 < MAX_ERRORS) { 33365f553182ab7069378ef863d30094d0327f178d0caryclark REPORTER_ASSERT(reporter, 0); 33465f553182ab7069378ef863d30094d0327f178d0caryclark } 33565f553182ab7069378ef863d30094d0327f178d0caryclark return 0; 33665f553182ab7069378ef863d30094d0327f178d0caryclark } 337818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (errors2x2 == 0) { 338818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return 0; 339818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 34038a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark if (errors2x2 >= MAX_ERRORS) { 3414431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkAutoMutexAcquire autoM(compareDebugOut3); 3424431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathOpPath(testName, one, two, a, b, scaledOne, scaledTwo, shapeOp, scale); 343aec251012542e971100e218bf463adbfb5d21d20caryclark SkDebugf("\n/*"); 344818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com REPORTER_ASSERT(reporter, 0); 345aec251012542e971100e218bf463adbfb5d21d20caryclark SkDebugf(" */\n"); 346818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 34738a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark return errors2x2 >= MAX_ERRORS ? errors2x2 : 0; 348818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 349818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 350409774e8accb8772765b376d3126209b198bc87ccommit-bot@chromium.org// Default values for when reporter->verbose() is false. 3514431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic int testNumber = 55; 352409774e8accb8772765b376d3126209b198bc87ccommit-bot@chromium.orgstatic const char* testName = "pathOpTest"; 35366089e4ec4f1702caf2154780471417872862148caryclark@google.com 35466089e4ec4f1702caf2154780471417872862148caryclark@google.comstatic void writeTestName(const char* nameSuffix, SkMemoryWStream& outFile) { 35566089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(testName); 35666089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeDecAsText(testNumber); 3574431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org ++testNumber; 35866089e4ec4f1702caf2154780471417872862148caryclark@google.com if (nameSuffix) { 35966089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(nameSuffix); 36066089e4ec4f1702caf2154780471417872862148caryclark@google.com } 36166089e4ec4f1702caf2154780471417872862148caryclark@google.com} 36266089e4ec4f1702caf2154780471417872862148caryclark@google.com 36366089e4ec4f1702caf2154780471417872862148caryclark@google.comstatic void outputToStream(const char* pathStr, const char* pathPrefix, const char* nameSuffix, 36466089e4ec4f1702caf2154780471417872862148caryclark@google.com const char* testFunction, bool twoPaths, SkMemoryWStream& outFile) { 3654431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if 0 36654359294a7c9dc54802d512a5d891a35c1663392caryclark outFile.writeText("\n<div id=\""); 36766089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 36866089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("\">\n"); 36966089e4ec4f1702caf2154780471417872862148caryclark@google.com if (pathPrefix) { 37066089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathPrefix); 37166089e4ec4f1702caf2154780471417872862148caryclark@google.com } 37266089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathStr); 37366089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("</div>\n\n"); 37466089e4ec4f1702caf2154780471417872862148caryclark@google.com 37566089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(marker); 37666089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" "); 37766089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 37866089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(",\n\n\n"); 3794431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 38066089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("static void "); 38166089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 3824431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org outFile.writeText("(skiatest::Reporter* reporter) {\n SkPath path"); 38366089e4ec4f1702caf2154780471417872862148caryclark@google.com if (twoPaths) { 38466089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(", pathB"); 38566089e4ec4f1702caf2154780471417872862148caryclark@google.com } 38666089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(";\n"); 38766089e4ec4f1702caf2154780471417872862148caryclark@google.com if (pathPrefix) { 38866089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathPrefix); 38966089e4ec4f1702caf2154780471417872862148caryclark@google.com } 39066089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(pathStr); 39166089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" "); 39266089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(testFunction); 39366089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("\n}\n\n"); 3944431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if 0 39566089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("static void (*firstTest)() = "); 39666089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 39766089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(";\n\n"); 39866089e4ec4f1702caf2154780471417872862148caryclark@google.com 39966089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("static struct {\n"); 40066089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" void (*fun)();\n"); 40166089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" const char* str;\n"); 40266089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("} tests[] = {\n"); 40366089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText(" TEST("); 40466089e4ec4f1702caf2154780471417872862148caryclark@google.com writeTestName(nameSuffix, outFile); 40566089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.writeText("),\n"); 4064431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 40766089e4ec4f1702caf2154780471417872862148caryclark@google.com outFile.flush(); 40866089e4ec4f1702caf2154780471417872862148caryclark@google.com} 40966089e4ec4f1702caf2154780471417872862148caryclark@google.com 410086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(simplifyDebugOut); 41154359294a7c9dc54802d512a5d891a35c1663392caryclark 41266089e4ec4f1702caf2154780471417872862148caryclark@google.combool testSimplify(SkPath& path, bool useXor, SkPath& out, PathOpsThreadState& state, 41366089e4ec4f1702caf2154780471417872862148caryclark@google.com const char* pathStr) { 414818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath::FillType fillType = useXor ? SkPath::kEvenOdd_FillType : SkPath::kWinding_FillType; 415818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com path.setFillType(fillType); 41654359294a7c9dc54802d512a5d891a35c1663392caryclark state.fReporter->bumpTestCount(); 41766560ca776773858abfffd59974eac32c942acc3caryclark@google.com if (!Simplify(path, &out)) { 41866560ca776773858abfffd59974eac32c942acc3caryclark@google.com SkDebugf("%s did not expect failure\n", __FUNCTION__); 41966560ca776773858abfffd59974eac32c942acc3caryclark@google.com REPORTER_ASSERT(state.fReporter, 0); 42066560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 42166560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 4228d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com if (!state.fReporter->verbose()) { 423818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return true; 424818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 42596fcdcc219d2a0d3579719b84b28bede76efba64halcanary int result = comparePaths(state.fReporter, nullptr, path, out, *state.fBitmap); 42654359294a7c9dc54802d512a5d891a35c1663392caryclark if (result) { 4274431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkAutoMutexAcquire autoM(simplifyDebugOut); 428818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com char temp[8192]; 429818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com sk_bzero(temp, sizeof(temp)); 430818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMemoryWStream stream(temp, sizeof(temp)); 43196fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* pathPrefix = nullptr; 43296fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* nameSuffix = nullptr; 433818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (fillType == SkPath::kEvenOdd_FillType) { 434818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com pathPrefix = " path.setFillType(SkPath::kEvenOdd_FillType);\n"; 435818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com nameSuffix = "x"; 436818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 4374431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const char testFunction[] = "testSimplify(reporter, path);"; 43866089e4ec4f1702caf2154780471417872862148caryclark@google.com outputToStream(pathStr, pathPrefix, nameSuffix, testFunction, false, stream); 439297aaf97a32ac16a2bc3f4bbc231d5de859ac02dkkinnunen SkDebugf("%s", temp); 44066089e4ec4f1702caf2154780471417872862148caryclark@google.com REPORTER_ASSERT(state.fReporter, 0); 441818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 44266089e4ec4f1702caf2154780471417872862148caryclark@google.com state.fReporter->bumpTestCount(); 443818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return result == 0; 444818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 445818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 44654359294a7c9dc54802d512a5d891a35c1663392caryclarkstatic bool inner_simplify(skiatest::Reporter* reporter, const SkPath& path, const char* filename, 44754359294a7c9dc54802d512a5d891a35c1663392caryclark bool checkFail) { 44854359294a7c9dc54802d512a5d891a35c1663392caryclark#if 0 && DEBUG_SHOW_TEST_NAME 4490361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com showPathData(path); 4500361032c0b53401030a720bc8b4930c3ec59f19ecaryclark@google.com#endif 451818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath out; 45266560ca776773858abfffd59974eac32c942acc3caryclark@google.com if (!Simplify(path, &out)) { 45354359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("%s did not expect %s failure\n", __FUNCTION__, filename); 45466560ca776773858abfffd59974eac32c942acc3caryclark@google.com REPORTER_ASSERT(reporter, 0); 45566560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 45666560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 457818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bitmap; 45854359294a7c9dc54802d512a5d891a35c1663392caryclark int errors = comparePaths(reporter, filename, path, out, bitmap); 45954359294a7c9dc54802d512a5d891a35c1663392caryclark if (!checkFail) { 46054359294a7c9dc54802d512a5d891a35c1663392caryclark if (!errors) { 46154359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("%s failing test %s now succeeds\n", __FUNCTION__, filename); 46254359294a7c9dc54802d512a5d891a35c1663392caryclark REPORTER_ASSERT(reporter, 0); 46354359294a7c9dc54802d512a5d891a35c1663392caryclark return false; 46454359294a7c9dc54802d512a5d891a35c1663392caryclark } 46554359294a7c9dc54802d512a5d891a35c1663392caryclark } else if (errors) { 466818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com REPORTER_ASSERT(reporter, 0); 467818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 46866089e4ec4f1702caf2154780471417872862148caryclark@google.com reporter->bumpTestCount(); 46954359294a7c9dc54802d512a5d891a35c1663392caryclark return errors == 0; 47054359294a7c9dc54802d512a5d891a35c1663392caryclark} 47154359294a7c9dc54802d512a5d891a35c1663392caryclark 47254359294a7c9dc54802d512a5d891a35c1663392caryclarkbool testSimplify(skiatest::Reporter* reporter, const SkPath& path, const char* filename) { 47354359294a7c9dc54802d512a5d891a35c1663392caryclark return inner_simplify(reporter, path, filename, true); 47454359294a7c9dc54802d512a5d891a35c1663392caryclark} 47554359294a7c9dc54802d512a5d891a35c1663392caryclark 47654359294a7c9dc54802d512a5d891a35c1663392caryclarkbool testSimplifyCheck(skiatest::Reporter* reporter, const SkPath& path, const char* filename, 47754359294a7c9dc54802d512a5d891a35c1663392caryclark bool checkFail) { 47854359294a7c9dc54802d512a5d891a35c1663392caryclark return inner_simplify(reporter, path, filename, checkFail); 479818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 480818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 48107e97fccd2d85076cd22ef411b0773ab92a18abecaryclark@google.com#if DEBUG_SHOW_TEST_NAME 4824431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgstatic void showName(const SkPath& a, const SkPath& b, const SkPathOp shapeOp) { 4834431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf("\n"); 4844431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathData(a); 4854431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showOp(shapeOp); 4864431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showPathData(b); 4874431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 4884431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 4894431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 4903f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclarkbool OpDebug(const SkPath& one, const SkPath& two, SkPathOp op, SkPath* result 4913f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark SkDEBUGPARAMS(bool skipAssert) 492dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark SkDEBUGPARAMS(const char* testName)); 493624637cc8ec22c000409704d0b403ac1b81ad4b0caryclark 4948d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.comstatic bool innerPathOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 495dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark const SkPathOp shapeOp, const char* testName, bool expectSuccess, bool skipAssert) { 49654359294a7c9dc54802d512a5d891a35c1663392caryclark#if 0 && DEBUG_SHOW_TEST_NAME 4974431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showName(a, b, shapeOp); 498818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 499818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath out; 5003f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark if (!OpDebug(a, b, shapeOp, &out SkDEBUGPARAMS(skipAssert) 501dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark SkDEBUGPARAMS(testName))) { 5023f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark if (expectSuccess) { 5033f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark SkDebugf("%s did not expect failure\n", __FUNCTION__); 5043f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark REPORTER_ASSERT(reporter, 0); 5053f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark } 50666560ca776773858abfffd59974eac32c942acc3caryclark@google.com return false; 50766560ca776773858abfffd59974eac32c942acc3caryclark@google.com } 50854359294a7c9dc54802d512a5d891a35c1663392caryclark if (!reporter->verbose()) { 5098d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com return true; 5108d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com } 511818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath pathOut, scaledPathOut; 512818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRegion rgnA, rgnB, openClip, rgnOut; 513818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com openClip.setRect(-16000, -16000, 16000, 16000); 514818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnA.setPath(a, openClip); 515818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnB.setPath(b, openClip); 516818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnOut.op(rgnA, rgnB, (SkRegion::Op) shapeOp); 517818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com rgnOut.getBoundaryPath(&pathOut); 518818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 519818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkMatrix scale; 520818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaleMatrix(a, b, scale); 521818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkRegion scaledRgnA, scaledRgnB, scaledRgnOut; 522818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledA, scaledB; 523818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledA.addPath(a, scale); 524818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledA.setFillType(a.getFillType()); 525818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledB.addPath(b, scale); 526818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledB.setFillType(b.getFillType()); 527818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnA.setPath(scaledA, openClip); 528818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnB.setPath(scaledB, openClip); 529818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnOut.op(scaledRgnA, scaledRgnB, (SkRegion::Op) shapeOp); 530818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledRgnOut.getBoundaryPath(&scaledPathOut); 531818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkBitmap bitmap; 532818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com SkPath scaledOut; 533818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledOut.addPath(out, scale); 534818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com scaledOut.setFillType(out.getFillType()); 5354431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org int result = comparePaths(reporter, testName, pathOut, scaledPathOut, out, scaledOut, bitmap, 53638a017bf44aa1ad25291ad0cbb4ccbe8bd31ab0bcaryclark a, b, shapeOp, scale, expectSuccess); 53766089e4ec4f1702caf2154780471417872862148caryclark@google.com reporter->bumpTestCount(); 538818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com return result == 0; 539818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 540818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 5418d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.combool testPathOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 54265f553182ab7069378ef863d30094d0327f178d0caryclark const SkPathOp shapeOp, const char* testName) { 543dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark return innerPathOp(reporter, a, b, shapeOp, testName, true, false); 54465f553182ab7069378ef863d30094d0327f178d0caryclark} 54565f553182ab7069378ef863d30094d0327f178d0caryclark 54665f553182ab7069378ef863d30094d0327f178d0caryclarkbool testPathOpCheck(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 54765f553182ab7069378ef863d30094d0327f178d0caryclark const SkPathOp shapeOp, const char* testName, bool checkFail) { 548dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark return innerPathOp(reporter, a, b, shapeOp, testName, checkFail, false); 5498d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com} 5508d0a524a4847bc7e1cc63a93b78922739466c201caryclark@google.com 5511049f1246e7be4ccb68001361efceb8933e6f81ccaryclarkbool testPathOpFailCheck(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 5521049f1246e7be4ccb68001361efceb8933e6f81ccaryclark const SkPathOp shapeOp, const char* testName) { 553dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark return innerPathOp(reporter, a, b, shapeOp, testName, false, false); 554dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark} 555dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark 556dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclarkbool testPathSkipAssertOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 557dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark const SkPathOp shapeOp, const char* testName) { 558dae6b97705fde08958b1a36fa6ce685d28fc692ccaryclark return innerPathOp(reporter, a, b, shapeOp, testName, true, true); 5591049f1246e7be4ccb68001361efceb8933e6f81ccaryclark} 5601049f1246e7be4ccb68001361efceb8933e6f81ccaryclark 5613f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclarkbool testPathFailSkipAssertOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 5623f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark const SkPathOp shapeOp, const char* testName) { 5633f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark return innerPathOp(reporter, a, b, shapeOp, testName, false, true); 5643f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark} 5653f0753d3eccece8ac7f02f6af36d66a96c3dfb26caryclark 5664431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.orgbool testPathFailOp(skiatest::Reporter* reporter, const SkPath& a, const SkPath& b, 5674431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org const SkPathOp shapeOp, const char* testName) { 5684431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#if DEBUG_SHOW_TEST_NAME 5694431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org showName(a, b, shapeOp); 5704431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org#endif 5711049f1246e7be4ccb68001361efceb8933e6f81ccaryclark SkPath orig; 5721049f1246e7be4ccb68001361efceb8933e6f81ccaryclark orig.lineTo(54, 43); 5731049f1246e7be4ccb68001361efceb8933e6f81ccaryclark SkPath out = orig; 5744431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (Op(a, b, shapeOp, &out) ) { 5754431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org SkDebugf("%s test is expected to fail\n", __FUNCTION__); 5764431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org REPORTER_ASSERT(reporter, 0); 5774431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org return false; 5784431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 5791049f1246e7be4ccb68001361efceb8933e6f81ccaryclark SkASSERT(out == orig); 5804431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org return true; 5814431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org} 5824431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org 583086eea93b1f8253420c233c33cdabc0e74b08091reedSK_DECLARE_STATIC_MUTEX(gMutex); 5847eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com 585406654be7a930b484159f5bca107d3b11d8a9edemtkleinvoid initializeTests(skiatest::Reporter* reporter, const char* test) { 586a2bbc6e19d5332e81784e582c290cc060f40c4c7caryclark@google.com#if 0 // doesn't work yet 587a2bbc6e19d5332e81784e582c290cc060f40c4c7caryclark@google.com SK_CONF_SET("images.jpeg.suppressDecoderWarnings", true); 588a2bbc6e19d5332e81784e582c290cc060f40c4c7caryclark@google.com SK_CONF_SET("images.png.suppressDecoderWarnings", true); 589a2bbc6e19d5332e81784e582c290cc060f40c4c7caryclark@google.com#endif 5907eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (reporter->verbose()) { 5917eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkAutoMutexAcquire lock(gMutex); 5927eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com testName = test; 5937eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com size_t testNameSize = strlen(test); 5947eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkFILEStream inFile("../../experimental/Intersection/op.htm"); 5957eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (inFile.isValid()) { 5967eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com SkTDArray<char> inData; 5974431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org inData.setCount((int) inFile.getLength()); 5987eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com size_t inLen = inData.count(); 5997eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com inFile.read(inData.begin(), inLen); 60096fcdcc219d2a0d3579719b84b28bede76efba64halcanary inFile.setPath(nullptr); 6017eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com char* insert = strstr(inData.begin(), marker); 6027eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com if (insert) { 6037eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com insert += sizeof(marker) - 1; 6047eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com const char* numLoc = insert + 4 /* indent spaces */ + testNameSize - 1; 6057eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com testNumber = atoi(numLoc) + 1; 6067eaa53d8f7e48fd17d02b5e3bd91f90e9c1899efcaryclark@google.com } 607818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 608818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 609818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 610818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 61166089e4ec4f1702caf2154780471417872862148caryclark@google.comvoid outputProgress(char* ramStr, const char* pathStr, SkPath::FillType pathFillType) { 61266089e4ec4f1702caf2154780471417872862148caryclark@google.com const char testFunction[] = "testSimplify(path);"; 61396fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* pathPrefix = nullptr; 61496fcdcc219d2a0d3579719b84b28bede76efba64halcanary const char* nameSuffix = nullptr; 615818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (pathFillType == SkPath::kEvenOdd_FillType) { 616818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com pathPrefix = " path.setFillType(SkPath::kEvenOdd_FillType);\n"; 617818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com nameSuffix = "x"; 618818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 61966089e4ec4f1702caf2154780471417872862148caryclark@google.com SkMemoryWStream rRamStream(ramStr, PATH_STR_SIZE); 62066089e4ec4f1702caf2154780471417872862148caryclark@google.com outputToStream(pathStr, pathPrefix, nameSuffix, testFunction, false, rRamStream); 621818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 622818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 62366089e4ec4f1702caf2154780471417872862148caryclark@google.comvoid outputProgress(char* ramStr, const char* pathStr, SkPathOp op) { 62466089e4ec4f1702caf2154780471417872862148caryclark@google.com const char testFunction[] = "testOp(path);"; 625ad65a3e5fb1f94699f183551b828efbcc6a133cecaryclark@google.com SkASSERT((size_t) op < SK_ARRAY_COUNT(opSuffixes)); 626818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com const char* nameSuffix = opSuffixes[op]; 62766089e4ec4f1702caf2154780471417872862148caryclark@google.com SkMemoryWStream rRamStream(ramStr, PATH_STR_SIZE); 62896fcdcc219d2a0d3579719b84b28bede76efba64halcanary outputToStream(pathStr, nullptr, nameSuffix, testFunction, true, rRamStream); 629818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 630818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com 631818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.comvoid RunTestSet(skiatest::Reporter* reporter, TestDesc tests[], size_t count, 6324431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org void (*firstTest)(skiatest::Reporter* , const char* filename), 63354359294a7c9dc54802d512a5d891a35c1663392caryclark void (*skipTest)(skiatest::Reporter* , const char* filename), 6344431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org void (*stopTest)(skiatest::Reporter* , const char* filename), bool reverse) { 635818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com size_t index; 636818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com if (firstTest) { 637818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index = count - 1; 638818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com while (index > 0 && tests[index].fun != firstTest) { 639818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com --index; 640818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 641a5e55925ea03e76885804bda77408a1d6f04c335caryclark@google.com#if DEBUG_SHOW_TEST_NAME 64254359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("\n<div id=\"%s\">\n", tests[index].str); 643818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com#endif 6444431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (*tests[index].fun)(reporter, tests[index].str); 6454431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org if (tests[index].fun == stopTest) { 6464431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org return; 6474431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org } 648818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 649818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index = reverse ? count - 1 : 0; 650818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com size_t last = reverse ? 0 : count - 1; 65154359294a7c9dc54802d512a5d891a35c1663392caryclark bool foundSkip = !skipTest; 652818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com do { 65354359294a7c9dc54802d512a5d891a35c1663392caryclark if (tests[index].fun == skipTest) { 65454359294a7c9dc54802d512a5d891a35c1663392caryclark foundSkip = true; 65554359294a7c9dc54802d512a5d891a35c1663392caryclark } 65654359294a7c9dc54802d512a5d891a35c1663392caryclark if (foundSkip && tests[index].fun != firstTest) { 657a5e55925ea03e76885804bda77408a1d6f04c335caryclark@google.com #if DEBUG_SHOW_TEST_NAME 65854359294a7c9dc54802d512a5d891a35c1663392caryclark SkDebugf("\n<div id=\"%s\">\n", tests[index].str); 659818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com #endif 6604431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org (*tests[index].fun)(reporter, tests[index].str); 661818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 66203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == stopTest || index == last) { 6634431e7757cfcb8cfa99535eed0e9f156dabf95c2commit-bot@chromium.org break; 664818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 66503b03cad01628146bbb8d4f33c073bd0c77ee558caryclark index += reverse ? -1 : 1; 66603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } while (true); 66703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark#if DEBUG_SHOW_TEST_NAME 66803b03cad01628146bbb8d4f33c073bd0c77ee558caryclark SkDebugf( 66903b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 67003b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "</div>\n" 67103b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 67203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "<script type=\"text/javascript\">\n" 67303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "\n" 67403b03cad01628146bbb8d4f33c073bd0c77ee558caryclark "var testDivs = [\n" 67503b03cad01628146bbb8d4f33c073bd0c77ee558caryclark ); 67603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark index = reverse ? count - 1 : 0; 67703b03cad01628146bbb8d4f33c073bd0c77ee558caryclark last = reverse ? 0 : count - 1; 67803b03cad01628146bbb8d4f33c073bd0c77ee558caryclark foundSkip = !skipTest; 67903b03cad01628146bbb8d4f33c073bd0c77ee558caryclark do { 68003b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == skipTest) { 68103b03cad01628146bbb8d4f33c073bd0c77ee558caryclark foundSkip = true; 68203b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } 68303b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (foundSkip && tests[index].fun != firstTest) { 68403b03cad01628146bbb8d4f33c073bd0c77ee558caryclark SkDebugf(" %s,\n", tests[index].str); 68503b03cad01628146bbb8d4f33c073bd0c77ee558caryclark } 68603b03cad01628146bbb8d4f33c073bd0c77ee558caryclark if (tests[index].fun == stopTest || index == last) { 687818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com break; 688818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } 689818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com index += reverse ? -1 : 1; 690818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com } while (true); 69103b03cad01628146bbb8d4f33c073bd0c77ee558caryclark#endif 692818b0cc1b8b0c4acc565e8e2cb8b0b61aa5a300ecaryclark@google.com} 693