blob: 6825daaef2d2939166551387031c67fac2e3b127 [file] [log] [blame]
caryclark@google.com07393ca2013-04-08 11:47:37 +00001/*
2 * Copyright 2013 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7#ifndef SkPathOpsDebug_DEFINED
8#define SkPathOpsDebug_DEFINED
9
caryclark@google.coma5e55922013-05-07 18:51:31 +000010#include "SkPathOps.h"
Cary Clark1d314432018-07-10 10:57:54 -040011#include "SkString.h"
caryclark@google.com07393ca2013-04-08 11:47:37 +000012#include "SkTypes.h"
bungeman60e0fee2015-08-26 05:15:46 -070013
14#include <stdlib.h>
bungeman@google.comfab44db2013-10-11 18:50:45 +000015#include <stdio.h>
caryclark@google.com07393ca2013-04-08 11:47:37 +000016
Cary Clarkab87d7a2016-10-04 10:01:04 -040017enum class SkOpPhase : char;
Cary Clarkb8421ed2018-03-14 15:55:02 -040018struct SkDQuad;
19class SkOpAngle;
20class SkOpCoincidence;
21class SkOpContour;
Cary Clarkab87d7a2016-10-04 10:01:04 -040022class SkOpContourHead;
Cary Clarkb8421ed2018-03-14 15:55:02 -040023class SkOpPtT;
24class SkOpSegment;
25class SkOpSpan;
26class SkOpSpanBase;
27struct SkDPoint;
28struct SkDLine;
29struct SkDQuad;
30struct SkDConic;
31struct SkDCubic;
Cary Clark8762fb62018-10-16 16:06:24 -040032class SkTSect;
Cary Clarkb8421ed2018-03-14 15:55:02 -040033
Cary Clark4929a4a2018-10-17 14:12:41 -040034// define this when running fuzz
35// #define IS_FUZZING_WITH_LIBFUZZER
36
Cary Clarkb8421ed2018-03-14 15:55:02 -040037// dummy classes to fool msvs Visual Studio 2018 Immediate Window
38#define DummyClasses(a, b) \
39class SkDebugTCoincident##a##b; \
40class SkDebugTSect##a##b; \
41class SkDebugTSpan##a##b
42
43DummyClasses(Quad, Quad);
44DummyClasses(Conic, Quad);
45DummyClasses(Conic, Conic);
46DummyClasses(Cubic, Quad);
47DummyClasses(Cubic, Conic);
48DummyClasses(Cubic, Cubic);
49
50#undef DummyClasses
Cary Clarkab87d7a2016-10-04 10:01:04 -040051
caryclark@google.com07393ca2013-04-08 11:47:37 +000052#ifdef SK_RELEASE
53#define FORCE_RELEASE 1
54#else
caryclark@google.comb3f09212013-04-17 15:49:16 +000055#define FORCE_RELEASE 1 // set force release to 1 for multiple thread -- no debugging
caryclark@google.com07393ca2013-04-08 11:47:37 +000056#endif
57
caryclarkb36a3cd2016-10-18 07:59:44 -070058#define DEBUG_UNDER_DEVELOPMENT 0
caryclark27c015d2016-09-23 05:47:20 -070059
caryclark@google.com07393ca2013-04-08 11:47:37 +000060#define ONE_OFF_DEBUG 0
61#define ONE_OFF_DEBUG_MATHEMATICA 0
62
caryclark@google.comdb60de72013-04-11 12:33:23 +000063#if defined(SK_BUILD_FOR_WIN) || defined(SK_BUILD_FOR_ANDROID)
caryclark@google.com07393ca2013-04-08 11:47:37 +000064 #define SK_RAND(seed) rand()
caryclark@google.com07393ca2013-04-08 11:47:37 +000065#else
66 #define SK_RAND(seed) rand_r(&seed)
caryclark@google.comdb60de72013-04-11 12:33:23 +000067#endif
68#ifdef SK_BUILD_FOR_WIN
69 #define SK_SNPRINTF _snprintf
70#else
skia.committer@gmail.com32840172013-04-09 07:01:27 +000071 #define SK_SNPRINTF snprintf
caryclark@google.com07393ca2013-04-08 11:47:37 +000072#endif
73
commit-bot@chromium.org4431e772014-04-14 17:08:59 +000074#define WIND_AS_STRING(x) char x##Str[12]; \
75 if (!SkPathOpsDebug::ValidWind(x)) strcpy(x##Str, "?"); \
76 else SK_SNPRINTF(x##Str, sizeof(x##Str), "%d", x)
77
caryclark@google.com07393ca2013-04-08 11:47:37 +000078#if FORCE_RELEASE
79
80#define DEBUG_ACTIVE_OP 0
81#define DEBUG_ACTIVE_SPANS 0
caryclark@google.com07393ca2013-04-08 11:47:37 +000082#define DEBUG_ADD_INTERSECTING_TS 0
caryclark54359292015-03-26 07:52:43 -070083#define DEBUG_ADD_T 0
caryclark26ad22a2015-10-16 09:03:38 -070084#define DEBUG_ALIGNMENT 0
caryclark@google.com07393ca2013-04-08 11:47:37 +000085#define DEBUG_ANGLE 0
caryclark@google.com07393ca2013-04-08 11:47:37 +000086#define DEBUG_ASSEMBLE 0
Cary Clarkab87d7a2016-10-04 10:01:04 -040087#define DEBUG_COINCIDENCE 0 // sanity checking
88#define DEBUG_COINCIDENCE_DUMP 0 // accumulate and dump which algorithms fired
89#define DEBUG_COINCIDENCE_ORDER 0 // for well behaved curves, check if pairs match up in t-order
90#define DEBUG_COINCIDENCE_VERBOSE 0 // usually whether the next function generates coincidence
commit-bot@chromium.org2db7fe72014-05-07 15:31:40 +000091#define DEBUG_CUBIC_BINARY_SEARCH 0
caryclark03b03ca2015-04-23 09:13:37 -070092#define DEBUG_CUBIC_SPLIT 0
caryclark624637c2015-05-11 07:21:27 -070093#define DEBUG_DUMP_SEGMENTS 0
Cary Clark918fb1f2016-11-15 13:22:25 -050094#define DEBUG_DUMP_VERIFY 0
caryclark@google.com07393ca2013-04-08 11:47:37 +000095#define DEBUG_FLOW 0
commit-bot@chromium.org8cb1daa2014-04-25 12:59:11 +000096#define DEBUG_LIMIT_WIND_SUM 0
caryclark@google.com07393ca2013-04-08 11:47:37 +000097#define DEBUG_MARK_DONE 0
98#define DEBUG_PATH_CONSTRUCTION 0
caryclark54359292015-03-26 07:52:43 -070099#define DEBUG_PERP 0
caryclark624637c2015-05-11 07:21:27 -0700100#define DEBUG_SHOW_TEST_NAME 0
caryclark@google.com07393ca2013-04-08 11:47:37 +0000101#define DEBUG_SORT 0
caryclark54359292015-03-26 07:52:43 -0700102#define DEBUG_T_SECT 0
103#define DEBUG_T_SECT_DUMP 0
caryclark26ad22a2015-10-16 09:03:38 -0700104#define DEBUG_T_SECT_LOOP_COUNT 0
caryclark@google.com4fdbb222013-07-23 15:27:41 +0000105#define DEBUG_VALIDATE 0
caryclark@google.com07393ca2013-04-08 11:47:37 +0000106#define DEBUG_WINDING 0
107#define DEBUG_WINDING_AT_T 0
108
109#else
110
111#define DEBUG_ACTIVE_OP 1
112#define DEBUG_ACTIVE_SPANS 1
caryclark@google.com07393ca2013-04-08 11:47:37 +0000113#define DEBUG_ADD_INTERSECTING_TS 1
caryclark54359292015-03-26 07:52:43 -0700114#define DEBUG_ADD_T 1
caryclark26ad22a2015-10-16 09:03:38 -0700115#define DEBUG_ALIGNMENT 0
caryclark@google.com07393ca2013-04-08 11:47:37 +0000116#define DEBUG_ANGLE 1
caryclark@google.com07393ca2013-04-08 11:47:37 +0000117#define DEBUG_ASSEMBLE 1
Cary Clarkff114282016-12-14 11:56:16 -0500118#define DEBUG_COINCIDENCE 1
Cary Clarkab87d7a2016-10-04 10:01:04 -0400119#define DEBUG_COINCIDENCE_DUMP 0
Cary Clark8762fb62018-10-16 16:06:24 -0400120#define DEBUG_COINCIDENCE_ORDER 0 // tight arc quads may generate out-of-order coincidence spans
Cary Clarkff114282016-12-14 11:56:16 -0500121#define DEBUG_COINCIDENCE_VERBOSE 1
caryclark65b427c2014-09-18 10:32:57 -0700122#define DEBUG_CUBIC_BINARY_SEARCH 0
caryclark03b03ca2015-04-23 09:13:37 -0700123#define DEBUG_CUBIC_SPLIT 1
Cary Clark918fb1f2016-11-15 13:22:25 -0500124#define DEBUG_DUMP_VERIFY 0
caryclark03b03ca2015-04-23 09:13:37 -0700125#define DEBUG_DUMP_SEGMENTS 1
caryclark@google.com07393ca2013-04-08 11:47:37 +0000126#define DEBUG_FLOW 1
caryclark55888e42016-07-18 10:01:36 -0700127#define DEBUG_LIMIT_WIND_SUM 15
caryclark@google.com07393ca2013-04-08 11:47:37 +0000128#define DEBUG_MARK_DONE 1
129#define DEBUG_PATH_CONSTRUCTION 1
caryclark03b03ca2015-04-23 09:13:37 -0700130#define DEBUG_PERP 1
caryclark@google.com03610322013-04-18 15:58:21 +0000131#define DEBUG_SHOW_TEST_NAME 1
caryclark@google.com07393ca2013-04-08 11:47:37 +0000132#define DEBUG_SORT 1
Cary Clarkb8421ed2018-03-14 15:55:02 -0400133#define DEBUG_T_SECT 0 // enabling may trigger validate asserts even though op does not fail
caryclarke839e782016-09-15 07:48:18 -0700134#define DEBUG_T_SECT_DUMP 0 // Use 1 normally. Use 2 to number segments, 3 for script output
caryclarked0935a2015-10-22 07:23:52 -0700135#define DEBUG_T_SECT_LOOP_COUNT 0
caryclark54359292015-03-26 07:52:43 -0700136#define DEBUG_VALIDATE 1
caryclark@google.com07393ca2013-04-08 11:47:37 +0000137#define DEBUG_WINDING 1
138#define DEBUG_WINDING_AT_T 1
139
140#endif
141
caryclark54359292015-03-26 07:52:43 -0700142#ifdef SK_RELEASE
caryclark1049f122015-04-20 08:31:59 -0700143 #define SkDEBUGRELEASE(a, b) b
144 #define SkDEBUGPARAMS(...)
reed0dc4dd62015-03-24 13:55:33 -0700145#else
caryclark1049f122015-04-20 08:31:59 -0700146 #define SkDEBUGRELEASE(a, b) a
147 #define SkDEBUGPARAMS(...) , __VA_ARGS__
reed0dc4dd62015-03-24 13:55:33 -0700148#endif
caryclark54359292015-03-26 07:52:43 -0700149
caryclark27c8eb82015-07-06 11:38:33 -0700150#if DEBUG_VALIDATE == 0
151 #define PATH_OPS_DEBUG_VALIDATE_PARAMS(...)
152#else
153 #define PATH_OPS_DEBUG_VALIDATE_PARAMS(...) , __VA_ARGS__
154#endif
155
caryclark54359292015-03-26 07:52:43 -0700156#if DEBUG_T_SECT == 0
157 #define PATH_OPS_DEBUG_T_SECT_RELEASE(a, b) b
158 #define PATH_OPS_DEBUG_T_SECT_PARAMS(...)
159 #define PATH_OPS_DEBUG_T_SECT_CODE(...)
160#else
161 #define PATH_OPS_DEBUG_T_SECT_RELEASE(a, b) a
162 #define PATH_OPS_DEBUG_T_SECT_PARAMS(...) , __VA_ARGS__
163 #define PATH_OPS_DEBUG_T_SECT_CODE(...) __VA_ARGS__
164#endif
165
166#if DEBUG_T_SECT_DUMP > 1
167 extern int gDumpTSectNum;
168#endif
169
Ben Wagner63fd7602017-10-09 15:45:33 -0400170#if DEBUG_COINCIDENCE || DEBUG_COINCIDENCE_DUMP
Cary Clarkab87d7a2016-10-04 10:01:04 -0400171 #define DEBUG_COIN 1
caryclark26ad22a2015-10-16 09:03:38 -0700172#else
Cary Clarkab87d7a2016-10-04 10:01:04 -0400173 #define DEBUG_COIN 0
174#endif
175
176#if DEBUG_COIN
177 #define DEBUG_COIN_DECLARE_ONLY_PARAMS() \
178 int lineNo, SkOpPhase phase, int iteration
179 #define DEBUG_COIN_DECLARE_PARAMS() \
180 , DEBUG_COIN_DECLARE_ONLY_PARAMS()
181 #define DEBUG_COIN_ONLY_PARAMS() \
182 __LINE__, SkOpPhase::kNoChange, 0
183 #define DEBUG_COIN_PARAMS() \
184 , DEBUG_COIN_ONLY_PARAMS()
185 #define DEBUG_ITER_ONLY_PARAMS(iteration) \
186 __LINE__, SkOpPhase::kNoChange, iteration
187 #define DEBUG_ITER_PARAMS(iteration) \
188 , DEBUG_ITER_ONLY_PARAMS(iteration)
189 #define DEBUG_PHASE_ONLY_PARAMS(phase) \
190 __LINE__, SkOpPhase::phase, 0
191 #define DEBUG_PHASE_PARAMS(phase) \
192 , DEBUG_PHASE_ONLY_PARAMS(phase)
193 #define DEBUG_SET_PHASE() \
194 this->globalState()->debugSetPhase(__func__, lineNo, phase, iteration)
195 #define DEBUG_STATIC_SET_PHASE(obj) \
196 obj->globalState()->debugSetPhase(__func__, lineNo, phase, iteration)
197#elif DEBUG_VALIDATE
198 #define DEBUG_COIN_DECLARE_ONLY_PARAMS() \
199 SkOpPhase phase
200 #define DEBUG_COIN_DECLARE_PARAMS() \
201 , DEBUG_COIN_DECLARE_ONLY_PARAMS()
202 #define DEBUG_COIN_ONLY_PARAMS() \
203 SkOpPhase::kNoChange
204 #define DEBUG_COIN_PARAMS() \
205 , DEBUG_COIN_ONLY_PARAMS()
206 #define DEBUG_ITER_ONLY_PARAMS(iteration) \
207 SkOpPhase::kNoChange
208 #define DEBUG_ITER_PARAMS(iteration) \
209 , DEBUG_ITER_ONLY_PARAMS(iteration)
210 #define DEBUG_PHASE_ONLY_PARAMS(phase) \
211 SkOpPhase::phase
212 #define DEBUG_PHASE_PARAMS(phase) \
213 , DEBUG_PHASE_ONLY_PARAMS(phase)
214 #define DEBUG_SET_PHASE() \
215 this->globalState()->debugSetPhase(phase)
216 #define DEBUG_STATIC_SET_PHASE(obj) \
217 obj->globalState()->debugSetPhase(phase)
218#else
219 #define DEBUG_COIN_DECLARE_ONLY_PARAMS()
220 #define DEBUG_COIN_DECLARE_PARAMS()
221 #define DEBUG_COIN_ONLY_PARAMS()
222 #define DEBUG_COIN_PARAMS()
223 #define DEBUG_ITER_ONLY_PARAMS(iteration)
224 #define DEBUG_ITER_PARAMS(iteration)
225 #define DEBUG_PHASE_ONLY_PARAMS(phase)
226 #define DEBUG_PHASE_PARAMS(phase)
227 #define DEBUG_SET_PHASE()
228 #define DEBUG_STATIC_SET_PHASE(obj)
caryclark26ad22a2015-10-16 09:03:38 -0700229#endif
230
caryclark1049f122015-04-20 08:31:59 -0700231#define CUBIC_DEBUG_STR "{{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}}}"
232#define CONIC_DEBUG_STR "{{{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}}}, %1.9g}"
233#define QUAD_DEBUG_STR "{{{%1.9g,%1.9g}, {%1.9g,%1.9g}, {%1.9g,%1.9g}}}"
234#define LINE_DEBUG_STR "{{{%1.9g,%1.9g}, {%1.9g,%1.9g}}}"
caryclark54359292015-03-26 07:52:43 -0700235#define PT_DEBUG_STR "{{%1.9g,%1.9g}}"
236
caryclark@google.com07393ca2013-04-08 11:47:37 +0000237#define T_DEBUG_STR(t, n) #t "[" #n "]=%1.9g"
238#define TX_DEBUG_STR(t) #t "[%d]=%1.9g"
239#define CUBIC_DEBUG_DATA(c) c[0].fX, c[0].fY, c[1].fX, c[1].fY, c[2].fX, c[2].fY, c[3].fX, c[3].fY
caryclark1049f122015-04-20 08:31:59 -0700240#define CONIC_DEBUG_DATA(c, w) c[0].fX, c[0].fY, c[1].fX, c[1].fY, c[2].fX, c[2].fY, w
caryclark@google.com07393ca2013-04-08 11:47:37 +0000241#define QUAD_DEBUG_DATA(q) q[0].fX, q[0].fY, q[1].fX, q[1].fY, q[2].fX, q[2].fY
242#define LINE_DEBUG_DATA(l) l[0].fX, l[0].fY, l[1].fX, l[1].fY
caryclarkdac1d172014-06-17 05:15:38 -0700243#define PT_DEBUG_DATA(i, n) i.pt(n).asSkPoint().fX, i.pt(n).asSkPoint().fY
caryclark@google.com07393ca2013-04-08 11:47:37 +0000244
caryclark@google.com07e97fc2013-07-08 17:17:02 +0000245#ifndef DEBUG_TEST
246#define DEBUG_TEST 0
caryclark@google.coma5e55922013-05-07 18:51:31 +0000247#endif
248
caryclark@google.com570863f2013-09-16 15:55:01 +0000249#if DEBUG_SHOW_TEST_NAME
250#include "SkTLS.h"
251#endif
252
caryclark29b25632016-08-25 11:27:17 -0700253// Tests with extreme numbers may fail, but all other tests should never fail.
254#define FAIL_IF(cond) \
255 do { bool fail = (cond); SkOPASSERT(!fail); if (fail) return false; } while (false)
caryclark025b11e2016-08-25 05:21:14 -0700256
caryclark29b25632016-08-25 11:27:17 -0700257#define FAIL_WITH_NULL_IF(cond) \
258 do { bool fail = (cond); SkOPASSERT(!fail); if (fail) return nullptr; } while (false)
259
260// Some functions serve two masters: one allows the function to fail, the other expects success
261// always. If abort is true, tests with normal numbers may not fail and assert if they do so.
262// If abort is false, both normal and extreme numbers may return false without asserting.
caryclark025b11e2016-08-25 05:21:14 -0700263#define RETURN_FALSE_IF(abort, cond) \
caryclark29b25632016-08-25 11:27:17 -0700264 do { bool fail = (cond); SkOPASSERT(!(abort) || !fail); if (fail) return false; \
265 } while (false)
caryclark025b11e2016-08-25 05:21:14 -0700266
caryclark@google.com570863f2013-09-16 15:55:01 +0000267class SkPathOpsDebug {
268public:
Cary Clarkab87d7a2016-10-04 10:01:04 -0400269#if DEBUG_COIN
caryclark26ad22a2015-10-16 09:03:38 -0700270 struct GlitchLog;
commit-bot@chromium.org8cb1daa2014-04-25 12:59:11 +0000271
Cary Clarkab87d7a2016-10-04 10:01:04 -0400272 enum GlitchType {
273 kUninitialized_Glitch,
274 kAddCorruptCoin_Glitch,
275 kAddExpandedCoin_Glitch,
276 kAddExpandedFail_Glitch,
277 kAddIfCollapsed_Glitch,
278 kAddIfMissingCoin_Glitch,
279 kAddMissingCoin_Glitch,
280 kAddMissingExtend_Glitch,
281 kAddOrOverlap_Glitch,
282 kCollapsedCoin_Glitch,
283 kCollapsedDone_Glitch,
284 kCollapsedOppValue_Glitch,
285 kCollapsedSpan_Glitch,
286 kCollapsedWindValue_Glitch,
287 kCorrectEnd_Glitch,
288 kDeletedCoin_Glitch,
289 kExpandCoin_Glitch,
290 kFail_Glitch,
291 kMarkCoinEnd_Glitch,
292 kMarkCoinInsert_Glitch,
293 kMarkCoinMissing_Glitch,
294 kMarkCoinStart_Glitch,
Cary Clarkab87d7a2016-10-04 10:01:04 -0400295 kMergeMatches_Glitch,
296 kMissingCoin_Glitch,
297 kMissingDone_Glitch,
298 kMissingIntersection_Glitch,
299 kMoveMultiple_Glitch,
300 kMoveNearbyClearAll_Glitch,
301 kMoveNearbyClearAll2_Glitch,
302 kMoveNearbyMerge_Glitch,
303 kMoveNearbyMergeFinal_Glitch,
304 kMoveNearbyRelease_Glitch,
305 kMoveNearbyReleaseFinal_Glitch,
306 kReleasedSpan_Glitch,
307 kReturnFalse_Glitch,
308 kUnaligned_Glitch,
309 kUnalignedHead_Glitch,
310 kUnalignedTail_Glitch,
311 };
312
313 struct CoinDictEntry {
314 int fIteration;
315 int fLineNumber;
316 GlitchType fGlitchType;
317 const char* fFunctionName;
318 };
319
320 struct CoinDict {
321 void add(const CoinDictEntry& key);
322 void add(const CoinDict& dict);
323 void dump(const char* str, bool visitCheck) const;
324 SkTDArray<CoinDictEntry> fDict;
325 };
326
327 static CoinDict gCoinSumChangedDict;
328 static CoinDict gCoinSumVisitedDict;
329 static CoinDict gCoinVistedDict;
330#endif
331
commit-bot@chromium.org8cb1daa2014-04-25 12:59:11 +0000332#if defined(SK_DEBUG) || !FORCE_RELEASE
caryclark@google.com570863f2013-09-16 15:55:01 +0000333 static int gContourID;
334 static int gSegmentID;
commit-bot@chromium.org8cb1daa2014-04-25 12:59:11 +0000335#endif
caryclark@google.com570863f2013-09-16 15:55:01 +0000336
caryclark624637c2015-05-11 07:21:27 -0700337#if DEBUG_SORT
caryclark@google.com570863f2013-09-16 15:55:01 +0000338 static int gSortCountDefault;
339 static int gSortCount;
340#endif
341
342#if DEBUG_ACTIVE_OP
343 static const char* kPathOpStr[];
344#endif
Cary Clarkb8421ed2018-03-14 15:55:02 -0400345 static bool gRunFail;
346 static bool gVeryVerbose;
caryclark@google.com570863f2013-09-16 15:55:01 +0000347
Cary Clarkb8421ed2018-03-14 15:55:02 -0400348#if DEBUG_ACTIVE_SPANS
349 static SkString gActiveSpans;
350#endif
351#if DEBUG_DUMP_VERIFY
352 static bool gDumpOp;
353 static bool gVerifyOp;
354#endif
355
356 static const char* OpStr(SkPathOp );
caryclark@google.com570863f2013-09-16 15:55:01 +0000357 static void MathematicaIze(char* str, size_t bufferSize);
358 static bool ValidWind(int winding);
359 static void WindingPrintf(int winding);
360
361#if DEBUG_SHOW_TEST_NAME
362 static void* CreateNameStr();
363 static void DeleteNameStr(void* v);
364#define DEBUG_FILENAME_STRING_LENGTH 64
365#define DEBUG_FILENAME_STRING (reinterpret_cast<char* >(SkTLS::Get(SkPathOpsDebug::CreateNameStr, \
366 SkPathOpsDebug::DeleteNameStr)))
367 static void BumpTestName(char* );
caryclark@google.com570863f2013-09-16 15:55:01 +0000368#endif
caryclark55888e42016-07-18 10:01:36 -0700369 static void ShowActiveSpans(SkOpContourHead* contourList);
caryclark19eb3b22014-07-18 05:08:14 -0700370 static void ShowOnePath(const SkPath& path, const char* name, bool includeDeclaration);
commit-bot@chromium.org4431e772014-04-14 17:08:59 +0000371 static void ShowPath(const SkPath& one, const SkPath& two, SkPathOp op, const char* name);
caryclark54359292015-03-26 07:52:43 -0700372
Cary Clarkb8421ed2018-03-14 15:55:02 -0400373 static bool ChaseContains(const SkTDArray<SkOpSpanBase*>& , const SkOpSpanBase* );
caryclark54359292015-03-26 07:52:43 -0700374
Cary Clarkab87d7a2016-10-04 10:01:04 -0400375 static void CheckHealth(class SkOpContourHead* contourList);
caryclark26ad22a2015-10-16 09:03:38 -0700376
Cary Clarkab87d7a2016-10-04 10:01:04 -0400377#if DEBUG_COIN
Cary Clarkb8421ed2018-03-14 15:55:02 -0400378 static void DumpCoinDict();
379 static void DumpGlitchType(GlitchType );
Cary Clarkff114282016-12-14 11:56:16 -0500380#endif
381
caryclark@google.com570863f2013-09-16 15:55:01 +0000382};
383
Cary Clarkb8421ed2018-03-14 15:55:02 -0400384// Visual Studio 2017 does not permit calling member functions from the Immediate Window.
Cary Clark8762fb62018-10-16 16:06:24 -0400385// Global functions work fine, however. Use globals rather than static members inside a class.
386const SkOpAngle* AngleAngle(const SkOpAngle*, int id);
387SkOpContour* AngleContour(SkOpAngle*, int id);
388const SkOpPtT* AnglePtT(const SkOpAngle*, int id);
389const SkOpSegment* AngleSegment(const SkOpAngle*, int id);
390const SkOpSpanBase* AngleSpan(const SkOpAngle*, int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400391
Cary Clark8762fb62018-10-16 16:06:24 -0400392const SkOpAngle* ContourAngle(SkOpContour*, int id);
393SkOpContour* ContourContour(SkOpContour*, int id);
394const SkOpPtT* ContourPtT(SkOpContour*, int id);
395const SkOpSegment* ContourSegment(SkOpContour*, int id);
396const SkOpSpanBase* ContourSpan(SkOpContour*, int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400397
Cary Clark8762fb62018-10-16 16:06:24 -0400398const SkOpAngle* CoincidenceAngle(SkOpCoincidence*, int id);
399SkOpContour* CoincidenceContour(SkOpCoincidence*, int id);
400const SkOpPtT* CoincidencePtT(SkOpCoincidence*, int id);
401const SkOpSegment* CoincidenceSegment(SkOpCoincidence*, int id);
402const SkOpSpanBase* CoincidenceSpan(SkOpCoincidence*, int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400403
Cary Clark8762fb62018-10-16 16:06:24 -0400404const SkOpAngle* PtTAngle(const SkOpPtT*, int id);
405SkOpContour* PtTContour(SkOpPtT*, int id);
406const SkOpPtT* PtTPtT(const SkOpPtT*, int id);
407const SkOpSegment* PtTSegment(const SkOpPtT*, int id);
408const SkOpSpanBase* PtTSpan(const SkOpPtT*, int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400409
Cary Clark8762fb62018-10-16 16:06:24 -0400410const SkOpAngle* SegmentAngle(const SkOpSegment*, int id);
411SkOpContour* SegmentContour(SkOpSegment*, int id);
412const SkOpPtT* SegmentPtT(const SkOpSegment*, int id);
413const SkOpSegment* SegmentSegment(const SkOpSegment*, int id);
414const SkOpSpanBase* SegmentSpan(const SkOpSegment*, int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400415
Cary Clark8762fb62018-10-16 16:06:24 -0400416const SkOpAngle* SpanAngle(const SkOpSpanBase*, int id);
417SkOpContour* SpanContour(SkOpSpanBase*, int id);
418const SkOpPtT* SpanPtT(const SkOpSpanBase*, int id);
419const SkOpSegment* SpanSegment(const SkOpSpanBase*, int id);
420const SkOpSpanBase* SpanSpan(const SkOpSpanBase*, int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400421
422#if DEBUG_DUMP_VERIFY
Cary Clark8762fb62018-10-16 16:06:24 -0400423void DumpOp(const SkPath& one, const SkPath& two, SkPathOp op,
424 const char* testName);
425void DumpOp(FILE* file, const SkPath& one, const SkPath& two, SkPathOp op,
426 const char* testName);
427void DumpSimplify(const SkPath& path, const char* testName);
428void DumpSimplify(FILE* file, const SkPath& path, const char* testName);
429void ReportOpFail(const SkPath& one, const SkPath& two, SkPathOp op);
430void ReportSimplifyFail(const SkPath& path);
431void VerifyOp(const SkPath& one, const SkPath& two, SkPathOp op,
432 const SkPath& result);
433void VerifySimplify(const SkPath& path, const SkPath& result);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400434#endif
435
Cary Clark8762fb62018-10-16 16:06:24 -0400436// global path dumps for msvs Visual Studio 17 to use from Immediate Window
437void Dump(const SkOpContour& );
438void DumpAll(const SkOpContour& );
439void DumpAngles(const SkOpContour& );
440void DumpContours(const SkOpContour& );
441void DumpContoursAll(const SkOpContour& );
442void DumpContoursAngles(const SkOpContour& );
443void DumpContoursPts(const SkOpContour& );
444void DumpContoursPt(const SkOpContour& , int segmentID);
445void DumpContoursSegment(const SkOpContour& , int segmentID);
446void DumpContoursSpan(const SkOpContour& , int segmentID);
447void DumpContoursSpans(const SkOpContour& );
448void DumpPt(const SkOpContour& , int );
449void DumpPts(const SkOpContour& , const char* prefix = "seg");
450void DumpSegment(const SkOpContour& , int );
451void DumpSegments(const SkOpContour& , const char* prefix = "seg", SkPathOp op = (SkPathOp) -1);
452void DumpSpan(const SkOpContour& , int );
453void DumpSpans(const SkOpContour& );
Cary Clarkb8421ed2018-03-14 15:55:02 -0400454
Cary Clark8762fb62018-10-16 16:06:24 -0400455void Dump(const SkOpSegment& );
456void DumpAll(const SkOpSegment& );
457void DumpAngles(const SkOpSegment& );
458void DumpCoin(const SkOpSegment& );
459void DumpPts(const SkOpSegment& , const char* prefix = "seg");
Cary Clarkb8421ed2018-03-14 15:55:02 -0400460
Cary Clark8762fb62018-10-16 16:06:24 -0400461void Dump(const SkOpPtT& );
462void DumpAll(const SkOpPtT& );
Cary Clarkb8421ed2018-03-14 15:55:02 -0400463
Cary Clark8762fb62018-10-16 16:06:24 -0400464void Dump(const SkOpSpanBase& );
465void DumpCoin(const SkOpSpanBase& );
466void DumpAll(const SkOpSpanBase& );
Cary Clarkb8421ed2018-03-14 15:55:02 -0400467
Cary Clark8762fb62018-10-16 16:06:24 -0400468void DumpCoin(const SkOpSpan& );
469bool DumpSpan(const SkOpSpan& );
Cary Clarkb8421ed2018-03-14 15:55:02 -0400470
Cary Clark8762fb62018-10-16 16:06:24 -0400471void Dump(const SkDConic& );
472void DumpID(const SkDConic& , int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400473
Cary Clark8762fb62018-10-16 16:06:24 -0400474void Dump(const SkDCubic& );
475void DumpID(const SkDCubic& , int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400476
Cary Clark8762fb62018-10-16 16:06:24 -0400477void Dump(const SkDLine& );
478void DumpID(const SkDLine& , int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400479
Cary Clark8762fb62018-10-16 16:06:24 -0400480void Dump(const SkDQuad& );
481void DumpID(const SkDQuad& , int id);
Cary Clarkb8421ed2018-03-14 15:55:02 -0400482
Cary Clark8762fb62018-10-16 16:06:24 -0400483void Dump(const SkDPoint& );
Cary Clarkb8421ed2018-03-14 15:55:02 -0400484
Cary Clark8762fb62018-10-16 16:06:24 -0400485void Dump(const SkOpAngle& );
caryclarkdac1d172014-06-17 05:15:38 -0700486
commit-bot@chromium.org4431e772014-04-14 17:08:59 +0000487// generates tools/path_sorter.htm and path_visualizer.htm compatible data
caryclark54359292015-03-26 07:52:43 -0700488void DumpQ(const SkDQuad& quad1, const SkDQuad& quad2, int testNo);
489void DumpT(const SkDQuad& quad, double t);
commit-bot@chromium.org4431e772014-04-14 17:08:59 +0000490
Cary Clarkb8421ed2018-03-14 15:55:02 -0400491// global path dumps for msvs Visual Studio 17 to use from Immediate Window
492void Dump(const SkPath& path);
493void DumpHex(const SkPath& path);
494
caryclark@google.com07393ca2013-04-08 11:47:37 +0000495#endif