Store context options on caps.

Review URL: https://codereview.chromium.org/1158433006
This commit is contained in:
bsalomon 2015-05-22 12:25:41 -07:00 committed by Commit bot
parent a624d12b2d
commit f28cff71db
29 changed files with 128 additions and 80 deletions

View File

@ -47,6 +47,8 @@
SkAutoTDelete<GrContextFactory> gGrFactory;
#endif
struct GrContextOptions;
__SK_FORCE_IMAGE_DECODER_LINKING;
static const int kAutoTuneLoops = 0;
@ -844,7 +846,7 @@ int nanobench_main() {
SkTaskGroup::Enabler enabled;
#if SK_SUPPORT_GPU
GrContext::Options grContextOpts;
GrContextOptions grContextOpts;
grContextOpts.fDrawPathToCompressedTexture = FLAGS_gpuCompressAlphaMasks;
gGrFactory.reset(SkNEW_ARGS(GrContextFactory, (grContextOpts)));
#endif

View File

@ -16,6 +16,7 @@
'<(skia_include_path)/gpu/GrClip.h',
'<(skia_include_path)/gpu/GrColor.h',
'<(skia_include_path)/gpu/GrConfig.h',
'<(skia_include_path)/gpu/GrContextOptions.h',
'<(skia_include_path)/gpu/GrContext.h',
'<(skia_include_path)/gpu/GrCoordTransform.h',
'<(skia_include_path)/gpu/GrFragmentProcessor.h',

View File

@ -14,6 +14,8 @@
#include "SkRefCnt.h"
#include "SkString.h"
struct GrContextOptions;
class GrShaderCaps : public SkRefCnt {
public:
SK_DECLARE_INST_COUNT(GrShaderCaps)
@ -103,7 +105,7 @@ class GrCaps : public SkRefCnt {
public:
SK_DECLARE_INST_COUNT(GrCaps)
GrCaps();
GrCaps(const GrContextOptions&);
virtual SkString dump() const;
@ -186,6 +188,11 @@ public:
return fConfigTextureSupport[config];
}
bool suppressPrints() const { return fSupressPrints; }
bool drawPathMasksToCompressedTexturesSupport() const {
return fDrawPathMasksToCompressedTextureSupport; }
protected:
SkAutoTUnref<GrShaderCaps> fShaderCaps;
@ -214,6 +221,9 @@ protected:
bool fConfigTextureSupport[kGrPixelConfigCnt];
private:
bool fSupressPrints : 1;
bool fDrawPathMasksToCompressedTextureSupport : 1;
typedef SkRefCnt INHERITED;
};

View File

@ -20,6 +20,7 @@
class GrAARectRenderer;
class GrBatchFontCache;
struct GrContextOptions;
class GrDrawTarget;
class GrFragmentProcessor;
class GrGpu;
@ -46,20 +47,11 @@ class SK_API GrContext : public SkRefCnt {
public:
SK_DECLARE_INST_COUNT(GrContext)
struct Options {
Options() : fDrawPathToCompressedTexture(false), fSuppressPrints(false) { }
// EXPERIMENTAL
// May be removed in the future, or may become standard depending
// on the outcomes of a variety of internal tests.
bool fDrawPathToCompressedTexture;
bool fSuppressPrints;
};
/**
* Creates a GrContext for a backend context.
*/
static GrContext* Create(GrBackend, GrBackendContext, const Options* opts = NULL);
static GrContext* Create(GrBackend, GrBackendContext, const GrContextOptions& options);
static GrContext* Create(GrBackend, GrBackendContext);
/**
* Only defined in test apps.
@ -530,7 +522,6 @@ public:
GrResourceProvider* resourceProvider() { return fResourceProvider; }
const GrResourceProvider* resourceProvider() const { return fResourceProvider; }
GrResourceCache* getResourceCache() { return fResourceCache; }
bool suppressPrints() const { return fOptions.fSuppressPrints; }
// Called by tests that draw directly to the context via GrDrawTarget
void getTestTarget(GrTestTarget*);
@ -548,12 +539,6 @@ public:
GrPathRendererChain::DrawType drawType = GrPathRendererChain::kColor_DrawType,
GrPathRendererChain::StencilSupport* stencilSupport = NULL);
/**
* This returns a copy of the the GrContext::Options that was passed to the
* constructor of this class.
*/
const Options& getOptions() const { return fOptions; }
/** Prints cache stats to the string if GR_CACHE_STATS == 1. */
void dumpCacheStats(SkString*) const;
void printCacheStats() const;
@ -599,11 +584,10 @@ private:
int fMaxTextureSizeOverride;
const Options fOptions;
const uint32_t fUniqueID;
GrContext(const Options&); // init must be called after the constructor.
bool init(GrBackend, GrBackendContext);
GrContext(); // init must be called after the constructor.
bool init(GrBackend, GrBackendContext, const GrContextOptions& options);
void initMockContext();
void initCommon();

View File

@ -0,0 +1,24 @@
/*
* Copyright 2015 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef GrContextOptions_DEFINED
#define GrContextOptions_DEFINED
#include "GrTypes.h"
struct GrContextOptions {
GrContextOptions() : fDrawPathToCompressedTexture(false), fSuppressPrints(false) {}
// EXPERIMENTAL
// May be removed in the future, or may become standard depending
// on the outcomes of a variety of internal tests.
bool fDrawPathToCompressedTexture;
// Suppress prints for the GrContext.
bool fSuppressPrints;
};
#endif

View File

@ -265,13 +265,13 @@ private:
};
#ifdef SK_DEBUG
// Takes a pointer to a GrContext, and will suppress prints if required
#define GrContextDebugf(context, ...) \
if (!context->suppressPrints()) { \
SkDebugf(__VA_ARGS__); \
// Takes a pointer to a GrCaps, and will suppress prints if required
#define GrCapsDebugf(caps, ...) \
if (!caps->suppressPrints()) { \
SkDebugf(__VA_ARGS__); \
}
#else
#define GrContextDebugf(context, ...)
#define GrCapsDebugf(caps, ...)
#endif
#endif

View File

@ -15,6 +15,7 @@
#include "GrBatchTarget.h"
#include "GrBatchTest.h"
#include "GrCaps.h"
#include "GrContextOptions.h"
#include "GrDefaultGeoProcFactory.h"
#include "GrGpuResource.h"
#include "GrGpuResourcePriv.h"
@ -70,16 +71,16 @@ private:
GrContext* fContext;
};
GrContext* GrContext::Create(GrBackend backend, GrBackendContext backendContext,
const Options* opts) {
GrContext* context;
if (NULL == opts) {
context = SkNEW_ARGS(GrContext, (Options()));
} else {
context = SkNEW_ARGS(GrContext, (*opts));
}
GrContext* GrContext::Create(GrBackend backend, GrBackendContext backendContext) {
GrContextOptions defaultOptions;
return Create(backend, backendContext, defaultOptions);
}
if (context->init(backend, backendContext)) {
GrContext* GrContext::Create(GrBackend backend, GrBackendContext backendContext,
const GrContextOptions& options) {
GrContext* context = SkNEW(GrContext);
if (context->init(backend, backendContext, options)) {
return context;
} else {
context->unref();
@ -96,7 +97,7 @@ static int32_t next_id() {
return id;
}
GrContext::GrContext(const Options& opts) : fOptions(opts), fUniqueID(next_id()) {
GrContext::GrContext() : fUniqueID(next_id()) {
fGpu = NULL;
fResourceCache = NULL;
fResourceProvider = NULL;
@ -110,10 +111,11 @@ GrContext::GrContext(const Options& opts) : fOptions(opts), fUniqueID(next_id())
fMaxTextureSizeOverride = 1 << 20;
}
bool GrContext::init(GrBackend backend, GrBackendContext backendContext) {
bool GrContext::init(GrBackend backend, GrBackendContext backendContext,
const GrContextOptions& options) {
SkASSERT(NULL == fGpu);
fGpu = GrGpu::Create(backend, backendContext, this);
fGpu = GrGpu::Create(backend, backendContext, options, this);
if (NULL == fGpu) {
return false;
}

View File

@ -75,7 +75,7 @@ GrContext* GrContextFactory::get(GLContextType type, GrGLStandard forcedGpuAPI)
glCtx->makeCurrent();
GrBackendContext p3dctx = reinterpret_cast<GrBackendContext>(glInterface.get());
grCtx.reset(GrContext::Create(kOpenGL_GrBackend, p3dctx, &fGlobalOptions));
grCtx.reset(GrContext::Create(kOpenGL_GrBackend, p3dctx, fGlobalOptions));
if (!grCtx.get()) {
return NULL;
}

View File

@ -9,6 +9,7 @@
#define GrContextFactory_DEFINED
#include "GrContext.h"
#include "GrContextOptions.h"
#include "gl/SkGLContext.h"
#include "SkTArray.h"
@ -80,7 +81,7 @@ public:
}
}
explicit GrContextFactory(const GrContext::Options& opts) : fGlobalOptions(opts) { }
explicit GrContextFactory(const GrContextOptions& opts) : fGlobalOptions(opts) { }
GrContextFactory() { }
~GrContextFactory() { this->destroyContexts(); }
@ -126,7 +127,7 @@ public:
return NULL;
}
const GrContext::Options& getGlobalOptions() const { return fGlobalOptions; }
const GrContextOptions& getGlobalOptions() const { return fGlobalOptions; }
private:
struct GPUContext {
@ -135,7 +136,7 @@ private:
GrContext* fGrContext;
};
SkTArray<GPUContext, true> fContexts;
const GrContext::Options fGlobalOptions;
const GrContextOptions fGlobalOptions;
};
#endif

View File

@ -11,6 +11,7 @@
#include "GrBatch.h"
#include "GrCaps.h"
#include "GrContext.h"
#include "GrContextOptions.h"
#include "GrPath.h"
#include "GrPipeline.h"
#include "GrMemoryPool.h"
@ -68,8 +69,8 @@ bool GrDrawTarget::setupDstReadIfNecessary(const GrPipelineBuilder& pipelineBuil
drawBounds->roundOut(&drawIBounds);
if (!copyRect.intersect(drawIBounds)) {
#ifdef SK_DEBUG
GrContextDebugf(fContext, "Missed an early reject. "
"Bailing on draw from setupDstReadIfNecessary.\n");
GrCapsDebugf(fCaps, "Missed an early reject. "
"Bailing on draw from setupDstReadIfNecessary.\n");
#endif
return false;
}
@ -598,7 +599,7 @@ SkString GrShaderCaps::dump() const {
///////////////////////////////////////////////////////////////////////////////
GrCaps::GrCaps() {
GrCaps::GrCaps(const GrContextOptions& options) {
fMipMapSupport = false;
fNPOTTextureTileSupport = false;
fTwoSidedStencilSupport = false;
@ -621,6 +622,9 @@ GrCaps::GrCaps() {
memset(fConfigRenderSupport, 0, sizeof(fConfigRenderSupport));
memset(fConfigTextureSupport, 0, sizeof(fConfigTextureSupport));
fSupressPrints = options.fSuppressPrints;
fDrawPathMasksToCompressedTextureSupport = options.fDrawPathToCompressedTexture;
}
static SkString map_flags_to_string(uint32_t flags) {

View File

@ -31,7 +31,7 @@ public:
* not supported (at compile-time or run-time) this returns NULL. The context will not be
* fully constructed and should not be used by GrGpu until after this function returns.
*/
static GrGpu* Create(GrBackend, GrBackendContext, GrContext* context);
static GrGpu* Create(GrBackend, GrBackendContext, const GrContextOptions&, GrContext* context);
////////////////////////////////////////////////////////////////////////////

View File

@ -20,10 +20,13 @@ GrGpuFactoryRegistrar::GrGpuFactoryRegistrar(int i, CreateGpuProc proc) {
gGpuFactories[i] = proc;
}
GrGpu* GrGpu::Create(GrBackend backend, GrBackendContext backendContext, GrContext* context) {
GrGpu* GrGpu::Create(GrBackend backend,
GrBackendContext backendContext,
const GrContextOptions& options,
GrContext* context) {
SkASSERT((int)backend < kMaxNumBackends);
if (!gGpuFactories[backend]) {
return NULL;
}
return (gGpuFactories[backend])(backendContext, context);
return (gGpuFactories[backend])(backendContext, options, context);
}

View File

@ -12,8 +12,9 @@
class GrGpu;
class GrContext;
struct GrContextOptions;
typedef GrGpu* (*CreateGpuProc)(GrBackendContext, GrContext*);
typedef GrGpu* (*CreateGpuProc)(GrBackendContext, const GrContextOptions& options, GrContext*);
class GrGpuFactoryRegistrar {
public:

View File

@ -174,7 +174,7 @@ bool GrSWMaskHelper::init(const SkIRect& resultBounds,
resultBounds.height());
if (allowCompression &&
fContext->getOptions().fDrawPathToCompressedTexture &&
fContext->getGpu()->caps()->drawPathMasksToCompressedTexturesSupport() &&
choose_compressed_fmt(fContext->getGpu()->caps(), &fCompressedFormat)) {
fCompressionMode = kCompress_CompressionMode;
}

View File

@ -7,6 +7,7 @@
*/
#include "GrTest.h"
#include "GrContextOptions.h"
#include "GrGpuResourceCacheAccess.h"
#include "GrInOrderDrawBuffer.h"
@ -138,7 +139,9 @@ class GrPipeline;
class MockGpu : public GrGpu {
public:
MockGpu(GrContext* context) : INHERITED(context) { fCaps.reset(SkNEW(GrCaps)); }
MockGpu(GrContext* context, const GrContextOptions& options) : INHERITED(context) {
fCaps.reset(SkNEW_ARGS(GrCaps, (options)));
}
~MockGpu() override {}
bool canWriteTexturePixels(const GrTexture*, GrPixelConfig srcConfig) const override {
return true;
@ -249,15 +252,16 @@ private:
};
GrContext* GrContext::CreateMockContext() {
GrContext* context = SkNEW_ARGS(GrContext, (Options()));
GrContext* context = SkNEW(GrContext);
context->initMockContext();
return context;
}
void GrContext::initMockContext() {
GrContextOptions options;
SkASSERT(NULL == fGpu);
fGpu = SkNEW_ARGS(MockGpu, (this));
fGpu = SkNEW_ARGS(MockGpu, (this, options));
SkASSERT(fGpu);
this->initCommon();

View File

@ -12,7 +12,9 @@
#include "SkTSearch.h"
#include "SkTSort.h"
GrGLCaps::GrGLCaps(const GrGLContextInfo& ctxInfo, const GrGLInterface* glInterface) {
GrGLCaps::GrGLCaps(const GrContextOptions& contextOptions,
const GrGLContextInfo& ctxInfo,
const GrGLInterface* glInterface) : INHERITED(contextOptions) {
fVerifiedColorConfigs.reset();
fStencilFormats.reset();
fStencilVerifiedColorConfigs.reset();

View File

@ -91,7 +91,8 @@ public:
* Initializes the GrGLCaps to the set of features supported in the current
* OpenGL context accessible via ctxInfo.
*/
GrGLCaps(const GrGLContextInfo& ctxInfo, const GrGLInterface* glInterface);
GrGLCaps(const GrContextOptions& contextOptions, const GrGLContextInfo& ctxInfo,
const GrGLInterface* glInterface);
/**
* Call to note that a color config has been verified as a valid color

View File

@ -9,7 +9,7 @@
////////////////////////////////////////////////////////////////////////////////
GrGLContext* GrGLContext::Create(const GrGLInterface* interface) {
GrGLContext* GrGLContext::Create(const GrGLInterface* interface, const GrContextOptions& options) {
// We haven't validated the GrGLInterface yet, so check for GetString function pointer
if (!interface->fFunctions.fGetString) {
return NULL;
@ -55,6 +55,9 @@ GrGLContext* GrGLContext::Create(const GrGLInterface* interface) {
args.fIsMesa = GrGLIsMesaFromVersionString(ver);
args.fIsChromium = GrGLIsChromiumFromRendererString(renderer);
args.fContextOptions = &options;
return SkNEW_ARGS(GrGLContext, (args));
}
@ -67,5 +70,5 @@ GrGLContextInfo::GrGLContextInfo(const ConstructorArgs& args) {
fIsMesa = args.fIsMesa;
fIsChromium = args.fIsChromium;
fGLCaps.reset(SkNEW_ARGS(GrGLCaps, (*this, fInterface)));
fGLCaps.reset(SkNEW_ARGS(GrGLCaps, (*args.fContextOptions, *this, fInterface)));
}

View File

@ -15,7 +15,7 @@
#include "GrGLSL.h"
#include "GrGLUtil.h"
#include "SkString.h"
struct GrContextOptions;
/**
* Encapsulates information about an OpenGL context including the OpenGL
@ -51,6 +51,7 @@ protected:
GrGLRenderer fRenderer;
bool fIsMesa;
bool fIsChromium;
const GrContextOptions* fContextOptions;
};
GrGLContextInfo(const ConstructorArgs& args);
@ -74,7 +75,7 @@ public:
* Creates a GrGLContext from a GrGLInterface and the currently
* bound OpenGL context accessible by the GrGLInterface.
*/
static GrGLContext* Create(const GrGLInterface* interface);
static GrGLContext* Create(const GrGLInterface* interface, const GrContextOptions& options);
const GrGLInterface* interface() const { return fInterface; }

View File

@ -157,7 +157,8 @@ bool GrGLGpu::BlendCoeffReferencesConstant(GrBlendCoeff coeff) {
///////////////////////////////////////////////////////////////////////////////
GrGpu* GrGLGpu::Create(GrBackendContext backendContext, GrContext* context) {
GrGpu* GrGLGpu::Create(GrBackendContext backendContext, const GrContextOptions& options,
GrContext* context) {
SkAutoTUnref<const GrGLInterface> glInterface(
reinterpret_cast<const GrGLInterface*>(backendContext));
if (!glInterface) {
@ -168,7 +169,7 @@ GrGpu* GrGLGpu::Create(GrBackendContext backendContext, GrContext* context) {
if (!glInterface) {
return NULL;
}
GrGLContext* glContext = GrGLContext::Create(glInterface);
GrGLContext* glContext = GrGLContext::Create(glInterface, options);
if (glContext) {
return SkNEW_ARGS(GrGLGpu, (glContext, context));
}
@ -1436,7 +1437,7 @@ bool GrGLGpu::flushGLState(const DrawArgs& args) {
fCurrentProgram.reset(fProgramCache->getProgram(args));
if (NULL == fCurrentProgram.get()) {
GrContextDebugf(this->getContext(), "Failed to create program!\n");
GrCapsDebugf(this->caps(), "Failed to create program!\n");
return false;
}

View File

@ -32,7 +32,8 @@ class GrNonInstancedVertices;
class GrGLGpu : public GrGpu {
public:
static GrGpu* Create(GrBackendContext backendContext, GrContext* context);
static GrGpu* Create(GrBackendContext backendContext, const GrContextOptions& options,
GrContext* context);
~GrGLGpu() override;
void contextAbandoned() override;

View File

@ -261,7 +261,7 @@ void GrGLProgramDataManager::setSkMatrix(UniformHandle u, const SkMatrix& matrix
#ifdef SK_DEBUG
void GrGLProgramDataManager::printUnused(const Uniform& uni) const {
if (kUnusedUniform == uni.fFSLocation && kUnusedUniform == uni.fVSLocation) {
GrContextDebugf(fGpu->getContext(), "Unused uniform in shader\n");
GrCapsDebugf(fGpu->caps(), "Unused uniform in shader\n");
}
}
#endif

View File

@ -207,7 +207,7 @@ bool GrGLProgramBuilder::emitAndInstallProcs(GrGLSLExpr4* inputColor, GrGLSLExpr
totalTextures += processor->numTextures();
if (totalTextures >= maxTextureUnits) {
GrContextDebugf(fGpu->getContext(), "Program would use too many texture units\n");
GrCapsDebugf(fGpu->caps(), "Program would use too many texture units\n");
return false;
}
}

View File

@ -283,7 +283,7 @@ DEF_GPUTEST(GLPrograms, reporter, factory) {
#endif
// We suppress prints to avoid spew
GrContext::Options opts;
GrContextOptions opts;
opts.fSuppressPrints = true;
GrContextFactory debugFactory(opts);
for (int type = 0; type < GrContextFactory::kLastGLContextType; ++type) {

View File

@ -18,7 +18,7 @@
namespace sk_tools {
#if SK_SUPPORT_GPU
CopyTilesRenderer::CopyTilesRenderer(const GrContext::Options& opts, int x, int y)
CopyTilesRenderer::CopyTilesRenderer(const GrContextOptions& opts, int x, int y)
: INHERITED(opts)
, fXTilesPerLargeTile(x)
, fYTilesPerLargeTile(y) { }

View File

@ -11,6 +11,7 @@
#include "PictureRenderer.h"
#include "SkTypes.h"
struct GrContextOptions;
class SkPicture;
class SkString;
@ -23,7 +24,7 @@ namespace sk_tools {
public:
#if SK_SUPPORT_GPU
CopyTilesRenderer(const GrContext::Options &opts, int x, int y);
CopyTilesRenderer(const GrContextOptions &opts, int x, int y);
#else
CopyTilesRenderer(int x, int y);
#endif

View File

@ -465,7 +465,7 @@ SkString SimplePictureRenderer::getConfigNameInternal() {
///////////////////////////////////////////////////////////////////////////////////////////////
#if SK_SUPPORT_GPU
TiledPictureRenderer::TiledPictureRenderer(const GrContext::Options& opts)
TiledPictureRenderer::TiledPictureRenderer(const GrContextOptions& opts)
: INHERITED(opts)
, fTileWidth(kDefaultTileWidth)
#else

View File

@ -28,6 +28,7 @@
#include "image_expectations.h"
struct GrContextOptions;
class SkBitmap;
class SkCanvas;
class SkGLContext;
@ -392,7 +393,7 @@ public:
return fGrContext;
}
const GrContext::Options& getGrContextOptions() {
const GrContextOptions& getGrContextOptions() {
return fGrContextFactory.getGlobalOptions();
}
#endif
@ -406,7 +407,7 @@ public:
}
#if SK_SUPPORT_GPU
explicit PictureRenderer(const GrContext::Options &opts)
explicit PictureRenderer(const GrContextOptions &opts)
#else
PictureRenderer()
#endif
@ -498,7 +499,7 @@ private:
class RecordPictureRenderer : public PictureRenderer {
public:
#if SK_SUPPORT_GPU
RecordPictureRenderer(const GrContext::Options &opts) : INHERITED(opts) { }
RecordPictureRenderer(const GrContextOptions &opts) : INHERITED(opts) { }
#endif
bool render(SkBitmap** out = NULL) override;
@ -519,7 +520,7 @@ private:
class PipePictureRenderer : public PictureRenderer {
public:
#if SK_SUPPORT_GPU
PipePictureRenderer(const GrContext::Options &opts) : INHERITED(opts) { }
PipePictureRenderer(const GrContextOptions &opts) : INHERITED(opts) { }
#endif
bool render(SkBitmap** out = NULL) override;
@ -533,7 +534,7 @@ private:
class SimplePictureRenderer : public PictureRenderer {
public:
#if SK_SUPPORT_GPU
SimplePictureRenderer(const GrContext::Options &opts) : INHERITED(opts) { }
SimplePictureRenderer(const GrContextOptions &opts) : INHERITED(opts) { }
#endif
virtual void init(const SkPicture* pict,
@ -554,7 +555,7 @@ private:
class TiledPictureRenderer : public PictureRenderer {
public:
#if SK_SUPPORT_GPU
TiledPictureRenderer(const GrContext::Options &opts);
TiledPictureRenderer(const GrContextOptions &opts);
#else
TiledPictureRenderer();
#endif
@ -689,7 +690,7 @@ private:
class PlaybackCreationRenderer : public PictureRenderer {
public:
#if SK_SUPPORT_GPU
PlaybackCreationRenderer(const GrContext::Options &opts) : INHERITED(opts) { }
PlaybackCreationRenderer(const GrContextOptions &opts) : INHERITED(opts) { }
#endif
void setup() override;
@ -709,7 +710,7 @@ private:
};
#if SK_SUPPORT_GPU
extern PictureRenderer* CreateGatherPixelRefsRenderer(const GrContext::Options& opts);
extern PictureRenderer* CreateGatherPixelRefsRenderer(const GrContextOptions& opts);
#else
extern PictureRenderer* CreateGatherPixelRefsRenderer();
#endif

View File

@ -8,6 +8,7 @@
#include "PictureRenderingFlags.h"
#include "CopyTilesRenderer.h"
#include "GrContextOptions.h"
#include "PictureRenderer.h"
#include "picture_utils.h"
#include "SkCommandLineFlags.h"
@ -94,7 +95,7 @@ sk_tools::PictureRenderer* parseRenderer(SkString& error, PictureTool tool) {
const char* mode = NULL;
#if SK_SUPPORT_GPU
GrContext::Options grContextOpts;
GrContextOptions grContextOpts;
grContextOpts.fDrawPathToCompressedTexture = FLAGS_gpuCompressAlphaMasks;
#define RENDERER_ARGS (grContextOpts)
#else