force readbuffer clients to use specialized readFoo for flattenables

BUG=
R=mtklein@google.com

Review URL: https://codereview.chromium.org/26702002

git-svn-id: http://skia.googlecode.com/svn/trunk@11803 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
reed@google.com 2013-10-16 13:05:06 +00:00
parent d36522d12d
commit 353482251e
21 changed files with 111 additions and 46 deletions

View File

@ -15,6 +15,7 @@
#include "SkPoint.h" #include "SkPoint.h"
class SkBitmap; class SkBitmap;
class SkDrawLooper;
class SkFlattenable; class SkFlattenable;
struct SkIRect; struct SkIRect;
class SkMatrix; class SkMatrix;
@ -28,8 +29,22 @@ class SkRegion;
class SkStream; class SkStream;
class SkString; class SkString;
class SkTypeface; class SkTypeface;
class SkUnitMapper;
class SkWStream; class SkWStream;
enum SkEffectType {
kColorFilter_SkEffectType,
kDrawLooper_SkEffectType,
kImageFilter_SkEffectType,
kMaskFilter_SkEffectType,
kPathEffect_SkEffectType,
kPixelRef_SkEffectType,
kRasterizer_SkEffectType,
kShader_SkEffectType,
kUnitMapper_SkEffectType,
kXfermode_SkEffectType,
};
class SkFlattenableReadBuffer { class SkFlattenableReadBuffer {
public: public:
SkFlattenableReadBuffer(); SkFlattenableReadBuffer();
@ -64,8 +79,40 @@ public:
virtual void readString(SkString* string) = 0; virtual void readString(SkString* string) = 0;
virtual void* readEncodedString(size_t* length, SkPaint::TextEncoding encoding) = 0; virtual void* readEncodedString(size_t* length, SkPaint::TextEncoding encoding) = 0;
virtual SkFlattenable* readFlattenable(SkEffectType) = 0;
SkColorFilter* readColorFilter() {
return (SkColorFilter*)this->readFlattenable(kColorFilter_SkEffectType);
}
SkDrawLooper* readDrawLooper() {
return (SkDrawLooper*)this->readFlattenable(kDrawLooper_SkEffectType);
}
SkImageFilter* readImageFilter() {
return (SkImageFilter*)this->readFlattenable(kImageFilter_SkEffectType);
}
SkMaskFilter* readMaskFilter() {
return (SkMaskFilter*)this->readFlattenable(kMaskFilter_SkEffectType);
}
SkPathEffect* readPathEffect() {
return (SkPathEffect*)this->readFlattenable(kPathEffect_SkEffectType);
}
SkPixelRef* readPixelRef() {
return (SkPixelRef*)this->readFlattenable(kPixelRef_SkEffectType);
}
SkRasterizer* readRasterizer() {
return (SkRasterizer*)this->readFlattenable(kRasterizer_SkEffectType);
}
SkShader* readShader() {
return (SkShader*)this->readFlattenable(kShader_SkEffectType);
}
SkUnitMapper* readUnitMapper() {
return (SkUnitMapper*)this->readFlattenable(kUnitMapper_SkEffectType);
}
SkXfermode* readXfermode() {
return (SkXfermode*)this->readFlattenable(kXfermode_SkEffectType);
}
// common data structures // common data structures
virtual SkFlattenable* readFlattenable() = 0;
virtual void readPoint(SkPoint* point) = 0; virtual void readPoint(SkPoint* point) = 0;
virtual void readMatrix(SkMatrix* matrix) = 0; virtual void readMatrix(SkMatrix* matrix) = 0;
virtual void readIRect(SkIRect* rect) = 0; virtual void readIRect(SkIRect* rect) = 0;
@ -106,10 +153,6 @@ public:
return SkData::NewFromMalloc(buffer, len); return SkData::NewFromMalloc(buffer, len);
} }
template <typename T> T* readFlattenableT() {
return static_cast<T*>(this->readFlattenable());
}
private: private:
uint32_t fFlags; uint32_t fFlags;
}; };

