| /* | 
 |  * Copyright 2015 Google Inc. | 
 |  * | 
 |  * Use of this source code is governed by a BSD-style license that can be | 
 |  * found in the LICENSE file. | 
 |  */ | 
 | #ifndef SubsetPath_DEFINED | 
 | #define SubsetPath_DEFINED | 
 |  | 
 | #include "SkPath.h" | 
 | #include "SkTDArray.h" | 
 |  | 
 | /* Given a path, generate a the desired minimal subset of the original. | 
 |     | 
 |    This does a binary divide-and-conquer on the path, first splitting by | 
 |    contours, and then by verbs. The caller passes whether the previous subset | 
 |    behaved the same as the original. If not, the subset() call restores the | 
 |    prior state before returning a new subset. | 
 |     | 
 |    If a path fails a local test, this reduces the data to the | 
 |    minimal set that fails using a pattern like: | 
 |     | 
 |    bool testFailed = true; | 
 |    SkPath minimal; | 
 |    SubsetContours subsetContours(testPath); | 
 |    while (subsetContours.subset(testFailed, &minimal)) { | 
 |        testFailed = myPathTest(minimal); | 
 |    } | 
 |    testFailed = true; | 
 |    SubsetVerbs subsetVerbs(testPath); | 
 |    while (subsetVerbs.subset(testFailed, &minimal)) { | 
 |        testFailed = myPathTest(minimal); | 
 |    } | 
 | */ | 
 |  | 
 | class SubsetPath { | 
 | public: | 
 |     SubsetPath(const SkPath& path); | 
 |     virtual ~SubsetPath() {} | 
 |     bool subset(bool testFailed, SkPath* sub); | 
 | protected: | 
 |     int range(int* end) const; | 
 |     virtual SkPath getSubsetPath() const = 0; | 
 |  | 
 |     const SkPath& fPath; | 
 |     SkTDArray<bool> fSelected; | 
 |     int fSubset; | 
 |     int fTries; | 
 |  | 
 | }; | 
 |  | 
 | class SubsetContours : public SubsetPath { | 
 | public: | 
 |     SubsetContours(const SkPath& path); | 
 | protected: | 
 |     SkPath getSubsetPath() const override; | 
 | }; | 
 |  | 
 | class SubsetVerbs : public SubsetPath { | 
 | public: | 
 |     SubsetVerbs(const SkPath& path); | 
 | protected: | 
 |     SkPath getSubsetPath() const override; | 
 | }; | 
 |  | 
 | #endif |