| /* |
| * Copyright 2017 Google Inc. |
| * |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| |
| #ifndef GrSurfaceProxyPriv_DEFINED |
| #define GrSurfaceProxyPriv_DEFINED |
| |
| #include "GrSurfaceProxy.h" |
| |
| #include "GrResourceProvider.h" |
| |
| /** Class that adds methods to GrSurfaceProxy that are only intended for use internal to Skia. |
| This class is purely a privileged window into GrSurfaceProxy. It should never have additional |
| data members or virtual methods. */ |
| class GrSurfaceProxyPriv { |
| public: |
| // Beware! Woe betide anyone whosoever calls this method. |
| // The refs on proxies and their backing GrSurfaces shift around based on whether the proxy |
| // is instantiated or not. Additionally, the lifetime of a proxy (and a GrSurface) also |
| // depends on the read and write refs (So this method can validly return 0). |
| int32_t getProxyRefCnt() const { return fProxy->getProxyRefCnt(); } |
| |
| // Beware! This call is only guaranteed to tell you if the proxy in question has |
| // any pending IO in its current state. It won't tell you about the IO state in the |
| // future when the proxy is actually used/instantiated. |
| bool hasPendingIO() const { return fProxy->hasPendingIO(); } |
| |
| // Beware! This call is only guaranteed to tell you if the proxy in question has |
| // any pending writes in its current state. It won't tell you about the IO state in the |
| // future when the proxy is actually used/instantiated. |
| bool hasPendingWrite() const { return fProxy->hasPendingWrite(); } |
| |
| void computeScratchKey(GrScratchKey* key) const { return fProxy->computeScratchKey(key); } |
| |
| // Create a GrSurface-derived class that meets the requirements (i.e, desc, renderability) |
| // of the GrSurfaceProxy. |
| sk_sp<GrSurface> createSurface(GrResourceProvider* resourceProvider) const { |
| return fProxy->createSurface(resourceProvider); |
| } |
| |
| // Assign this proxy the provided GrSurface as its backing surface |
| void assign(sk_sp<GrSurface> surface) { fProxy->assign(std::move(surface)); } |
| |
| bool requiresNoPendingIO() const { |
| return fProxy->fSurfaceFlags & GrInternalSurfaceFlags::kNoPendingIO; |
| } |
| |
| // Don't abuse this call!!!!!!! |
| bool isExact() const { return SkBackingFit::kExact == fProxy->fFit; } |
| |
| // Don't. Just don't. |
| void exactify(); |
| |
| bool doLazyInstantiation(GrResourceProvider*); |
| |
| GrSurfaceProxy::LazyInstantiationType lazyInstantiationType() const { |
| return fProxy->fLazyInstantiationType; |
| } |
| |
| bool isSafeToDeinstantiate() const { |
| return SkToBool(fProxy->fTarget) && |
| SkToBool(fProxy->fLazyInstantiateCallback) && |
| GrSurfaceProxy::LazyInstantiationType::kDeinstantiate == lazyInstantiationType(); |
| } |
| |
| static bool SK_WARN_UNUSED_RESULT AttachStencilIfNeeded(GrResourceProvider*, GrSurface*, |
| bool needsStencil); |
| |
| private: |
| explicit GrSurfaceProxyPriv(GrSurfaceProxy* proxy) : fProxy(proxy) {} |
| GrSurfaceProxyPriv(const GrSurfaceProxyPriv&) {} // unimpl |
| GrSurfaceProxyPriv& operator=(const GrSurfaceProxyPriv&); // unimpl |
| |
| // No taking addresses of this type. |
| const GrSurfaceProxyPriv* operator&() const; |
| GrSurfaceProxyPriv* operator&(); |
| |
| GrSurfaceProxy* fProxy; |
| |
| friend class GrSurfaceProxy; // to construct/copy this type. |
| }; |
| |
| inline GrSurfaceProxyPriv GrSurfaceProxy::priv() { return GrSurfaceProxyPriv(this); } |
| |
| inline const GrSurfaceProxyPriv GrSurfaceProxy::priv () const { |
| return GrSurfaceProxyPriv(const_cast<GrSurfaceProxy*>(this)); |
| } |
| |
| #endif |