diff options
author | csmartdalton <csmartdalton@google.com> | 2017-02-21 12:36:05 -0700 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2017-02-21 21:45:45 +0000 |
commit | e812d496aaa5e5e9f2117de8f442c297c9cb1367 (patch) | |
tree | 7342c7c6e048e3a226e162d7d1bcbf6ffbcddc55 /dm | |
parent | e026511f4c4b90bfe842f89966d088b663fc8c13 (diff) |
Rename GrContextFactory::ContextOptions to ContextOverrides
Also changes the behavior of these flags to only override their
corresponding context options when set, and to leave them unchanged
when not set.
BUG=skia:
Change-Id: I09f6be09997594fa888d9045dd4901354ef3f880
Reviewed-on: https://skia-review.googlesource.com/8780
Reviewed-by: Brian Salomon <bsalomon@google.com>
Commit-Queue: Chris Dalton <csmartdalton@google.com>
Diffstat (limited to 'dm')
-rw-r--r-- | dm/DM.cpp | 11 | ||||
-rw-r--r-- | dm/DMGpuSupport.h | 13 | ||||
-rw-r--r-- | dm/DMSrcSink.cpp | 8 | ||||
-rw-r--r-- | dm/DMSrcSink.h | 16 |
4 files changed, 23 insertions, 25 deletions
@@ -843,14 +843,14 @@ static Sink* create_sink(const SkCommandLineConfig* config) { if (gpu_supported()) { if (const SkCommandLineConfigGpu* gpuConfig = config->asConfigGpu()) { GrContextFactory::ContextType contextType = gpuConfig->getContextType(); - GrContextFactory::ContextOptions contextOptions = gpuConfig->getContextOptions(); + GrContextFactory::ContextOverrides contextOverrides = gpuConfig->getContextOverrides(); GrContextFactory testFactory; - if (!testFactory.get(contextType, contextOptions)) { + if (!testFactory.get(contextType, contextOverrides)) { info("WARNING: can not create GPU context for config '%s'. " "GM tests will be skipped.\n", gpuConfig->getTag().c_str()); return nullptr; } - return new GPUSink(contextType, contextOptions, gpuConfig->getSamples(), + return new GPUSink(contextType, contextOverrides, gpuConfig->getSamples(), gpuConfig->getUseDIText(), gpuConfig->getColorType(), sk_ref_sp(gpuConfig->getColorSpace()), FLAGS_gpu_threading); } @@ -1462,7 +1462,8 @@ void RunWithGPUTestContexts(GrContextTestFn* test, GrContextTypeFilterFn* contex continue; } } - ContextInfo ctxInfo = factory->getContextInfo(contextType); + ContextInfo ctxInfo = factory->getContextInfo(contextType, + GrContextFactory::ContextOverrides::kDisableNVPR); if (contextTypeFilter && !(*contextTypeFilter)(contextType)) { continue; } @@ -1471,7 +1472,7 @@ void RunWithGPUTestContexts(GrContextTestFn* test, GrContextTypeFilterFn* contex (*test)(reporter, ctxInfo); } ctxInfo = factory->getContextInfo(contextType, - GrContextFactory::ContextOptions::kEnableNVPR); + GrContextFactory::ContextOverrides::kRequireNVPRSupport); if (ctxInfo.grContext()) { (*test)(reporter, ctxInfo); } diff --git a/dm/DMGpuSupport.h b/dm/DMGpuSupport.h index 1ea51d2621..75bfc3b23e 100644 --- a/dm/DMGpuSupport.h +++ b/dm/DMGpuSupport.h @@ -31,13 +31,13 @@ static const bool kGPUDisabled = false; static inline sk_sp<SkSurface> NewGpuSurface( sk_gpu_test::GrContextFactory* grFactory, sk_gpu_test::GrContextFactory::ContextType type, - sk_gpu_test::GrContextFactory::ContextOptions options, + sk_gpu_test::GrContextFactory::ContextOverrides overrides, SkImageInfo info, int samples, bool useDIText) { uint32_t flags = useDIText ? SkSurfaceProps::kUseDeviceIndependentFonts_Flag : 0; SkSurfaceProps props(flags, SkSurfaceProps::kLegacyFontHost_InitType); - return SkSurface::MakeRenderTarget(grFactory->get(type, options), SkBudgeted::kNo, + return SkSurface::MakeRenderTarget(grFactory->get(type, overrides), SkBudgeted::kNo, info, samples, &props); } @@ -63,7 +63,7 @@ public: namespace sk_gpu_test { class GrContextFactory { public: - GrContextFactory() {}; + GrContextFactory() {} explicit GrContextFactory(const GrContextOptions&) {} typedef int ContextType; @@ -80,10 +80,7 @@ public: kNullGL_ContextType = 0, kVulkan_ContextType = 0; static const int kContextTypeCnt = 1; - enum ContextOptions { - kNone_ContextOptions = 0, - kEnableNVPR_ContextOptions = 0x1, - }; + enum class ContextOverrides {}; void destroyContexts() {} void abandonContexts() {} @@ -98,7 +95,7 @@ static const bool kGPUDisabled = true; static inline SkSurface* NewGpuSurface(sk_gpu_test::GrContextFactory*, sk_gpu_test::GrContextFactory::ContextType, - sk_gpu_test::GrContextFactory::ContextOptions, + sk_gpu_test::GrContextFactory::ContextOverrides, SkImageInfo, int, bool) { diff --git a/dm/DMSrcSink.cpp b/dm/DMSrcSink.cpp index e70cae31a4..a4991116ca 100644 --- a/dm/DMSrcSink.cpp +++ b/dm/DMSrcSink.cpp @@ -1223,14 +1223,14 @@ Error NullSink::draw(const Src& src, SkBitmap*, SkWStream*, SkString*) const { DEFINE_bool(gpuStats, false, "Append GPU stats to the log for each GPU task?"); GPUSink::GPUSink(GrContextFactory::ContextType ct, - GrContextFactory::ContextOptions options, + GrContextFactory::ContextOverrides overrides, int samples, bool diText, SkColorType colorType, sk_sp<SkColorSpace> colorSpace, bool threaded) : fContextType(ct) - , fContextOptions(options) + , fContextOverrides(overrides) , fSampleCount(samples) , fUseDIText(diText) , fColorType(colorType) @@ -1257,7 +1257,7 @@ Error GPUSink::draw(const Src& src, SkBitmap* dst, SkWStream*, SkString* log) co SkImageInfo::Make(size.width(), size.height(), fColorType, kPremul_SkAlphaType, fColorSpace); #if SK_SUPPORT_GPU - GrContext* context = factory.getContextInfo(fContextType, fContextOptions).grContext(); + GrContext* context = factory.getContextInfo(fContextType, fContextOverrides).grContext(); const int maxDimension = context->caps()->maxTextureSize(); if (maxDimension < SkTMax(size.width(), size.height())) { return Error::Nonfatal("Src too large to create a texture.\n"); @@ -1265,7 +1265,7 @@ Error GPUSink::draw(const Src& src, SkBitmap* dst, SkWStream*, SkString* log) co #endif auto surface( - NewGpuSurface(&factory, fContextType, fContextOptions, info, fSampleCount, fUseDIText)); + NewGpuSurface(&factory, fContextType, fContextOverrides, info, fSampleCount, fUseDIText)); if (!surface) { return "Could not create a surface."; } diff --git a/dm/DMSrcSink.h b/dm/DMSrcSink.h index 9c6808ecd6..92c5773d36 100644 --- a/dm/DMSrcSink.h +++ b/dm/DMSrcSink.h @@ -303,7 +303,7 @@ public: class GPUSink : public Sink { public: GPUSink(sk_gpu_test::GrContextFactory::ContextType, - sk_gpu_test::GrContextFactory::ContextOptions, + sk_gpu_test::GrContextFactory::ContextOverrides, int samples, bool diText, SkColorType colorType, sk_sp<SkColorSpace> colorSpace, bool threaded); @@ -312,13 +312,13 @@ public: const char* fileExtension() const override { return "png"; } SinkFlags flags() const override { return SinkFlags{ SinkFlags::kGPU, SinkFlags::kDirect }; } private: - sk_gpu_test::GrContextFactory::ContextType fContextType; - sk_gpu_test::GrContextFactory::ContextOptions fContextOptions; - int fSampleCount; - bool fUseDIText; - SkColorType fColorType; - sk_sp<SkColorSpace> fColorSpace; - bool fThreaded; + sk_gpu_test::GrContextFactory::ContextType fContextType; + sk_gpu_test::GrContextFactory::ContextOverrides fContextOverrides; + int fSampleCount; + bool fUseDIText; + SkColorType fColorType; + sk_sp<SkColorSpace> fColorSpace; + bool fThreaded; }; class PDFSink : public Sink { |