/*! @file Forward declares `boost::hana::is_empty`. 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_IS_EMPTY_HPP #define BOOST_HANA_FWD_IS_EMPTY_HPP #include #include namespace boost { namespace hana { //! Returns whether the iterable is empty. //! @ingroup group-Iterable //! //! Given an `Iterable` `xs`, `is_empty` returns whether `xs` contains //! no more elements. In other words, it returns whether trying to //! extract the tail of `xs` would be an error. In the current version //! of the library, `is_empty` must return an `IntegralConstant` holding //! a value convertible to `bool`. This is because only compile-time //! `Iterable`s are supported right now. //! //! //! Example //! ------- //! @include example/is_empty.cpp #ifdef BOOST_HANA_DOXYGEN_INVOKED constexpr auto is_empty = [](auto const& xs) { return tag-dispatched; }; #else template struct is_empty_impl : is_empty_impl> { }; struct is_empty_t { template constexpr auto operator()(Xs const& xs) const; }; BOOST_HANA_INLINE_VARIABLE constexpr is_empty_t is_empty{}; #endif }} // end namespace boost::hana #endif // !BOOST_HANA_FWD_IS_EMPTY_HPP