a008b0fa8b
To my surprise, this even works with homegrown smart pointers (such as SkTLazy). https://clang.llvm.org/extra/clang-tidy/checks/readability-redundant-smartptr-get.html Find and remove redundant calls to smart pointer’s .get() method. Examples: ptr.get()->Foo() ==> ptr->Foo() *ptr.get() ==> *ptr *ptr->get() ==> **ptr if (ptr.get() == nullptr) ... => if (ptr == nullptr) ... Change-Id: I8ff541e0229656b4d8e875c8053a7e6138302547 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/310976 Auto-Submit: John Stiles <johnstiles@google.com> Commit-Queue: Mike Klein <mtklein@google.com> Reviewed-by: Mike Klein <mtklein@google.com>
108 lines
3.9 KiB
C++
108 lines
3.9 KiB
C++
/*
|
|
* Copyright 2016 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
// This is a GPU-backend specific test.
|
|
|
|
#include "tests/Test.h"
|
|
|
|
#include "include/gpu/GrDirectContext.h"
|
|
#include "src/gpu/GrContextPriv.h"
|
|
#include "src/gpu/GrProxyProvider.h"
|
|
#include "src/gpu/GrRecordingContextPriv.h"
|
|
#include "src/gpu/GrRenderTargetProxy.h"
|
|
#include "src/gpu/GrResourceProvider.h"
|
|
#include "src/gpu/GrSurfaceProxy.h"
|
|
#include "src/gpu/GrTexture.h"
|
|
#include "src/gpu/GrTextureProxy.h"
|
|
#include "tests/TestUtils.h"
|
|
|
|
static const int kWidthHeight = 128;
|
|
|
|
static sk_sp<GrTextureProxy> make_deferred(GrRecordingContext* rContext) {
|
|
GrProxyProvider* proxyProvider = rContext->priv().proxyProvider();
|
|
const GrCaps* caps = rContext->priv().caps();
|
|
|
|
const GrBackendFormat format = caps->getDefaultBackendFormat(GrColorType::kRGBA_8888,
|
|
GrRenderable::kYes);
|
|
return proxyProvider->createProxy(format, {kWidthHeight, kWidthHeight}, GrRenderable::kYes, 1,
|
|
GrMipmapped::kNo, SkBackingFit::kApprox, SkBudgeted::kYes,
|
|
GrProtected::kNo);
|
|
}
|
|
|
|
static sk_sp<GrTextureProxy> make_wrapped(GrRecordingContext* rContext) {
|
|
GrProxyProvider* proxyProvider = rContext->priv().proxyProvider();
|
|
|
|
return proxyProvider->testingOnly_createInstantiatedProxy(
|
|
{kWidthHeight, kWidthHeight}, GrColorType::kRGBA_8888, GrRenderable::kYes, 1,
|
|
SkBackingFit::kExact, SkBudgeted::kNo, GrProtected::kNo);
|
|
}
|
|
|
|
DEF_GPUTEST_FOR_RENDERING_CONTEXTS(ProxyRefTest, reporter, ctxInfo) {
|
|
auto dContext = ctxInfo.directContext();
|
|
GrResourceProvider* resourceProvider = dContext->priv().resourceProvider();
|
|
|
|
for (auto make : { make_deferred, make_wrapped }) {
|
|
// An extra ref
|
|
{
|
|
sk_sp<GrTextureProxy> proxy((*make)(dContext));
|
|
if (proxy) {
|
|
sk_sp<GrTextureProxy> extraRef(proxy); // NOLINT(performance-unnecessary-copy-initialization)
|
|
|
|
int backingRefs = proxy->isInstantiated() ? 1 : -1;
|
|
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 2, backingRefs);
|
|
|
|
proxy->instantiate(resourceProvider);
|
|
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 2, 1);
|
|
}
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 1, 1);
|
|
}
|
|
|
|
// Multiple normal refs
|
|
{
|
|
sk_sp<GrTextureProxy> proxy((*make)(dContext));
|
|
if (proxy) {
|
|
proxy->ref();
|
|
proxy->ref();
|
|
|
|
int backingRefs = proxy->isInstantiated() ? 1 : -1;
|
|
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 3, backingRefs);
|
|
|
|
proxy->instantiate(resourceProvider);
|
|
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 3, 1);
|
|
|
|
proxy->unref();
|
|
proxy->unref();
|
|
}
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 1, 1);
|
|
}
|
|
|
|
// Continue using (reffing) proxy after instantiation
|
|
{
|
|
sk_sp<GrTextureProxy> proxy((*make)(dContext));
|
|
if (proxy) {
|
|
sk_sp<GrTextureProxy> firstExtraRef(proxy); // NOLINT(performance-unnecessary-copy-initialization)
|
|
|
|
int backingRefs = proxy->isInstantiated() ? 1 : -1;
|
|
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 2, backingRefs);
|
|
|
|
proxy->instantiate(resourceProvider);
|
|
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 2, 1);
|
|
|
|
sk_sp<GrTextureProxy> secondExtraRef(proxy); // NOLINT(performance-unnecessary-copy-initialization)
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 3, 1);
|
|
}
|
|
CheckSingleThreadedProxyRefs(reporter, proxy.get(), 1, 1);
|
|
}
|
|
}
|
|
}
|