5 #ifndef BITCOIN_LIMITEDMAP_H
6 #define BITCOIN_LIMITEDMAP_H
12 template <
typename K,
typename V>
18 typedef std::pair<const key_type, mapped_type>
value_type;
20 typedef typename std::map<K, V>::size_type
size_type;
24 typedef typename std::map<K, V>::iterator
iterator;
25 std::multimap<V, iterator>
rmap;
39 std::pair<iterator, bool> ret =
map.insert(x);
42 map.erase(
rmap.begin()->second);
45 rmap.insert(std::make_pair(x.second, ret.first));
52 if (itTarget ==
map.end())
54 std::pair<rmap_iterator, rmap_iterator> itPair =
rmap.equal_range(itTarget->second);
55 for (
rmap_iterator it = itPair.first; it != itPair.second; ++it)
56 if (it->second == itTarget) {
68 if (itTarget ==
map.end())
70 std::pair<rmap_iterator, rmap_iterator> itPair =
rmap.equal_range(itTarget->second);
71 for (
rmap_iterator it = itPair.first; it != itPair.second; ++it)
72 if (it->second == itTarget) {
75 rmap.insert(std::make_pair(v, itTarget));
85 while (
map.size() > s) {
86 map.erase(
rmap.begin()->second);
94 #endif // BITCOIN_LIMITEDMAP_H