ActiveLib
Loading...
Searching...
No Matches
MultiMap.h
1
6#ifndef ACTIVE_CONTAINER_MULTI_MAP
7#define ACTIVE_CONTAINER_MULTI_MAP
8
9#include "Active/Utility/Cloner.h"
10#include "Active/Utility/Mover.h"
11
12#include <map>
13
14namespace active::container {
15
25 template<class Key, class T> requires utility::Clonable<T>
26 class MultiMap : public std::multimap<Key, std::unique_ptr<T>> {
27 public:
28
29 // MARK: Types
30
32 using base = std::multimap<Key, std::unique_ptr<T>>;
34 using raw_type = std::pair<const Key, T>;
36 using mapped_type = typename base::mapped_type;
38 using value_type = typename base::value_type;
40 using node_type = typename base::node_type;
42 using size_type = typename base::size_type;
44 using iterator = typename base::iterator;
46 using const_iterator = typename base::const_iterator;
47
48 // MARK: Constructors
49
53 MultiMap() : base() {}
58 MultiMap(const MultiMap& source) : base () { cloneFrom(source); }
63 MultiMap(MultiMap&& source) : base(std::move(source)) {}
67 virtual ~MultiMap() = default;
68
69 // MARK: Operators
70
76 auto operator= (const MultiMap& source) {
77 if (this != &source) {
78 base::clear();
79 cloneFrom(source);
80 }
81 return *this;
82 }
88 auto operator= (MultiMap&& source) {
89 if (this != &source)
90 base::operator=(std::move(source));
91 return *this;
92 }
93
94 // MARK: Functions (const)
95
100 auto find(const Key& key) const { return base::find(key); }
101
102 // MARK: Functions (mutating)
103
109 auto insert(const raw_type& item) { return emplace(item.first, clone(item.second)); }
115 auto insert(const value_type& item) { return emplace(item.first, clone(*item.second)); }
121 auto insert(value_type&& item) {
122 emplace(item.first, std::move(item.second));
123 }
129 auto insert(node_type&& node) { return base::insert(std::move(node)); }
134 auto emplace(const Key& key, mapped_type&& item) { return base::emplace(key, std::move(item)); }
139 auto emplace(const Key& key, T&& item) {
140 if constexpr(utility::Movable<T>)
141 base::emplace(key, cloneMove(std::move(item)));
142 else
143 base::emplace(key, clone(item));
144 }
150 auto release(iterator& pos) { return release(const_iterator(pos)); }
157 auto item = std::move(pos.second);
158 erase(pos);
159 return item;
160 }
161
162 private:
167 void cloneFrom(const MultiMap& source) {
168 for (const auto& item : source)
169 base::insert(std::make_pair(item.first, item.second ? clone(*item.second) : mapped_type()));
170 }
171 };
172
173}
174
175#endif //ACTIVE_CONTAINER_MULTI_MAP
Definition MultiMap.h:26
auto insert(const value_type &item)
Definition MultiMap.h:115
auto emplace(const Key &key, mapped_type &&item)
Definition MultiMap.h:134
typename base::const_iterator const_iterator
Container const iterator type.
Definition MultiMap.h:46
auto insert(value_type &&item)
Definition MultiMap.h:121
MultiMap(MultiMap &&source)
Definition MultiMap.h:63
auto operator=(const MultiMap &source)
Definition MultiMap.h:76
MultiMap(const MultiMap &source)
Definition MultiMap.h:58
auto insert(node_type &&node)
Definition MultiMap.h:129
auto release(iterator &pos)
Definition MultiMap.h:150
typename base::value_type value_type
Paired key/value type.
Definition MultiMap.h:38
typename base::node_type node_type
Node handle type.
Definition MultiMap.h:40
auto release(const_iterator pos)
Definition MultiMap.h:156
std::multimap< Key, std::unique_ptr< T > > base
Base container type.
Definition MultiMap.h:32
auto emplace(const Key &key, T &&item)
Definition MultiMap.h:139
virtual ~MultiMap()=default
typename base::mapped_type mapped_type
Stored type.
Definition MultiMap.h:36
typename base::iterator iterator
Container iterator type.
Definition MultiMap.h:44
MultiMap()
Definition MultiMap.h:53
typename base::size_type size_type
Container size (index) type.
Definition MultiMap.h:42
auto insert(const raw_type &item)
Definition MultiMap.h:109
auto find(const Key &key) const
Definition MultiMap.h:100
std::pair< const Key, T > raw_type
Paired key/raw value type.
Definition MultiMap.h:34
Movable concept for classes/functions dependent on cloning with a move.
Definition Mover.h:33
Definition HashMap.h:14