Index: src/effects/SkComposeImageFilter.cpp |
diff --git a/src/effects/SkComposeImageFilter.cpp b/src/effects/SkComposeImageFilter.cpp |
index 645d63372a0ccd475c72a87e7613edb1ecaede18..837df3870c84228354f383876b4154c99ea24e3a 100644 |
--- a/src/effects/SkComposeImageFilter.cpp |
+++ b/src/effects/SkComposeImageFilter.cpp |
@@ -21,14 +21,6 @@ bool SkComposeImageFilter::onFilterImage(Proxy* proxy, |
SkImageFilter* outer = getInput(0); |
SkImageFilter* inner = getInput(1); |
- if (!outer && !inner) { |
- return false; |
- } |
- |
- if (!outer || !inner) { |
- return (outer ? outer : inner)->filterImage(proxy, src, ctx, result, offset); |
- } |
- |
SkBitmap tmp; |
return inner->filterImage(proxy, src, ctx, &tmp, offset) && |
outer->filterImage(proxy, tmp, ctx, result, offset); |
@@ -40,19 +32,20 @@ bool SkComposeImageFilter::onFilterBounds(const SkIRect& src, |
SkImageFilter* outer = getInput(0); |
SkImageFilter* inner = getInput(1); |
- if (!outer && !inner) { |
- return false; |
- } |
+ SkIRect tmp; |
+ return inner->filterBounds(src, ctm, &tmp) && outer->filterBounds(tmp, ctm, dst); |
+} |
- if (!outer || !inner) { |
- return (outer ? outer : inner)->filterBounds(src, ctm, dst); |
+SkFlattenable* SkComposeImageFilter::CreateProc(SkReadBuffer& buffer) { |
+ Common common; |
+ if (!common.unflatten(buffer, 2)) { |
+ return NULL; |
} |
- |
- SkIRect tmp; |
- return inner->filterBounds(src, ctm, &tmp) && |
- outer->filterBounds(tmp, ctm, dst); |
+ return SkComposeImageFilter::Create(common.inputAt(0), common.inputAt(1)); |
} |
+#ifdef SK_SUPPORT_LEGACY_DEEPFLATTENING |
SkComposeImageFilter::SkComposeImageFilter(SkReadBuffer& buffer) |
: INHERITED(2, buffer) { |
} |
+#endif |