Gaia-ECS v0.9.3
A simple and powerful entity component system
Loading...
Searching...
No Matches
ser_common.h
1#pragma once
2#include "gaia/config/config.h"
3
4#include <cstdint>
5#include <type_traits>
6
7#include "gaia/core/utility.h"
8
9namespace gaia {
10 namespace ser {
11 enum class serialization_type_id : uint8_t {
12 // Dummy
13 ignore = 0,
14
15 // Integer types
16 s8 = 1,
17 u8 = 2,
18 s16 = 3,
19 u16 = 4,
20 s32 = 5,
21 u32 = 6,
22 s64 = 7,
23 u64 = 8,
24
25 // Boolean
26 b = 9,
27
28 // Character types
29 c8 = 10,
30 c16 = 11,
31 c32 = 12,
32 cw = 13,
33
34 // Floating point types
35 f8 = 14,
36 f16 = 15,
37 f32 = 16,
38 f64 = 17,
39 f128 = 18,
40
41 // Special
42 special_begin = 19,
43 trivial_wrapper = special_begin,
44 data_and_size = 20,
45
46 Last = data_and_size,
47 };
48
49 inline uint32_t serialization_type_size(serialization_type_id id, uint32_t size) {
50 static const uint32_t sizes[] = {
51 // Dummy
52 0, // ignore
53
54 // Integer types
55 1, // s8
56 1, // u8
57 2, // s16
58 2, // u16
59 4, // s32
60 4, // u32
61 8, // s64
62 8, // u64
63
64 // Boolean
65 1, // b
66
67 // Character types
68 1, // c8
69 2, // c16
70 4, // c32
71 8, // cw
72
73 // Floating point types
74 1, // f8
75 2, // f16
76 4, // f32
77 8, // f64
78 16, // f128
79
80 // Special
81 size, // trivial_wrapper
82 sizeof(uintptr_t), // data_and_size, assume natural alignment
83 };
84
85 const auto s = sizes[(uint32_t)id];
86 // Make sure we do not return an invalid value
87 GAIA_ASSERT(s != (uint32_t)-1);
88 return s;
89 }
90
91 template <typename T>
93 private:
94 static constexpr bool update() {
95 return std::is_enum_v<T> || std::is_fundamental_v<T> || std::is_trivially_copyable_v<T>;
96 }
97
98 public:
99 static constexpr bool value = update();
100 };
101
102 template <typename T>
104 std::disjunction<
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>> {};
110
111 template <typename T>
113 std::disjunction<
114 // std::is_same<T, float8_t>, //
115 // std::is_same<T, float16_t>, //
116 std::is_same<T, float>, //
117 std::is_same<T, double>, //
118 std::is_same<T, long double>> {};
119
120 template <typename T>
121 GAIA_NODISCARD constexpr serialization_type_id int_kind_id() {
122 static_assert(is_int_kind_id<T>::value, "Unsupported integral type");
123
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;
142 } else { // if constexpr (std::is_same_v<bool, T>) {
143 return serialization_type_id::b;
144 }
145 }
146
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");
150
151 // if constexpr (std::is_same_v<float8_t, T>) {
152 // return serialization_type_id::f8;
153 // } else if constexpr (std::is_same_v<float16_t, T>) {
154 // return serialization_type_id::f16;
155 // } else
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;
160 } else { // if constexpr (std::is_same_v<long double, T>) {
161 return serialization_type_id::f128;
162 }
163 }
164
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;
177 }
178
179 // --------------------
180 // Define function detectors
181 // --------------------
182
183 GAIA_DEFINE_HAS_MEMBER_FUNC(save);
184 GAIA_DEFINE_HAS_MEMBER_FUNC(load);
185 GAIA_DEFINE_HAS_MEMBER_FUNC(resize);
186
187 // --------------------
188 // Customization tags
189 // --------------------
190
191 struct save_tag {};
192 struct load_tag {};
193 inline constexpr save_tag save_v{};
194 inline constexpr load_tag load_v{};
195
196 // --------------------
197 // Detection traits
198 // --------------------
199
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));
207
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));
215 } // namespace ser
216} // namespace gaia
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