MessagePack for C++
unordered_map.hpp
Go to the documentation of this file.
1 //
2 // MessagePack for C++ static resolution routine
3 //
4 // Copyright (C) 2014-2015 KONDO Takatoshi
5 //
6 // Distributed under the Boost Software License, Version 1.0.
7 // (See accompanying file LICENSE_1_0.txt or copy at
8 // http://www.boost.org/LICENSE_1_0.txt)
9 //
10 #ifndef MSGPACK_V1_TYPE_CPP11_UNORDERED_MAP_HPP
11 #define MSGPACK_V1_TYPE_CPP11_UNORDERED_MAP_HPP
12 
13 #include "msgpack/versioning.hpp"
15 #include "msgpack/object.hpp"
17 
18 #include <unordered_map>
19 
20 namespace msgpack {
21 
25 
26 namespace adaptor {
27 
28 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
29 struct as<
30  std::unordered_map<K, V, Hash, Compare, Alloc>,
31  typename std::enable_if<msgpack::has_as<K>::value || msgpack::has_as<V>::value>::type> {
32  std::unordered_map<K, V, Hash, Compare, Alloc> operator()(msgpack::object const& o) const {
33  if (o.type != msgpack::type::MAP) { throw msgpack::type_error(); }
35  msgpack::object_kv* const pend(o.via.map.ptr + o.via.map.size);
36  std::unordered_map<K, V, Hash, Compare, Alloc> v;
37  for (; p != pend; ++p) {
38  v.emplace(p->key.as<K>(), p->val.as<V>());
39  }
40  return v;
41  }
42 };
43 
44 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
45 struct convert<std::unordered_map<K, V, Hash, Compare, Alloc>> {
46  msgpack::object const& operator()(msgpack::object const& o, std::unordered_map<K, V, Hash, Compare, Alloc>& v) const {
47  if(o.type != msgpack::type::MAP) { throw msgpack::type_error(); }
49  msgpack::object_kv* const pend(o.via.map.ptr + o.via.map.size);
50  std::unordered_map<K, V, Hash, Compare, Alloc> tmp;
51  for(; p != pend; ++p) {
52  K key;
53  p->key.convert(key);
54  p->val.convert(tmp[std::move(key)]);
55  }
56  v = std::move(tmp);
57  return o;
58  }
59 };
60 
61 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
62 struct pack<std::unordered_map<K, V, Hash, Compare, Alloc>> {
63  template <typename Stream>
64  msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const std::unordered_map<K, V, Hash, Compare, Alloc>& v) const {
65  uint32_t size = checked_get_container_size(v.size());
66  o.pack_map(size);
67  for(typename std::unordered_map<K, V, Hash, Compare, Alloc>::const_iterator it(v.begin()), it_end(v.end());
68  it != it_end; ++it) {
69  o.pack(it->first);
70  o.pack(it->second);
71  }
72  return o;
73  }
74 };
75 
76 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
77 struct object_with_zone<std::unordered_map<K, V, Hash, Compare, Alloc>> {
78  void operator()(msgpack::object::with_zone& o, const std::unordered_map<K, V, Hash, Compare, Alloc>& v) const {
80  if(v.empty()) {
82  o.via.map.size = 0;
83  } else {
84  uint32_t size = checked_get_container_size(v.size());
86  msgpack::object_kv* const pend = p + size;
87  o.via.map.ptr = p;
88  o.via.map.size = size;
89  typename std::unordered_map<K, V, Hash, Compare, Alloc>::const_iterator it(v.begin());
90  do {
91  p->key = msgpack::object(it->first, o.zone);
92  p->val = msgpack::object(it->second, o.zone);
93  ++p;
94  ++it;
95  } while(p < pend);
96  }
97  }
98 };
99 
100 
101 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
102 struct as<
103  std::unordered_multimap<K, V, Hash, Compare, Alloc>,
104  typename std::enable_if<msgpack::has_as<K>::value || msgpack::has_as<V>::value>::type> {
105  std::unordered_multimap<K, V, Hash, Compare, Alloc> operator()(msgpack::object const& o) const {
106  if (o.type != msgpack::type::MAP) { throw msgpack::type_error(); }
108  msgpack::object_kv* const pend(o.via.map.ptr + o.via.map.size);
109  std::unordered_multimap<K, V, Hash, Compare, Alloc> v;
110  for (; p != pend; ++p) {
111  v.emplace(p->key.as<K>(), p->val.as<V>());
112  }
113  return v;
114  }
115 };
116 
117 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
118 struct convert<std::unordered_multimap<K, V, Hash, Compare, Alloc>> {
119  msgpack::object const& operator()(msgpack::object const& o, std::unordered_multimap<K, V, Hash, Compare, Alloc>& v) const {
120  if(o.type != msgpack::type::MAP) { throw msgpack::type_error(); }
122  msgpack::object_kv* const pend(o.via.map.ptr + o.via.map.size);
123  std::unordered_multimap<K, V, Hash, Compare, Alloc> tmp;
124  for(; p != pend; ++p) {
125  std::pair<K, V> value;
126  p->key.convert(value.first);
127  p->val.convert(value.second);
128  tmp.insert(std::move(value));
129  }
130  v = std::move(tmp);
131  return o;
132  }
133 };
134 
135 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
136 struct pack<std::unordered_multimap<K, V, Hash, Compare, Alloc>> {
137  template <typename Stream>
138  msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const std::unordered_multimap<K, V, Hash, Compare, Alloc>& v) const {
139  uint32_t size = checked_get_container_size(v.size());
140  o.pack_map(size);
141  for(typename std::unordered_multimap<K, V, Hash, Compare, Alloc>::const_iterator it(v.begin()), it_end(v.end());
142  it != it_end; ++it) {
143  o.pack(it->first);
144  o.pack(it->second);
145  }
146  return o;
147  }
148 };
149 
150 template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
151 struct object_with_zone<std::unordered_multimap<K, V, Hash, Compare, Alloc>> {
152  void operator()(msgpack::object::with_zone& o, const std::unordered_multimap<K, V, Hash, Compare, Alloc>& v) const {
154  if(v.empty()) {
156  o.via.map.size = 0;
157  } else {
158  uint32_t size = checked_get_container_size(v.size());
160  msgpack::object_kv* const pend = p + size;
161  o.via.map.ptr = p;
162  o.via.map.size = size;
163  typename std::unordered_multimap<K, V, Hash, Compare, Alloc>::const_iterator it(v.begin());
164  do {
165  p->key = msgpack::object(it->first, o.zone);
166  p->val = msgpack::object(it->second, o.zone);
167  ++p;
168  ++it;
169  } while(p < pend);
170  }
171  }
172 };
173 
174 } // namespace adaptor
175 
177 } // MSGPACK_API_VERSION_NAMESPACE(v1)
179 
180 } // namespace msgpack
181 
182 
183 #endif // MSGPACK_V1_TYPE_CPP11_UNORDERED_MAP_HPP
The class template that supports continuous packing.
Definition: pack.hpp:33
packer< Stream > & pack_map(uint32_t n)
Packing map header and size.
Definition: pack.hpp:1235
packer< Stream > & pack(const T &v)
Packing function template.
Definition: object_fwd.hpp:231
void * allocate_align(size_t size, size_t align=MSGPACK_ZONE_ALIGN)
Definition: cpp03_zone.hpp:255
std::size_t size(T const &t)
Definition: size_equal_only.hpp:24
@ MAP
Definition: object_fwd_decl.hpp:41
Definition: adaptor_base.hpp:15
uint32_t checked_get_container_size(T size)
Definition: check_container_size.hpp:55
std::unordered_map< K, V, Hash, Compare, Alloc > operator()(msgpack::object const &o) const
Definition: unordered_map.hpp:32
std::unordered_multimap< K, V, Hash, Compare, Alloc > operator()(msgpack::object const &o) const
Definition: unordered_map.hpp:105
Definition: object_fwd_decl.hpp:61
msgpack::object const & operator()(msgpack::object const &o, std::unordered_map< K, V, Hash, Compare, Alloc > &v) const
Definition: unordered_map.hpp:46
msgpack::object const & operator()(msgpack::object const &o, std::unordered_multimap< K, V, Hash, Compare, Alloc > &v) const
Definition: unordered_map.hpp:119
Definition: adaptor_base.hpp:27
void operator()(msgpack::object::with_zone &o, const std::unordered_map< K, V, Hash, Compare, Alloc > &v) const
Definition: unordered_map.hpp:78
void operator()(msgpack::object::with_zone &o, const std::unordered_multimap< K, V, Hash, Compare, Alloc > &v) const
Definition: unordered_map.hpp:152
Definition: adaptor_base.hpp:43
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const std::unordered_map< K, V, Hash, Compare, Alloc > &v) const
Definition: unordered_map.hpp:64
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const std::unordered_multimap< K, V, Hash, Compare, Alloc > &v) const
Definition: unordered_map.hpp:138
Definition: adaptor_base.hpp:32
Definition: object.hpp:35
msgpack::zone & zone
Definition: object.hpp:37
Definition: object.hpp:30
msgpack::object val
Definition: object.hpp:32
msgpack::object key
Definition: object.hpp:31
uint32_t size
Definition: object_fwd.hpp:28
msgpack::object_kv * ptr
Definition: object_fwd.hpp:29
Object class that corresponding to MessagePack format object.
Definition: object_fwd.hpp:75
std::enable_if< msgpack::has_as< T >::value, T >::type as() const
Get value as T.
Definition: object.hpp:1126
union_type via
Definition: object_fwd.hpp:93
msgpack::enable_if< !msgpack::is_array< T >::value &&!msgpack::is_pointer< T >::value, T & >::type convert(T &v) const
Convert the object.
Definition: object.hpp:1076
msgpack::type::object_type type
Definition: object_fwd.hpp:92
msgpack::object_map map
Definition: object_fwd.hpp:86
#define MSGPACK_NULLPTR
Definition: cpp_config_decl.hpp:85
#define MSGPACK_ZONE_ALIGNOF(type)
Definition: cpp03_zone_decl.hpp:30
#define MSGPACK_API_VERSION_NAMESPACE(ns)
Definition: versioning.hpp:66