15template <msgpack_concepts::HasMsgPack T>
struct convert<T> {
16 msgpack::object
const&
operator()(msgpack::object
const& o, T& v)
const
19 "MSGPACK_FIELDS requires default-constructible types (used during unpacking)");
20 v.msgpack([&](
auto&... args) {
21 auto static_checker = [&](
auto&... value_args) {
23 "MSGPACK_FIELDS requires a constructor that can take the types listed in MSGPACK_FIELDS. "
24 "Type or arg count mismatch, or member initializer constructor not available.");
27 if constexpr (!
requires {
typename T::MSGPACK_NO_STATIC_CHECK; }) {
28 std::apply(static_checker,
drop_keys(std::tie(args...)));
30 msgpack::type::define_map<
decltype(args)...>{ args... }.msgpack_unpack(o);
37template <msgpack_concepts::HasMsgPack T>
struct pack<T> {
38 template <
typename Stream> packer<Stream>&
operator()(msgpack::packer<Stream>& o, T
const& v)
const
41 "MSGPACK_FIELDS requires default-constructible types (used during unpacking)");
42 const_cast<T&
>(v).
msgpack([&](
auto&... args) {
43 auto static_checker = [&](
auto&... value_args) {
45 "T requires a constructor that can take the fields listed in MSGPACK_FIELDS (T will be "
46 "in template parameters in the compiler stack trace)"
47 "Check the MSGPACK_FIELDS macro usage in T for incompleteness or wrong order. "
48 "Alternatively, a matching member initializer constructor might not be available for T "
49 "and should be defined.");
52 if constexpr (!
requires {
typename T::MSGPACK_NO_STATIC_CHECK; }) {
53 std::apply(static_checker,
drop_keys(std::tie(args...)));
55 msgpack::type::define_map<
decltype(args)...>{ args... }.msgpack_pack(o);
constexpr std::array< uint8_t, S > convert(const std::string_view &in)
auto drop_keys(std::tuple< Args... > &&tuple)
Drops every first value pairwise of a flat argument tuple, assuming that they are keys.
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
msgpack::object const & operator()(msgpack::object const &o, T &v) const
packer< Stream > & operator()(msgpack::packer< Stream > &o, T const &v) const