12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- /*!
- @file
- Forward declares `boost::hana::is_a` and `boost::hana::is_an`.
- 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_CORE_IS_A_HPP
- #define BOOST_HANA_FWD_CORE_IS_A_HPP
- #include <boost/hana/config.hpp>
- namespace boost { namespace hana {
- //! @ingroup group-core
- //! Returns whether the tag of an object matches a given tag.
- //!
- //! Given a tag `Tag` and a C++ type `T`, `is_a<Tag, T>` is a compile-time
- //! Logical representing whether the tag of `T` is exactly `Tag`. In other
- //! words, it is equivalent to
- //! @code
- //! std::is_same<Tag, tag_of<T>::type>
- //! @endcode
- //!
- //! For convenience, an alternate syntax is provided for using `is_a`.
- //! Specifically, `is_a<Tag>` is a function object returning whether the
- //! argument it is passed has the given tag. In other words,
- //! @code
- //! is_a<Tag>(x) == is_a<Tag, decltype(x)>
- //! @endcode
- //!
- //!
- //! Example
- //! -------
- //! @include example/core/is_a.cpp
- #ifdef BOOST_HANA_DOXYGEN_INVOKED
- template <typename Tag, typename optional_T>
- constexpr auto is_a = see-documentation;
- #else
- template <typename Tag, typename ...T>
- struct is_a_t;
- template <typename Tag, typename ...T>
- BOOST_HANA_INLINE_VARIABLE constexpr is_a_t<Tag, T...> is_a{};
- #endif
- //! @ingroup group-core
- //! Equivalent to `is_a`; provided for consistency with the rules of the
- //! English language.
- #ifdef BOOST_HANA_DOXYGEN_INVOKED
- template <typename Tag, typename ...T>
- constexpr auto is_an = is_a<Tag, T...>;
- #else
- template <typename Tag, typename ...T>
- BOOST_HANA_INLINE_VARIABLE constexpr is_a_t<Tag, T...> is_an{};
- #endif
- }} // end namespace boost::hana
- #endif // !BOOST_HANA_FWD_CORE_IS_A_HPP
|