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
40 // Special
41 special_begin = 19,
42 trivial_wrapper = special_begin,
43 data_and_size = 20,
44
45 Last = data_and_size,
46 };
47
48 inline uint32_t serialization_type_size(serialization_type_id id, uint32_t size) {
49 static const uint32_t sizes[] = {
50 // Dummy
51 0, // ignore
52
53 // Integer types
54 1, // s8
55 1, // u8
56 2, // s16
57 2, // u16
58 4, // s32
59 4, // u32
60 8, // s64
61 8, // u64
62
63 // Boolean
64 1, // b
65
66 // Character types
67 1, // c8
68 2, // c16
69 4, // c32
70 8, // cw
71
72 // Floating point types
73 1, // f8
74 2, // f16
75 4, // f32
76 8, // f64
77
78 // Special
79 size, // trivial_wrapper
80 sizeof(uintptr_t), // data_and_size, assume natural alignment
81 };
82
83 const auto s = sizes[(uint32_t)id];
84 // Make sure we do not return an invalid value
85 GAIA_ASSERT(s != (uint32_t)-1);
86 return s;
87 }
88
89 template <typename T>
91 private:
92 static constexpr bool update() {
93 return std::is_enum_v<T> || std::is_fundamental_v<T> || std::is_trivially_copyable_v<T>;
94 }
95
96 public:
97 static constexpr bool value = update();
98 };
99
100 template <typename T>
102 std::disjunction<
103 std::is_same<T, char>, std::is_same<T, unsigned char>, //
104 std::is_same<T, int8_t>, std::is_same<T, uint8_t>, //
105 std::is_same<T, int16_t>, std::is_same<T, uint16_t>, //
106 std::is_same<T, int32_t>, std::is_same<T, uint32_t>, //
107 std::is_same<T, int64_t>, std::is_same<T, uint64_t>, //
108 std::is_same<T, size_t>, std::is_same<T, bool>> {};
109
110 template <typename T>
112 std::disjunction<
113 // std::is_same<T, float8_t>, //
114 // std::is_same<T, float16_t>, //
115 std::is_same<T, float>, //
116 std::is_same<T, double>, //
117 std::is_same<T, long double>> {};
118
119 template <typename T>
120 GAIA_NODISCARD constexpr serialization_type_id int_kind_id() {
121 static_assert(is_int_kind_id<T>::value, "Unsupported integral type");
122
123 if constexpr (std::is_same_v<char, T>) {
124 return serialization_type_id::s8;
125 } else if constexpr (std::is_same_v<unsigned char, T>) {
126 return serialization_type_id::u8;
127 } else if constexpr (std::is_same_v<int8_t, T>) {
128 return serialization_type_id::s8;
129 } else if constexpr (std::is_same_v<uint8_t, T>) {
130 return serialization_type_id::u8;
131 } else if constexpr (std::is_same_v<int16_t, T>) {
132 return serialization_type_id::s16;
133 } else if constexpr (std::is_same_v<uint16_t, T>) {
134 return serialization_type_id::u16;
135 } else if constexpr (std::is_same_v<int32_t, T>) {
136 return serialization_type_id::s32;
137 } else if constexpr (std::is_same_v<uint32_t, T>) {
138 return serialization_type_id::u32;
139 } else if constexpr (std::is_same_v<int64_t, T>) {
140 return serialization_type_id::s64;
141 } else if constexpr (std::is_same_v<uint64_t, T>) {
142 return serialization_type_id::u64;
143 } else if constexpr (std::is_same_v<size_t, T>) {
144 return serialization_type_id::u64;
145 } else { // if constexpr (std::is_same_v<bool, T>) {
146 return serialization_type_id::b;
147 }
148 }
149
150 template <typename T>
151 GAIA_NODISCARD constexpr serialization_type_id flt_type_id() {
152 static_assert(is_flt_kind_id<T>::value, "Unsupported floating type");
153
154 // if constexpr (std::is_same_v<float8_t, T>) {
155 // return serialization_type_id::f8;
156 // } else if constexpr (std::is_same_v<float16_t, T>) {
157 // return serialization_type_id::f16;
158 // } else
159 if constexpr (std::is_same_v<float, T>) {
160 return serialization_type_id::f32;
161 } else { //if constexpr (std::is_same_v<double, T>) {
162 return serialization_type_id::f64;
163 }
164 }
165
166 template <typename T>
167 GAIA_NODISCARD constexpr serialization_type_id type_id() {
168 if constexpr (std::is_enum_v<T>)
169 return int_kind_id<std::underlying_type_t<T>>();
170 else if constexpr (std::is_integral_v<T>)
171 return int_kind_id<T>();
172 else if constexpr (std::is_floating_point_v<T>)
173 return flt_type_id<T>();
174 else if constexpr (std::is_pointer_v<T>)
175 return serialization_type_id::data_and_size;
176 else if constexpr (core::has_size_begin_end<T>::value)
177 return serialization_type_id::data_and_size;
178 else if constexpr (std::is_class_v<T>)
179 return serialization_type_id::trivial_wrapper;
180 else
181 return serialization_type_id::ignore;
182 }
183
184 // --------------------
185 // Define function detectors
186 // --------------------
187
188 GAIA_DEFINE_HAS_MEMBER_FUNC(save);
189 GAIA_DEFINE_HAS_MEMBER_FUNC(load);
190 GAIA_DEFINE_HAS_MEMBER_FUNC(resize);
191
192 // --------------------
193 // Customization tags
194 // --------------------
195
196 struct save_tag {};
197 struct load_tag {};
198 inline constexpr save_tag save_v{};
199 inline constexpr load_tag load_v{};
200
201 // --------------------
202 // Detection traits
203 // --------------------
204
205 template <typename S, typename T>
206 auto has_tag_save_impl(int)
207 -> decltype(tag_invoke(save_v, std::declval<S&>(), std::declval<const T&>()), std::true_type{});
208 template <typename, typename>
209 std::false_type has_tag_save_impl(...);
210 template <typename S, typename T>
211 using has_tag_save = decltype(has_tag_save_impl<S, T>(0));
212
213 template <typename S, typename T>
214 auto has_tag_load_impl(int)
215 -> decltype(tag_invoke(load_v, std::declval<S&>(), std::declval<T&>()), std::true_type{});
216 template <typename, typename>
217 std::false_type has_tag_load_impl(...);
218 template <typename S, typename T>
219 using has_tag_load = decltype(has_tag_load_impl<S, T>(0));
220 } // namespace ser
221} // namespace gaia
Checks if endianess was detected correctly at compile-time.
Definition bitset.h:9
Definition ser_common.h:117
Definition ser_common.h:108
Definition ser_common.h:90
Definition ser_common.h:197
Definition ser_common.h:196