Index: src/image/SkImage_Generator.cpp |
diff --git a/src/image/SkImage_Generator.cpp b/src/image/SkImage_Generator.cpp |
index 412f573ba6dbe38d3a9da521fdc48889715db07d..8fa022de7bdc1a6f11fb21c73cf0504ec0963e0b 100644 |
--- a/src/image/SkImage_Generator.cpp |
+++ b/src/image/SkImage_Generator.cpp |
@@ -16,20 +16,20 @@ |
class SkImage_Generator : public SkImage_Base { |
public: |
- SkImage_Generator(SkImageCacherator* cache) |
- : INHERITED(cache->info().width(), cache->info().height(), cache->uniqueID()) |
- , fCache(cache) // take ownership |
+ SkImage_Generator(SkImageCacherator::Validator* validator) |
+ : INHERITED(validator->fInfo.width(), validator->fInfo.height(), validator->fUniqueID) |
+ , fCache(validator) |
{} |
virtual SkImageInfo onImageInfo() const override { |
- return fCache->info(); |
+ return fCache.info(); |
} |
SkAlphaType onAlphaType() const override { |
- return fCache->info().alphaType(); |
+ return fCache.info().alphaType(); |
} |
bool onReadPixels(const SkImageInfo&, void*, size_t, int srcX, int srcY, CachingHint) const override; |
- SkImageCacherator* peekCacherator() const override { return fCache; } |
+ SkImageCacherator* peekCacherator() const override { return &fCache; } |
SkData* onRefEncoded(GrContext*) const override; |
sk_sp<SkImage> onMakeSubset(const SkIRect&) const override; |
bool getROPixels(SkBitmap*, CachingHint) const override; |
@@ -38,7 +38,7 @@ public: |
bool onIsLazyGenerated() const override { return true; } |
private: |
- SkAutoTDelete<SkImageCacherator> fCache; |
+ mutable SkImageCacherator fCache; |
typedef SkImage_Base INHERITED; |
}; |
@@ -49,13 +49,13 @@ bool SkImage_Generator::onReadPixels(const SkImageInfo& dstInfo, void* dstPixels |
int srcX, int srcY, CachingHint chint) const { |
SkBitmap bm; |
if (kDisallow_CachingHint == chint) { |
- if (fCache->lockAsBitmapOnlyIfAlreadyCached(&bm)) { |
+ if (fCache.lockAsBitmapOnlyIfAlreadyCached(&bm)) { |
return bm.readPixels(dstInfo, dstPixels, dstRB, srcX, srcY); |
} else { |
// Try passing the caller's buffer directly down to the generator. If this fails we |
// may still succeed in the general case, as the generator may prefer some other |
// config, which we could then convert via SkBitmap::readPixels. |
- if (fCache->directGeneratePixels(dstInfo, dstPixels, dstRB, srcX, srcY)) { |
+ if (fCache.directGeneratePixels(dstInfo, dstPixels, dstRB, srcX, srcY)) { |
return true; |
} |
// else fall through |
@@ -69,16 +69,16 @@ bool SkImage_Generator::onReadPixels(const SkImageInfo& dstInfo, void* dstPixels |
} |
SkData* SkImage_Generator::onRefEncoded(GrContext* ctx) const { |
- return fCache->refEncoded(ctx); |
+ return fCache.refEncoded(ctx); |
} |
bool SkImage_Generator::getROPixels(SkBitmap* bitmap, CachingHint chint) const { |
- return fCache->lockAsBitmap(bitmap, this, chint); |
+ return fCache.lockAsBitmap(bitmap, this, chint); |
} |
GrTexture* SkImage_Generator::asTextureRef(GrContext* ctx, const GrTextureParams& params, |
SkSourceGammaTreatment gammaTreatment) const { |
- return fCache->lockAsTexture(ctx, params, gammaTreatment, this); |
+ return fCache.lockAsTexture(ctx, params, gammaTreatment, this); |
} |
sk_sp<SkImage> SkImage_Generator::onMakeSubset(const SkIRect& subset) const { |
@@ -98,12 +98,7 @@ sk_sp<SkImage> SkImage_Generator::onMakeSubset(const SkIRect& subset) const { |
} |
sk_sp<SkImage> SkImage::MakeFromGenerator(SkImageGenerator* generator, const SkIRect* subset) { |
- if (!generator) { |
- return nullptr; |
- } |
- SkImageCacherator* cache = SkImageCacherator::NewFromGenerator(generator, subset); |
- if (!cache) { |
- return nullptr; |
- } |
- return sk_make_sp<SkImage_Generator>(cache); |
+ SkImageCacherator::Validator validator(generator, subset); |
+ |
+ return validator ? sk_make_sp<SkImage_Generator>(&validator) : nullptr; |
reed1
2016/10/27 13:45:19
Can we force somebody to assert (Validator?) if we
f(malita)
2016/10/27 14:17:07
The SkImageCacherator ctor (the only "user" of val
|
} |