20#include <xrpld/ledger/CachedView.h>
21#include <xrpl/basics/contract.h>
22#include <xrpl/protocol/Serializer.h>
30 return read(k) !=
nullptr;
39 bool cacheHit =
false;
40 bool baseRead =
false;
45 auto const iter =
map_.find(k.
key);
46 if (iter !=
map_.end())
63 "ripple::CachedView::read : null SLE result from base");
64 if (cacheHit && baseRead)
65 hitsexpired.increment();
79 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.
std::shared_ptr< T > fetch(const key_type &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.