11#ifndef MSGPACK_V1_TYPE_CPP11_CHRONO_HPP
12#define MSGPACK_V1_TYPE_CPP11_CHRONO_HPP
14#if !defined(MSGPACK_NO_BOOST)
23#include <boost/numeric/conversion/cast.hpp>
33template <
typename Clock,
typename Duration>
34struct as<std::chrono::time_point<Clock, Duration>> {
38 std::chrono::time_point<Clock, Duration>
tp;
39 switch(
o.via.ext.size) {
43 tp += std::chrono::seconds(
sec);
50 tp += std::chrono::duration_cast<Duration>(
51 std::chrono::nanoseconds(
nanosec));
52 tp += std::chrono::seconds(
sec);
61 tp += std::chrono::seconds(
sec);
62 tp += std::chrono::duration_cast<Duration>(
63 std::chrono::nanoseconds(
nanosec));
67 tp += std::chrono::seconds(
sec);
71 tp += std::chrono::seconds(
sec);
73 tp += std::chrono::duration_cast<Duration>(
74 std::chrono::nanoseconds(
ns));
85template <
typename Clock,
typename Duration>
86struct convert<std::chrono::time_point<Clock, Duration>> {
90 std::chrono::time_point<Clock, Duration>
tp;
91 switch(
o.via.ext.size) {
95 tp += std::chrono::seconds(
sec);
103 tp += std::chrono::duration_cast<Duration>(
104 std::chrono::nanoseconds(
nanosec));
105 tp += std::chrono::seconds(
sec);
115 tp += std::chrono::seconds(
sec);
116 tp += std::chrono::duration_cast<Duration>(
117 std::chrono::nanoseconds(
nanosec));
121 tp += std::chrono::seconds(
sec);
125 tp += std::chrono::seconds(
sec);
127 tp += std::chrono::duration_cast<Duration>(
128 std::chrono::nanoseconds(
ns));
141template <
typename Clock,
typename Duration>
142struct pack<std::chrono::time_point<Clock, Duration>> {
143 template <
typename Stream>
145 int64_t count = boost::numeric_cast<int64_t>(
v.time_since_epoch().count());
147 Duration::period::ratio::num *
148 (1000000000L / Duration::period::ratio::den);
157 * Duration::period::ratio::num
158 / Duration::period::ratio::den;
160 if ((
sec >> 34) == 0) {
162 if ((
data64 & 0xffffffff00000000L) == 0) {
168 o.pack_ext_body(
buf, 4);
175 o.pack_ext_body(
buf, 8);
186 o.pack_ext_body(
buf, 12);
192template <
typename Clock,
typename Duration>
195 int64_t count = boost::numeric_cast<int64_t>(
v.time_since_epoch().count());
198 Duration::period::ratio::num *
199 (1000000000L / Duration::period::ratio::den);
208 * Duration::period::ratio::num
209 / Duration::period::ratio::den;
210 if ((
sec >> 34) == 0) {
212 if ((
data64 & 0xffffffff00000000L) == 0) {
214 o.type = msgpack::type::EXT;
216 char*
p =
static_cast<char*
>(
o.zone.allocate_no_align(
o.via.ext.size + 1));
217 p[0] =
static_cast<char>(-1);
224 o.type = msgpack::type::EXT;
226 char*
p =
static_cast<char*
>(
o.zone.allocate_no_align(
o.via.ext.size + 1));
227 p[0] =
static_cast<char>(-1);
234 o.type = msgpack::type::EXT;
236 char*
p =
static_cast<char*
>(
o.zone.allocate_no_align(
o.via.ext.size + 1));
237 p[0] =
static_cast<char>(-1);
The class template that supports continuous packing.
Definition pack.hpp:33
Definition object_fwd.hpp:231
Definition adaptor_base.hpp:15
std::chrono::time_point< Clock, Duration > operator()(msgpack::object const &o) const
Definition chrono.hpp:35
Definition object_fwd_decl.hpp:61
msgpack::object const & operator()(msgpack::object const &o, std::chrono::time_point< Clock, Duration > &v) const
Definition chrono.hpp:87
Definition adaptor_base.hpp:27
void operator()(msgpack::object::with_zone &o, const std::chrono::time_point< Clock, Duration > &v) const
Definition chrono.hpp:194
Definition adaptor_base.hpp:43
msgpack::packer< Stream > & operator()(msgpack::packer< Stream > &o, std::chrono::time_point< Clock, Duration > const &v) const
Definition chrono.hpp:144
Definition adaptor_base.hpp:32
Object class that corresponding to MessagePack format object.
Definition object_fwd.hpp:75
#define _msgpack_load64(cast, from, to)
Definition sysdep.hpp:180
#define _msgpack_store32(to, num)
Definition sysdep.hpp:187
#define _msgpack_store64(to, num)
Definition sysdep.hpp:189
#define _msgpack_load32(cast, from, to)
Definition sysdep.hpp:176
#define MSGPACK_API_VERSION_NAMESPACE(ns)
Definition versioning.hpp:66