From ad21fe27627c8f4a1de886a2d1c5296694dc3501 Mon Sep 17 00:00:00 2001 From: Doris Liu Date: Thu, 14 Apr 2016 18:13:36 -0700 Subject: [PATCH] Fix ref count of fillGradient and strokeGradient Bug: 28086621 Change-Id: Ibb52bdfb20904f0ad102878fbb33d3679bb5132d --- libs/hwui/VectorDrawable.h | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/libs/hwui/VectorDrawable.h b/libs/hwui/VectorDrawable.h index e4c7ed71f361f..e8fba0d48193a 100644 --- a/libs/hwui/VectorDrawable.h +++ b/libs/hwui/VectorDrawable.h @@ -219,22 +219,24 @@ public: int fillType = 0; /* non-zero or kWinding_FillType in Skia */ }; FullPathProperties(Node* mNode) : Properties(mNode), mTrimDirty(false) {} + ~FullPathProperties() { + SkSafeUnref(fillGradient); + SkSafeUnref(strokeGradient); + } void syncProperties(const FullPathProperties& prop) { mPrimitiveFields = prop.mPrimitiveFields; mTrimDirty = true; - fillGradient.reset(prop.fillGradient); - strokeGradient.reset(prop.strokeGradient); + UPDATE_SKPROP(fillGradient, prop.fillGradient); + UPDATE_SKPROP(strokeGradient, prop.strokeGradient); onPropertyChanged(); } void setFillGradient(SkShader* gradient) { - if(fillGradient != gradient){ - fillGradient.reset(gradient); + if(UPDATE_SKPROP(fillGradient, gradient)) { onPropertyChanged(); } } void setStrokeGradient(SkShader* gradient) { - if(strokeGradient != gradient){ - strokeGradient.reset(gradient); + if(UPDATE_SKPROP(strokeGradient, gradient)) { onPropertyChanged(); } } @@ -346,8 +348,8 @@ public: count, }; PrimitiveFields mPrimitiveFields; - SkAutoTUnref fillGradient; - SkAutoTUnref strokeGradient; + SkShader* fillGradient = nullptr; + SkShader* strokeGradient = nullptr; }; // Called from UI thread