/*
|
* Copyright 2013 Google Inc.
|
*
|
* Use of this source code is governed by a BSD-style license that can be
|
* found in the LICENSE file.
|
*/
|
|
#ifndef SkDiscardableMemory_DEFINED
|
#define SkDiscardableMemory_DEFINED
|
|
#include "SkRefCnt.h"
|
#include "SkTypes.h"
|
|
/**
|
* Interface for discardable memory. Implementation is provided by the
|
* embedder.
|
*/
|
class SK_API SkDiscardableMemory {
|
public:
|
/**
|
* Factory method that creates, initializes and locks an SkDiscardableMemory
|
* object. If either of these steps fails, a nullptr pointer will be returned.
|
*/
|
static SkDiscardableMemory* Create(size_t bytes);
|
|
/**
|
* Factory class that creates, initializes and locks an SkDiscardableMemory
|
* object. If either of these steps fails, a nullptr pointer will be returned.
|
*/
|
class Factory : public SkRefCnt {
|
public:
|
virtual SkDiscardableMemory* create(size_t bytes) = 0;
|
private:
|
typedef SkRefCnt INHERITED;
|
};
|
|
/** Must not be called while locked.
|
*/
|
virtual ~SkDiscardableMemory() {}
|
|
/**
|
* Locks the memory, prevent it from being discarded. Once locked. you may
|
* obtain a pointer to that memory using the data() method.
|
*
|
* lock() may return false, indicating that the underlying memory was
|
* discarded and that the lock failed.
|
*
|
* Nested calls to lock are not allowed.
|
*/
|
virtual bool SK_WARN_UNUSED_RESULT lock() = 0;
|
|
/**
|
* Returns the current pointer for the discardable memory. This call is ONLY
|
* valid when the discardable memory object is locked.
|
*/
|
virtual void* data() = 0;
|
|
/**
|
* Unlock the memory so that it can be purged by the system. Must be called
|
* after every successful lock call.
|
*/
|
virtual void unlock() = 0;
|
};
|
|
#endif
|