Index: src/core/SkLightingShader.cpp |
diff --git a/src/core/SkLightingShader.cpp b/src/core/SkLightingShader.cpp |
index c8a5a2b7372957a1dabf14dce67c523e53fd2e94..2b43e500d78c86ba7663ba747a58ebf0d940fc9c 100644 |
--- a/src/core/SkLightingShader.cpp |
+++ b/src/core/SkLightingShader.cpp |
@@ -79,8 +79,6 @@ public: |
SkFilterQuality) const override; |
#endif |
- size_t contextSize(const ContextRec&) const override; |
- |
class LightingShaderContext : public SkShader::Context { |
public: |
// The context takes ownership of the states. It will call their destructors |
@@ -106,6 +104,7 @@ public: |
protected: |
void flatten(SkWriteBuffer&) const override; |
+ size_t onContextSize(const ContextRec&) const override; |
Context* onCreateContext(const ContextRec&, void*) const override; |
bool computeNormTotalInverse(const ContextRec& rec, SkMatrix* normTotalInverse) const; |
@@ -416,10 +415,6 @@ bool SkLightingShaderImpl::isOpaque() const { |
return fDiffuseMap.isOpaque(); |
} |
-size_t SkLightingShaderImpl::contextSize(const ContextRec&) const { |
- return 2 * sizeof(SkBitmapProcState) + sizeof(LightingShaderContext); |
-} |
- |
SkLightingShaderImpl::LightingShaderContext::LightingShaderContext(const SkLightingShaderImpl& shader, |
const ContextRec& rec, |
SkBitmapProcState* diffuseState, |
@@ -655,6 +650,10 @@ bool SkLightingShaderImpl::computeNormTotalInverse(const ContextRec& rec, |
return m->invert(normTotalInverse); |
} |
+size_t SkLightingShaderImpl::onContextSize(const ContextRec&) const { |
+ return SkAlign16(2 * sizeof(SkBitmapProcState) + sizeof(LightingShaderContext)); |
+} |
+ |
SkShader::Context* SkLightingShaderImpl::onCreateContext(const ContextRec& rec, |
void* storage) const { |