diff options
author | qiankun.miao <qiankun.miao@intel.com> | 2014-10-23 07:58:17 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2014-10-23 07:58:17 -0700 |
commit | d9aac34eceeb197c5551f38583670be7729dd00a (patch) | |
tree | 16bc7b580f4ae2e96aa24939599cac24cf00ed4e /src/core/SkResourceCache.cpp | |
parent | 26979c826048a5d62c64c9c907dbb579f28f7709 (diff) |
Add SkMaskCache
BUG=skia:
Review URL: https://codereview.chromium.org/670063004
Diffstat (limited to 'src/core/SkResourceCache.cpp')
-rw-r--r-- | src/core/SkResourceCache.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/core/SkResourceCache.cpp b/src/core/SkResourceCache.cpp index 1eb53cd8c6..ae8412d8b4 100644 --- a/src/core/SkResourceCache.cpp +++ b/src/core/SkResourceCache.cpp @@ -303,6 +303,15 @@ size_t SkResourceCache::setTotalByteLimit(size_t newLimit) { return prevLimit; } +SkCachedData* SkResourceCache::newCachedData(size_t bytes) { + if (fDiscardableFactory) { + SkDiscardableMemory* dm = fDiscardableFactory(bytes); + return dm ? SkNEW_ARGS(SkCachedData, (bytes, dm)) : NULL; + } else { + return SkNEW_ARGS(SkCachedData, (sk_malloc_throw(bytes), bytes)); + } +} + /////////////////////////////////////////////////////////////////////////////// void SkResourceCache::detach(Rec* rec) { @@ -482,6 +491,11 @@ SkBitmap::Allocator* SkResourceCache::GetAllocator() { return get_cache()->allocator(); } +SkCachedData* SkResourceCache::NewCachedData(size_t bytes) { + SkAutoMutexAcquire am(gMutex); + return get_cache()->newCachedData(bytes); +} + void SkResourceCache::Dump() { SkAutoMutexAcquire am(gMutex); get_cache()->dump(); |