mirror of
https://git.wownero.com/wownero/onion-wownero-blockchain-explorer.git
synced 2024-08-15 00:33:12 +00:00
77 lines
1.3 KiB
C++
77 lines
1.3 KiB
C++
#ifndef CACHE_POLICY_HPP
|
|
#define CACHE_POLICY_HPP
|
|
|
|
#include <unordered_set>
|
|
|
|
namespace caches
|
|
{
|
|
|
|
template <typename Key>
|
|
|
|
class ICachePolicy
|
|
{
|
|
public:
|
|
|
|
virtual ~ICachePolicy() {}
|
|
|
|
// handle element insertion in a cache
|
|
virtual void Insert(const Key& key) = 0;
|
|
|
|
// handle request to the key-element in a cache
|
|
virtual void Touch(const Key& key) = 0;
|
|
|
|
// handle element deletion from a cache
|
|
virtual void Erase(const Key& key) = 0;
|
|
|
|
// return a key of a replacement candidate
|
|
virtual const Key& ReplCandidate() const = 0;
|
|
|
|
// clear the cache
|
|
virtual void Clear() = 0;
|
|
|
|
};
|
|
|
|
template <typename Key>
|
|
class NoCachePolicy : public ICachePolicy<Key>
|
|
{
|
|
public:
|
|
|
|
NoCachePolicy() = default;
|
|
|
|
~NoCachePolicy() override = default;
|
|
|
|
void Insert(const Key& key) override
|
|
{
|
|
key_storage.emplace(key);
|
|
}
|
|
|
|
void Touch(const Key& key) override
|
|
{
|
|
// do not do anything
|
|
}
|
|
|
|
void Erase(const Key& key) override
|
|
{
|
|
key_storage.erase(key);
|
|
}
|
|
|
|
// return a key of a displacement candidate
|
|
const Key& ReplCandidate() const override
|
|
{
|
|
return *key_storage.crbegin();
|
|
}
|
|
|
|
// return a key of a displacement candidate
|
|
void Clear() override
|
|
{
|
|
key_storage.clear();
|
|
}
|
|
|
|
private:
|
|
|
|
std::unordered_set<Key> key_storage;
|
|
};
|
|
|
|
} // namespace caches
|
|
|
|
#endif // CACHE_POLICY_HPP
|