/*! @file Forward declares `boost::hana::accessors`. Copyright Louis Dionne 2013-2022 Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt) */ #ifndef BOOST_HANA_FWD_ACCESSORS_HPP #define BOOST_HANA_FWD_ACCESSORS_HPP #include #include namespace boost { namespace hana { //! Returns a `Sequence` of pairs representing the accessors of the //! data structure. //! @ingroup group-Struct //! //! Given a `Struct` `S`, `accessors()` is a `Sequence` of `Product`s //! where the first element of each pair is the "name" of a member of //! the `Struct`, and the second element of each pair is a function that //! can be used to access that member when given an object of the proper //! data type. As described in the global documentation for `Struct`, the //! accessor functions in this sequence must be move-independent. //! //! //! Example //! ------- //! @include example/accessors.cpp #ifdef BOOST_HANA_DOXYGEN_INVOKED template constexpr auto accessors = []() { return tag-dispatched; }; #else template struct accessors_impl : accessors_impl> { }; template struct accessors_t; template BOOST_HANA_INLINE_VARIABLE constexpr accessors_t accessors{}; #endif }} // end namespace boost::hana #endif // !BOOST_HANA_FWD_ACCESSORS_HPP