| 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 |