blob: b09dcc1872c6b4133e4746d0d2859814e88b3a55 [file] [log] [blame]
bsalomon453cf402014-11-11 14:15:57 -08001/*
2 * Copyright 2014 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#ifndef GrGpuResourceCacheAccess_DEFINED
9#define GrGpuResourceCacheAccess_DEFINED
10
11#include "GrGpuResource.h"
bsalomon3582d3e2015-02-13 14:20:05 -080012#include "GrGpuResourcePriv.h"
13
14namespace skiatest {
15 class Reporter;
16}
bsalomon453cf402014-11-11 14:15:57 -080017
18/**
bsalomon3582d3e2015-02-13 14:20:05 -080019 * This class allows GrResourceCache increased privileged access to GrGpuResource objects.
bsalomon453cf402014-11-11 14:15:57 -080020 */
21class GrGpuResource::CacheAccess {
bsalomon3582d3e2015-02-13 14:20:05 -080022private:
bsalomon453cf402014-11-11 14:15:57 -080023 /**
bsalomonc2f35b72015-01-23 07:19:22 -080024 * Is the resource currently cached as scratch? This means it is cached, has a valid scratch
bsalomon8718aaf2015-02-19 07:24:21 -080025 * key, and does not have a unique key.
bsalomon453cf402014-11-11 14:15:57 -080026 */
27 bool isScratch() const {
bsalomon8718aaf2015-02-19 07:24:21 -080028 return !fResource->getUniqueKey().isValid() && fResource->fScratchKey.isValid() &&
bsalomon5ec26ae2016-02-25 08:33:02 -080029 SkBudgeted::kYes == fResource->resourcePriv().isBudgeted();
bsalomon453cf402014-11-11 14:15:57 -080030 }
31
bsalomon10e23ca2014-11-25 05:52:06 -080032 /**
bsalomon12299ab2014-11-14 13:33:09 -080033 * Called by the cache to delete the resource under normal circumstances.
34 */
35 void release() {
36 fResource->release();
halcanary385fe4d2015-08-26 13:07:48 -070037 if (fResource->isPurgeable()) {
38 delete fResource;
bsalomon12299ab2014-11-14 13:33:09 -080039 }
40 }
41
42 /**
43 * Called by the cache to delete the resource when the backend 3D context is no longer valid.
44 */
45 void abandon() {
46 fResource->abandon();
halcanary385fe4d2015-08-26 13:07:48 -070047 if (fResource->isPurgeable()) {
48 delete fResource;
bsalomon12299ab2014-11-14 13:33:09 -080049 }
50 }
51
bsalomonf99e9612015-02-19 08:24:16 -080052 /** Called by the cache to assign a new unique key. */
53 void setUniqueKey(const GrUniqueKey& key) { fResource->fUniqueKey = key; }
54
55 /** Called by the cache to make the unique key invalid. */
56 void removeUniqueKey() { fResource->fUniqueKey.reset(); }
57
bsalomon9f2d1572015-02-17 11:47:40 -080058 uint32_t timestamp() const { return fResource->fTimestamp; }
59 void setTimestamp(uint32_t ts) { fResource->fTimestamp = ts; }
60
61 int* accessCacheIndex() const { return &fResource->fCacheArrayIndex; }
62
bsalomon3582d3e2015-02-13 14:20:05 -080063 CacheAccess(GrGpuResource* resource) : fResource(resource) {}
64 CacheAccess(const CacheAccess& that) : fResource(that.fResource) {}
bsalomon453cf402014-11-11 14:15:57 -080065 CacheAccess& operator=(const CacheAccess&); // unimpl
66
67 // No taking addresses of this type.
68 const CacheAccess* operator&() const;
69 CacheAccess* operator&();
70
71 GrGpuResource* fResource;
72
73 friend class GrGpuResource; // to construct/copy this type.
bsalomon3582d3e2015-02-13 14:20:05 -080074 friend class GrResourceCache; // to use this type
75 friend void test_unbudgeted_to_scratch(skiatest::Reporter* reporter); // for unit testing
bsalomon453cf402014-11-11 14:15:57 -080076};
77
78inline GrGpuResource::CacheAccess GrGpuResource::cacheAccess() { return CacheAccess(this); }
79
80inline const GrGpuResource::CacheAccess GrGpuResource::cacheAccess() const {
81 return CacheAccess(const_cast<GrGpuResource*>(this));
82}
83
84#endif