Removing path drawing gm tests that produce either an entirely
filled or entirely empty clip area. Requested but not reviewed by
reed@google.com.

TEST=Covered now by unit testing.

git-svn-id: http://skia.googlecode.com/svn/trunk@2956 2bbb7eff-a529-9590-31e7-b0007b416f81
diff --git a/gm/cubicpaths.cpp b/gm/cubicpaths.cpp
index e8c38d1..7cd3df1 100644
--- a/gm/cubicpaths.cpp
+++ b/gm/cubicpaths.cpp
@@ -10,292 +10,6 @@
 #include "SkRandom.h"
 
 namespace skiagm {
-class ZeroCubicPathGM : public GM {
-public:
-    ZeroCubicPathGM() {}
-
-protected:
-    SkString onShortName() {
-        return SkString("zerocubicpath");
-    }
-        
-    SkISize onISize() { return make_isize(1240, 390); }
-    
-    void drawPath(SkPath& path,SkCanvas* canvas,SkColor color,
-                  const SkRect& clip,SkPaint::Cap cap, SkPaint::Join join,
-                  SkPaint::Style style, SkPath::FillType fill,
-                  SkScalar strokeWidth) {
-        path.setFillType(fill);
-        SkPaint paint;
-        paint.setStrokeCap(cap);
-        paint.setStrokeWidth(strokeWidth);
-        paint.setStrokeJoin(join);
-        paint.setColor(color);
-        paint.setStyle(style);
-        canvas->save();
-        canvas->clipRect(clip);
-        canvas->drawPath(path, paint);
-        canvas->restore();
-    }
-    
-    virtual void onDraw(SkCanvas* canvas) {
-        struct FillAndName {
-            SkPath::FillType fFill;
-            const char*      fName;
-        };
-        static const FillAndName gFills[] = {
-            {SkPath::kWinding_FillType, "Winding"},
-            {SkPath::kEvenOdd_FillType, "Even / Odd"},
-            {SkPath::kInverseWinding_FillType, "Inverse Winding"},
-            {SkPath::kInverseEvenOdd_FillType, "Inverse Even / Odd"},
-        };
-        struct StyleAndName {
-            SkPaint::Style fStyle;
-            const char*    fName;
-        };
-        static const StyleAndName gStyles[] = {
-            {SkPaint::kFill_Style, "Fill"},
-            {SkPaint::kStroke_Style, "Stroke"},
-            {SkPaint::kStrokeAndFill_Style, "Stroke And Fill"},
-        };
-        struct CapAndName {
-            SkPaint::Cap  fCap;
-            SkPaint::Join fJoin;
-            const char*   fName;
-        };
-        static const CapAndName gCaps[] = {
-            {SkPaint::kButt_Cap, SkPaint::kBevel_Join, "Butt"},
-            {SkPaint::kRound_Cap, SkPaint::kRound_Join, "Round"},
-            {SkPaint::kSquare_Cap, SkPaint::kBevel_Join, "Square"}
-        };
-        struct PathAndName {
-            SkPath      fPath;
-            const char* fName;
-        };
-        PathAndName path;
-        path.fPath.moveTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.cubicTo(50*SK_Scalar1, 15*SK_Scalar1,
-                           50*SK_Scalar1, 15*SK_Scalar1,
-                           50*SK_Scalar1, 15*SK_Scalar1);
-        path.fName = "moveTo-zerocubic";
-
-        SkPaint titlePaint;
-        titlePaint.setColor(SK_ColorBLACK);
-        titlePaint.setAntiAlias(true);
-        titlePaint.setLCDRenderText(true);
-        titlePaint.setTextSize(15 * SK_Scalar1);
-        const char title[] = "Zero-Length Cubic Drawn Into Rectangle Clips With "
-                             "Indicated Style, Fill and Linecaps, with stroke width 10";
-        canvas->drawText(title, strlen(title),
-                            20 * SK_Scalar1,
-                            20 * SK_Scalar1,
-                            titlePaint);
-
-        SkRandom rand;
-        SkRect rect = SkRect::MakeWH(100*SK_Scalar1, 30*SK_Scalar1);
-        canvas->save();
-        canvas->translate(10 * SK_Scalar1, 30 * SK_Scalar1);
-        canvas->save();
-        for (size_t cap = 0; cap < SK_ARRAY_COUNT(gCaps); ++cap) {
-            if (0 < cap) {
-                canvas->translate((rect.width() + 40 * SK_Scalar1) * SK_ARRAY_COUNT(gStyles), 0);
-            }
-            canvas->save();
-            for (size_t fill = 0; fill < SK_ARRAY_COUNT(gFills); ++fill) {
-                if (0 < fill) {
-                    canvas->translate(0, rect.height() + 40 * SK_Scalar1);
-                }
-                canvas->save();
-                for (size_t style = 0; style < SK_ARRAY_COUNT(gStyles); ++style) {
-                    if (0 < style) {
-                        canvas->translate(rect.width() + 40 * SK_Scalar1, 0);
-                    }
-        
-                    SkColor color = 0xff007000;
-                    this->drawPath(path.fPath, canvas, color, rect,
-                                    gCaps[cap].fCap, gCaps[cap].fJoin, gStyles[style].fStyle,
-                                    gFills[fill].fFill, SK_Scalar1*10);
-        
-                    SkPaint rectPaint;
-                    rectPaint.setColor(SK_ColorBLACK);
-                    rectPaint.setStyle(SkPaint::kStroke_Style);
-                    rectPaint.setStrokeWidth(-1);
-                    rectPaint.setAntiAlias(true);
-                    canvas->drawRect(rect, rectPaint);
-        
-                    SkPaint labelPaint;
-                    labelPaint.setColor(color);
-                    labelPaint.setAntiAlias(true);
-                    labelPaint.setLCDRenderText(true);
-                    labelPaint.setTextSize(10 * SK_Scalar1);
-                    canvas->drawText(gStyles[style].fName,
-                                        strlen(gStyles[style].fName),
-                                        0, rect.height() + 12 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gFills[fill].fName,
-                                        strlen(gFills[fill].fName),
-                                        0, rect.height() + 24 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gCaps[cap].fName,
-                                        strlen(gCaps[cap].fName),
-                                        0, rect.height() + 36 * SK_Scalar1,
-                                        labelPaint);
-                }
-                canvas->restore();
-            }
-            canvas->restore();
-        }
-        canvas->restore();
-        canvas->restore();
-    }
-    
-private:
-    typedef GM INHERITED;
-};
-
-class ZeroCubicClosePathGM : public GM {
-public:
-    ZeroCubicClosePathGM() {}
-
-protected:
-    SkString onShortName() {
-        return SkString("zerocubicclosepath");
-    }
-        
-    SkISize onISize() { return make_isize(1240, 390); }
-    
-    void drawPath(SkPath& path,SkCanvas* canvas,SkColor color,
-                  const SkRect& clip,SkPaint::Cap cap, SkPaint::Join join,
-                  SkPaint::Style style, SkPath::FillType fill,
-                  SkScalar strokeWidth) {
-        path.setFillType(fill);
-        SkPaint paint;
-        paint.setStrokeCap(cap);
-        paint.setStrokeWidth(strokeWidth);
-        paint.setStrokeJoin(join);
-        paint.setColor(color);
-        paint.setStyle(style);
-        canvas->save();
-        canvas->clipRect(clip);
-        canvas->drawPath(path, paint);
-        canvas->restore();
-    }
-    
-    virtual void onDraw(SkCanvas* canvas) {
-        struct FillAndName {
-            SkPath::FillType fFill;
-            const char*      fName;
-        };
-        static const FillAndName gFills[] = {
-            {SkPath::kWinding_FillType, "Winding"},
-            {SkPath::kEvenOdd_FillType, "Even / Odd"},
-            {SkPath::kInverseWinding_FillType, "Inverse Winding"},
-            {SkPath::kInverseEvenOdd_FillType, "Inverse Even / Odd"},
-        };
-        struct StyleAndName {
-            SkPaint::Style fStyle;
-            const char*    fName;
-        };
-        static const StyleAndName gStyles[] = {
-            {SkPaint::kFill_Style, "Fill"},
-            {SkPaint::kStroke_Style, "Stroke"},
-            {SkPaint::kStrokeAndFill_Style, "Stroke And Fill"},
-        };
-        struct CapAndName {
-            SkPaint::Cap  fCap;
-            SkPaint::Join fJoin;
-            const char*   fName;
-        };
-        static const CapAndName gCaps[] = {
-            {SkPaint::kButt_Cap, SkPaint::kBevel_Join, "Butt"},
-            {SkPaint::kRound_Cap, SkPaint::kRound_Join, "Round"},
-            {SkPaint::kSquare_Cap, SkPaint::kBevel_Join, "Square"}
-        };
-        struct PathAndName {
-            SkPath      fPath;
-            const char* fName;
-        };
-        PathAndName path;
-        path.fPath.moveTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.cubicTo(50*SK_Scalar1, 15*SK_Scalar1,
-                           50*SK_Scalar1, 15*SK_Scalar1,
-                           50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.close();
-        path.fName = "moveTo-zerocubic-close";
-
-        SkPaint titlePaint;
-        titlePaint.setColor(SK_ColorBLACK);
-        titlePaint.setAntiAlias(true);
-        titlePaint.setLCDRenderText(true);
-        titlePaint.setTextSize(15 * SK_Scalar1);
-        const char title[] = "Zero-Length Cubic Closed Drawn Into Rectangle Clips With "
-                             "Indicated Style, Fill and Linecaps, with stroke width 10";
-        canvas->drawText(title, strlen(title),
-                            20 * SK_Scalar1,
-                            20 * SK_Scalar1,
-                            titlePaint);
-
-        SkRandom rand;
-        SkRect rect = SkRect::MakeWH(100*SK_Scalar1, 30*SK_Scalar1);
-        canvas->save();
-        canvas->translate(10 * SK_Scalar1, 30 * SK_Scalar1);
-        canvas->save();
-        for (size_t cap = 0; cap < SK_ARRAY_COUNT(gCaps); ++cap) {
-            if (0 < cap) {
-                canvas->translate((rect.width() + 40 * SK_Scalar1) * SK_ARRAY_COUNT(gStyles), 0);
-            }
-            canvas->save();
-            for (size_t fill = 0; fill < SK_ARRAY_COUNT(gFills); ++fill) {
-                if (0 < fill) {
-                    canvas->translate(0, rect.height() + 40 * SK_Scalar1);
-                }
-                canvas->save();
-                for (size_t style = 0; style < SK_ARRAY_COUNT(gStyles); ++style) {
-                    if (0 < style) {
-                        canvas->translate(rect.width() + 40 * SK_Scalar1, 0);
-                    }
-        
-                    SkColor color = 0xff007000;
-                    this->drawPath(path.fPath, canvas, color, rect,
-                                    gCaps[cap].fCap, gCaps[cap].fJoin, gStyles[style].fStyle,
-                                    gFills[fill].fFill, SK_Scalar1*10);
-        
-                    SkPaint rectPaint;
-                    rectPaint.setColor(SK_ColorBLACK);
-                    rectPaint.setStyle(SkPaint::kStroke_Style);
-                    rectPaint.setStrokeWidth(-1);
-                    rectPaint.setAntiAlias(true);
-                    canvas->drawRect(rect, rectPaint);
-        
-                    SkPaint labelPaint;
-                    labelPaint.setColor(color);
-                    labelPaint.setAntiAlias(true);
-                    labelPaint.setLCDRenderText(true);
-                    labelPaint.setTextSize(10 * SK_Scalar1);
-                    canvas->drawText(gStyles[style].fName,
-                                        strlen(gStyles[style].fName),
-                                        0, rect.height() + 12 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gFills[fill].fName,
-                                        strlen(gFills[fill].fName),
-                                        0, rect.height() + 24 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gCaps[cap].fName,
-                                        strlen(gCaps[cap].fName),
-                                        0, rect.height() + 36 * SK_Scalar1,
-                                        labelPaint);
-                }
-                canvas->restore();
-            }
-            canvas->restore();
-        }
-        canvas->restore();
-        canvas->restore();
-    }
-    
-private:
-    typedef GM INHERITED;
-};
 
 class CubicPathGM : public GM {
 public:
@@ -586,12 +300,6 @@
 
 //////////////////////////////////////////////////////////////////////////////
 
-static GM* ZeroCubicPathFactory(void*) { return new ZeroCubicPathGM; }
-static GMRegistry regZeroCubicPath(ZeroCubicPathFactory);
-
-static GM* ZeroCubicClosePathFactory(void*) { return new ZeroCubicClosePathGM; }
-static GMRegistry regZeroCubicClosePath(ZeroCubicClosePathFactory);
-
 static GM* CubicPathFactory(void*) { return new CubicPathGM; }
 static GMRegistry regCubicPath(CubicPathFactory);
 
diff --git a/gm/linepaths.cpp b/gm/linepaths.cpp
index 99c9c49..3d84c37 100644
--- a/gm/linepaths.cpp
+++ b/gm/linepaths.cpp
@@ -11,289 +11,6 @@
 
 namespace skiagm {
 
-class ZeroLinePathGM : public GM {
-public:
-    ZeroLinePathGM() {}
-
-protected:
-    SkString onShortName() {
-        return SkString("zerolinepath");
-    }
-        
-    SkISize onISize() { return make_isize(1240, 390); }
-    
-    void drawPath(SkPath& path,SkCanvas* canvas,SkColor color,
-                  const SkRect& clip,SkPaint::Cap cap, SkPaint::Join join,
-                  SkPaint::Style style, SkPath::FillType fill,
-                  SkScalar strokeWidth) {
-        path.setFillType(fill);
-        SkPaint paint;
-        paint.setStrokeCap(cap);
-        paint.setStrokeWidth(strokeWidth);
-        paint.setStrokeJoin(join);
-        paint.setColor(color);
-        paint.setStyle(style);
-        canvas->save();
-        canvas->clipRect(clip);
-        canvas->drawPath(path, paint);
-        canvas->restore();
-    }
-    
-    virtual void onDraw(SkCanvas* canvas) {
-        struct FillAndName {
-            SkPath::FillType fFill;
-            const char*      fName;
-        };
-        static const FillAndName gFills[] = {
-            {SkPath::kWinding_FillType, "Winding"},
-            {SkPath::kEvenOdd_FillType, "Even / Odd"},
-            {SkPath::kInverseWinding_FillType, "Inverse Winding"},
-            {SkPath::kInverseEvenOdd_FillType, "Inverse Even / Odd"},
-        };
-        struct StyleAndName {
-            SkPaint::Style fStyle;
-            const char*    fName;
-        };
-        static const StyleAndName gStyles[] = {
-            {SkPaint::kFill_Style, "Fill"},
-            {SkPaint::kStroke_Style, "Stroke"},
-            {SkPaint::kStrokeAndFill_Style, "Stroke And Fill"},
-        };
-        struct CapAndName {
-            SkPaint::Cap  fCap;
-            SkPaint::Join fJoin;
-            const char*   fName;
-        };
-        static const CapAndName gCaps[] = {
-            {SkPaint::kButt_Cap, SkPaint::kBevel_Join, "Butt"},
-            {SkPaint::kRound_Cap, SkPaint::kRound_Join, "Round"},
-            {SkPaint::kSquare_Cap, SkPaint::kBevel_Join, "Square"}
-        };
-        struct PathAndName {
-            SkPath      fPath;
-            const char* fName;
-        };
-        PathAndName path;
-        path.fPath.moveTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.lineTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fName = "moveTo-zeroline";
-
-        SkPaint titlePaint;
-        titlePaint.setColor(SK_ColorBLACK);
-        titlePaint.setAntiAlias(true);
-        titlePaint.setLCDRenderText(true);
-        titlePaint.setTextSize(15 * SK_Scalar1);
-        const char title[] = "Zero-Length Line Drawn Into Rectangle Clips With "
-                             "Indicated Style, Fill and Linecaps, with stroke width 10";
-        canvas->drawText(title, strlen(title),
-                            20 * SK_Scalar1,
-                            20 * SK_Scalar1,
-                            titlePaint);
-
-        SkRandom rand;
-        SkRect rect = SkRect::MakeWH(100*SK_Scalar1, 30*SK_Scalar1);
-        canvas->save();
-        canvas->translate(10 * SK_Scalar1, 30 * SK_Scalar1);
-        canvas->save();
-        for (size_t cap = 0; cap < SK_ARRAY_COUNT(gCaps); ++cap) {
-            if (0 < cap) {
-                canvas->translate((rect.width() + 40 * SK_Scalar1) * SK_ARRAY_COUNT(gStyles), 0);
-            }
-            canvas->save();
-            for (size_t fill = 0; fill < SK_ARRAY_COUNT(gFills); ++fill) {
-                if (0 < fill) {
-                    canvas->translate(0, rect.height() + 40 * SK_Scalar1);
-                }
-                canvas->save();
-                for (size_t style = 0; style < SK_ARRAY_COUNT(gStyles); ++style) {
-                    if (0 < style) {
-                        canvas->translate(rect.width() + 40 * SK_Scalar1, 0);
-                    }
-        
-                    SkColor color = 0xff007000;
-                    this->drawPath(path.fPath, canvas, color, rect,
-                                    gCaps[cap].fCap, gCaps[cap].fJoin, gStyles[style].fStyle,
-                                    gFills[fill].fFill, SK_Scalar1*10);
-        
-                    SkPaint rectPaint;
-                    rectPaint.setColor(SK_ColorBLACK);
-                    rectPaint.setStyle(SkPaint::kStroke_Style);
-                    rectPaint.setStrokeWidth(-1);
-                    rectPaint.setAntiAlias(true);
-                    canvas->drawRect(rect, rectPaint);
-        
-                    SkPaint labelPaint;
-                    labelPaint.setColor(color);
-                    labelPaint.setAntiAlias(true);
-                    labelPaint.setLCDRenderText(true);
-                    labelPaint.setTextSize(10 * SK_Scalar1);
-                    canvas->drawText(gStyles[style].fName,
-                                        strlen(gStyles[style].fName),
-                                        0, rect.height() + 12 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gFills[fill].fName,
-                                        strlen(gFills[fill].fName),
-                                        0, rect.height() + 24 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gCaps[cap].fName,
-                                        strlen(gCaps[cap].fName),
-                                        0, rect.height() + 36 * SK_Scalar1,
-                                        labelPaint);
-                }
-                canvas->restore();
-            }
-            canvas->restore();
-        }
-        canvas->restore();
-        canvas->restore();
-    }
-    
-private:
-    typedef GM INHERITED;
-};
-
-class ZeroLineClosePathGM : public GM {
-public:
-    ZeroLineClosePathGM() {}
-
-protected:
-    SkString onShortName() {
-        return SkString("zerolineclosepath");
-    }
-        
-    SkISize onISize() { return make_isize(1240, 390); }
-    
-    void drawPath(SkPath& path,SkCanvas* canvas,SkColor color,
-                  const SkRect& clip,SkPaint::Cap cap, SkPaint::Join join,
-                  SkPaint::Style style, SkPath::FillType fill,
-                  SkScalar strokeWidth) {
-        path.setFillType(fill);
-        SkPaint paint;
-        paint.setStrokeCap(cap);
-        paint.setStrokeJoin(join);
-        paint.setStrokeWidth(strokeWidth);
-        paint.setColor(color);
-        paint.setStyle(style);
-        canvas->save();
-        canvas->clipRect(clip);
-        canvas->drawPath(path, paint);
-        canvas->restore();
-    }
-    
-    virtual void onDraw(SkCanvas* canvas) {
-        struct FillAndName {
-            SkPath::FillType fFill;
-            const char*      fName;
-        };
-        static const FillAndName gFills[] = {
-            {SkPath::kWinding_FillType, "Winding"},
-            {SkPath::kEvenOdd_FillType, "Even / Odd"},
-            {SkPath::kInverseWinding_FillType, "Inverse Winding"},
-            {SkPath::kInverseEvenOdd_FillType, "Inverse Even / Odd"},
-        };
-        struct StyleAndName {
-            SkPaint::Style fStyle;
-            const char*    fName;
-        };
-        static const StyleAndName gStyles[] = {
-            {SkPaint::kFill_Style, "Fill"},
-            {SkPaint::kStroke_Style, "Stroke"},
-            {SkPaint::kStrokeAndFill_Style, "Stroke And Fill"},
-        };
-        struct CapAndName {
-            SkPaint::Cap  fCap;
-            SkPaint::Join fJoin;
-            const char*   fName;
-        };
-        static const CapAndName gCaps[] = {
-            {SkPaint::kButt_Cap, SkPaint::kBevel_Join, "Butt"},
-            {SkPaint::kRound_Cap, SkPaint::kRound_Join, "Round"},
-            {SkPaint::kSquare_Cap, SkPaint::kBevel_Join, "Square"}
-        };
-        struct PathAndName {
-            SkPath      fPath;
-            const char* fName;
-        };
-        PathAndName path;
-        path.fPath.moveTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.lineTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.close();
-        path.fName = "moveTo-zeroline-close";
-
-        SkPaint titlePaint;
-        titlePaint.setColor(SK_ColorBLACK);
-        titlePaint.setAntiAlias(true);
-        titlePaint.setLCDRenderText(true);
-        titlePaint.setTextSize(15 * SK_Scalar1);
-        const char title[] = "Zero-Length Line Closed Drawn Into Rectangle Clips With "
-                             "Indicated Style, Fill and Linecaps, with stroke width 10";
-        canvas->drawText(title, strlen(title),
-                            20 * SK_Scalar1,
-                            20 * SK_Scalar1,
-                            titlePaint);
-
-        SkRandom rand;
-        SkRect rect = SkRect::MakeWH(100*SK_Scalar1, 30*SK_Scalar1);
-        canvas->save();
-        canvas->translate(10 * SK_Scalar1, 30 * SK_Scalar1);
-        canvas->save();
-        for (size_t cap = 0; cap < SK_ARRAY_COUNT(gCaps); ++cap) {
-            if (0 < cap) {
-                canvas->translate((rect.width() + 40 * SK_Scalar1) * SK_ARRAY_COUNT(gStyles), 0);
-            }
-            canvas->save();
-            for (size_t fill = 0; fill < SK_ARRAY_COUNT(gFills); ++fill) {
-                if (0 < fill) {
-                    canvas->translate(0, rect.height() + 40 * SK_Scalar1);
-                }
-                canvas->save();
-                for (size_t style = 0; style < SK_ARRAY_COUNT(gStyles); ++style) {
-                    if (0 < style) {
-                        canvas->translate(rect.width() + 40 * SK_Scalar1, 0);
-                    }
-        
-                    SkColor color = 0xff007000;
-                    this->drawPath(path.fPath, canvas, color, rect,
-                                    gCaps[cap].fCap, gCaps[cap].fJoin, gStyles[style].fStyle,
-                                    gFills[fill].fFill, SK_Scalar1*10);
-        
-                    SkPaint rectPaint;
-                    rectPaint.setColor(SK_ColorBLACK);
-                    rectPaint.setStyle(SkPaint::kStroke_Style);
-                    rectPaint.setStrokeWidth(-1);
-                    rectPaint.setAntiAlias(true);
-                    canvas->drawRect(rect, rectPaint);
-        
-                    SkPaint labelPaint;
-                    labelPaint.setColor(color);
-                    labelPaint.setAntiAlias(true);
-                    labelPaint.setLCDRenderText(true);
-                    labelPaint.setTextSize(10 * SK_Scalar1);
-                    canvas->drawText(gStyles[style].fName,
-                                        strlen(gStyles[style].fName),
-                                        0, rect.height() + 12 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gFills[fill].fName,
-                                        strlen(gFills[fill].fName),
-                                        0, rect.height() + 24 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gCaps[cap].fName,
-                                        strlen(gCaps[cap].fName),
-                                        0, rect.height() + 36 * SK_Scalar1,
-                                        labelPaint);
-                }
-                canvas->restore();
-            }
-            canvas->restore();
-        }
-        canvas->restore();
-        canvas->restore();
-    }
-    
-private:
-    typedef GM INHERITED;
-};
-
 class LinePathGM : public GM {
 public:
     LinePathGM() {}
@@ -579,12 +296,6 @@
 
 //////////////////////////////////////////////////////////////////////////////
 
-static GM* ZeroLinePathFactory(void*) { return new ZeroLinePathGM; }
-static GMRegistry regZeroLinePath(ZeroLinePathFactory);
-
-static GM* ZeroLineClosePathFactory(void*) { return new ZeroLineClosePathGM; }
-static GMRegistry regZeroLineClosePath(ZeroLineClosePathFactory);
-
 static GM* LinePathFactory(void*) { return new LinePathGM; }
 static GMRegistry regLinePath(LinePathFactory);
 
diff --git a/gm/quadpaths.cpp b/gm/quadpaths.cpp
index 1ae9e15..f8b172b 100644
--- a/gm/quadpaths.cpp
+++ b/gm/quadpaths.cpp
@@ -11,291 +11,6 @@
 
 namespace skiagm {
 
-class ZeroQuadPathGM : public GM {
-public:
-    ZeroQuadPathGM() {}
-
-protected:
-    SkString onShortName() {
-        return SkString("zeroquadpath");
-    }
-        
-    SkISize onISize() { return make_isize(1240, 390); }
-    
-    void drawPath(SkPath& path,SkCanvas* canvas,SkColor color,
-                  const SkRect& clip,SkPaint::Cap cap, SkPaint::Join join,
-                  SkPaint::Style style, SkPath::FillType fill,
-                  SkScalar strokeWidth) {
-        path.setFillType(fill);
-        SkPaint paint;
-        paint.setStrokeCap(cap);
-        paint.setStrokeWidth(strokeWidth);
-        paint.setStrokeJoin(join);
-        paint.setColor(color);
-        paint.setStyle(style);
-        canvas->save();
-        canvas->clipRect(clip);
-        canvas->drawPath(path, paint);
-        canvas->restore();
-    }
-    
-    virtual void onDraw(SkCanvas* canvas) {
-        struct FillAndName {
-            SkPath::FillType fFill;
-            const char*      fName;
-        };
-        static const FillAndName gFills[] = {
-            {SkPath::kWinding_FillType, "Winding"},
-            {SkPath::kEvenOdd_FillType, "Even / Odd"},
-            {SkPath::kInverseWinding_FillType, "Inverse Winding"},
-            {SkPath::kInverseEvenOdd_FillType, "Inverse Even / Odd"},
-        };
-        struct StyleAndName {
-            SkPaint::Style fStyle;
-            const char*    fName;
-        };
-        static const StyleAndName gStyles[] = {
-            {SkPaint::kFill_Style, "Fill"},
-            {SkPaint::kStroke_Style, "Stroke"},
-            {SkPaint::kStrokeAndFill_Style, "Stroke And Fill"},
-        };
-        struct CapAndName {
-            SkPaint::Cap  fCap;
-            SkPaint::Join fJoin;
-            const char*   fName;
-        };
-        static const CapAndName gCaps[] = {
-            {SkPaint::kButt_Cap, SkPaint::kBevel_Join, "Butt"},
-            {SkPaint::kRound_Cap, SkPaint::kRound_Join, "Round"},
-            {SkPaint::kSquare_Cap, SkPaint::kBevel_Join, "Square"}
-        };
-        struct PathAndName {
-            SkPath      fPath;
-            const char* fName;
-        };
-        PathAndName path;
-        path.fPath.moveTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.quadTo(50*SK_Scalar1, 15*SK_Scalar1,
-                          50*SK_Scalar1, 15*SK_Scalar1);
-        path.fName = "moveTo-zeroquad";
-
-        SkPaint titlePaint;
-        titlePaint.setColor(SK_ColorBLACK);
-        titlePaint.setAntiAlias(true);
-        titlePaint.setLCDRenderText(true);
-        titlePaint.setTextSize(15 * SK_Scalar1);
-        const char title[] = "Zero-Length Quad Drawn Into Rectangle Clips With "
-                             "Indicated Style, Fill and Linecaps, with stroke width 10";
-        canvas->drawText(title, strlen(title),
-                            20 * SK_Scalar1,
-                            20 * SK_Scalar1,
-                            titlePaint);
-
-        SkRandom rand;
-        SkRect rect = SkRect::MakeWH(100*SK_Scalar1, 30*SK_Scalar1);
-        canvas->save();
-        canvas->translate(10 * SK_Scalar1, 30 * SK_Scalar1);
-        canvas->save();
-        for (size_t cap = 0; cap < SK_ARRAY_COUNT(gCaps); ++cap) {
-            if (0 < cap) {
-                canvas->translate((rect.width() + 40 * SK_Scalar1) * SK_ARRAY_COUNT(gStyles), 0);
-            }
-            canvas->save();
-            for (size_t fill = 0; fill < SK_ARRAY_COUNT(gFills); ++fill) {
-                if (0 < fill) {
-                    canvas->translate(0, rect.height() + 40 * SK_Scalar1);
-                }
-                canvas->save();
-                for (size_t style = 0; style < SK_ARRAY_COUNT(gStyles); ++style) {
-                    if (0 < style) {
-                        canvas->translate(rect.width() + 40 * SK_Scalar1, 0);
-                    }
-        
-                    SkColor color = 0xff007000;
-                    this->drawPath(path.fPath, canvas, color, rect,
-                                    gCaps[cap].fCap, gCaps[cap].fJoin, gStyles[style].fStyle,
-                                    gFills[fill].fFill, SK_Scalar1*10);
-        
-                    SkPaint rectPaint;
-                    rectPaint.setColor(SK_ColorBLACK);
-                    rectPaint.setStyle(SkPaint::kStroke_Style);
-                    rectPaint.setStrokeWidth(-1);
-                    rectPaint.setAntiAlias(true);
-                    canvas->drawRect(rect, rectPaint);
-        
-                    SkPaint labelPaint;
-                    labelPaint.setColor(color);
-                    labelPaint.setAntiAlias(true);
-                    labelPaint.setLCDRenderText(true);
-                    labelPaint.setTextSize(10 * SK_Scalar1);
-                    canvas->drawText(gStyles[style].fName,
-                                        strlen(gStyles[style].fName),
-                                        0, rect.height() + 12 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gFills[fill].fName,
-                                        strlen(gFills[fill].fName),
-                                        0, rect.height() + 24 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gCaps[cap].fName,
-                                        strlen(gCaps[cap].fName),
-                                        0, rect.height() + 36 * SK_Scalar1,
-                                        labelPaint);
-                }
-                canvas->restore();
-            }
-            canvas->restore();
-        }
-        canvas->restore();
-        canvas->restore();
-    }
-    
-private:
-    typedef GM INHERITED;
-};
-
-class ZeroQuadClosePathGM : public GM {
-public:
-    ZeroQuadClosePathGM() {}
-
-protected:
-    SkString onShortName() {
-        return SkString("zeroquadclosepath");
-    }
-        
-    SkISize onISize() { return make_isize(1240, 390); }
-    
-    void drawPath(SkPath& path,SkCanvas* canvas,SkColor color,
-                  const SkRect& clip,SkPaint::Cap cap, SkPaint::Join join,
-                  SkPaint::Style style, SkPath::FillType fill,
-                  SkScalar strokeWidth) {
-        path.setFillType(fill);
-        SkPaint paint;
-        paint.setStrokeCap(cap);
-        paint.setStrokeWidth(strokeWidth);
-        paint.setStrokeJoin(join);
-        paint.setColor(color);
-        paint.setStyle(style);
-        canvas->save();
-        canvas->clipRect(clip);
-        canvas->drawPath(path, paint);
-        canvas->restore();
-    }
-    
-    virtual void onDraw(SkCanvas* canvas) {
-        struct FillAndName {
-            SkPath::FillType fFill;
-            const char*      fName;
-        };
-        static const FillAndName gFills[] = {
-            {SkPath::kWinding_FillType, "Winding"},
-            {SkPath::kEvenOdd_FillType, "Even / Odd"},
-            {SkPath::kInverseWinding_FillType, "Inverse Winding"},
-            {SkPath::kInverseEvenOdd_FillType, "Inverse Even / Odd"},
-        };
-        struct StyleAndName {
-            SkPaint::Style fStyle;
-            const char*    fName;
-        };
-        static const StyleAndName gStyles[] = {
-            {SkPaint::kFill_Style, "Fill"},
-            {SkPaint::kStroke_Style, "Stroke"},
-            {SkPaint::kStrokeAndFill_Style, "Stroke And Fill"},
-        };
-        struct CapAndName {
-            SkPaint::Cap  fCap;
-            SkPaint::Join fJoin;
-            const char*   fName;
-        };
-        static const CapAndName gCaps[] = {
-            {SkPaint::kButt_Cap, SkPaint::kBevel_Join, "Butt"},
-            {SkPaint::kRound_Cap, SkPaint::kRound_Join, "Round"},
-            {SkPaint::kSquare_Cap, SkPaint::kBevel_Join, "Square"}
-        };
-        struct PathAndName {
-            SkPath      fPath;
-            const char* fName;
-        };
-        PathAndName path;
-        path.fPath.moveTo(50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.quadTo(50*SK_Scalar1, 15*SK_Scalar1,
-                          50*SK_Scalar1, 15*SK_Scalar1);
-        path.fPath.close();
-        path.fName = "moveTo-zeroquad-close";
-
-        SkPaint titlePaint;
-        titlePaint.setColor(SK_ColorBLACK);
-        titlePaint.setAntiAlias(true);
-        titlePaint.setLCDRenderText(true);
-        titlePaint.setTextSize(15 * SK_Scalar1);
-        const char title[] = "Zero-Length Quad Closed Drawn Into Rectangle Clips With "
-                             "Indicated Style, Fill and Linecaps, with stroke width 10";
-        canvas->drawText(title, strlen(title),
-                            20 * SK_Scalar1,
-                            20 * SK_Scalar1,
-                            titlePaint);
-
-        SkRandom rand;
-        SkRect rect = SkRect::MakeWH(100*SK_Scalar1, 30*SK_Scalar1);
-        canvas->save();
-        canvas->translate(10 * SK_Scalar1, 30 * SK_Scalar1);
-        canvas->save();
-        for (size_t cap = 0; cap < SK_ARRAY_COUNT(gCaps); ++cap) {
-            if (0 < cap) {
-                canvas->translate((rect.width() + 40 * SK_Scalar1) * SK_ARRAY_COUNT(gStyles), 0);
-            }
-            canvas->save();
-            for (size_t fill = 0; fill < SK_ARRAY_COUNT(gFills); ++fill) {
-                if (0 < fill) {
-                    canvas->translate(0, rect.height() + 40 * SK_Scalar1);
-                }
-                canvas->save();
-                for (size_t style = 0; style < SK_ARRAY_COUNT(gStyles); ++style) {
-                    if (0 < style) {
-                        canvas->translate(rect.width() + 40 * SK_Scalar1, 0);
-                    }
-        
-                    SkColor color = 0xff007000;
-                    this->drawPath(path.fPath, canvas, color, rect,
-                                    gCaps[cap].fCap, gCaps[cap].fJoin, gStyles[style].fStyle,
-                                    gFills[fill].fFill, SK_Scalar1*10);
-        
-                    SkPaint rectPaint;
-                    rectPaint.setColor(SK_ColorBLACK);
-                    rectPaint.setStyle(SkPaint::kStroke_Style);
-                    rectPaint.setStrokeWidth(-1);
-                    rectPaint.setAntiAlias(true);
-                    canvas->drawRect(rect, rectPaint);
-        
-                    SkPaint labelPaint;
-                    labelPaint.setColor(color);
-                    labelPaint.setAntiAlias(true);
-                    labelPaint.setLCDRenderText(true);
-                    labelPaint.setTextSize(10 * SK_Scalar1);
-                    canvas->drawText(gStyles[style].fName,
-                                        strlen(gStyles[style].fName),
-                                        0, rect.height() + 12 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gFills[fill].fName,
-                                        strlen(gFills[fill].fName),
-                                        0, rect.height() + 24 * SK_Scalar1,
-                                        labelPaint);
-                    canvas->drawText(gCaps[cap].fName,
-                                        strlen(gCaps[cap].fName),
-                                        0, rect.height() + 36 * SK_Scalar1,
-                                        labelPaint);
-                }
-                canvas->restore();
-            }
-            canvas->restore();
-        }
-        canvas->restore();
-        canvas->restore();
-    }
-    
-private:
-    typedef GM INHERITED;
-};
-
 class QuadPathGM : public GM {
 public:
     QuadPathGM() {}
@@ -583,16 +298,10 @@
 
 //////////////////////////////////////////////////////////////////////////////
 
-static GM* ZeroQuadPathFactory(void*) { return new ZeroQuadPathGM; }
-static GMRegistry regZeroQuadPath(ZeroQuadPathFactory);
-
-static GM* ZeroQuadClosePathFactory(void*) { return new ZeroQuadClosePathGM; }
-static GMRegistry regZeroQuadClosePath(ZeroQuadClosePathFactory);
-
 static GM* QuadPathFactory(void*) { return new QuadPathGM; }
 static GMRegistry regQuadPath(QuadPathFactory);
 
 static GM* QuadClosePathFactory(void*) { return new QuadClosePathGM; }
 static GMRegistry regQuadClosePath(QuadClosePathFactory);
 
-}
\ No newline at end of file
+}