View File

@ -1610,7 +1610,7 @@ void SkBitmap::unflatten(SkFlattenableReadBuffer& buffer) {
switch (reftype) { switch (reftype) {
case SERIALIZE_PIXELTYPE_REF_DATA: { case SERIALIZE_PIXELTYPE_REF_DATA: {
size_t offset = buffer.readUInt(); size_t offset = buffer.readUInt();
SkPixelRef* pr = buffer.readFlattenableT<SkPixelRef>(); SkPixelRef* pr = buffer.readPixelRef();
SkSafeUnref(this->setPixelRef(pr, offset)); SkSafeUnref(this->setPixelRef(pr, offset));
break; break;
} }

View File

@ -683,7 +683,7 @@ public:
protected: protected:
Sk3DShader(SkFlattenableReadBuffer& buffer) : INHERITED(buffer) { Sk3DShader(SkFlattenableReadBuffer& buffer) : INHERITED(buffer) {
fProxy = buffer.readFlattenableT<SkShader>(); fProxy = buffer.readShader();
fPMColor = buffer.readColor(); fPMColor = buffer.readColor();
fMask = NULL; fMask = NULL;
} }

View File

@ -27,15 +27,15 @@ SkComposeShader::SkComposeShader(SkShader* sA, SkShader* sB, SkXfermode* mode) {
SkComposeShader::SkComposeShader(SkFlattenableReadBuffer& buffer) : SkComposeShader::SkComposeShader(SkFlattenableReadBuffer& buffer) :
INHERITED(buffer) { INHERITED(buffer) {
fShaderA = buffer.readFlattenableT<SkShader>(); fShaderA = buffer.readShader();
if (NULL == fShaderA) { if (NULL == fShaderA) {
fShaderA = SkNEW_ARGS(SkColorShader, (0)); fShaderA = SkNEW_ARGS(SkColorShader, (0));
} }
fShaderB = buffer.readFlattenableT<SkShader>(); fShaderB = buffer.readShader();
if (NULL == fShaderB) { if (NULL == fShaderB) {
fShaderB = SkNEW_ARGS(SkColorShader, (0)); fShaderB = SkNEW_ARGS(SkColorShader, (0));
} }
fMode = buffer.readFlattenableT<SkXfermode>(); fMode = buffer.readXfermode();
} }
SkComposeShader::~SkComposeShader() { SkComposeShader::~SkComposeShader() {

View File

@ -22,8 +22,8 @@ SkFilterShader::SkFilterShader(SkShader* shader, SkColorFilter* filter) {
SkFilterShader::SkFilterShader(SkFlattenableReadBuffer& buffer) SkFilterShader::SkFilterShader(SkFlattenableReadBuffer& buffer)
: INHERITED(buffer) { : INHERITED(buffer) {
fShader = buffer.readFlattenableT<SkShader>(); fShader = buffer.readShader();
fFilter = buffer.readFlattenableT<SkColorFilter>(); fFilter = buffer.readColorFilter();
} }
SkFilterShader::~SkFilterShader() { SkFilterShader::~SkFilterShader() {

View File

@ -54,3 +54,4 @@ void SkFlattenableWriteBuffer::writePaint(const SkPaint& paint) {
void SkFlattenableWriteBuffer::flattenObject(SkFlattenable* obj, SkFlattenableWriteBuffer& buffer) { void SkFlattenableWriteBuffer::flattenObject(SkFlattenable* obj, SkFlattenableWriteBuffer& buffer) {
obj->flatten(buffer); obj->flatten(buffer);
} }

View File

@ -9,6 +9,7 @@
#include "SkData.h" #include "SkData.h"
#include "SkFlattenable.h" #include "SkFlattenable.h"
#include "SkImageFilter.h"
#include "SkOrderedReadBuffer.h" #include "SkOrderedReadBuffer.h"
#include "SkOrderedWriteBuffer.h" #include "SkOrderedWriteBuffer.h"
@ -22,7 +23,9 @@ SkData* SkSerializeFlattenable(SkFlattenable* flattenable) {
return SkData::NewFromMalloc(data, size); return SkData::NewFromMalloc(data, size);
} }
// TODO: this guy should be renamed to ImageFilter, or take SkEffectType as
// a parameter.
SkFlattenable* SkDeserializeFlattenable(const void* data, size_t size) { SkFlattenable* SkDeserializeFlattenable(const void* data, size_t size) {
SkOrderedReadBuffer buffer(data, size); SkOrderedReadBuffer buffer(data, size);
return buffer.readFlattenable(); return buffer.readImageFilter();
} }

View File

@ -68,7 +68,7 @@ SkImageFilter::SkImageFilter(SkFlattenableReadBuffer& buffer)
: fInputCount(buffer.readInt()), fInputs(new SkImageFilter*[fInputCount]) { : fInputCount(buffer.readInt()), fInputs(new SkImageFilter*[fInputCount]) {
for (int i = 0; i < fInputCount; i++) { for (int i = 0; i < fInputCount; i++) {
if (buffer.readBool()) { if (buffer.readBool()) {
fInputs[i] = static_cast<SkImageFilter*>(buffer.readFlattenable()); fInputs[i] = buffer.readImageFilter();
} else { } else {
fInputs[i] = NULL; fInputs[i] = NULL;
} }

View File

@ -268,7 +268,11 @@ SkTypeface* SkOrderedReadBuffer::readTypeface() {
} }
} }
SkFlattenable* SkOrderedReadBuffer::readFlattenable() { SkFlattenable* SkOrderedReadBuffer::readFlattenable(SkEffectType et) {
//
// TODO: confirm that et matches the factory we decide to use
//
SkFlattenable::Factory factory = NULL; SkFlattenable::Factory factory = NULL;
if (fFactoryCount > 0) { if (fFactoryCount > 0) {

View File

@ -52,7 +52,7 @@ public:
virtual void* readEncodedString(size_t* length, SkPaint::TextEncoding encoding) SK_OVERRIDE; virtual void* readEncodedString(size_t* length, SkPaint::TextEncoding encoding) SK_OVERRIDE;
// common data structures // common data structures
virtual SkFlattenable* readFlattenable() SK_OVERRIDE; virtual SkFlattenable* readFlattenable(SkEffectType) SK_OVERRIDE;
virtual void readPoint(SkPoint* point) SK_OVERRIDE; virtual void readPoint(SkPoint* point) SK_OVERRIDE;
virtual void readMatrix(SkMatrix* matrix) SK_OVERRIDE; virtual void readMatrix(SkMatrix* matrix) SK_OVERRIDE;
virtual void readIRect(SkIRect* rect) SK_OVERRIDE; virtual void readIRect(SkIRect* rect) SK_OVERRIDE;

View File

@ -2178,14 +2178,14 @@ void SkPaint::unflatten(SkFlattenableReadBuffer& buffer) {
} }
if (flatFlags & kHasEffects_FlatFlag) { if (flatFlags & kHasEffects_FlatFlag) {
SkSafeUnref(this->setPathEffect(buffer.readFlattenableT<SkPathEffect>())); SkSafeUnref(this->setPathEffect(buffer.readPathEffect()));
SkSafeUnref(this->setShader(buffer.readFlattenableT<SkShader>())); SkSafeUnref(this->setShader(buffer.readShader()));
SkSafeUnref(this->setXfermode(buffer.readFlattenableT<SkXfermode>())); SkSafeUnref(this->setXfermode(buffer.readXfermode()));
SkSafeUnref(this->setMaskFilter(buffer.readFlattenableT<SkMaskFilter>())); SkSafeUnref(this->setMaskFilter(buffer.readMaskFilter()));
SkSafeUnref(this->setColorFilter(buffer.readFlattenableT<SkColorFilter>())); SkSafeUnref(this->setColorFilter(buffer.readColorFilter()));
SkSafeUnref(this->setRasterizer(buffer.readFlattenableT<SkRasterizer>())); SkSafeUnref(this->setRasterizer(buffer.readRasterizer()));
SkSafeUnref(this->setLooper(buffer.readFlattenableT<SkDrawLooper>())); SkSafeUnref(this->setLooper(buffer.readDrawLooper()));
SkSafeUnref(this->setImageFilter(buffer.readFlattenableT<SkImageFilter>())); SkSafeUnref(this->setImageFilter(buffer.readImageFilter()));
if (buffer.readBool()) { if (buffer.readBool()) {
this->setAnnotation(SkNEW_ARGS(SkAnnotation, (buffer)))->unref(); this->setAnnotation(SkNEW_ARGS(SkAnnotation, (buffer)))->unref();

View File

@ -48,8 +48,8 @@ void SkPairPathEffect::flatten(SkFlattenableWriteBuffer& buffer) const {
} }
SkPairPathEffect::SkPairPathEffect(SkFlattenableReadBuffer& buffer) { SkPairPathEffect::SkPairPathEffect(SkFlattenableReadBuffer& buffer) {
fPE0 = buffer.readFlattenableT<SkPathEffect>(); fPE0 = buffer.readPathEffect();
fPE1 = buffer.readFlattenableT<SkPathEffect>(); fPE1 = buffer.readPathEffect();
// either of these may fail, so we have to check for nulls later on // either of these may fail, so we have to check for nulls later on
} }

View File

@ -66,14 +66,15 @@ void SkGlyph::zeroMetrics() {
#define DUMP_RECx #define DUMP_RECx
#endif #endif
static SkFlattenable* load_flattenable(const SkDescriptor* desc, uint32_t tag) { static SkFlattenable* load_flattenable(const SkDescriptor* desc, uint32_t tag,
SkEffectType et) {
SkFlattenable* obj = NULL; SkFlattenable* obj = NULL;
uint32_t len; uint32_t len;
const void* data = desc->findEntry(tag, &len); const void* data = desc->findEntry(tag, &len);
if (data) { if (data) {
SkOrderedReadBuffer buffer(data, len); SkOrderedReadBuffer buffer(data, len);
obj = buffer.readFlattenable(); obj = buffer.readFlattenable(et);
SkASSERT(buffer.offset() == buffer.size()); SkASSERT(buffer.offset() == buffer.size());
} }
return obj; return obj;
@ -84,9 +85,9 @@ SkScalerContext::SkScalerContext(SkTypeface* typeface, const SkDescriptor* desc)
, fBaseGlyphCount(0) , fBaseGlyphCount(0)
, fTypeface(SkRef(typeface)) , fTypeface(SkRef(typeface))
, fPathEffect(static_cast<SkPathEffect*>(load_flattenable(desc, kPathEffect_SkDescriptorTag))) , fPathEffect(static_cast<SkPathEffect*>(load_flattenable(desc, kPathEffect_SkDescriptorTag, kPathEffect_SkEffectType)))
, fMaskFilter(static_cast<SkMaskFilter*>(load_flattenable(desc, kMaskFilter_SkDescriptorTag))) , fMaskFilter(static_cast<SkMaskFilter*>(load_flattenable(desc, kMaskFilter_SkDescriptorTag, kMaskFilter_SkEffectType)))
, fRasterizer(static_cast<SkRasterizer*>(load_flattenable(desc, kRasterizer_SkDescriptorTag))) , fRasterizer(static_cast<SkRasterizer*>(load_flattenable(desc, kRasterizer_SkDescriptorTag, kRasterizer_SkEffectType)))
// Initialize based on our settings. Subclasses can also force this. // Initialize based on our settings. Subclasses can also force this.
, fGenerateImageFromPath(fRec.fFrameWidth > 0 || fPathEffect != NULL || fRasterizer != NULL) , fGenerateImageFromPath(fRec.fFrameWidth > 0 || fPathEffect != NULL || fRasterizer != NULL)

View File

@ -69,8 +69,8 @@ SkBlurDrawLooper::SkBlurDrawLooper(SkFlattenableReadBuffer& buffer)
fDx = buffer.readScalar(); fDx = buffer.readScalar();
fDy = buffer.readScalar(); fDy = buffer.readScalar();
fBlurColor = buffer.readColor(); fBlurColor = buffer.readColor();
fBlur = buffer.readFlattenableT<SkMaskFilter>(); fBlur = buffer.readMaskFilter();
fColorFilter = buffer.readFlattenableT<SkColorFilter>(); fColorFilter = buffer.readColorFilter();
fBlurFlags = buffer.readUInt() & kAll_BlurFlag; fBlurFlags = buffer.readUInt() & kAll_BlurFlag;
} }

View File

@ -83,7 +83,7 @@ SkColorFilterImageFilter::SkColorFilterImageFilter(SkColorFilter* cf,
} }
SkColorFilterImageFilter::SkColorFilterImageFilter(SkFlattenableReadBuffer& buffer) : INHERITED(buffer) { SkColorFilterImageFilter::SkColorFilterImageFilter(SkFlattenableReadBuffer& buffer) : INHERITED(buffer) {
fColorFilter = buffer.readFlattenableT<SkColorFilter>(); fColorFilter = buffer.readColorFilter();
} }
void SkColorFilterImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const { void SkColorFilterImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const {

View File

@ -45,7 +45,7 @@ SkRectShaderImageFilter::SkRectShaderImageFilter(SkShader* s, const CropRect* cr
SkRectShaderImageFilter::SkRectShaderImageFilter(SkFlattenableReadBuffer& buffer) SkRectShaderImageFilter::SkRectShaderImageFilter(SkFlattenableReadBuffer& buffer)
: INHERITED(buffer) { : INHERITED(buffer) {
fShader = buffer.readFlattenableT<SkShader>(); fShader = buffer.readShader();
} }
void SkRectShaderImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const { void SkRectShaderImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const {

View File

@ -34,7 +34,7 @@ SkXfermodeImageFilter::~SkXfermodeImageFilter() {
SkXfermodeImageFilter::SkXfermodeImageFilter(SkFlattenableReadBuffer& buffer) SkXfermodeImageFilter::SkXfermodeImageFilter(SkFlattenableReadBuffer& buffer)
: INHERITED(buffer) { : INHERITED(buffer) {
fMode = buffer.readFlattenableT<SkXfermode>(); fMode = buffer.readXfermode();
} }
void SkXfermodeImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const { void SkXfermodeImageFilter::flatten(SkFlattenableWriteBuffer& buffer) const {

View File

@ -146,7 +146,7 @@ static uint32_t unpack_flags(uint32_t packed) {
SkGradientShaderBase::SkGradientShaderBase(SkFlattenableReadBuffer& buffer) : INHERITED(buffer) { SkGradientShaderBase::SkGradientShaderBase(SkFlattenableReadBuffer& buffer) : INHERITED(buffer) {
fCacheAlpha = 256; fCacheAlpha = 256;
fMapper = buffer.readFlattenableT<SkUnitMapper>(); fMapper = buffer.readUnitMapper();
fCache16 = fCache16Storage = NULL; fCache16 = fCache16Storage = NULL;
fCache32 = NULL; fCache32 = NULL;

View File

@ -19,11 +19,11 @@
enum PaintFlats { enum PaintFlats {
kColorFilter_PaintFlat, kColorFilter_PaintFlat,
kDrawLooper_PaintFlat, kDrawLooper_PaintFlat,
kImageFilter_PaintFlat,
kMaskFilter_PaintFlat, kMaskFilter_PaintFlat,
kPathEffect_PaintFlat, kPathEffect_PaintFlat,
kRasterizer_PaintFlat, kRasterizer_PaintFlat,
kShader_PaintFlat, kShader_PaintFlat,
kImageFilter_PaintFlat,
kXfermode_PaintFlat, kXfermode_PaintFlat,
kLast_PaintFlat = kXfermode_PaintFlat kLast_PaintFlat = kXfermode_PaintFlat

View File

@ -18,6 +18,7 @@
#include "SkAnnotation.h" #include "SkAnnotation.h"
#include "SkColorFilter.h" #include "SkColorFilter.h"
#include "SkDrawLooper.h" #include "SkDrawLooper.h"
#include "SkImageFilter.h"
#include "SkMaskFilter.h" #include "SkMaskFilter.h"
#include "SkOrderedReadBuffer.h" #include "SkOrderedReadBuffer.h"
#include "SkPathEffect.h" #include "SkPathEffect.h"
@ -27,6 +28,22 @@
#include "SkTypeface.h" #include "SkTypeface.h"
#include "SkXfermode.h" #include "SkXfermode.h"
static SkEffectType paintflat_to_effecttype(PaintFlats pf) {
static const uint8_t gEffectTypesInPaintFlatsOrder[] = {
kColorFilter_SkEffectType,
kDrawLooper_SkEffectType,
kImageFilter_SkEffectType,
kMaskFilter_SkEffectType,
kPathEffect_SkEffectType,
kRasterizer_SkEffectType,
kShader_SkEffectType,
kXfermode_SkEffectType,
};
SkASSERT((size_t)pf < SK_ARRAY_COUNT(gEffectTypesInPaintFlatsOrder));
return (SkEffectType)gEffectTypesInPaintFlatsOrder[pf];
}
static void set_paintflat(SkPaint* paint, SkFlattenable* obj, unsigned paintFlat) { static void set_paintflat(SkPaint* paint, SkFlattenable* obj, unsigned paintFlat) {
SkASSERT(paintFlat < kCount_PaintFlats); SkASSERT(paintFlat < kCount_PaintFlats);
switch (paintFlat) { switch (paintFlat) {
@ -105,7 +122,7 @@ public:
void defFlattenable(PaintFlats pf, int index) { void defFlattenable(PaintFlats pf, int index) {
index--; index--;
SkFlattenable* obj = fReader->readFlattenable(); SkFlattenable* obj = fReader->readFlattenable(paintflat_to_effecttype(pf));
if (fFlatArray.count() == index) { if (fFlatArray.count() == index) {
*fFlatArray.append() = obj; *fFlatArray.append() = obj;
} else { } else {

View File

@ -15,7 +15,7 @@
#include "SkOrderedReadBuffer.h" #include "SkOrderedReadBuffer.h"
#include "SkOrderedWriteBuffer.h" #include "SkOrderedWriteBuffer.h"
static SkFlattenable* reincarnate_flattenable(SkFlattenable* obj) { static SkColorFilter* reincarnate_colorfilter(SkFlattenable* obj) {
SkOrderedWriteBuffer wb(1024); SkOrderedWriteBuffer wb(1024);
wb.writeFlattenable(obj); wb.writeFlattenable(obj);
@ -25,11 +25,7 @@ static SkFlattenable* reincarnate_flattenable(SkFlattenable* obj) {
wb.writeToMemory(storage.get()); wb.writeToMemory(storage.get());
SkOrderedReadBuffer rb(storage.get(), size); SkOrderedReadBuffer rb(storage.get(), size);
return rb.readFlattenable(); return rb.readColorFilter();
}
template <typename T> T* reincarnate(T* obj) {
return (T*)reincarnate_flattenable(obj);
} }
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
@ -82,7 +78,7 @@ static void test_asColorMode(skiatest::Reporter* reporter) {
REPORTER_ASSERT(reporter, m == expectedMode); REPORTER_ASSERT(reporter, m == expectedMode);
{ {
SkColorFilter* cf2 = reincarnate(cf); SkColorFilter* cf2 = reincarnate_colorfilter(cf);
SkAutoUnref aur2(cf2); SkAutoUnref aur2(cf2);
REPORTER_ASSERT(reporter, cf2); REPORTER_ASSERT(reporter, cf2);