10#ifndef MSGPACK_TYPE_TR1_UNORDERED_MAP_HPP
11#define MSGPACK_TYPE_TR1_UNORDERED_MAP_HPP
18#if defined(_LIBCPP_VERSION) || (_MSC_VER >= 1700)
20#define MSGPACK_HAS_STD_UNORDERED_MAP
21#include <unordered_map>
22#define MSGPACK_STD_TR1 std
28#define MSGPACK_HAS_STD_TR1_UNORDERED_MAP
30#include <tr1/unordered_map>
31#define MSGPACK_STD_TR1 std::tr1
37#if defined(MSGPACK_STD_TR1)
47template <
typename K,
typename V,
typename Hash,
typename Pred,
typename Alloc>
48struct convert<MSGPACK_STD_TR1::unordered_map<K, V, Hash, Pred, Alloc> > {
53 MSGPACK_STD_TR1::unordered_map<K, V, Hash, Pred, Alloc> tmp;
54 for(; p != pend; ++p) {
57 p->val.convert(tmp[key]);
64template <
typename K,
typename V,
typename Hash,
typename Pred,
typename Alloc>
65struct pack<MSGPACK_STD_TR1::unordered_map<K, V, Hash, Pred, Alloc> > {
66 template <
typename Stream>
70 for(
typename MSGPACK_STD_TR1::unordered_map<K, V, Hash, Pred, Alloc>::const_iterator it(v.begin()), it_end(v.end());
79template <
typename K,
typename V,
typename Hash,
typename Pred,
typename Alloc>
80struct object_with_zone<MSGPACK_STD_TR1::unordered_map<K, V, Hash, Pred, Alloc> > {
92 typename MSGPACK_STD_TR1::unordered_map<K, V, Hash, Pred, Alloc>::const_iterator it(v.begin());
103template <
typename K,
typename V,
typename Hash,
typename Pred,
typename Alloc>
104struct convert<MSGPACK_STD_TR1::unordered_multimap<K, V, Hash, Pred, Alloc> > {
109 MSGPACK_STD_TR1::unordered_multimap<K, V, Hash, Pred, Alloc> tmp;
110 for(; p != pend; ++p) {
111 std::pair<K, V> value;
121template <
typename K,
typename V,
typename Hash,
typename Pred,
typename Alloc>
122struct pack<MSGPACK_STD_TR1::unordered_multimap<K, V, Hash, Pred, Alloc> > {
123 template <
typename Stream>
127 for(
typename MSGPACK_STD_TR1::unordered_multimap<K, V, Hash, Pred, Alloc>::const_iterator it(v.begin()), it_end(v.end());
128 it != it_end; ++it) {
136template <
typename K,
typename V,
typename Hash,
typename Pred,
typename Alloc>
137struct object_with_zone<MSGPACK_STD_TR1::unordered_multimap<K, V, Hash, Pred, Alloc> > {
149 typename MSGPACK_STD_TR1::unordered_multimap<K, V, Hash, Pred, Alloc>::const_iterator it(v.begin());
168#undef MSGPACK_STD_TR1
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
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
void pack(msgpack::packer< Stream > &o, const T &v)
Definition object.hpp:1185
uint32_t checked_get_container_size(T size)
Definition check_container_size.hpp:55
void convert(T &v, msgpack::object const &o)
Definition object.hpp:1178
msgpack::object const & operator()(msgpack::object const &o, T &v) const
Definition object.hpp:646
void operator()(msgpack::object::with_zone &o, T const &v) const
Definition object.hpp:662
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, T const &v) const
Definition object.hpp:655
msgpack::zone & zone
Definition object.hpp:37
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
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