Hideaki Tai / msgpack-embedded

Dependents:   hello_message_pack

Committer:
hideakitai
Date:
Mon Feb 22 01:43:48 2016 +0000
Revision:
4:bd0c06dd6e92
Parent:
0:3f9dbf1e2cb0
fix throw error

Who changed what in which revision?

UserRevisionLine numberNew contents of line
hideakitai 0:3f9dbf1e2cb0 1 //
hideakitai 0:3f9dbf1e2cb0 2 // MessagePack for C++ static resolution routine
hideakitai 0:3f9dbf1e2cb0 3 //
hideakitai 0:3f9dbf1e2cb0 4 // Copyright (C) 2008-2015 FURUHASHI Sadayuki
hideakitai 0:3f9dbf1e2cb0 5 //
hideakitai 0:3f9dbf1e2cb0 6 // Distributed under the Boost Software License, Version 1.0.
hideakitai 0:3f9dbf1e2cb0 7 // (See accompanying file LICENSE_1_0.txt or copy at
hideakitai 0:3f9dbf1e2cb0 8 // http://www.boost.org/LICENSE_1_0.txt)
hideakitai 0:3f9dbf1e2cb0 9 //
hideakitai 0:3f9dbf1e2cb0 10 #ifndef MSGPACK_TYPE_LIST_HPP
hideakitai 0:3f9dbf1e2cb0 11 #define MSGPACK_TYPE_LIST_HPP
hideakitai 0:3f9dbf1e2cb0 12
hideakitai 0:3f9dbf1e2cb0 13 #include "msgpack/versioning.hpp"
hideakitai 0:3f9dbf1e2cb0 14 #include "msgpack/adaptor/adaptor_base.hpp"
hideakitai 0:3f9dbf1e2cb0 15 #include "msgpack/adaptor/check_container_size.hpp"
hideakitai 0:3f9dbf1e2cb0 16
hideakitai 0:3f9dbf1e2cb0 17 #include <list>
hideakitai 0:3f9dbf1e2cb0 18
hideakitai 0:3f9dbf1e2cb0 19 namespace msgpack {
hideakitai 0:3f9dbf1e2cb0 20
hideakitai 0:3f9dbf1e2cb0 21 /// @cond
hideakitai 0:3f9dbf1e2cb0 22 MSGPACK_API_VERSION_NAMESPACE(v1) {
hideakitai 0:3f9dbf1e2cb0 23 /// @endcond
hideakitai 0:3f9dbf1e2cb0 24
hideakitai 0:3f9dbf1e2cb0 25 namespace adaptor {
hideakitai 0:3f9dbf1e2cb0 26
hideakitai 0:3f9dbf1e2cb0 27 #if !defined(MSGPACK_USE_CPP03)
hideakitai 0:3f9dbf1e2cb0 28
hideakitai 0:3f9dbf1e2cb0 29 template <typename T, typename Alloc>
hideakitai 0:3f9dbf1e2cb0 30 struct as<std::list<T, Alloc>, typename std::enable_if<msgpack::has_as<T>::value>::type> {
hideakitai 0:3f9dbf1e2cb0 31 std::list<T, Alloc> operator()(msgpack::object const& o) const {
hideakitai 0:3f9dbf1e2cb0 32 if (o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
hideakitai 0:3f9dbf1e2cb0 33 std::list<T, Alloc> v;
hideakitai 0:3f9dbf1e2cb0 34 msgpack::object* p = o.via.array.ptr;
hideakitai 0:3f9dbf1e2cb0 35 msgpack::object* const pend = o.via.array.ptr + o.via.array.size;
hideakitai 0:3f9dbf1e2cb0 36 for (; p < pend; ++p) {
hideakitai 0:3f9dbf1e2cb0 37 v.push_back(p->as<T>());
hideakitai 0:3f9dbf1e2cb0 38 }
hideakitai 0:3f9dbf1e2cb0 39 return v;
hideakitai 0:3f9dbf1e2cb0 40 }
hideakitai 0:3f9dbf1e2cb0 41 };
hideakitai 0:3f9dbf1e2cb0 42
hideakitai 0:3f9dbf1e2cb0 43 #endif // !defined(MSGPACK_USE_CPP03)
hideakitai 0:3f9dbf1e2cb0 44
hideakitai 0:3f9dbf1e2cb0 45 template <typename T, typename Alloc>
hideakitai 0:3f9dbf1e2cb0 46 struct convert<std::list<T, Alloc> > {
hideakitai 0:3f9dbf1e2cb0 47 msgpack::object const& operator()(msgpack::object const& o, std::list<T, Alloc>& v) const {
hideakitai 0:3f9dbf1e2cb0 48 if (o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
hideakitai 0:3f9dbf1e2cb0 49 v.resize(o.via.array.size);
hideakitai 0:3f9dbf1e2cb0 50 msgpack::object* p = o.via.array.ptr;
hideakitai 0:3f9dbf1e2cb0 51 msgpack::object* const pend = o.via.array.ptr + o.via.array.size;
hideakitai 0:3f9dbf1e2cb0 52 typename std::list<T, Alloc>::iterator it = v.begin();
hideakitai 0:3f9dbf1e2cb0 53 for (; p < pend; ++p, ++it) {
hideakitai 0:3f9dbf1e2cb0 54 p->convert(*it);
hideakitai 0:3f9dbf1e2cb0 55 }
hideakitai 0:3f9dbf1e2cb0 56 return o;
hideakitai 0:3f9dbf1e2cb0 57 }
hideakitai 0:3f9dbf1e2cb0 58 };
hideakitai 0:3f9dbf1e2cb0 59
hideakitai 0:3f9dbf1e2cb0 60 template <typename T, typename Alloc>
hideakitai 0:3f9dbf1e2cb0 61 struct pack<std::list<T, Alloc> > {
hideakitai 0:3f9dbf1e2cb0 62 template <typename Stream>
hideakitai 0:3f9dbf1e2cb0 63 msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const std::list<T, Alloc>& v) const {
hideakitai 0:3f9dbf1e2cb0 64 uint32_t size = checked_get_container_size(v.size());
hideakitai 0:3f9dbf1e2cb0 65 o.pack_array(size);
hideakitai 0:3f9dbf1e2cb0 66 for (typename std::list<T, Alloc>::const_iterator it(v.begin()), it_end(v.end());
hideakitai 0:3f9dbf1e2cb0 67 it != it_end; ++it) {
hideakitai 0:3f9dbf1e2cb0 68 o.pack(*it);
hideakitai 0:3f9dbf1e2cb0 69 }
hideakitai 0:3f9dbf1e2cb0 70 return o;
hideakitai 0:3f9dbf1e2cb0 71 }
hideakitai 0:3f9dbf1e2cb0 72 };
hideakitai 0:3f9dbf1e2cb0 73
hideakitai 0:3f9dbf1e2cb0 74 template <typename T, typename Alloc>
hideakitai 0:3f9dbf1e2cb0 75 struct object_with_zone<std::list<T, Alloc> > {
hideakitai 0:3f9dbf1e2cb0 76 void operator()(msgpack::object::with_zone& o, const std::list<T, Alloc>& v) const {
hideakitai 0:3f9dbf1e2cb0 77 o.type = msgpack::type::ARRAY;
hideakitai 0:3f9dbf1e2cb0 78 if (v.empty()) {
hideakitai 0:3f9dbf1e2cb0 79 o.via.array.ptr = nullptr;
hideakitai 0:3f9dbf1e2cb0 80 o.via.array.size = 0;
hideakitai 0:3f9dbf1e2cb0 81 }
hideakitai 0:3f9dbf1e2cb0 82 else {
hideakitai 0:3f9dbf1e2cb0 83 uint32_t size = checked_get_container_size(v.size());
hideakitai 0:3f9dbf1e2cb0 84 msgpack::object* p = static_cast<msgpack::object*>(o.zone.allocate_align(sizeof(msgpack::object)*size));
hideakitai 0:3f9dbf1e2cb0 85 msgpack::object* const pend = p + size;
hideakitai 0:3f9dbf1e2cb0 86 o.via.array.ptr = p;
hideakitai 0:3f9dbf1e2cb0 87 o.via.array.size = size;
hideakitai 0:3f9dbf1e2cb0 88 typename std::list<T, Alloc>::const_iterator it(v.begin());
hideakitai 0:3f9dbf1e2cb0 89 do {
hideakitai 0:3f9dbf1e2cb0 90 *p = msgpack::object(*it, o.zone);
hideakitai 0:3f9dbf1e2cb0 91 ++p;
hideakitai 0:3f9dbf1e2cb0 92 ++it;
hideakitai 0:3f9dbf1e2cb0 93 } while(p < pend);
hideakitai 0:3f9dbf1e2cb0 94 }
hideakitai 0:3f9dbf1e2cb0 95 }
hideakitai 0:3f9dbf1e2cb0 96 };
hideakitai 0:3f9dbf1e2cb0 97
hideakitai 0:3f9dbf1e2cb0 98 } // namespace adaptor
hideakitai 0:3f9dbf1e2cb0 99
hideakitai 0:3f9dbf1e2cb0 100 /// @cond
hideakitai 0:3f9dbf1e2cb0 101 } // MSGPACK_API_VERSION_NAMESPACE(v1)
hideakitai 0:3f9dbf1e2cb0 102 /// @endcond
hideakitai 0:3f9dbf1e2cb0 103
hideakitai 0:3f9dbf1e2cb0 104 } // namespace msgpack
hideakitai 0:3f9dbf1e2cb0 105
hideakitai 0:3f9dbf1e2cb0 106 #endif // MSGPACK_TYPE_LIST_HPP