Index: src/core/SkColorFilter.cpp |
diff --git a/src/core/SkColorFilter.cpp b/src/core/SkColorFilter.cpp |
index dab4ccf7b55d09f8aa791804c3bb5e1bb176cf33..59a625d0b6d4b0b7f54a3b0354d3f5992fe2d4e1 100644 |
--- a/src/core/SkColorFilter.cpp |
+++ b/src/core/SkColorFilter.cpp |
@@ -114,14 +114,15 @@ |
protected: |
void flatten(SkWriteBuffer& buffer) const override { |
- buffer.writeFlattenable(fOuter); |
- buffer.writeFlattenable(fInner); |
+ buffer.writeFlattenable(fOuter.get()); |
+ buffer.writeFlattenable(fInner.get()); |
} |
private: |
- SkComposeColorFilter(SkColorFilter* outer, SkColorFilter* inner, int composedFilterCount) |
- : fOuter(SkRef(outer)) |
- , fInner(SkRef(inner)) |
+ SkComposeColorFilter(sk_sp<SkColorFilter> outer, sk_sp<SkColorFilter> inner, |
+ int composedFilterCount) |
+ : fOuter(std::move(outer)) |
+ , fInner(std::move(inner)) |
, fComposedFilterCount(composedFilterCount) |
{ |
SkASSERT(composedFilterCount >= 2); |
@@ -132,9 +133,9 @@ |
return fComposedFilterCount; |
} |
- SkAutoTUnref<SkColorFilter> fOuter; |
- SkAutoTUnref<SkColorFilter> fInner; |
- const int fComposedFilterCount; |
+ sk_sp<SkColorFilter> fOuter; |
+ sk_sp<SkColorFilter> fInner; |
+ const int fComposedFilterCount; |
friend class SkColorFilter; |
@@ -142,23 +143,24 @@ |
}; |
SkFlattenable* SkComposeColorFilter::CreateProc(SkReadBuffer& buffer) { |
- SkAutoTUnref<SkColorFilter> outer(buffer.readColorFilter()); |
- SkAutoTUnref<SkColorFilter> inner(buffer.readColorFilter()); |
- return CreateComposeFilter(outer, inner); |
+ sk_sp<SkColorFilter> outer(buffer.readColorFilter()); |
+ sk_sp<SkColorFilter> inner(buffer.readColorFilter()); |
+ return MakeComposeFilter(std::move(outer), std::move(inner)).release(); |
} |
/////////////////////////////////////////////////////////////////////////////////////////////////// |
-SkColorFilter* SkColorFilter::CreateComposeFilter(SkColorFilter* outer, SkColorFilter* inner) { |
+sk_sp<SkColorFilter> SkColorFilter::MakeComposeFilter(sk_sp<SkColorFilter> outer, |
+ sk_sp<SkColorFilter> inner) { |
if (!outer) { |
- return SkSafeRef(inner); |
+ return inner; |
} |
if (!inner) { |
- return SkSafeRef(outer); |
+ return outer; |
} |
// Give the subclass a shot at a more optimal composition... |
- SkColorFilter* composition = outer->newComposed(inner); |
+ auto composition = outer->makeComposed(inner); |
if (composition) { |
return composition; |
} |
@@ -167,7 +169,7 @@ |
if (count > SK_MAX_COMPOSE_COLORFILTER_COUNT) { |
return nullptr; |
} |
- return new SkComposeColorFilter(outer, inner, count); |
+ return sk_sp<SkColorFilter>(new SkComposeColorFilter(std::move(outer), std::move(inner),count)); |
} |
#include "SkModeColorFilter.h" |