MessagePack for C++
vector_byte.hpp
Go to the documentation of this file.
1 //
2 // MessagePack for C++ static resolution routine
3 //
4 // Copyright (C) 2018 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_BYTE_HPP
11 #define MSGPACK_V1_TYPE_VECTOR_BYTE_HPP
12 
13 #include "msgpack/cpp_version.hpp"
14 
15 #if MSGPACK_CPP_VERSION >= 201703
16 
17 #include "msgpack/versioning.hpp"
19 #include "msgpack/object.hpp"
21 
22 #include <vector>
23 #include <cstring>
24 #include <cstddef>
25 
26 namespace msgpack {
27 
31 
32 namespace adaptor {
33 
34 template <typename Alloc>
35 struct convert<std::vector<std::byte, Alloc> > {
36  msgpack::object const& operator()(msgpack::object const& o, std::vector<std::byte, Alloc>& v) const {
37  switch (o.type) {
38  case msgpack::type::BIN:
39  v.resize(o.via.bin.size);
40  if (o.via.bin.size != 0) {
41 #if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
42 #pragma GCC diagnostic push
43 #pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
44 #endif // defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
45  std::memcpy(&v.front(), o.via.bin.ptr, o.via.bin.size);
46 #if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
47 #pragma GCC diagnostic pop
48 #endif // defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
49  }
50  break;
51  case msgpack::type::STR:
52  v.resize(o.via.str.size);
53  if (o.via.str.size != 0) {
54 #if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
55 #pragma GCC diagnostic push
56 #pragma GCC diagnostic ignored "-Wmaybe-uninitialized"
57 #endif // defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
58  std::memcpy(&v.front(), o.via.str.ptr, o.via.str.size);
59 #if defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
60 #pragma GCC diagnostic pop
61 #endif // defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 7)) && !defined(__clang__)
62  }
63  break;
64  default:
65  throw msgpack::type_error();
66  break;
67  }
68  return o;
69  }
70 };
71 
72 template <typename Alloc>
73 struct pack<std::vector<std::byte, Alloc> > {
74  template <typename Stream>
75  msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const std::vector<std::byte, Alloc>& v) const {
76  uint32_t size = checked_get_container_size(v.size());
77  o.pack_bin(size);
78  if (size != 0) {
79  o.pack_bin_body(reinterpret_cast<char const*>(&v.front()), size);
80  }
81 
82  return o;
83  }
84 };
85 
86 template <typename Alloc>
87 struct object<std::vector<std::byte, Alloc> > {
88  void operator()(msgpack::object& o, const std::vector<std::byte, Alloc>& v) const {
89  uint32_t size = checked_get_container_size(v.size());
91  if (size != 0) {
92  o.via.bin.ptr = reinterpret_cast<char const*>(&v.front());
93  }
94  o.via.bin.size = size;
95  }
96 };
97 
98 template <typename Alloc>
99 struct object_with_zone<std::vector<std::byte, Alloc> > {
100  void operator()(msgpack::object::with_zone& o, const std::vector<std::byte, Alloc>& v) const {
101  uint32_t size = checked_get_container_size(v.size());
103  o.via.bin.size = size;
104  if (size != 0) {
105  char* ptr = static_cast<char*>(o.zone.allocate_align(size, MSGPACK_ZONE_ALIGNOF(char)));
106  o.via.bin.ptr = ptr;
107  std::memcpy(ptr, &v.front(), size);
108  }
109  }
110 };
111 
112 } // namespace adaptor
113 
115 } // MSGPACK_API_VERSION_NAMESPACE(v1)
117 
118 } // namespace msgpack
119 
120 #endif // MSGPACK_CPP_VERSION >= 201703
121 
122 #endif // MSGPACK_V1_TYPE_VECTOR_BYTE_HPP
The class template that supports continuous packing.
Definition: pack.hpp:33
packer< Stream > & pack_bin(uint32_t l)
Packing bin header and length.
Definition: pack.hpp:1312
packer< Stream > & pack_bin_body(const char *b, uint32_t l)
Packing bin body.
Definition: pack.hpp:1331
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
@ STR
Definition: object_fwd_decl.hpp:38
@ BIN
Definition: object_fwd_decl.hpp:39
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
void operator()(msgpack::object &o, T const &v) const
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, T const &v) const
Definition: object.hpp:655
Definition: object.hpp:35
msgpack::zone & zone
Definition: object.hpp:37
uint32_t size
Definition: object_fwd.hpp:38
const char * ptr
Definition: object_fwd.hpp:39
const char * ptr
Definition: object_fwd.hpp:34
uint32_t size
Definition: object_fwd.hpp:33
Object class that corresponding to MessagePack format object.
Definition: object_fwd.hpp:75
union_type via
Definition: object_fwd.hpp:93
msgpack::type::object_type type
Definition: object_fwd.hpp:92
msgpack::object_str str
Definition: object_fwd.hpp:87
msgpack::object_bin bin
Definition: object_fwd.hpp:88
#define MSGPACK_ZONE_ALIGNOF(type)
Definition: cpp03_zone_decl.hpp:30
#define MSGPACK_API_VERSION_NAMESPACE(ns)
Definition: versioning.hpp:66