MessagePack for C++
Loading...
Searching...
No Matches
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
15#include "msgpack/object.hpp"
17
18#include <unordered_map>
19
20namespace msgpack {
21
25
26namespace adaptor {
27
28template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
29struct 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
44template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
45struct 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
61template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
62struct 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
76template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
77struct 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 {
79 o.type = msgpack::type::MAP;
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
101template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
102struct 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
117template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
118struct 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
135template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
136struct 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
150template <typename K, typename V, typename Hash, typename Compare, typename Alloc>
151struct 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 {
153 o.type = msgpack::type::MAP;
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:1213
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
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
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
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::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