diff options
author | jcgregorio <jcgregorio@google.com> | 2016-01-05 04:15:23 -0800 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-01-05 04:15:23 -0800 |
commit | 54e2ca5a2338b6700fd4c147ad2f934c70ecac90 (patch) | |
tree | 775efcc4d587a3630476cd73b7604083f3cf70e5 /dm | |
parent | bc7d235c8b0ddbe7080c6e9eba5b617fddc16135 (diff) |
Revert of Make SkGLContext lifetime more well-defined (patchset #7 id:120001 of https://codereview.chromium.org/1511773005/ )
Reason for revert:
Broke tests on Android, iOS, Mac and Windows.
Original issue's description:
> Make SkGLContext lifetime more well-defined
>
> Remove refcounting from SkGLContext.
>
> SkGLContext is expected to behave like GrContextFactory would own
> it, as implied by the GrContextFactory function.
>
> If it is refcounted, this does not hold.
>
> Also other use sites, such as in SkOSWindow_win (command buffer gl
> object), confirm the behavior. The object is explicitly owned and
> destroyed, not shared.
>
> Also fixes potential crashes from using GL context of an abandoned
> context.
>
> Also fixes potential crashes in DM/nanobench, if the GrContext lives
> longer than GLContext through internal refing of GrContext.
>
> Moves the non-trivial implementations from GrContextFactory.h to
> .cpp, just for consistency sake.
>
> Changes pathops_unittest.gyp. The pathops_unittest uses
> GrContextFactory, but did not link to its implementation. The reason
> they worked was that the implementation used (constructors, destructors)
> happened to be in the .h file.
>
> This works towards being able to use command buffer and NVPR from
> the SampleApp.
>
> BUG=skia:2992
> GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1511773005
>
> Committed: https://skia.googlesource.com/skia/+/830e012187f951d49d7e46e196ac8d1e653a25da
TBR=bsalomon@google.com,kkinnunen@nvidia.com
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=skia:2992
Review URL: https://codereview.chromium.org/1555053003
Diffstat (limited to 'dm')
-rw-r--r-- | dm/DM.cpp | 18 |
1 files changed, 8 insertions, 10 deletions
@@ -1147,16 +1147,16 @@ typedef void(*TestWithGrContext)(skiatest::Reporter*, GrContext*); typedef void(*TestWithGrContextAndGLContext)(skiatest::Reporter*, GrContext*, SkGLContext*); #if SK_SUPPORT_GPU template<typename T> -void call_test(T test, skiatest::Reporter* reporter, const GrContextFactory::ContextInfo& context); +void call_test(T test, skiatest::Reporter* reporter, GrContextFactory::ContextInfo* context); template<> void call_test(TestWithGrContext test, skiatest::Reporter* reporter, - const GrContextFactory::ContextInfo& context) { - test(reporter, context.fGrContext); + GrContextFactory::ContextInfo* context) { + test(reporter, context->fGrContext); } template<> void call_test(TestWithGrContextAndGLContext test, skiatest::Reporter* reporter, - const GrContextFactory::ContextInfo& context) { - test(reporter, context.fGrContext, context.fGLContext); + GrContextFactory::ContextInfo* context) { + test(reporter, context->fGrContext, context->fGLContext); } #endif } // namespace @@ -1202,13 +1202,11 @@ void RunWithGPUTestContexts(T test, GPUTestContexts testContexts, Reporter* repo if ((testContexts & contextSelector) == 0) { continue; } - GrContextFactory::ContextInfo context = factory->getContextInfo(contextType); - if (context.fGrContext) { + if (GrContextFactory::ContextInfo* context = factory->getContextInfo(contextType)) { call_test(test, reporter, context); } - context = factory->getContextInfo(contextType, - GrContextFactory::kEnableNVPR_GLContextOptions); - if (context.fGrContext) { + if (GrContextFactory::ContextInfo* context = + factory->getContextInfo(contextType, GrContextFactory::kEnableNVPR_GLContextOptions)) { call_test(test, reporter, context); } } |