Index: tests/WritePixelsTest.cpp |
diff --git a/tests/WritePixelsTest.cpp b/tests/WritePixelsTest.cpp |
index 70b91f227f24e48f13a767ac0ab7027e7af3a3e8..2a8d0592bbb558178323617695972cbb8d9b2de4 100644 |
--- a/tests/WritePixelsTest.cpp |
+++ b/tests/WritePixelsTest.cpp |
@@ -186,9 +186,9 @@ static bool checkPixel(SkPMColor a, SkPMColor b, bool didPremulConversion) { |
SkAbs32(aB - bB) <= 1; |
} |
-static bool checkWrite(skiatest::Reporter* reporter, SkCanvas* canvas, const SkBitmap& bitmap, |
+static bool check_write(skiatest::Reporter* reporter, SkCanvas* canvas, const SkBitmap& bitmap, |
int writeX, int writeY) { |
- SkImageInfo canvasInfo; |
+ const SkImageInfo canvasInfo = canvas->imageInfo(); |
size_t canvasRowBytes; |
const uint32_t* canvasPixels; |
@@ -196,15 +196,9 @@ static bool checkWrite(skiatest::Reporter* reporter, SkCanvas* canvas, const SkB |
// At some point this will be unsupported, as we won't allow accessBitmap() to magically call |
// readPixels for the client. |
SkBitmap secretDevBitmap; |
- { |
- SkBaseDevice* dev = canvas->getDevice(); |
- if (!dev) { |
- return false; |
- } |
- secretDevBitmap = dev->accessBitmap(false); |
- } |
+ canvas->readPixels(SkIRect::MakeWH(canvasInfo.width(), canvasInfo.height()), &secretDevBitmap); |
+ |
SkAutoLockPixels alp(secretDevBitmap); |
- canvasInfo = secretDevBitmap.info(); |
canvasRowBytes = secretDevBitmap.rowBytes(); |
canvasPixels = static_cast<const uint32_t*>(secretDevBitmap.getPixels()); |
@@ -299,25 +293,22 @@ static bool allocRowBytes(SkBitmap* bm, const SkImageInfo& info, size_t rowBytes |
return true; |
} |
-static SkBaseDevice* createDevice(const CanvasConfig& c, GrContext* grCtx) { |
+static void free_pixels(void* pixels, void* ctx) { |
+ sk_free(pixels); |
+} |
+ |
+static SkSurface* create_surface(const CanvasConfig& c, GrContext* grCtx) { |
+ SkImageInfo info = SkImageInfo::MakeN32Premul(DEV_W, DEV_H); |
switch (c.fDevType) { |
case kRaster_DevType: { |
- SkBitmap bmp; |
- size_t rowBytes = c.fTightRowBytes ? 0 : 4 * DEV_W + 100; |
- SkImageInfo info = SkImageInfo::MakeN32Premul(DEV_W, DEV_H); |
- if (!allocRowBytes(&bmp, info, rowBytes)) { |
- sk_throw(); |
- return NULL; |
- } |
+ const size_t rowBytes = c.fTightRowBytes ? info.minRowBytes() : 4 * DEV_W + 100; |
+ const size_t size = info.getSafeSize(rowBytes); |
+ void* pixels = sk_malloc_throw(size); |
// if rowBytes isn't tight then set the padding to a known value |
- if (rowBytes) { |
- SkAutoLockPixels alp(bmp); |
- // We'd just use memset here but GCC 4.8.1 throws up a bogus warning when we do. |
- for (size_t i = 0; i < bmp.getSafeSize(); i++) { |
- ((uint8_t*)bmp.getPixels())[i] = DEV_PAD; |
- } |
+ if (!c.fTightRowBytes) { |
+ memset(pixels, DEV_PAD, size); |
} |
- return new SkBitmapDevice(bmp); |
+ return SkSurface::NewRasterDirectReleaseProc(info, pixels, rowBytes, free_pixels, NULL); |
} |
#if SK_SUPPORT_GPU |
case kGpu_BottomLeft_DevType: |
@@ -331,13 +322,13 @@ static SkBaseDevice* createDevice(const CanvasConfig& c, GrContext* grCtx) { |
kTopLeft_GrSurfaceOrigin : kBottomLeft_GrSurfaceOrigin; |
GrAutoScratchTexture ast(grCtx, desc, GrContext::kExact_ScratchTexMatch); |
SkAutoTUnref<GrTexture> tex(ast.detach()); |
- return new SkGpuDevice(grCtx, tex); |
+ return SkSurface::NewRenderTargetDirect(tex->asRenderTarget()); |
#endif |
} |
return NULL; |
} |
-static bool setupBitmap(SkBitmap* bm, SkColorType ct, SkAlphaType at, int w, int h, int tightRB) { |
+static bool setup_bitmap(SkBitmap* bm, SkColorType ct, SkAlphaType at, int w, int h, int tightRB) { |
size_t rowBytes = tightRB ? 0 : 4 * w + 60; |
SkImageInfo info = SkImageInfo::Make(w, h, ct, at); |
if (!allocRowBytes(bm, info, rowBytes)) { |
@@ -444,8 +435,8 @@ DEF_GPUTEST(WritePixels, reporter, factory) { |
} |
#endif |
- SkAutoTUnref<SkBaseDevice> device(createDevice(gCanvasConfigs[i], context)); |
- SkCanvas canvas(device); |
+ SkAutoTUnref<SkSurface> surface(create_surface(gCanvasConfigs[i], context)); |
+ SkCanvas& canvas = *surface->getCanvas(); |
static const struct { |
SkColorType fColorType; |
@@ -465,15 +456,16 @@ DEF_GPUTEST(WritePixels, reporter, factory) { |
fillCanvas(&canvas); |
SkBitmap bmp; |
- REPORTER_ASSERT(reporter, setupBitmap(&bmp, ct, at, rect.width(), |
- rect.height(), SkToBool(tightBmp))); |
- uint32_t idBefore = canvas.getDevice()->accessBitmap(false).getGenerationID(); |
+ REPORTER_ASSERT(reporter, setup_bitmap(&bmp, ct, at, rect.width(), |
+ rect.height(), SkToBool(tightBmp))); |
+ uint32_t idBefore = surface->generationID(); |
// sk_tool_utils::write_pixels(&canvas, bmp, rect.fLeft, rect.fTop, ct, at); |
canvas.writePixels(bmp, rect.fLeft, rect.fTop); |
- uint32_t idAfter = canvas.getDevice()->accessBitmap(false).getGenerationID(); |
- REPORTER_ASSERT(reporter, checkWrite(reporter, &canvas, bmp, rect.fLeft, rect.fTop)); |
+ uint32_t idAfter = surface->generationID(); |
+ REPORTER_ASSERT(reporter, check_write(reporter, &canvas, bmp, |
+ rect.fLeft, rect.fTop)); |
// we should change the genID iff pixels were actually written. |
SkIRect canvasRect = SkIRect::MakeSize(canvas.getDeviceSize()); |