Files
libconfig/build-config/reflect-cpp/include/rfl/internal/processed_t.hpp
Emily Boudreaux ec13264050 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
2025-12-06 10:55:46 -05:00

30 lines
853 B
C++

#ifndef RFL_INTERNAL_PROCESSED_T_HPP_
#define RFL_INTERNAL_PROCESSED_T_HPP_
#include <type_traits>
#include "../Processors.hpp"
#include "ptr_named_tuple_t.hpp"
#include "remove_ptrs_nt.hpp"
namespace rfl::internal {
template <class StructType, class ProcessorsType>
struct Processed;
template <class StructType, class... Ps>
struct Processed<StructType, Processors<Ps...>> {
using PtrNamedTupleType = ptr_named_tuple_t<StructType>;
using type = typename remove_ptrs_nt<
std::invoke_result_t<decltype(Processors<Ps...>::template process<
StructType, PtrNamedTupleType>),
PtrNamedTupleType>>::NamedTupleType;
};
template <class StructType, class ProcessorsType>
using processed_t = typename Processed<StructType, ProcessorsType>::type;
} // namespace rfl::internal
#endif