// // MessagePack for C++ static resolution routine // // Copyright (C) 2020 KONDO Takatoshi // // Distributed under the Boost Software License, Version 1.0. // (See accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) // #ifndef MSGPACK_V1_TYPE_COMPLEX_HPP #define MSGPACK_V1_TYPE_COMPLEX_HPP #include #include "msgpack/versioning.hpp" #include "msgpack/adaptor/adaptor_base.hpp" #include "msgpack/meta.hpp" namespace msgpack { /// @cond MSGPACK_API_VERSION_NAMESPACE(v1) { /// @endcond namespace adaptor { #if !defined(MSGPACK_USE_CPP03) template struct as, typename std::enable_if::value>::type> { std::complex operator()(msgpack::object const& o) const { if (o.type != msgpack::type::ARRAY) throw msgpack::type_error(); if (o.via.array.size != 2) throw msgpack::type_error(); return std::complex(o.via.array.ptr[0].as(), o.via.array.ptr[1].as()); } }; #endif // !defined(MSGPACK_USE_CPP03) template struct convert > { msgpack::object const& operator()(msgpack::object const& o, std::complex& v) const { if(o.type != msgpack::type::ARRAY) throw msgpack::type_error(); if(o.via.array.size != 2) throw msgpack::type_error(); T real; T imag; o.via.array.ptr[0].convert(real); o.via.array.ptr[1].convert(imag); v.real(real); v.imag(imag); return o; } }; template struct pack > { template msgpack::packer& operator()(msgpack::packer& o, std::complex const& v) const { o.pack_array(2); o.pack(v.real()); o.pack(v.imag()); return o; } }; template struct object_with_zone > { void operator()(msgpack::object::with_zone& o, std::complex const& v) const { o.type = msgpack::type::ARRAY; msgpack::object* p = static_cast(o.zone.allocate_align(sizeof(msgpack::object)*2, MSGPACK_ZONE_ALIGNOF(msgpack::object))); o.via.array.ptr = p; o.via.array.size = 2; p[0] = msgpack::object(v.real(), o.zone); p[1] = msgpack::object(v.imag(), o.zone); } }; } // namespace adaptor /// @cond } // MSGPACK_API_VERSION_NAMESPACE(v1) /// @endcond } // namespace msgpack #endif // MSGPACK_V1_TYPE_COMPLEX_HPP