blob: a75522e4fddb0e7f7f25af0754f09fa61071930c [file] [log] [blame]
caryclark@google.com7dfbb072013-04-22 14:37:05 +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#include "PathOpsExtendedTest.h"
8
tfarina@chromium.org78e7b4e2014-01-02 21:45:03 +00009DEF_TEST(PathOpsInverse, reporter) {
caryclark@google.com7dfbb072013-04-22 14:37:05 +000010 SkPath one, two;
Cary Clark4533f3d2018-08-08 09:48:09 -040011 int testCount = 0;
caryclark54359292015-03-26 07:52:43 -070012 for (int op = kDifference_SkPathOp; op <= kReverseDifference_SkPathOp; ++op) {
caryclark@google.com7dfbb072013-04-22 14:37:05 +000013 for (int oneFill = SkPath::kWinding_FillType; oneFill <= SkPath::kInverseEvenOdd_FillType;
14 ++oneFill) {
15 for (int oneDir = SkPath::kCW_Direction; oneDir != SkPath::kCCW_Direction; ++oneDir) {
16 one.reset();
17 one.setFillType((SkPath::FillType) oneFill);
18 one.addRect(0, 0, 6, 6, (SkPath::Direction) oneDir);
19 for (int twoFill = SkPath::kWinding_FillType;
20 twoFill <= SkPath::kInverseEvenOdd_FillType; ++twoFill) {
21 for (int twoDir = SkPath::kCW_Direction; twoDir != SkPath::kCCW_Direction;
22 ++twoDir) {
23 two.reset();
24 two.setFillType((SkPath::FillType) twoFill);
25 two.addRect(3, 3, 9, 9, (SkPath::Direction) twoDir);
Cary Clark4533f3d2018-08-08 09:48:09 -040026 SkString testName;
27 testName.printf("inverseTest%d", ++testCount);
28 testPathOp(reporter, one, two, (SkPathOp) op, testName.c_str());
caryclark@google.com7dfbb072013-04-22 14:37:05 +000029 }
30 }
31 }
32 }
33 }
34}