msgpack/include/msgpack/adaptor/detail/cpp03_define_array.hpp
2015-07-05 09:23:43 +09:00

3499 lines
143 KiB
C++

//
// MessagePack for C++ static resolution routine
//
// Copyright (C) 2008-2009 FURUHASHI Sadayuki
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#ifndef MSGPACK_CPP03_DEFINE_ARRAY_HPP
#define MSGPACK_CPP03_DEFINE_ARRAY_HPP
#include "msgpack/versioning.hpp"
#include "msgpack/adaptor/msgpack_tuple.hpp"
#include "msgpack/adaptor/adaptor_base.hpp"
#include "msgpack/object_fwd.hpp"
#define MSGPACK_DEFINE_ARRAY(...) \
template <typename Packer> \
void msgpack_pack(Packer& pk) const \
{ \
msgpack::type::make_define_array(__VA_ARGS__).msgpack_pack(pk); \
} \
void msgpack_unpack(msgpack::object const& o) \
{ \
msgpack::type::make_define_array(__VA_ARGS__).msgpack_unpack(o); \
}\
template <typename MSGPACK_OBJECT> \
void msgpack_object(MSGPACK_OBJECT* o, msgpack::zone& z) const \
{ \
msgpack::type::make_define_array(__VA_ARGS__).msgpack_object(o, z); \
}
#define MSGPACK_BASE_ARRAY(base) (*const_cast<base *>(static_cast<base const*>(this)))
// MSGPACK_ADD_ENUM must be used in the global namespace.
#define MSGPACK_ADD_ENUM(enum_name) \
namespace msgpack { \
/** @cond */ \
MSGPACK_API_VERSION_NAMESPACE(v1) { \
/** @endcond */ \
namespace adaptor { \
template<> \
struct convert<enum_name> { \
msgpack::object const& operator()(msgpack::object const& o, enum_name& v) const {\
int tmp; \
o >> tmp; \
v = static_cast<enum_name>(tmp); \
return o; \
} \
}; \
template<> \
struct object<enum_name> { \
void operator()(msgpack::object& o, const enum_name& v) const {\
o << static_cast<int>(v); \
} \
}; \
template<> \
struct object_with_zone<enum_name> { \
void operator()(msgpack::object::with_zone& o, const enum_name& v) const { \
o << static_cast<int>(v); \
} \
}; \
template<> \
struct pack<enum_name> { \
template <typename Stream> \
msgpack::packer<Stream>& operator()(msgpack::packer<Stream>& o, const enum_name& v) const { \
return o << static_cast<int>(v); \
} \
}; \
} \
/** @cond */ \
} \
/** @endcond */ \
}
namespace msgpack {
/// @cond
MSGPACK_API_VERSION_NAMESPACE(v1) {
/// @endcond
namespace type {
/// @cond
template <typename A0 = void, typename A1 = void, typename A2 = void, typename A3 = void, typename A4 = void, typename A5 = void, typename A6 = void, typename A7 = void, typename A8 = void, typename A9 = void, typename A10 = void, typename A11 = void, typename A12 = void, typename A13 = void, typename A14 = void, typename A15 = void, typename A16 = void, typename A17 = void, typename A18 = void, typename A19 = void, typename A20 = void, typename A21 = void, typename A22 = void, typename A23 = void, typename A24 = void, typename A25 = void, typename A26 = void, typename A27 = void, typename A28 = void, typename A29 = void, typename A30 = void, typename A31 = void, typename A32 = void>
struct define_array;
/// @endcond
template <>
struct define_array<> {
typedef define_array<> value_type;
typedef tuple<> tuple_type;
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(0);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
}
void msgpack_object(msgpack::object* o, msgpack::zone&) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = nullptr;
o->via.array.size = 0;
}
};
/// @cond
template <typename A0>
struct define_array<A0> {
typedef define_array<A0> value_type;
typedef tuple<A0> tuple_type;
define_array(A0& _a0) :
a0(_a0) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(1);
pk.pack(a0);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*1));
o->via.array.size = 1;
o->via.array.ptr[0] = msgpack::object(a0, z);
}
A0& a0;
};
template <typename A0, typename A1>
struct define_array<A0, A1> {
typedef define_array<A0, A1> value_type;
typedef tuple<A0, A1> tuple_type;
define_array(A0& _a0, A1& _a1) :
a0(_a0), a1(_a1) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(2);
pk.pack(a0);
pk.pack(a1);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*2));
o->via.array.size = 2;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
}
A0& a0;
A1& a1;
};
template <typename A0, typename A1, typename A2>
struct define_array<A0, A1, A2> {
typedef define_array<A0, A1, A2> value_type;
typedef tuple<A0, A1, A2> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2) :
a0(_a0), a1(_a1), a2(_a2) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(3);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*3));
o->via.array.size = 3;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
}
A0& a0;
A1& a1;
A2& a2;
};
template <typename A0, typename A1, typename A2, typename A3>
struct define_array<A0, A1, A2, A3> {
typedef define_array<A0, A1, A2, A3> value_type;
typedef tuple<A0, A1, A2, A3> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(4);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*4));
o->via.array.size = 4;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4>
struct define_array<A0, A1, A2, A3, A4> {
typedef define_array<A0, A1, A2, A3, A4> value_type;
typedef tuple<A0, A1, A2, A3, A4> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(5);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*5));
o->via.array.size = 5;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5>
struct define_array<A0, A1, A2, A3, A4, A5> {
typedef define_array<A0, A1, A2, A3, A4, A5> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(6);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*6));
o->via.array.size = 6;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6>
struct define_array<A0, A1, A2, A3, A4, A5, A6> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(7);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*7));
o->via.array.size = 7;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(8);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*8));
o->via.array.size = 8;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(9);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*9));
o->via.array.size = 9;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(10);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*10));
o->via.array.size = 10;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(11);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*11));
o->via.array.size = 11;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(12);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*12));
o->via.array.size = 12;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(13);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*13));
o->via.array.size = 13;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(14);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*14));
o->via.array.size = 14;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(15);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*15));
o->via.array.size = 15;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(16);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*16));
o->via.array.size = 16;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(17);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*17));
o->via.array.size = 17;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(18);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*18));
o->via.array.size = 18;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(19);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*19));
o->via.array.size = 19;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(20);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*20));
o->via.array.size = 20;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(21);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*21));
o->via.array.size = 21;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(22);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*22));
o->via.array.size = 22;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(23);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*23));
o->via.array.size = 23;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(24);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*24));
o->via.array.size = 24;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(25);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*25));
o->via.array.size = 25;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24, A25& _a25) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24), a25(_a25) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(26);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
pk.pack(a25);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 26: ptr[25].convert(a25);
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*26));
o->via.array.size = 26;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
o->via.array.ptr[25] = msgpack::object(a25, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
A25& a25;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24, A25& _a25, A26& _a26) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24), a25(_a25), a26(_a26) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(27);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
pk.pack(a25);
pk.pack(a26);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 27: ptr[26].convert(a26);
case 26: ptr[25].convert(a25);
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*27));
o->via.array.size = 27;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
o->via.array.ptr[25] = msgpack::object(a25, z);
o->via.array.ptr[26] = msgpack::object(a26, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
A25& a25;
A26& a26;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24, A25& _a25, A26& _a26, A27& _a27) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24), a25(_a25), a26(_a26), a27(_a27) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(28);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
pk.pack(a25);
pk.pack(a26);
pk.pack(a27);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 28: ptr[27].convert(a27);
case 27: ptr[26].convert(a26);
case 26: ptr[25].convert(a25);
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*28));
o->via.array.size = 28;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
o->via.array.ptr[25] = msgpack::object(a25, z);
o->via.array.ptr[26] = msgpack::object(a26, z);
o->via.array.ptr[27] = msgpack::object(a27, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
A25& a25;
A26& a26;
A27& a27;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24, A25& _a25, A26& _a26, A27& _a27, A28& _a28) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24), a25(_a25), a26(_a26), a27(_a27), a28(_a28) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(29);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
pk.pack(a25);
pk.pack(a26);
pk.pack(a27);
pk.pack(a28);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 29: ptr[28].convert(a28);
case 28: ptr[27].convert(a27);
case 27: ptr[26].convert(a26);
case 26: ptr[25].convert(a25);
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*29));
o->via.array.size = 29;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
o->via.array.ptr[25] = msgpack::object(a25, z);
o->via.array.ptr[26] = msgpack::object(a26, z);
o->via.array.ptr[27] = msgpack::object(a27, z);
o->via.array.ptr[28] = msgpack::object(a28, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
A25& a25;
A26& a26;
A27& a27;
A28& a28;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28, typename A29>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24, A25& _a25, A26& _a26, A27& _a27, A28& _a28, A29& _a29) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24), a25(_a25), a26(_a26), a27(_a27), a28(_a28), a29(_a29) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(30);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
pk.pack(a25);
pk.pack(a26);
pk.pack(a27);
pk.pack(a28);
pk.pack(a29);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 30: ptr[29].convert(a29);
case 29: ptr[28].convert(a28);
case 28: ptr[27].convert(a27);
case 27: ptr[26].convert(a26);
case 26: ptr[25].convert(a25);
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*30));
o->via.array.size = 30;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
o->via.array.ptr[25] = msgpack::object(a25, z);
o->via.array.ptr[26] = msgpack::object(a26, z);
o->via.array.ptr[27] = msgpack::object(a27, z);
o->via.array.ptr[28] = msgpack::object(a28, z);
o->via.array.ptr[29] = msgpack::object(a29, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
A25& a25;
A26& a26;
A27& a27;
A28& a28;
A29& a29;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28, typename A29, typename A30>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24, A25& _a25, A26& _a26, A27& _a27, A28& _a28, A29& _a29, A30& _a30) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24), a25(_a25), a26(_a26), a27(_a27), a28(_a28), a29(_a29), a30(_a30) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(31);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
pk.pack(a25);
pk.pack(a26);
pk.pack(a27);
pk.pack(a28);
pk.pack(a29);
pk.pack(a30);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 31: ptr[30].convert(a30);
case 30: ptr[29].convert(a29);
case 29: ptr[28].convert(a28);
case 28: ptr[27].convert(a27);
case 27: ptr[26].convert(a26);
case 26: ptr[25].convert(a25);
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*31));
o->via.array.size = 31;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
o->via.array.ptr[25] = msgpack::object(a25, z);
o->via.array.ptr[26] = msgpack::object(a26, z);
o->via.array.ptr[27] = msgpack::object(a27, z);
o->via.array.ptr[28] = msgpack::object(a28, z);
o->via.array.ptr[29] = msgpack::object(a29, z);
o->via.array.ptr[30] = msgpack::object(a30, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
A25& a25;
A26& a26;
A27& a27;
A28& a28;
A29& a29;
A30& a30;
};
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28, typename A29, typename A30, typename A31>
struct define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30, A31> {
typedef define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30, A31> value_type;
typedef tuple<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30, A31> tuple_type;
define_array(A0& _a0, A1& _a1, A2& _a2, A3& _a3, A4& _a4, A5& _a5, A6& _a6, A7& _a7, A8& _a8, A9& _a9, A10& _a10, A11& _a11, A12& _a12, A13& _a13, A14& _a14, A15& _a15, A16& _a16, A17& _a17, A18& _a18, A19& _a19, A20& _a20, A21& _a21, A22& _a22, A23& _a23, A24& _a24, A25& _a25, A26& _a26, A27& _a27, A28& _a28, A29& _a29, A30& _a30, A31& _a31) :
a0(_a0), a1(_a1), a2(_a2), a3(_a3), a4(_a4), a5(_a5), a6(_a6), a7(_a7), a8(_a8), a9(_a9), a10(_a10), a11(_a11), a12(_a12), a13(_a13), a14(_a14), a15(_a15), a16(_a16), a17(_a17), a18(_a18), a19(_a19), a20(_a20), a21(_a21), a22(_a22), a23(_a23), a24(_a24), a25(_a25), a26(_a26), a27(_a27), a28(_a28), a29(_a29), a30(_a30), a31(_a31) {}
template <typename Packer>
void msgpack_pack(Packer& pk) const
{
pk.pack_array(32);
pk.pack(a0);
pk.pack(a1);
pk.pack(a2);
pk.pack(a3);
pk.pack(a4);
pk.pack(a5);
pk.pack(a6);
pk.pack(a7);
pk.pack(a8);
pk.pack(a9);
pk.pack(a10);
pk.pack(a11);
pk.pack(a12);
pk.pack(a13);
pk.pack(a14);
pk.pack(a15);
pk.pack(a16);
pk.pack(a17);
pk.pack(a18);
pk.pack(a19);
pk.pack(a20);
pk.pack(a21);
pk.pack(a22);
pk.pack(a23);
pk.pack(a24);
pk.pack(a25);
pk.pack(a26);
pk.pack(a27);
pk.pack(a28);
pk.pack(a29);
pk.pack(a30);
pk.pack(a31);
}
void msgpack_unpack(msgpack::object const& o)
{
if(o.type != msgpack::type::ARRAY) { throw msgpack::type_error(); }
const size_t size = o.via.array.size;
if(size > 0) {
msgpack::object *ptr = o.via.array.ptr;
switch(size) {
default:
case 32: ptr[31].convert(a31);
case 31: ptr[30].convert(a30);
case 30: ptr[29].convert(a29);
case 29: ptr[28].convert(a28);
case 28: ptr[27].convert(a27);
case 27: ptr[26].convert(a26);
case 26: ptr[25].convert(a25);
case 25: ptr[24].convert(a24);
case 24: ptr[23].convert(a23);
case 23: ptr[22].convert(a22);
case 22: ptr[21].convert(a21);
case 21: ptr[20].convert(a20);
case 20: ptr[19].convert(a19);
case 19: ptr[18].convert(a18);
case 18: ptr[17].convert(a17);
case 17: ptr[16].convert(a16);
case 16: ptr[15].convert(a15);
case 15: ptr[14].convert(a14);
case 14: ptr[13].convert(a13);
case 13: ptr[12].convert(a12);
case 12: ptr[11].convert(a11);
case 11: ptr[10].convert(a10);
case 10: ptr[9].convert(a9);
case 9: ptr[8].convert(a8);
case 8: ptr[7].convert(a7);
case 7: ptr[6].convert(a6);
case 6: ptr[5].convert(a5);
case 5: ptr[4].convert(a4);
case 4: ptr[3].convert(a3);
case 3: ptr[2].convert(a2);
case 2: ptr[1].convert(a1);
case 1: ptr[0].convert(a0);
}
}
}
void msgpack_object(msgpack::object* o, msgpack::zone& z) const
{
o->type = msgpack::type::ARRAY;
o->via.array.ptr = static_cast<msgpack::object*>(z.allocate_align(sizeof(msgpack::object)*32));
o->via.array.size = 32;
o->via.array.ptr[0] = msgpack::object(a0, z);
o->via.array.ptr[1] = msgpack::object(a1, z);
o->via.array.ptr[2] = msgpack::object(a2, z);
o->via.array.ptr[3] = msgpack::object(a3, z);
o->via.array.ptr[4] = msgpack::object(a4, z);
o->via.array.ptr[5] = msgpack::object(a5, z);
o->via.array.ptr[6] = msgpack::object(a6, z);
o->via.array.ptr[7] = msgpack::object(a7, z);
o->via.array.ptr[8] = msgpack::object(a8, z);
o->via.array.ptr[9] = msgpack::object(a9, z);
o->via.array.ptr[10] = msgpack::object(a10, z);
o->via.array.ptr[11] = msgpack::object(a11, z);
o->via.array.ptr[12] = msgpack::object(a12, z);
o->via.array.ptr[13] = msgpack::object(a13, z);
o->via.array.ptr[14] = msgpack::object(a14, z);
o->via.array.ptr[15] = msgpack::object(a15, z);
o->via.array.ptr[16] = msgpack::object(a16, z);
o->via.array.ptr[17] = msgpack::object(a17, z);
o->via.array.ptr[18] = msgpack::object(a18, z);
o->via.array.ptr[19] = msgpack::object(a19, z);
o->via.array.ptr[20] = msgpack::object(a20, z);
o->via.array.ptr[21] = msgpack::object(a21, z);
o->via.array.ptr[22] = msgpack::object(a22, z);
o->via.array.ptr[23] = msgpack::object(a23, z);
o->via.array.ptr[24] = msgpack::object(a24, z);
o->via.array.ptr[25] = msgpack::object(a25, z);
o->via.array.ptr[26] = msgpack::object(a26, z);
o->via.array.ptr[27] = msgpack::object(a27, z);
o->via.array.ptr[28] = msgpack::object(a28, z);
o->via.array.ptr[29] = msgpack::object(a29, z);
o->via.array.ptr[30] = msgpack::object(a30, z);
o->via.array.ptr[31] = msgpack::object(a31, z);
}
A0& a0;
A1& a1;
A2& a2;
A3& a3;
A4& a4;
A5& a5;
A6& a6;
A7& a7;
A8& a8;
A9& a9;
A10& a10;
A11& a11;
A12& a12;
A13& a13;
A14& a14;
A15& a15;
A16& a16;
A17& a17;
A18& a18;
A19& a19;
A20& a20;
A21& a21;
A22& a22;
A23& a23;
A24& a24;
A25& a25;
A26& a26;
A27& a27;
A28& a28;
A29& a29;
A30& a30;
A31& a31;
};
/// @endcond
inline define_array<> make_define_array()
{
return define_array<>();
}
/// @cond
template <typename A0>
inline define_array<A0> make_define_array(A0& a0)
{
return define_array<A0>(a0);
}
template <typename A0, typename A1>
inline define_array<A0, A1> make_define_array(A0& a0, A1& a1)
{
return define_array<A0, A1>(a0, a1);
}
template <typename A0, typename A1, typename A2>
inline define_array<A0, A1, A2> make_define_array(A0& a0, A1& a1, A2& a2)
{
return define_array<A0, A1, A2>(a0, a1, a2);
}
template <typename A0, typename A1, typename A2, typename A3>
inline define_array<A0, A1, A2, A3> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3)
{
return define_array<A0, A1, A2, A3>(a0, a1, a2, a3);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4>
inline define_array<A0, A1, A2, A3, A4> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4)
{
return define_array<A0, A1, A2, A3, A4>(a0, a1, a2, a3, a4);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5>
inline define_array<A0, A1, A2, A3, A4, A5> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5)
{
return define_array<A0, A1, A2, A3, A4, A5>(a0, a1, a2, a3, a4, a5);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6>
inline define_array<A0, A1, A2, A3, A4, A5, A6> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6)
{
return define_array<A0, A1, A2, A3, A4, A5, A6>(a0, a1, a2, a3, a4, a5, a6);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7>(a0, a1, a2, a3, a4, a5, a6, a7);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8>(a0, a1, a2, a3, a4, a5, a6, a7, a8);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24, A25& a25)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24, A25& a25, A26& a26)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25, a26);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24, A25& a25, A26& a26, A27& a27)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25, a26, a27);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24, A25& a25, A26& a26, A27& a27, A28& a28)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25, a26, a27, a28);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28, typename A29>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24, A25& a25, A26& a26, A27& a27, A28& a28, A29& a29)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25, a26, a27, a28, a29);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28, typename A29, typename A30>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24, A25& a25, A26& a26, A27& a27, A28& a28, A29& a29, A30& a30)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25, a26, a27, a28, a29, a30);
}
template <typename A0, typename A1, typename A2, typename A3, typename A4, typename A5, typename A6, typename A7, typename A8, typename A9, typename A10, typename A11, typename A12, typename A13, typename A14, typename A15, typename A16, typename A17, typename A18, typename A19, typename A20, typename A21, typename A22, typename A23, typename A24, typename A25, typename A26, typename A27, typename A28, typename A29, typename A30, typename A31>
inline define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30, A31> make_define_array(A0& a0, A1& a1, A2& a2, A3& a3, A4& a4, A5& a5, A6& a6, A7& a7, A8& a8, A9& a9, A10& a10, A11& a11, A12& a12, A13& a13, A14& a14, A15& a15, A16& a16, A17& a17, A18& a18, A19& a19, A20& a20, A21& a21, A22& a22, A23& a23, A24& a24, A25& a25, A26& a26, A27& a27, A28& a28, A29& a29, A30& a30, A31& a31)
{
return define_array<A0, A1, A2, A3, A4, A5, A6, A7, A8, A9, A10, A11, A12, A13, A14, A15, A16, A17, A18, A19, A20, A21, A22, A23, A24, A25, A26, A27, A28, A29, A30, A31>(a0, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20, a21, a22, a23, a24, a25, a26, a27, a28, a29, a30, a31);
}
/// @endcond
} // namespace type
/// @cond
} // MSGPACK_API_VERSION_NAMESPACE(v1)
/// @endcond
} // namespace msgpack
#endif // MSGPACK_CPP03_DEFINE_ARRAY_HPP