MessagePack for C++
Loading...
Searching...
No Matches
pair.hpp
Go to the documentation of this file.
1//
2// MessagePack for C++ static resolution routine
3//
4// Copyright (C) 2008-2009 FURUHASHI Sadayuki
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_PAIR_HPP
11#define MSGPACK_V1_TYPE_PAIR_HPP
12
15#include "msgpack/object.hpp"
16#include "msgpack/meta.hpp"
17
18#include <utility>
19
20namespace msgpack {
21
25
26namespace adaptor {
27
28#if !defined(MSGPACK_USE_CPP03)
29
30template <typename T1, typename T2>
31struct as<std::pair<T1, T2>,
32 typename std::enable_if<msgpack::any_of<msgpack::has_as, T1, T2>::value>::type> {
33 std::pair<T1, T2> operator()(msgpack::object const& o) const {
34 if (o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
35 if (o.via.array.size != 2) { throw msgpack::type_error(); }
36 return std::make_pair(o.via.array.ptr[0].as<T1>(), o.via.array.ptr[1].as<T2>());
37 }
38};
39
40#endif // !defined(MSGPACK_USE_CPP03)
41
42template <typename T1, typename T2>
43struct convert<std::pair<T1, T2> > {
44 msgpack::object const& operator()(msgpack::object const& o, std::pair<T1, T2>& v) const {
45 if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
46 if(o.via.array.size != 2) { throw msgpack::type_error(); }
47 o.via.array.ptr[0].convert(v.first);
48 o.via.array.ptr[1].convert(v.second);
49 return o;
50 }
51};
52
53template <typename T1, typename T2>
54struct pack<std::pair<T1, T2> > {
55 template <typename Stream>
56 msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const std::pair<T1, T2>& v) const {
57 o.pack_array(2);
58 o.pack(v.first);
59 o.pack(v.second);
60 return o;
61 }
62};
63
64template <typename T1, typename T2>
65struct object_with_zone<std::pair<T1, T2> > {
66 void operator()(msgpack::object::with_zone& o, const std::pair<T1, T2>& v) const {
67 o.type = msgpack::type::ARRAY;
69 o.via.array.ptr = p;
70 o.via.array.size = 2;
71 p[0] = msgpack::object(v.first, o.zone);
72 p[1] = msgpack::object(v.second, o.zone);
73 }
74};
75
76} // namespace adaptor
77
79} // MSGPACK_API_VERSION_NAMESPACE(v1)
81
82} // namespace msgpack
83
84#endif // MSGPACK_V1_TYPE_PAIR_HPP
The class template that supports continuous packing.
Definition pack.hpp:33
packer< Stream > & pack_array(uint32_t n)
Packing array header and size.
Definition pack.hpp:1195
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
Definition object_fwd_decl.hpp:61
msgpack::object const & operator()(msgpack::object const &o, std::pair< T1, T2 > &v) const
Definition pair.hpp:44
Definition adaptor_base.hpp:27
void operator()(msgpack::object::with_zone &o, const std::pair< T1, T2 > &v) const
Definition pair.hpp:66
Definition adaptor_base.hpp:43
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const std::pair< T1, T2 > &v) const
Definition pair.hpp:56
Definition adaptor_base.hpp:32
Definition object.hpp:35
msgpack::zone & zone
Definition object.hpp:37
uint32_t size
Definition object_fwd.hpp:23
msgpack::object * ptr
Definition object_fwd.hpp:24
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_array array
Definition object_fwd.hpp:85
#define MSGPACK_ZONE_ALIGNOF(type)
Definition cpp03_zone_decl.hpp:30
#define MSGPACK_API_VERSION_NAMESPACE(ns)
Definition versioning.hpp:66