MessagePack for C++
vector.hpp
Go to the documentation of this file.
1 //
2 // MessagePack for C++ static resolution routine
3 //
4 // Copyright (C) 2008-2015 FURUHASHI Sadayuki and 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_VECTOR_HPP
11 #define MSGPACK_V1_TYPE_VECTOR_HPP
12 
13 #include "msgpack/versioning.hpp"
16 
17 #include <vector>
18 
19 namespace msgpack {
20 
24 
25 namespace adaptor {
26 
27 #if !defined(MSGPACK_USE_CPP03)
28 
29 template <typename T, typename Alloc>
30 struct as<std::vector<T, Alloc>, typename std::enable_if<msgpack::has_as<T>::value>::type> {
31  std::vector<T, Alloc> operator()(const msgpack::object& o) const {
32  if (o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
33  std::vector<T, Alloc> v;
34  v.reserve(o.via.array.size);
35  if (o.via.array.size > 0) {
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 
49 template <typename T, typename Alloc>
50 struct convert<std::vector<T, Alloc> > {
51  msgpack::object const& operator()(msgpack::object const& o, std::vector<T, Alloc>& v) const {
52  if (o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
53  v.resize(o.via.array.size);
54  if (o.via.array.size > 0) {
56  msgpack::object* const pend = o.via.array.ptr + o.via.array.size;
57  typename std::vector<T, Alloc>::iterator it = v.begin();
58  do {
59  p->convert(*it);
60  ++p;
61  ++it;
62  } while(p < pend);
63  }
64  return o;
65  }
66 };
67 
68 template <typename T, typename Alloc>
69 struct pack<std::vector<T, Alloc> > {
70  template <typename Stream>
71  msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const std::vector<T, Alloc>& v) const {
72  uint32_t size = checked_get_container_size(v.size());
73  o.pack_array(size);
74  for (typename std::vector<T, Alloc>::const_iterator it(v.begin()), it_end(v.end());
75  it != it_end; ++it) {
76  o.pack(*it);
77  }
78  return o;
79  }
80 };
81 
82 template <typename T, typename Alloc>
83 struct object_with_zone<std::vector<T, Alloc> > {
84  void operator()(msgpack::object::with_zone& o, const std::vector<T, Alloc>& v) const {
86  if (v.empty()) {
88  o.via.array.size = 0;
89  }
90  else {
91  uint32_t size = checked_get_container_size(v.size());
93  msgpack::object* const pend = p + size;
94  o.via.array.ptr = p;
95  o.via.array.size = size;
96  typename std::vector<T, Alloc>::const_iterator it(v.begin());
97  do {
98 #if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
99 #pragma GCC diagnostic push
100 #pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
101 #endif // defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
102  *p = msgpack::object(*it, o.zone);
103 #if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
104 #pragma GCC diagnostic pop
105 #endif // defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
106  ++p;
107  ++it;
108  } while(p < pend);
109  }
110  }
111 };
112 
113 } // namespace adaptor
114 
116 } // MSGPACK_API_VERSION_NAMESPACE(v1)
118 
119 } // namespace msgpack
120 
121 #endif // MSGPACK_V1_TYPE_VECTOR_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:256
std::size_t size(T const &t)
Definition: size_equal_only.hpp:24
@ ARRAY
Definition: object_fwd_decl.hpp:40
Definition: adaptor_base.hpp:15
uint32_t checked_get_container_size(T size)
Definition: check_container_size.hpp:55
std::vector< T, Alloc > operator()(const msgpack::object &o) const
Definition: vector.hpp:31
Definition: object_fwd_decl.hpp:61
msgpack::object const & operator()(msgpack::object const &o, std::vector< T, Alloc > &v) const
Definition: vector.hpp:51
Definition: adaptor_base.hpp:27
void operator()(msgpack::object::with_zone &o, const std::vector< T, Alloc > &v) const
Definition: vector.hpp:84
Definition: adaptor_base.hpp:43
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const std::vector< T, Alloc > &v) const
Definition: vector.hpp:71
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
std::enable_if< msgpack::has_as< T >::value, T >::type as() const
Get value as T.
Definition: object.hpp:1121
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:1071
msgpack::type::object_type type
Definition: object_fwd.hpp:92
msgpack::object_array array
Definition: object_fwd.hpp:85
#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