// // MessagePack for C++ static resolution routine // // Copyright (C) 2008-2009 FURUHASHI Sadayuki // // 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_PAIR_HPP #define MSGPACK_V1_TYPE_PAIR_HPP #include "msgpack/versioning.hpp" #include "msgpack/adaptor/adaptor_base.hpp" #include "msgpack/meta.hpp" #include 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::pair 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::make_pair(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::pair& v) const { if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); } if(o.via.array.size != 2) { throw msgpack::type_error(); } o.via.array.ptr[0].convert(v.first); o.via.array.ptr[1].convert(v.second); return o; } }; template struct pack > { template msgpack::packer& operator()(msgpack::packer& o, const std::pair& v) const { o.pack_array(2); o.pack(v.first); o.pack(v.second); return o; } }; template struct object_with_zone > { void operator()(msgpack::object::with_zone& o, const std::pair& v) const { o.type = msgpack::type::ARRAY; msgpack::object* p = static_cast(o.zone.allocate_align(sizeof(msgpack::object)*2)); o.via.array.ptr = p; o.via.array.size = 2; p[0] = msgpack::object(v.first, o.zone); p[1] = msgpack::object(v.second, o.zone); } }; } // namespace adaptor /// @cond } // MSGPACK_API_VERSION_NAMESPACE(v1) /// @endcond } // namespace msgpack #endif // MSGPACK_V1_TYPE_PAIR_HPP