MessagePack for C++
Loading...
Searching...
No Matches
carray.hpp
Go to the documentation of this file.
1//
2// MessagePack for C++ static resolution routine
3//
4// Copyright (C) 2016 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_CARRAY_HPP
11#define MSGPACK_V1_TYPE_CARRAY_HPP
12
17
18namespace msgpack {
19
23
24namespace adaptor {
25
26template <typename T, std::size_t N>
27struct convert<T[N]> {
28 msgpack::object const& operator()(msgpack::object const& o, T* v) const {
29 if (o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
30 if (o.via.array.size > N) { throw msgpack::type_error(); }
31 msgpack::object* p = o.via.array.ptr;
32 msgpack::object* const pend = o.via.array.ptr + o.via.array.size;
33 do {
34 p->convert(*v);
35 ++p;
36 ++v;
37 } while(p < pend);
38 return o;
39 }
40};
41
42template <std::size_t N>
43struct convert<char[N]> {
44 msgpack::object const& operator()(msgpack::object const& o, char(&v)[N]) const {
45 switch (o.type) {
46 case msgpack::type::BIN:
47 if (o.via.bin.size > N) { throw msgpack::type_error(); }
48 std::memcpy(v, o.via.bin.ptr, o.via.bin.size);
49 break;
50 case msgpack::type::STR:
51 if (o.via.str.size > N) { throw msgpack::type_error(); }
52 std::memcpy(v, o.via.str.ptr, o.via.str.size);
53 if (o.via.str.size < N) v[o.via.str.size] = '\0';
54 break;
55 default:
56 throw msgpack::type_error();
57 break;
58 }
59 return o;
60 }
61};
62
63template <std::size_t N>
65 msgpack::object const& operator()(msgpack::object const& o, unsigned char(&v)[N]) const {
66 switch (o.type) {
67 case msgpack::type::BIN:
68 if (o.via.bin.size > N) { throw msgpack::type_error(); }
69 std::memcpy(v, o.via.bin.ptr, o.via.bin.size);
70 break;
71 case msgpack::type::STR:
72 if (o.via.str.size > N) { throw msgpack::type_error(); }
73 std::memcpy(v, o.via.str.ptr, o.via.str.size);
74 if (o.via.str.size < N) v[o.via.str.size] = '\0';
75 break;
76 default:
77 throw msgpack::type_error();
78 break;
79 }
80 return o;
81 }
82};
83
84
85template <typename T, std::size_t N>
86struct pack<T[N]> {
87 template <typename Stream>
90 o.pack_array(size);
91 const T* ptr = v;
92 for (; ptr != &v[N]; ++ptr) o.pack(*ptr);
93 return o;
94 }
95};
96
97template <std::size_t N>
98struct pack<char[N]> {
99 template <typename Stream>
101 char const* p = v;
103 char const* p2 = static_cast<char const*>(std::memchr(p, '\0', size));
104 uint32_t adjusted_size = p2 ? static_cast<uint32_t>(p2 - p) : size;
105 o.pack_str(adjusted_size);
106 o.pack_str_body(p, adjusted_size);
107 return o;
108 }
109};
110
111template <std::size_t N>
112struct pack<const char[N]> {
113 template <typename Stream>
116 char const* p = v;
117 char const* p2 = static_cast<char const*>(std::memchr(p, '\0', size));
118 uint32_t adjusted_size = p2 ? static_cast<uint32_t>(p2 - p) : size;
119 o.pack_str(adjusted_size);
120 o.pack_str_body(p, adjusted_size);
121 return o;
122 }
123};
124
125template <std::size_t N>
126struct pack<unsigned char[N]> {
127 template <typename Stream>
129 unsigned char const* p = v;
131 o.pack_bin(size);
132 o.pack_bin_body(reinterpret_cast<char const*>(p), size);
133 return o;
134 }
135};
136
137template <std::size_t N>
139 template <typename Stream>
141 unsigned char const* p = v;
143 o.pack_bin(size);
144 o.pack_bin_body(reinterpret_cast<char const*>(p), size);
145 return o;
146 }
147};
148
149template <typename T, std::size_t N>
151 void operator()(msgpack::object::with_zone& o, const T(&v)[N]) const {
153 o.type = msgpack::type::ARRAY;
154 msgpack::object* ptr = static_cast<msgpack::object*>(o.zone.allocate_align(sizeof(msgpack::object) * size, MSGPACK_ZONE_ALIGNOF(msgpack::object)));
155 o.via.array.ptr = ptr;
156 o.via.array.size = size;
157 const T* pv = v;
158 for (; pv != &v[size]; ++pv) {
159 *ptr++ = msgpack::object(*pv, o.zone);
160 }
161 }
162};
163
164template <std::size_t N>
166 void operator()(msgpack::object::with_zone& o, const char(&v)[N]) const {
167 char const* p = v;
169 char const* p2 = static_cast<char const*>(std::memchr(p, '\0', size));
170 uint32_t adjusted_size = p2 ? static_cast<uint32_t>(p2 - p) : size;
171 o.type = msgpack::type::STR;
172 char* ptr = static_cast<char*>(o.zone.allocate_align(adjusted_size, MSGPACK_ZONE_ALIGNOF(char)));
173 o.via.str.ptr = ptr;
174 o.via.str.size = adjusted_size;
175 std::memcpy(ptr, p, adjusted_size);
176 }
177};
178
179template <std::size_t N>
181 void operator()(msgpack::object::with_zone& o, const char(&v)[N]) const {
182 char const* p = v;
184 char const* p2 = static_cast<char const*>(std::memchr(p, '\0', size));
185 uint32_t adjusted_size = p2 ? static_cast<uint32_t>(p2 - p) : size;
186 o.type = msgpack::type::STR;
187 char* ptr = static_cast<char*>(o.zone.allocate_align(adjusted_size, MSGPACK_ZONE_ALIGNOF(char)));
188 o.via.str.ptr = ptr;
189 o.via.str.size = adjusted_size;
190 std::memcpy(ptr, p, adjusted_size);
191 }
192};
193
194template <std::size_t N>
196 void operator()(msgpack::object::with_zone& o, const unsigned char(&v)[N]) const {
198 o.type = msgpack::type::BIN;
199 char* ptr = static_cast<char*>(o.zone.allocate_align(size, MSGPACK_ZONE_ALIGNOF(char)));
200 o.via.bin.ptr = ptr;
201 o.via.bin.size = size;
202 std::memcpy(ptr, v, size);
203 }
204};
205
206template <std::size_t N>
208 void operator()(msgpack::object::with_zone& o, const unsigned char(&v)[N]) const {
210 o.type = msgpack::type::BIN;
211 char* ptr = static_cast<char*>(o.zone.allocate_align(size, MSGPACK_ZONE_ALIGNOF(char)));
212 o.via.bin.ptr = ptr;
213 o.via.bin.size = size;
214 std::memcpy(ptr, v, size);
215 }
216};
217
218template <std::size_t N>
219struct object<char[N]> {
220 void operator()(msgpack::object& o, const char(&v)[N]) const {
221 char const* p = v;
223 char const* p2 = static_cast<char const*>(std::memchr(p, '\0', size));
224 uint32_t adjusted_size = p2 ? static_cast<uint32_t>(p2 - p) : size;
225 o.type = msgpack::type::STR;
226 o.via.str.ptr = p;
227 o.via.str.size = adjusted_size;
228 }
229};
230
231template <std::size_t N>
232struct object<const char[N]> {
233 void operator()(msgpack::object& o, const char(&v)[N]) const {
234 char const* p = v;
236 char const* p2 = static_cast<char const*>(std::memchr(p, '\0', size));
237 uint32_t adjusted_size = p2 ? static_cast<uint32_t>(p2 - p) : size;
238 o.type = msgpack::type::STR;
239 o.via.str.ptr = p;
240 o.via.str.size = adjusted_size;
241 }
242};
243
244
245} // namespace adaptor
246
248} // MSGPACK_API_VERSION_NAMESPACE(v1)
250
251} // namespace msgpack
252
253#endif // MSGPACK_V1_TYPE_CARRAY_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
msgpack::object const & operator()(msgpack::object const &o, T *v) const
Definition carray.hpp:28
msgpack::object const & operator()(msgpack::object const &o, char(&v)[N]) const
Definition carray.hpp:44
msgpack::object const & operator()(msgpack::object const &o, unsigned char(&v)[N]) const
Definition carray.hpp:65
Definition adaptor_base.hpp:27
void operator()(msgpack::object &o, const char(&v)[N]) const
Definition carray.hpp:220
void operator()(msgpack::object &o, const char(&v)[N]) const
Definition carray.hpp:233
void operator()(msgpack::object::with_zone &o, const T(&v)[N]) const
Definition carray.hpp:151
void operator()(msgpack::object::with_zone &o, const char(&v)[N]) const
Definition carray.hpp:166
void operator()(msgpack::object::with_zone &o, const char(&v)[N]) const
Definition carray.hpp:181
void operator()(msgpack::object::with_zone &o, const unsigned char(&v)[N]) const
Definition carray.hpp:208
void operator()(msgpack::object::with_zone &o, const unsigned char(&v)[N]) const
Definition carray.hpp:196
Definition adaptor_base.hpp:43
Definition adaptor_base.hpp:38
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const T(&v)[N]) const
Definition carray.hpp:88
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const char(&v)[N]) const
Definition carray.hpp:100
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const char(&v)[N]) const
Definition carray.hpp:114
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const unsigned char(&v)[N]) const
Definition carray.hpp:140
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, const unsigned char(&v)[N]) const
Definition carray.hpp:128
Definition adaptor_base.hpp:32
Definition object.hpp:35
Object class that corresponding to MessagePack format object.
Definition object_fwd.hpp:75
#define MSGPACK_ZONE_ALIGNOF(type)
Definition cpp03_zone_decl.hpp:30
#define MSGPACK_API_VERSION_NAMESPACE(ns)
Definition versioning.hpp:66