feat(reflect-cpp): Switched from glaze -> reflect cpp
A bug was discovered in glaze which prevented valid toml output. We have switched to toml++ and reflect-cpp. The interface has remained the same so this should not break any code
This commit is contained in:
53
build-config/reflect-cpp/include/rfl/from_named_tuple.hpp
Normal file
53
build-config/reflect-cpp/include/rfl/from_named_tuple.hpp
Normal file
@@ -0,0 +1,53 @@
|
||||
#ifndef RFL_FROM_NAMED_TUPLE_HPP_
|
||||
#define RFL_FROM_NAMED_TUPLE_HPP_
|
||||
|
||||
#include <type_traits>
|
||||
|
||||
#include "internal/copy_from_named_tuple.hpp"
|
||||
#include "internal/copy_from_tuple.hpp"
|
||||
#include "internal/has_fields.hpp"
|
||||
#include "internal/move_from_named_tuple.hpp"
|
||||
#include "internal/move_from_tuple.hpp"
|
||||
#include "named_tuple_t.hpp"
|
||||
|
||||
namespace rfl {
|
||||
|
||||
/// Generates the struct T from a named tuple.
|
||||
template <class T, class NamedTupleType>
|
||||
auto from_named_tuple(NamedTupleType&& _n) {
|
||||
using RequiredType = std::remove_cvref_t<rfl::named_tuple_t<T>>;
|
||||
if constexpr (!std::is_same<std::remove_cvref_t<NamedTupleType>,
|
||||
RequiredType>()) {
|
||||
return from_named_tuple<T>(RequiredType(std::forward<NamedTupleType>(_n)));
|
||||
} else if constexpr (internal::has_fields<T>()) {
|
||||
if constexpr (std::is_lvalue_reference<NamedTupleType>{}) {
|
||||
return internal::copy_from_named_tuple<T>(_n);
|
||||
} else {
|
||||
return internal::move_from_named_tuple<T>(_n);
|
||||
}
|
||||
} else {
|
||||
if constexpr (std::is_lvalue_reference<NamedTupleType>{}) {
|
||||
return internal::copy_from_tuple<T>(_n.values());
|
||||
} else {
|
||||
return internal::move_from_tuple<T>(std::move(_n.values()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// Generates the struct T from a named tuple.
|
||||
template <class T, class NamedTupleType>
|
||||
auto from_named_tuple(const NamedTupleType& _n) {
|
||||
using RequiredType = std::remove_cvref_t<rfl::named_tuple_t<T>>;
|
||||
if constexpr (!std::is_same<std::remove_cvref_t<NamedTupleType>,
|
||||
RequiredType>()) {
|
||||
return from_named_tuple<T>(RequiredType(_n));
|
||||
} else if constexpr (internal::has_fields<T>()) {
|
||||
return internal::copy_from_named_tuple<T>(_n);
|
||||
} else {
|
||||
return internal::copy_from_tuple<T>(_n.values());
|
||||
}
|
||||
}
|
||||
|
||||
} // namespace rfl
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user