Index: src/gpu/SkGpuDevice.cpp |
diff --git a/src/gpu/SkGpuDevice.cpp b/src/gpu/SkGpuDevice.cpp |
index d04d2d8185345a35fda486989313bdbc8306bb85..124f994612da23a9a96137599ca794e2ba624eee 100644 |
--- a/src/gpu/SkGpuDevice.cpp |
+++ b/src/gpu/SkGpuDevice.cpp |
@@ -1751,24 +1751,24 @@ |
/////////////////////////////////////////////////////////////////////////////// |
-SkBaseDevice* SkGpuDevice::onCreateCompatibleDevice(const CreateInfo& cinfo) { |
+SkBaseDevice* SkGpuDevice::onCreateDevice(const SkImageInfo& info, Usage usage) { |
GrSurfaceDesc desc; |
desc.fConfig = fRenderTarget->config(); |
desc.fFlags = kRenderTarget_GrSurfaceFlag; |
- desc.fWidth = cinfo.fInfo.width(); |
- desc.fHeight = cinfo.fInfo.height(); |
+ desc.fWidth = info.width(); |
+ desc.fHeight = info.height(); |
desc.fSampleCnt = fRenderTarget->numSamples(); |
SkAutoTUnref<GrTexture> texture; |
// Skia's convention is to only clear a device if it is non-opaque. |
- unsigned flags = cinfo.fInfo.isOpaque() ? 0 : kNeedClear_Flag; |
+ unsigned flags = info.isOpaque() ? 0 : kNeedClear_Flag; |
// If we're using distance field text, enable in the new device |
flags |= (fFlags & kDFText_Flag) ? kDFText_Flag : 0; |
#if CACHE_COMPATIBLE_DEVICE_TEXTURES |
// layers are never draw in repeat modes, so we can request an approx |
// match and ignore any padding. |
- const GrContext::ScratchTexMatch match = (kSaveLayer_Usage == cinfo.fUsage) ? |
+ const GrContext::ScratchTexMatch match = (kSaveLayer_Usage == usage) ? |
GrContext::kApprox_ScratchTexMatch : |
GrContext::kExact_ScratchTexMatch; |
texture.reset(fContext->refScratchTexture(desc, match)); |
@@ -1779,7 +1779,7 @@ |
return SkGpuDevice::Create(texture, SkSurfaceProps(SkSurfaceProps::kLegacyFontHost_InitType), flags); |
} else { |
SkDebugf("---- failed to create compatible device texture [%d %d]\n", |
- cinfo.fInfo.width(), cinfo.fInfo.height()); |
+ info.width(), info.height()); |
return NULL; |
} |
} |