2#include "gaia/config/config.h"
7#include "gaia/core/utility.h"
11 enum class serialization_type_id : uint8_t {
43 trivial_wrapper = special_begin,
49 inline uint32_t serialization_type_size(serialization_type_id
id, uint32_t size) {
50 static const uint32_t sizes[] = {
85 const auto s = sizes[(uint32_t)
id];
87 GAIA_ASSERT(s != (uint32_t)-1);
94 static constexpr bool update() {
95 return std::is_enum_v<T> || std::is_fundamental_v<T> || std::is_trivially_copyable_v<T>;
99 static constexpr bool value = update();
102 template <
typename T>
105 std::is_same<T, int8_t>, std::is_same<T, uint8_t>,
106 std::is_same<T, int16_t>, std::is_same<T, uint16_t>,
107 std::is_same<T, int32_t>, std::is_same<T, uint32_t>,
108 std::is_same<T, int64_t>, std::is_same<T, uint64_t>,
109 std::is_same<T, size_t>, std::is_same<T, bool>> {};
111 template <
typename T>
116 std::is_same<T, float>,
117 std::is_same<T, double>,
118 std::is_same<T, long double>> {};
120 template <
typename T>
121 GAIA_NODISCARD
constexpr serialization_type_id int_kind_id() {
124 if constexpr (std::is_same_v<int8_t, T>) {
125 return serialization_type_id::s8;
126 }
else if constexpr (std::is_same_v<uint8_t, T>) {
127 return serialization_type_id::u8;
128 }
else if constexpr (std::is_same_v<int16_t, T>) {
129 return serialization_type_id::s16;
130 }
else if constexpr (std::is_same_v<uint16_t, T>) {
131 return serialization_type_id::u16;
132 }
else if constexpr (std::is_same_v<int32_t, T>) {
133 return serialization_type_id::s32;
134 }
else if constexpr (std::is_same_v<uint32_t, T>) {
135 return serialization_type_id::u32;
136 }
else if constexpr (std::is_same_v<int64_t, T>) {
137 return serialization_type_id::s64;
138 }
else if constexpr (std::is_same_v<uint64_t, T>) {
139 return serialization_type_id::u64;
140 }
else if constexpr (std::is_same_v<size_t, T>) {
141 return serialization_type_id::u64;
143 return serialization_type_id::b;
147 template <
typename T>
148 GAIA_NODISCARD
constexpr serialization_type_id flt_type_id() {
149 static_assert(is_flt_kind_id<T>::value,
"Unsupported floating type");
156 if constexpr (std::is_same_v<float, T>) {
157 return serialization_type_id::f32;
158 }
else if constexpr (std::is_same_v<double, T>) {
159 return serialization_type_id::f64;
161 return serialization_type_id::f128;
165 template <
typename T>
166 GAIA_NODISCARD
constexpr serialization_type_id type_id() {
167 if constexpr (std::is_enum_v<T>)
168 return int_kind_id<std::underlying_type_t<T>>();
169 else if constexpr (std::is_integral_v<T>)
170 return int_kind_id<T>();
171 else if constexpr (std::is_floating_point_v<T>)
172 return flt_type_id<T>();
173 else if constexpr (core::has_size_begin_end<T>::value)
174 return serialization_type_id::data_and_size;
175 else if constexpr (std::is_class_v<T>)
176 return serialization_type_id::trivial_wrapper;
183 GAIA_DEFINE_HAS_MEMBER_FUNC(save);
184 GAIA_DEFINE_HAS_MEMBER_FUNC(load);
185 GAIA_DEFINE_HAS_MEMBER_FUNC(resize);
194 inline constexpr load_tag load_v{};
200 template <
typename S,
typename T>
201 auto has_tag_save_impl(
int)
202 ->
decltype(tag_invoke(save_v, std::declval<S&>(), std::declval<const T&>()), std::true_type{});
203 template <
typename,
typename>
204 std::false_type has_tag_save_impl(...);
205 template <
typename S,
typename T>
206 using has_tag_save =
decltype(has_tag_save_impl<S, T>(0));
208 template <
typename S,
typename T>
209 auto has_tag_load_impl(
int)
210 ->
decltype(tag_invoke(load_v, std::declval<S&>(), std::declval<T&>()), std::true_type{});
211 template <
typename,
typename>
212 std::false_type has_tag_load_impl(...);
213 template <
typename S,
typename T>
214 using has_tag_load =
decltype(has_tag_load_impl<S, T>(0));
Checks if endianess was detected correctly at compile-time.
Definition bitset.h:9
Definition ser_common.h:118
Definition ser_common.h:109
Definition ser_common.h:92
Definition ser_common.h:192
Definition ser_common.h:191