// Copyright (c) 2016-2025 Antony Polukhin // // Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #ifndef BOOST_PFR_DETAIL_FOR_EACH_FIELD_IMPL_HPP #define BOOST_PFR_DETAIL_FOR_EACH_FIELD_IMPL_HPP #pragma once #include #include #include #if !defined(BOOST_PFR_INTERFACE_UNIT) #include // metaprogramming stuff #endif namespace boost { namespace pfr { namespace detail { template using size_t_ = std::integral_constant; template ()(std::declval(), I{}))> constexpr void for_each_field_impl_apply(T&& v, F&& f, I i, long) { std::forward(f)(std::forward(v), i); } template constexpr void for_each_field_impl_apply(T&& v, F&& f, I /*i*/, int) { std::forward(f)(std::forward(v)); } #if BOOST_PFR_USE_CPP26 template constexpr void for_each_field_impl(T& t, F&& f, std::index_sequence, auto move_values) { if constexpr (std::is_aggregate_v || std::is_bounded_array_v) { auto &&[... members] = t; if constexpr (move_values) (detail::for_each_field_impl_apply(std::move(members...[I]), std::forward(f), size_t_{}, 1L), ...); else (detail::for_each_field_impl_apply( members... [I], std::forward(f), size_t_ {}, 1L), ...); } else { if constexpr (move_values) (detail::for_each_field_impl_apply(std::move(t), std::forward(f), size_t_{}, 1L), ...); else (detail::for_each_field_impl_apply(t, std::forward(f), size_t_{}, 1L), ...); } } #elif !defined(__cpp_fold_expressions) || __cpp_fold_expressions < 201603 template constexpr void for_each_field_impl(T& t, F&& f, std::index_sequence, std::false_type /*move_values*/) { const int v[] = {0, ( detail::for_each_field_impl_apply(sequence_tuple::get(t), std::forward(f), size_t_{}, 1L), 0 )...}; (void)v; } template constexpr void for_each_field_impl(T& t, F&& f, std::index_sequence, std::true_type /*move_values*/) { const int v[] = {0, ( detail::for_each_field_impl_apply(sequence_tuple::get(std::move(t)), std::forward(f), size_t_{}, 1L), 0 )...}; (void)v; } #else template constexpr void for_each_field_impl(T& t, F&& f, std::index_sequence, std::false_type /*move_values*/) { (detail::for_each_field_impl_apply(sequence_tuple::get(t), std::forward(f), size_t_{}, 1L), ...); } template constexpr void for_each_field_impl(T& t, F&& f, std::index_sequence, std::true_type /*move_values*/) { (detail::for_each_field_impl_apply(sequence_tuple::get(std::move(t)), std::forward(f), size_t_{}, 1L), ...); } #endif }}} // namespace boost::pfr::detail #endif // BOOST_PFR_DETAIL_FOR_EACH_FIELD_IMPL_HPP