/* * Copyright 2016 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #include "GrTextureContext.h" #include "GrContextPriv.h" #include "GrDrawingManager.h" #include "GrTextureOpList.h" #include "../private/GrAuditTrail.h" #define ASSERT_SINGLE_OWNER \ SkDEBUGCODE(GrSingleOwner::AutoEnforce debug_SingleOwner(this->singleOwner());) #define RETURN_FALSE_IF_ABANDONED if (this->drawingManager()->wasAbandoned()) { return false; } GrTextureContext::GrTextureContext(GrContext* context, GrDrawingManager* drawingMgr, sk_sp textureProxy, sk_sp colorSpace, GrAuditTrail* auditTrail, GrSingleOwner* singleOwner) : GrSurfaceContext(context, drawingMgr, textureProxy->config(), std::move(colorSpace), auditTrail, singleOwner) , fTextureProxy(std::move(textureProxy)) , fOpList(sk_ref_sp(fTextureProxy->getLastTextureOpList())) { SkDEBUGCODE(this->validate();) } #ifdef SK_DEBUG void GrTextureContext::validate() const { SkASSERT(fTextureProxy); fTextureProxy->validate(fContext); if (fOpList && !fOpList->isClosed()) { SkASSERT(fTextureProxy->getLastOpList() == fOpList.get()); } } #endif GrTextureContext::~GrTextureContext() { ASSERT_SINGLE_OWNER } GrRenderTargetProxy* GrTextureContext::asRenderTargetProxy() { // If the proxy can return an RTProxy it should've been wrapped in a RTContext SkASSERT(!fTextureProxy->asRenderTargetProxy()); return nullptr; } sk_sp GrTextureContext::asRenderTargetProxyRef() { // If the proxy can return an RTProxy it should've been wrapped in a RTContext SkASSERT(!fTextureProxy->asRenderTargetProxy()); return nullptr; } GrOpList* GrTextureContext::getOpList() { ASSERT_SINGLE_OWNER SkDEBUGCODE(this->validate();) if (!fOpList || fOpList->isClosed()) { fOpList = this->drawingManager()->newTextureOpList(fTextureProxy.get()); } return fOpList.get(); }