| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * Copyright 2014 Google Inc. | 2  * Copyright 2014 Google Inc. | 
| 3  * | 3  * | 
| 4  * Use of this source code is governed by a BSD-style license that can be | 4  * Use of this source code is governed by a BSD-style license that can be | 
| 5  * found in the LICENSE file. | 5  * found in the LICENSE file. | 
| 6  */ | 6  */ | 
| 7 | 7 | 
| 8 #include "PathOpsTSectDebug.h" | 8 #include "PathOpsTSectDebug.h" | 
| 9 #include "SkOpCoincidence.h" | 9 #include "SkOpCoincidence.h" | 
| 10 #include "SkOpContour.h" | 10 #include "SkOpContour.h" | 
| (...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 54     dumpInner(); | 54     dumpInner(); | 
| 55     SkDebugf("},\n"); | 55     SkDebugf("},\n"); | 
| 56 } | 56 } | 
| 57 | 57 | 
| 58 void SkDConic::dumpID(int id) const { | 58 void SkDConic::dumpID(int id) const { | 
| 59     dumpInner(); | 59     dumpInner(); | 
| 60     SkDebugf("} id=%d\n", id); | 60     SkDebugf("} id=%d\n", id); | 
| 61 } | 61 } | 
| 62 | 62 | 
| 63 void SkDConic::dumpInner() const { | 63 void SkDConic::dumpInner() const { | 
| 64     SkDebugf("{{"); | 64     SkDebugf("{"); | 
| 65     int index = 0; | 65     fPts.dumpInner(); | 
| 66     do { | 66     SkDebugf("}}, %1.9gf", fWeight); | 
| 67         fPts[index].dump(); |  | 
| 68         SkDebugf(", "); |  | 
| 69     } while (++index < 2); |  | 
| 70     fPts[index].dump(); |  | 
| 71     SkDebugf("}, %1.9g", fWeight); |  | 
| 72 } | 67 } | 
| 73 | 68 | 
| 74 void SkDCubic::dump() const { | 69 void SkDCubic::dump() const { | 
| 75     this->dumpInner(); | 70     this->dumpInner(); | 
| 76     SkDebugf("}},\n"); | 71     SkDebugf("}},\n"); | 
| 77 } | 72 } | 
| 78 | 73 | 
| 79 void SkDCubic::dumpID(int id) const { | 74 void SkDCubic::dumpID(int id) const { | 
| 80     this->dumpInner(); | 75     this->dumpInner(); | 
| 81     SkDebugf("}} id=%d\n", id); | 76     SkDebugf("}} id=%d\n", id); | 
| (...skipping 585 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 667     Dump(&q1c2); | 662     Dump(&q1c2); | 
| 668     Dump(&k1q2); | 663     Dump(&k1q2); | 
| 669     Dump(&k1k2); | 664     Dump(&k1k2); | 
| 670     Dump(&k1c2); | 665     Dump(&k1c2); | 
| 671     Dump(&c1q2); | 666     Dump(&c1q2); | 
| 672     Dump(&c1k2); | 667     Dump(&c1k2); | 
| 673     Dump(&c1c2); | 668     Dump(&c1c2); | 
| 674 } | 669 } | 
| 675 | 670 | 
| 676 template <typename TCurve, typename OppCurve> | 671 template <typename TCurve, typename OppCurve> | 
|  | 672 void DumpAll(const SkTSpan<TCurve, OppCurve>* span) { | 
|  | 673     span->dumpAll(); | 
|  | 674 } | 
|  | 675 | 
|  | 676 void DontCallDumpSpanAll(); | 
|  | 677 void DontCallDumpSpanAll() {  // exists to instantiate the templates | 
|  | 678     SkTSpan<SkDQuad, SkDQuad> q1q2; q1q2.debugInit(); | 
|  | 679     SkTSpan<SkDQuad, SkDConic> q1k2; q1k2.debugInit(); | 
|  | 680     SkTSpan<SkDQuad, SkDCubic> q1c2; q1c2.debugInit(); | 
|  | 681     SkTSpan<SkDConic, SkDQuad> k1q2; k1q2.debugInit(); | 
|  | 682     SkTSpan<SkDConic, SkDConic> k1k2; k1k2.debugInit(); | 
|  | 683     SkTSpan<SkDConic, SkDCubic> k1c2; k1c2.debugInit(); | 
|  | 684     SkTSpan<SkDCubic, SkDQuad> c1q2; c1q2.debugInit(); | 
|  | 685     SkTSpan<SkDCubic, SkDConic> c1k2; c1k2.debugInit(); | 
|  | 686     SkTSpan<SkDCubic, SkDCubic> c1c2; c1c2.debugInit(); | 
|  | 687     DumpAll(&q1q2); | 
|  | 688     DumpAll(&q1k2); | 
|  | 689     DumpAll(&q1c2); | 
|  | 690     DumpAll(&k1q2); | 
|  | 691     DumpAll(&k1k2); | 
|  | 692     DumpAll(&k1c2); | 
|  | 693     DumpAll(&c1q2); | 
|  | 694     DumpAll(&c1k2); | 
|  | 695     DumpAll(&c1c2); | 
|  | 696 } | 
|  | 697 | 
|  | 698 template <typename TCurve, typename OppCurve> | 
|  | 699 void DumpBounded(const SkTSpan<TCurve, OppCurve>* span) { | 
|  | 700     span->dumpBounded(0); | 
|  | 701 } | 
|  | 702 | 
|  | 703 void DontCallDumpSpanBounded(); | 
|  | 704 void DontCallDumpSpanBounded() {  // exists to instantiate the templates | 
|  | 705     SkTSpan<SkDQuad, SkDQuad> q1q2; q1q2.debugInit(); | 
|  | 706     SkTSpan<SkDQuad, SkDConic> q1k2; q1k2.debugInit(); | 
|  | 707     SkTSpan<SkDQuad, SkDCubic> q1c2; q1c2.debugInit(); | 
|  | 708     SkTSpan<SkDConic, SkDQuad> k1q2; k1q2.debugInit(); | 
|  | 709     SkTSpan<SkDConic, SkDConic> k1k2; k1k2.debugInit(); | 
|  | 710     SkTSpan<SkDConic, SkDCubic> k1c2; k1c2.debugInit(); | 
|  | 711     SkTSpan<SkDCubic, SkDQuad> c1q2; c1q2.debugInit(); | 
|  | 712     SkTSpan<SkDCubic, SkDConic> c1k2; c1k2.debugInit(); | 
|  | 713     SkTSpan<SkDCubic, SkDCubic> c1c2; c1c2.debugInit(); | 
|  | 714     DumpBounded(&q1q2); | 
|  | 715     DumpBounded(&q1k2); | 
|  | 716     DumpBounded(&q1c2); | 
|  | 717     DumpBounded(&k1q2); | 
|  | 718     DumpBounded(&k1k2); | 
|  | 719     DumpBounded(&k1c2); | 
|  | 720     DumpBounded(&c1q2); | 
|  | 721     DumpBounded(&c1k2); | 
|  | 722     DumpBounded(&c1c2); | 
|  | 723 } | 
|  | 724 | 
|  | 725 template <typename TCurve, typename OppCurve> | 
| 677 void DumpCoin(const SkTSpan<TCurve, OppCurve>* span) { | 726 void DumpCoin(const SkTSpan<TCurve, OppCurve>* span) { | 
| 678     span->dumpCoin(); | 727     span->dumpCoin(); | 
| 679 } | 728 } | 
| 680 | 729 | 
| 681 void DontCallDumpSpanCoin(); | 730 void DontCallDumpSpanCoin(); | 
| 682 void DontCallDumpSpanCoin() {  // exists to instantiate the templates | 731 void DontCallDumpSpanCoin() {  // exists to instantiate the templates | 
| 683     SkTSpan<SkDQuad, SkDQuad> q1q2; q1q2.debugInit(); | 732     SkTSpan<SkDQuad, SkDQuad> q1q2; q1q2.debugInit(); | 
| 684     SkTSpan<SkDQuad, SkDConic> q1k2; q1k2.debugInit(); | 733     SkTSpan<SkDQuad, SkDConic> q1k2; q1k2.debugInit(); | 
| 685     SkTSpan<SkDQuad, SkDCubic> q1c2; q1c2.debugInit(); | 734     SkTSpan<SkDQuad, SkDCubic> q1c2; q1c2.debugInit(); | 
| 686     SkTSpan<SkDConic, SkDQuad> k1q2; k1q2.debugInit(); | 735     SkTSpan<SkDConic, SkDQuad> k1q2; k1q2.debugInit(); | 
| (...skipping 391 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1078     } while (!span->final() && (span = span->upCast()->next())); | 1127     } while (!span->final() && (span = span->upCast()->next())); | 
| 1079 } | 1128 } | 
| 1080 | 1129 | 
| 1081 void SkOpSegment::dumpCoin() const { | 1130 void SkOpSegment::dumpCoin() const { | 
| 1082     const SkOpSpan* span = &fHead; | 1131     const SkOpSpan* span = &fHead; | 
| 1083     do { | 1132     do { | 
| 1084         span->dumpCoin(); | 1133         span->dumpCoin(); | 
| 1085     } while ((span = span->next()->upCastable())); | 1134     } while ((span = span->next()->upCastable())); | 
| 1086 } | 1135 } | 
| 1087 | 1136 | 
| 1088 void SkOpSegment::dumpPtsInner() const { | 1137 void SkOpSegment::dumpPtsInner(const char* prefix) const { | 
| 1089     int last = SkPathOpsVerbToPoints(fVerb); | 1138     int last = SkPathOpsVerbToPoints(fVerb); | 
| 1090     SkDebugf("seg=%d {{", this->debugID()); | 1139     SkDebugf("%s=%d {{", prefix, this->debugID()); | 
| 1091     if (fVerb == SkPath::kConic_Verb) { | 1140     if (fVerb == SkPath::kConic_Verb) { | 
| 1092         SkDebugf("{"); | 1141         SkDebugf("{"); | 
| 1093     } | 1142     } | 
| 1094     int index = 0; | 1143     int index = 0; | 
| 1095     do { | 1144     do { | 
| 1096         SkDPoint::Dump(fPts[index]); | 1145         SkDPoint::Dump(fPts[index]); | 
| 1097         SkDebugf(", "); | 1146         SkDebugf(", "); | 
| 1098     } while (++index < last); | 1147     } while (++index < last); | 
| 1099     SkDPoint::Dump(fPts[index]); | 1148     SkDPoint::Dump(fPts[index]); | 
| 1100     SkDebugf("}}"); | 1149     SkDebugf("}}"); | 
| 1101     if (fVerb == SkPath::kConic_Verb) { | 1150     if (fVerb == SkPath::kConic_Verb) { | 
| 1102         SkDebugf(", %1.9gf}", fWeight); | 1151         SkDebugf(", %1.9gf}", fWeight); | 
| 1103     } | 1152     } | 
| 1104 } | 1153 } | 
| 1105 | 1154 | 
| 1106 void SkOpSegment::dumpPts() const { | 1155 void SkOpSegment::dumpPts(const char* prefix) const { | 
| 1107     dumpPtsInner(); | 1156     dumpPtsInner(prefix); | 
| 1108     SkDebugf("\n"); | 1157     SkDebugf("\n"); | 
| 1109 } | 1158 } | 
| 1110 | 1159 | 
| 1111 void SkCoincidentSpans::dump() const { | 1160 void SkCoincidentSpans::dump() const { | 
| 1112     SkDebugf("- seg=%d span=%d ptT=%d ", fCoinPtTStart->segment()->debugID(), | 1161     SkDebugf("- seg=%d span=%d ptT=%d ", fCoinPtTStart->segment()->debugID(), | 
| 1113         fCoinPtTStart->span()->debugID(), fCoinPtTStart->debugID()); | 1162         fCoinPtTStart->span()->debugID(), fCoinPtTStart->debugID()); | 
| 1114     fCoinPtTStart->dumpBase(); | 1163     fCoinPtTStart->dumpBase(); | 
| 1115     SkDebugf(" span=%d ptT=%d ", fCoinPtTEnd->span()->debugID(), fCoinPtTEnd->de
      bugID()); | 1164     SkDebugf(" span=%d ptT=%d ", fCoinPtTEnd->span()->debugID(), fCoinPtTEnd->de
      bugID()); | 
| 1116     fCoinPtTEnd->dumpBase(); | 1165     fCoinPtTEnd->dumpBase(); | 
| 1117     if (fCoinPtTStart->segment()->operand()) { | 1166     if (fCoinPtTStart->segment()->operand()) { | 
| (...skipping 16 matching lines...) Expand all  Loading... | 
| 1134     } | 1183     } | 
| 1135     SkDebugf("\n"); | 1184     SkDebugf("\n"); | 
| 1136 } | 1185 } | 
| 1137 | 1186 | 
| 1138 void SkOpCoincidence::dump() const { | 1187 void SkOpCoincidence::dump() const { | 
| 1139     SkCoincidentSpans* span = fHead; | 1188     SkCoincidentSpans* span = fHead; | 
| 1140     while (span) { | 1189     while (span) { | 
| 1141         span->dump(); | 1190         span->dump(); | 
| 1142         span = span->fNext; | 1191         span = span->fNext; | 
| 1143     } | 1192     } | 
| 1144     if (!fTop) { | 1193     if (!fTop || fHead == fTop) { | 
| 1145         return; | 1194         return; | 
| 1146     } | 1195     } | 
| 1147     SkDebugf("top:\n"); | 1196     SkDebugf("top:\n"); | 
| 1148     span = fTop; | 1197     span = fTop; | 
|  | 1198     if (fHead) { | 
|  | 1199         span->dump(); | 
|  | 1200         return; | 
|  | 1201     } | 
| 1149     while (span) { | 1202     while (span) { | 
| 1150         span->dump(); | 1203         span->dump(); | 
| 1151         span = span->fNext; | 1204         span = span->fNext; | 
| 1152     } | 1205     } | 
| 1153 } | 1206 } | 
| 1154 | 1207 | 
| 1155 void SkOpContour::dump() const { | 1208 void SkOpContour::dump() const { | 
| 1156     SkDebugf("contour=%d count=%d op=%d xor=%d\n", this->debugID(), fCount, fOpe
      rand, fXor); | 1209     SkDebugf("contour=%d count=%d op=%d xor=%d\n", this->debugID(), fCount, fOpe
      rand, fXor); | 
| 1157     if (!fCount) { | 1210     if (!fCount) { | 
| 1158         return; | 1211         return; | 
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1192 | 1245 | 
| 1193 void SkOpContour::dumpPt(int index) const { | 1246 void SkOpContour::dumpPt(int index) const { | 
| 1194     const SkOpSegment* segment = &fHead; | 1247     const SkOpSegment* segment = &fHead; | 
| 1195     do { | 1248     do { | 
| 1196         if (segment->debugID() == index) { | 1249         if (segment->debugID() == index) { | 
| 1197             segment->dumpPts(); | 1250             segment->dumpPts(); | 
| 1198         } | 1251         } | 
| 1199     } while ((segment = segment->next())); | 1252     } while ((segment = segment->next())); | 
| 1200 } | 1253 } | 
| 1201 | 1254 | 
| 1202 void SkOpContour::dumpPts() const { | 1255 void SkOpContour::dumpPts(const char* prefix) const { | 
| 1203     SkDebugf("contour=%d\n", this->debugID()); | 1256     SkDebugf("contour=%d\n", this->debugID()); | 
| 1204     const SkOpSegment* segment = &fHead; | 1257     const SkOpSegment* segment = &fHead; | 
| 1205     do { | 1258     do { | 
| 1206         SkDebugf("  seg=%d ", segment->debugID()); | 1259         SkDebugf("  %s=%d ", prefix, segment->debugID()); | 
| 1207         segment->dumpPts(); | 1260         segment->dumpPts(prefix); | 
| 1208     } while ((segment = segment->next())); | 1261     } while ((segment = segment->next())); | 
| 1209 } | 1262 } | 
| 1210 | 1263 | 
| 1211 void SkOpContour::dumpPtsX() const { | 1264 void SkOpContour::dumpPtsX(const char* prefix) const { | 
| 1212     if (!this->fCount) { | 1265     if (!this->fCount) { | 
| 1213         SkDebugf("<empty>\n"); | 1266         SkDebugf("<empty>\n"); | 
| 1214         return; | 1267         return; | 
| 1215     } | 1268     } | 
| 1216     const SkOpSegment* segment = &fHead; | 1269     const SkOpSegment* segment = &fHead; | 
| 1217     do { | 1270     do { | 
| 1218         segment->dumpPts(); | 1271         segment->dumpPts(prefix); | 
| 1219     } while ((segment = segment->next())); | 1272     } while ((segment = segment->next())); | 
| 1220 } | 1273 } | 
| 1221 | 1274 | 
| 1222 void SkOpContour::dumpSegment(int index) const { | 1275 void SkOpContour::dumpSegment(int index) const { | 
| 1223     debugSegment(index)->dump(); | 1276     debugSegment(index)->dump(); | 
| 1224 } | 1277 } | 
| 1225 | 1278 | 
| 1226 void SkOpContour::dumpSegments(SkPathOp op) const { | 1279 void SkOpContour::dumpSegments(const char* prefix, SkPathOp op) const { | 
| 1227     bool firstOp = false; | 1280     bool firstOp = false; | 
| 1228     const SkOpContour* c = this; | 1281     const SkOpContour* c = this; | 
| 1229     do { | 1282     do { | 
| 1230         if (!firstOp && c->operand()) { | 1283         if (!firstOp && c->operand() && op >= 0) { | 
| 1231 #if DEBUG_ACTIVE_OP | 1284 #if DEBUG_ACTIVE_OP | 
| 1232             SkDebugf("op %s\n", SkPathOpsDebug::kPathOpStr[op]); | 1285             SkDebugf("op %s\n", SkPathOpsDebug::kPathOpStr[op]); | 
| 1233 #endif | 1286 #endif | 
| 1234             firstOp = true; | 1287             firstOp = true; | 
| 1235         } | 1288         } | 
| 1236         c->dumpPtsX(); | 1289         c->dumpPtsX(prefix); | 
| 1237     } while ((c = c->next())); | 1290     } while ((c = c->next())); | 
| 1238 } | 1291 } | 
| 1239 | 1292 | 
| 1240 void SkOpContour::dumpSpan(int index) const { | 1293 void SkOpContour::dumpSpan(int index) const { | 
| 1241     debugSpan(index)->dump(); | 1294     debugSpan(index)->dump(); | 
| 1242 } | 1295 } | 
| 1243 | 1296 | 
| 1244 void SkOpContour::dumpSpans() const { | 1297 void SkOpContour::dumpSpans() const { | 
| 1245     SkDebugf("contour=%d\n", this->debugID()); | 1298     SkDebugf("contour=%d\n", this->debugID()); | 
| 1246     const SkOpSegment* segment = &fHead; | 1299     const SkOpSegment* segment = &fHead; | 
| (...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1353             segment = segment->next(); | 1406             segment = segment->next(); | 
| 1354         } | 1407         } | 
| 1355     } while ((contour = contour->next())); | 1408     } while ((contour = contour->next())); | 
| 1356     return nullptr; | 1409     return nullptr; | 
| 1357 } | 1410 } | 
| 1358 #endif | 1411 #endif | 
| 1359 | 1412 | 
| 1360 #if DEBUG_T_SECT_DUMP > 1 | 1413 #if DEBUG_T_SECT_DUMP > 1 | 
| 1361 int gDumpTSectNum; | 1414 int gDumpTSectNum; | 
| 1362 #endif | 1415 #endif | 
| OLD | NEW | 
|---|