check for huge paths
Bug:802976
Change-Id: Ibb5930442f75ca8483afc8dfa5869cac98573904
Reviewed-on: https://skia-review.googlesource.com/98440
Reviewed-by: Cary Clark <caryclark@google.com>
Reviewed-by: Florin Malita <fmalita@chromium.org>
Commit-Queue: Mike Reed <reed@google.com>
diff --git a/src/core/SkPaint.cpp b/src/core/SkPaint.cpp
index 05e3e36..6198aa3 100644
--- a/src/core/SkPaint.cpp
+++ b/src/core/SkPaint.cpp
@@ -1937,6 +1937,11 @@
bool SkPaint::getFillPath(const SkPath& src, SkPath* dst, const SkRect* cullRect,
SkScalar resScale) const {
+ if (!src.isFinite()) {
+ dst->reset();
+ return false;
+ }
+
SkStrokeRec rec(*this, resScale);
const SkPath* srcPtr = &src;
@@ -1957,6 +1962,11 @@
*dst = *srcPtr;
}
}
+
+ if (!dst->isFinite()) {
+ dst->reset();
+ return false;
+ }
return !rec.isHairlineStyle();
}
diff --git a/src/core/SkScan_AntiPath.cpp b/src/core/SkScan_AntiPath.cpp
index 70c8d1f..db1527f 100644
--- a/src/core/SkScan_AntiPath.cpp
+++ b/src/core/SkScan_AntiPath.cpp
@@ -756,9 +756,8 @@
#include "SkRasterClip.h"
-void SkScan::FillPath(const SkPath& path, const SkRasterClip& clip,
- SkBlitter* blitter) {
- if (clip.isEmpty()) {
+void SkScan::FillPath(const SkPath& path, const SkRasterClip& clip, SkBlitter* blitter) {
+ if (clip.isEmpty() || !path.isFinite()) {
return;
}
@@ -776,7 +775,7 @@
void SkScan::AntiFillPath(const SkPath& path, const SkRasterClip& clip,
SkBlitter* blitter, bool forceDAA) {
- if (clip.isEmpty()) {
+ if (clip.isEmpty() || !path.isFinite()) {
return;
}