Chromium Code Reviews| Index: src/lazy/SkDiscardablePixelRef.cpp |
| diff --git a/src/lazy/SkDiscardablePixelRef.cpp b/src/lazy/SkDiscardablePixelRef.cpp |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..9bbcee086ed5ce1f0179b92fc4e238859bab6a03 |
| --- /dev/null |
| +++ b/src/lazy/SkDiscardablePixelRef.cpp |
| @@ -0,0 +1,66 @@ |
| +/* |
| + * Copyright 2013 Google Inc. |
| + * |
| + * Use of this source code is governed by a BSD-style license that can be |
| + * found in the LICENSE file. |
| + */ |
| + |
| +#include "SkDiscardablePixelRef.h" |
| +#include "SkDiscardableMemory.h" |
| + |
| +SkDiscardablePixelRef::SkDiscardablePixelRef(SkImageGenerator* generator, |
| + const SkImageInfo& info, |
| + size_t size, |
| + size_t rowBytes) |
| + : fGenerator(generator) |
| + , fDiscardableMemory(NULL) |
| + , fInfo(info) |
| + , fSize(size) |
| + , fRowBytes(rowBytes) { |
| + SkASSERT(fGenerator != NULL); |
| + SkASSERT(fSize > 0); |
| + SkASSERT(fRowBytes > 0); |
| +} |
| + |
| +SkDiscardablePixelRef::~SkDiscardablePixelRef() { |
| + SkDELETE(fGenerator); |
| +} |
| + |
| +void* SkDiscardablePixelRef::onLockPixels(SkColorTable**) { |
| + if (fDiscardableMemory != NULL) { |
| + if (fDiscardableMemory->lock()) { |
| + return fDiscardableMemory->data(); |
| + } |
| + fDiscardableMemory = NULL; |
| + } |
| + fDiscardableMemory = SkDiscardableMemory::Create(fSize); |
| + if (NULL == fDiscardableMemory) { |
| + return NULL; // Memory allocation failed. |
| + } |
| + void* pixels = fDiscardableMemory->data(); |
| + if (!fGenerator->getPixels(fInfo, pixels, fRowBytes)) { |
| + return NULL; // TODO(halcanary) Find out correct thing to do. |
| + } |
| + return pixels; |
| +} |
| +void SkDiscardablePixelRef::onUnlockPixels() { |
| + if (fDiscardableMemory != NULL) { |
| + fDiscardableMemory->unlock(); |
| + } |
| +} |
| + |
| +bool SkDiscardablePixelRef::Install(SkImageGenerator* generator, SkBitmap* dst) { |
| + SkImageInfo info; |
| + if (!generator->getInfo(&info)) { |
| + return false; |
| + } |
| + if (!dst->setConfig(info, 0)) { |
| + return false; |
|
scroggo
2013/11/19 22:19:27
Who should be responsible for deleting generator i
hal.canary
2013/11/20 00:07:10
changed, and commented
|
| + } |
| + SkAutoTUnref<SkDiscardablePixelRef> ref(SkNEW_ARGS(SkDiscardablePixelRef, |
| + (generator, info, |
| + dst->getSize(), |
| + dst->rowBytes()))); |
| + dst->setPixelRef(ref); |
| + return true; |
| +} |