Index: src/lazy/SkDiscardablePixelRef.cpp |
diff --git a/src/lazy/SkDiscardablePixelRef.cpp b/src/lazy/SkDiscardablePixelRef.cpp |
index 4e19c7f65b9c011e6e2ab424a5e05a67218f2986..fcb70c7b401a7bf871b0a0d23304f83bba3d450c 100644 |
--- a/src/lazy/SkDiscardablePixelRef.cpp |
+++ b/src/lazy/SkDiscardablePixelRef.cpp |
@@ -12,8 +12,8 @@ SkDiscardablePixelRef::SkDiscardablePixelRef(SkImageGenerator* generator, |
const SkImageInfo& info, |
size_t size, |
size_t rowBytes) |
- : fGenerator(generator) |
- , fInfo(info) |
+ : INHERITED(info) |
+ , fGenerator(generator) |
, fSize(size) |
, fRowBytes(rowBytes) |
, fDiscardableMemory(NULL) { |
@@ -29,22 +29,29 @@ SkDiscardablePixelRef::~SkDiscardablePixelRef() { |
SkDELETE(fGenerator); |
} |
-void* SkDiscardablePixelRef::onLockPixels(SkColorTable**) { |
+bool SkDiscardablePixelRef::onNewLockPixels(LockRec* rec) { |
if (fDiscardableMemory != NULL) { |
if (fDiscardableMemory->lock()) { |
- return fDiscardableMemory->data(); |
+ rec->fPixels = fDiscardableMemory->data(); |
+ rec->fColorTable = NULL; |
+ rec->fRowBytes = fRowBytes; |
+ return true; |
} |
fDiscardableMemory = NULL; |
} |
fDiscardableMemory = SkDiscardableMemory::Create(fSize); |
if (NULL == fDiscardableMemory) { |
- return NULL; // Memory allocation failed. |
+ return false; // Memory allocation failed. |
} |
void* pixels = fDiscardableMemory->data(); |
- if (!fGenerator->getPixels(fInfo, pixels, fRowBytes)) { |
- return NULL; // TODO(halcanary) Find out correct thing to do. |
+ if (!fGenerator->getPixels(this->info(), pixels, fRowBytes)) { |
+ return false; // TODO(halcanary) Find out correct thing to do. |
} |
- return pixels; |
+ |
+ rec->fPixels = pixels; |
+ rec->fColorTable = NULL; |
+ rec->fRowBytes = fRowBytes; |
+ return true; |
} |
void SkDiscardablePixelRef::onUnlockPixels() { |
if (fDiscardableMemory != NULL) { |