|
|
@@ -13,56 +13,6 @@
|
|
|
|
|
|
namespace entt {
|
|
|
|
|
|
-/*! @cond TURN_OFF_DOXYGEN */
|
|
|
-namespace internal {
|
|
|
-
|
|
|
-template<typename Policy, typename Candidate, typename... Args>
|
|
|
-[[nodiscard]] meta_any meta_invoke_with_args(const meta_ctx &ctx, Candidate &&candidate, Args &&...args) {
|
|
|
- if constexpr(std::is_void_v<decltype(std::invoke(std::forward<Candidate>(candidate), args...))>) {
|
|
|
- std::invoke(std::forward<Candidate>(candidate), args...);
|
|
|
- return meta_any{ctx, std::in_place_type<void>};
|
|
|
- } else {
|
|
|
- return meta_dispatch<Policy>(ctx, std::invoke(std::forward<Candidate>(candidate), args...));
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-template<typename Type, typename Policy, typename Candidate, std::size_t... Index>
|
|
|
-[[nodiscard]] meta_any meta_invoke(const meta_ctx &ctx, [[maybe_unused]] meta_handle instance, Candidate &&candidate, [[maybe_unused]] meta_any *const args, std::index_sequence<Index...>) {
|
|
|
- using descriptor = meta_function_helper_t<Type, std::remove_reference_t<Candidate>>;
|
|
|
-
|
|
|
- // NOLINTBEGIN(cppcoreguidelines-pro-bounds-pointer-arithmetic) - waiting for C++20 (and std::span)
|
|
|
- if constexpr(std::is_invocable_v<std::remove_reference_t<Candidate>, const Type &, type_list_element_t<Index, typename descriptor::args_type>...>) {
|
|
|
- if(const auto *const clazz = instance->try_cast<const Type>(); clazz && ((args + Index)->allow_cast<type_list_element_t<Index, typename descriptor::args_type>>() && ...)) {
|
|
|
- return meta_invoke_with_args<Policy>(ctx, std::forward<Candidate>(candidate), *clazz, (args + Index)->cast<type_list_element_t<Index, typename descriptor::args_type>>()...);
|
|
|
- }
|
|
|
- } else if constexpr(std::is_invocable_v<std::remove_reference_t<Candidate>, Type &, type_list_element_t<Index, typename descriptor::args_type>...>) {
|
|
|
- if(auto *const clazz = instance->try_cast<Type>(); clazz && ((args + Index)->allow_cast<type_list_element_t<Index, typename descriptor::args_type>>() && ...)) {
|
|
|
- return meta_invoke_with_args<Policy>(ctx, std::forward<Candidate>(candidate), *clazz, (args + Index)->cast<type_list_element_t<Index, typename descriptor::args_type>>()...);
|
|
|
- }
|
|
|
- } else {
|
|
|
- if(((args + Index)->allow_cast<type_list_element_t<Index, typename descriptor::args_type>>() && ...)) {
|
|
|
- return meta_invoke_with_args<Policy>(ctx, std::forward<Candidate>(candidate), (args + Index)->cast<type_list_element_t<Index, typename descriptor::args_type>>()...);
|
|
|
- }
|
|
|
- }
|
|
|
- // NOLINTEND(cppcoreguidelines-pro-bounds-pointer-arithmetic)
|
|
|
-
|
|
|
- return meta_any{meta_ctx_arg, ctx};
|
|
|
-}
|
|
|
-
|
|
|
-template<typename Type, typename... Args, std::size_t... Index>
|
|
|
-[[nodiscard]] meta_any meta_construct(const meta_ctx &ctx, meta_any *const args, std::index_sequence<Index...>) {
|
|
|
- // NOLINTBEGIN(cppcoreguidelines-pro-bounds-pointer-arithmetic) - waiting for C++20 (and std::span)
|
|
|
- if(((args + Index)->allow_cast<Args>() && ...)) {
|
|
|
- return meta_any{ctx, std::in_place_type<Type>, (args + Index)->cast<Args>()...};
|
|
|
- }
|
|
|
- // NOLINTEND(cppcoreguidelines-pro-bounds-pointer-arithmetic)
|
|
|
-
|
|
|
- return meta_any{meta_ctx_arg, ctx};
|
|
|
-}
|
|
|
-
|
|
|
-} // namespace internal
|
|
|
-/*! @endcond */
|
|
|
-
|
|
|
/**
|
|
|
* @brief Meta function descriptor traits.
|
|
|
* @tparam Ret Function return type.
|
|
|
@@ -240,6 +190,56 @@ template<typename Policy = as_is_t, typename Type>
|
|
|
return meta_dispatch<Policy, Type>(locator<meta_ctx>::value_or(), std::forward<Type>(value));
|
|
|
}
|
|
|
|
|
|
+/*! @cond TURN_OFF_DOXYGEN */
|
|
|
+namespace internal {
|
|
|
+
|
|
|
+template<typename Policy, typename Candidate, typename... Args>
|
|
|
+[[nodiscard]] meta_any meta_invoke_with_args(const meta_ctx &ctx, Candidate &&candidate, Args &&...args) {
|
|
|
+ if constexpr(std::is_void_v<decltype(std::invoke(std::forward<Candidate>(candidate), args...))>) {
|
|
|
+ std::invoke(std::forward<Candidate>(candidate), args...);
|
|
|
+ return meta_any{ctx, std::in_place_type<void>};
|
|
|
+ } else {
|
|
|
+ return meta_dispatch<Policy>(ctx, std::invoke(std::forward<Candidate>(candidate), args...));
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+template<typename Type, typename Policy, typename Candidate, std::size_t... Index>
|
|
|
+[[nodiscard]] meta_any meta_invoke(const meta_ctx &ctx, [[maybe_unused]] meta_handle instance, Candidate &&candidate, [[maybe_unused]] meta_any *const args, std::index_sequence<Index...>) {
|
|
|
+ using descriptor = meta_function_helper_t<Type, std::remove_reference_t<Candidate>>;
|
|
|
+
|
|
|
+ // NOLINTBEGIN(cppcoreguidelines-pro-bounds-pointer-arithmetic) - waiting for C++20 (and std::span)
|
|
|
+ if constexpr(std::is_invocable_v<std::remove_reference_t<Candidate>, const Type &, type_list_element_t<Index, typename descriptor::args_type>...>) {
|
|
|
+ if(const auto *const clazz = instance->try_cast<const Type>(); clazz && ((args + Index)->allow_cast<type_list_element_t<Index, typename descriptor::args_type>>() && ...)) {
|
|
|
+ return meta_invoke_with_args<Policy>(ctx, std::forward<Candidate>(candidate), *clazz, (args + Index)->cast<type_list_element_t<Index, typename descriptor::args_type>>()...);
|
|
|
+ }
|
|
|
+ } else if constexpr(std::is_invocable_v<std::remove_reference_t<Candidate>, Type &, type_list_element_t<Index, typename descriptor::args_type>...>) {
|
|
|
+ if(auto *const clazz = instance->try_cast<Type>(); clazz && ((args + Index)->allow_cast<type_list_element_t<Index, typename descriptor::args_type>>() && ...)) {
|
|
|
+ return meta_invoke_with_args<Policy>(ctx, std::forward<Candidate>(candidate), *clazz, (args + Index)->cast<type_list_element_t<Index, typename descriptor::args_type>>()...);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if(((args + Index)->allow_cast<type_list_element_t<Index, typename descriptor::args_type>>() && ...)) {
|
|
|
+ return meta_invoke_with_args<Policy>(ctx, std::forward<Candidate>(candidate), (args + Index)->cast<type_list_element_t<Index, typename descriptor::args_type>>()...);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ // NOLINTEND(cppcoreguidelines-pro-bounds-pointer-arithmetic)
|
|
|
+
|
|
|
+ return meta_any{meta_ctx_arg, ctx};
|
|
|
+}
|
|
|
+
|
|
|
+template<typename Type, typename... Args, std::size_t... Index>
|
|
|
+[[nodiscard]] meta_any meta_construct(const meta_ctx &ctx, meta_any *const args, std::index_sequence<Index...>) {
|
|
|
+ // NOLINTBEGIN(cppcoreguidelines-pro-bounds-pointer-arithmetic) - waiting for C++20 (and std::span)
|
|
|
+ if(((args + Index)->allow_cast<Args>() && ...)) {
|
|
|
+ return meta_any{ctx, std::in_place_type<Type>, (args + Index)->cast<Args>()...};
|
|
|
+ }
|
|
|
+ // NOLINTEND(cppcoreguidelines-pro-bounds-pointer-arithmetic)
|
|
|
+
|
|
|
+ return meta_any{meta_ctx_arg, ctx};
|
|
|
+}
|
|
|
+
|
|
|
+} // namespace internal
|
|
|
+/*! @endcond */
|
|
|
+
|
|
|
/**
|
|
|
* @brief Returns the meta type of the i-th element of a list of arguments.
|
|
|
* @tparam Type Type list of the actual types of arguments.
|