MessagePack for C++
Loading...
Searching...
No Matches
deque.hpp
Go to the documentation of this file.
1//
2// MessagePack for C++ static resolution routine
3//
4// Copyright (C) 2008-2015 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_DEQUE_HPP
11#define MSGPACK_V1_TYPE_DEQUE_HPP
12
15#include "msgpack/object.hpp"
17
18#include <deque>
19
20namespace msgpack {
21
25
26namespace adaptor {
27
28#if !defined(MSGPACK_USE_CPP03)
29
30template <typename T, typename Alloc>
31struct as<std::deque<T, Alloc>, typename std::enable_if<msgpack::has_as<T>::value>::type> {
32 std::deque<T, Alloc> operator()(const msgpack::object& o) const {
33 if (o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
34 std::deque<T, Alloc> v;
35 if (o.via.array.size > 0) {
36 msgpack::object* p = o.via.array.ptr;
37 msgpack::object* const pend = o.via.array.ptr + o.via.array.size;
38 do {
39 v.push_back(p->as<T>());
40 ++p;
41 } while (p < pend);
42 }
43 return v;
44 }
45};
46
47#endif // !defined(MSGPACK_USE_CPP03)
48
49template <typename T, typename Alloc>
50struct convert<std::deque<T, Alloc> > {
51 msgpack::object const& operator()(msgpack::object const& o, std::deque<T, Alloc>& v) const {
52 if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
53 v.resize(o.via.array.size);
54 msgpack::object* p = o.via.array.ptr;
55 msgpack::object* const pend = o.via.array.ptr + o.via.array.size;
56 typename std::deque<T, Alloc>::iterator it = v.begin();
57 for(; p < pend; ++p, ++it) {
58 p->convert(*it);
59 }
60 return o;
61 }
62};
63
64template <typename T, typename Alloc>
65struct pack<std::deque<T, Alloc> > {
66 template <typename Stream>
67 msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const std::deque<T, Alloc>& v) const {
69 o.pack_array(size);
70 for(typename std::deque<T, Alloc>::const_iterator it(v.begin()), it_end(v.end());
71 it != it_end; ++it) {
72 o.pack(*it);
73 }
74 return o;
75 }
76};
77
78template <typename T, typename Alloc>
79struct object_with_zone<std::deque<T, Alloc> > {
80 void operator()(msgpack::object::with_zone& o, const std::deque<T, Alloc>& v) const {
81 o.type = msgpack::type::ARRAY;
82 if(v.empty()) {
83 o.via.array.ptr = MSGPACK_NULLPTR;
84 o.via.array.size = 0;
85 } else {
87 msgpack::object* p = static_cast<msgpack::object*>(o.zone.allocate_align(sizeof(msgpack::object)*size, MSGPACK_ZONE_ALIGNOF(msgpack::object)));
88 msgpack::object* const pend = p + size;
89 o.via.array.ptr = p;
90 o.via.array.size = size;
91 typename std::deque<T, Alloc>::const_iterator it(v.begin());
92 do {
93 *p = msgpack::object(*it, o.zone);
94 ++p;
95 ++it;
96 } while(p < pend);
97 }
98 }
99};
100
101} // namespace adaptor
102
104} // MSGPACK_API_VERSION_NAMESPACE(v1)
106
107} // namespace msgpack
108
109#endif // MSGPACK_V1_TYPE_DEQUE_HPP
The class template that supports continuous packing.
Definition pack.hpp:33
Definition object_fwd.hpp:231
Definition adaptor_base.hpp:15
uint32_t checked_get_container_size(T size)
Definition check_container_size.hpp:55
std::deque< T, Alloc > operator()(const msgpack::object &o) const
Definition deque.hpp:32
Definition object_fwd_decl.hpp:61
msgpack::object const & operator()(msgpack::object const &o, std::deque< T, Alloc > &v) const
Definition deque.hpp:51
Definition adaptor_base.hpp:27
void operator()(msgpack::object::with_zone &o, const std::deque< T, Alloc > &v) const
Definition deque.hpp:80
Definition adaptor_base.hpp:43
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const std::deque< T, Alloc > &v) const
Definition deque.hpp:67
Definition adaptor_base.hpp:32
Definition object.hpp:35
Object class that corresponding to MessagePack format object.
Definition object_fwd.hpp:75
#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