20#include <xrpl/basics/TaggedCache.ipp>
21#include <xrpl/ledger/CachedView.h>
29 return read(k) !=
nullptr;
38 bool cacheHit =
false;
39 bool baseRead =
false;
44 auto const iter =
map_.find(k.
key);
45 if (iter !=
map_.end())
62 "ripple::CachedView::read : null SLE result from base");
63 if (cacheHit && baseRead)
64 hitsexpired.increment();
78 if (!sle || !k.
check(*sle))
Implementation for CountedObject.
virtual std::optional< digest_type > digest(key_type const &key) const =0
Return the digest associated with the key.
virtual std::shared_ptr< SLE const > read(Keylet const &k) const =0
Return the state item associated with a key.
SharedPointerType fetch(key_type const &key)
std::optional< digest_type > digest(key_type const &key) const override
Return the digest associated with the key.
DigestAwareReadView const & base_
std::shared_ptr< SLE const > read(Keylet const &k) const override
Return the state item associated with a key.
bool exists(Keylet const &k) const override
Determine if a state item exists.
std::unordered_map< key_type, uint256, hardened_hash<> > map_
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
A pair of SHAMap key and LedgerEntryType.
bool check(STLedgerEntry const &) const
Returns true if the SLE matches the type.