Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1289)

Unified Diff: tests/PathOpsTSectDebug.h

Issue 1037573004: cumulative pathops patch (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: fix pathopsinverse gm Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tests/PathOpsSkpTest.cpp ('k') | tests/PathOpsTestCommon.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/PathOpsTSectDebug.h
diff --git a/tests/PathOpsTSectDebug.h b/tests/PathOpsTSectDebug.h
index 5f8915f68123778a857c7abea9e99286ab10f33d..e28cba8bc266227b702b3a6296514f563dca3cd1 100644
--- a/tests/PathOpsTSectDebug.h
+++ b/tests/PathOpsTSectDebug.h
@@ -8,77 +8,161 @@
#include "SkPathOpsTSect.h"
template<typename TCurve>
+const SkTSpan<TCurve>* SkTSect<TCurve>::debugSpan(int id) const {
+ const SkTSpan<TCurve>* test = fHead;
+ do {
+ if (test->debugID() == id) {
+ return test;
+ }
+ } while ((test = test->next()));
+#ifndef SK_RELEASE
+ test = fOppSect->fHead;
+ do {
+ if (test->debugID() == id) {
+ return test;
+ }
+ } while ((test = test->next()));
+#endif
+ return NULL;
+}
+
+template<typename TCurve>
+const SkTSpan<TCurve>* SkTSect<TCurve>::debugT(double t) const {
+ const SkTSpan<TCurve>* test = fHead;
+ const SkTSpan<TCurve>* closest = NULL;
+ double bestDist = DBL_MAX;
+ do {
+ if (between(test->fStartT, t, test->fEndT)) {
+ return test;
+ }
+ double testDist = SkTMin(fabs(test->fStartT - t), fabs(test->fEndT - t));
+ if (bestDist > testDist) {
+ bestDist = testDist;
+ closest = test;
+ }
+ } while ((test = test->next()));
+ SkASSERT(closest);
+ return closest;
+}
+
+template<typename TCurve>
void SkTSect<TCurve>::dump() const {
+ dumpCommon(fHead);
+}
+
+extern int gDumpTSectNum;
+
+template<typename TCurve>
+void SkTSect<TCurve>::dumpBoth(SkTSect* opp) const {
+#if DEBUG_T_SECT_DUMP <= 2
+#if DEBUG_T_SECT_DUMP == 2
+ SkDebugf("%d ", ++gDumpTSectNum);
+#endif
+ this->dump();
+ SkDebugf(" ");
+ opp->dump();
+ SkDebugf("\n");
+#elif DEBUG_T_SECT_DUMP == 3
+ SkDebugf("<div id=\"sect%d\">\n", ++gDumpTSectNum);
+ if (this->fHead) {
+ this->dumpCurves();
+ }
+ if (opp->fHead) {
+ PATH_OPS_DEBUG_CODE(opp->dumpCurves());
+ }
+ SkDebugf("</div>\n\n");
+#endif
+}
+
+template<typename TCurve>
+void SkTSect<TCurve>::dumpBounds(int id) const {
+ const SkTSpan<TCurve>* bounded = debugSpan(id);
+ if (!bounded) {
+ SkDebugf("no span matches %d\n", id);
+ return;
+ }
+ const SkTSpan<TCurve>* test = bounded->debugOpp()->fHead;
+ do {
+ if (test->findOppSpan(bounded)) {
+ test->dump();
+ }
+ } while ((test = test->next()));
+}
+
+template<typename TCurve>
+void SkTSect<TCurve>::dumpCoin() const {
+ dumpCommon(fCoincident);
+}
+
+template<typename TCurve>
+void SkTSect<TCurve>::dumpCoinCurves() const {
+ dumpCommonCurves(fCoincident);
+}
+
+template<typename TCurve>
+void SkTSect<TCurve>::dumpCommon(const SkTSpan<TCurve>* test) const {
SkDebugf("id=%d", debugID());
- const SkTSpan<TCurve>* test = fHead;
if (!test) {
SkDebugf(" (empty)");
return;
}
do {
SkDebugf(" ");
- test->dump(this);
+ test->dump();
} while ((test = test->next()));
}
template<typename TCurve>
-void SkTSect<TCurve>::dumpBoth(const SkTSect& opp) const {
- dump();
- SkDebugf(" ");
- opp.dump();
- SkDebugf("\n");
+void SkTSect<TCurve>::dumpCommonCurves(const SkTSpan<TCurve>* test) const {
+ do {
+ test->fPart.dumpID(test->debugID());
+ } while ((test = test->next()));
}
template<typename TCurve>
-void SkTSect<TCurve>::dumpBoth(const SkTSect* opp) const {
- dumpBoth(*opp);
+void SkTSect<TCurve>::dumpCurves() const {
+ dumpCommonCurves(fHead);
}
template<typename TCurve>
-void SkTSect<TCurve>::dumpCurves() const {
- const SkTSpan<TCurve>* test = fHead;
- do {
- test->fPart.dump();
- } while ((test = test->next()));
+const SkTSpan<TCurve>* SkTSpan<TCurve>::debugSpan(int id) const {
+ return PATH_OPS_DEBUG_RELEASE(fDebugSect->debugSpan(id), NULL);
}
-#if !DEBUG_T_SECT
template<typename TCurve>
-int SkTSpan<TCurve>::debugID(const SkTSect<TCurve>* sect) const {
- if (!sect) {
- return -1;
- }
- int id = 1;
- const SkTSpan* test = sect->fHead;
- while (test && test != this) {
- ++id;
- test = test->fNext;
+const SkTSpan<TCurve>* SkTSpan<TCurve>::debugT(double t) const {
+ return PATH_OPS_DEBUG_RELEASE(fDebugSect->debugT(t), NULL);
+}
+
+template<typename TCurve>
+void SkTSpan<TCurve>::dump() const {
+ dumpID();
+ SkDebugf("=(%g,%g) [", fStartT, fEndT);
+ const SkTSpanBounded<TCurve>* testBounded = fBounded;
+ while (testBounded) {
+ const SkTSpan* span = testBounded->fBounded;
+ const SkTSpanBounded<TCurve>* next = testBounded->fNext;
+ span->dumpID();
+ if (next) {
+ SkDebugf(",");
+ }
+ testBounded = next;
}
- return id;
+ SkDebugf("]");
}
-#endif
template<typename TCurve>
-void SkTSpan<TCurve>::dumpID(const SkTSect<TCurve>* sect) const {
+void SkTSpan<TCurve>::dumpBounds(int id) const {
+ PATH_OPS_DEBUG_CODE(fDebugSect->dumpBounds(id));
+}
+
+template<typename TCurve>
+void SkTSpan<TCurve>::dumpID() const {
if (fCoinStart.isCoincident()) {
SkDebugf("%c", '*');
}
- SkDebugf("%d", debugID(sect));
+ SkDebugf("%d", debugID());
if (fCoinEnd.isCoincident()) {
SkDebugf("%c", '*');
}
}
-
-template<typename TCurve>
-void SkTSpan<TCurve>::dump(const SkTSect<TCurve>* sect) const {
- dumpID(sect);
- SkDebugf("=(%g,%g) [", fStartT, fEndT);
- for (int index = 0; index < fBounded.count(); ++index) {
- SkTSpan* span = fBounded[index];
- span->dumpID(sect);
- if (index < fBounded.count() - 1) {
- SkDebugf(",");
- }
- }
- SkDebugf("]");
-}
« no previous file with comments | « tests/PathOpsSkpTest.cpp ('k') | tests/PathOpsTestCommon.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698