/*! @file Forward declares `boost::hana::take_front` and `boost::hana::take_front_c`. @copyright Louis Dionne 2013-2016 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_TAKE_FRONT_HPP #define BOOST_HANA_FWD_TAKE_FRONT_HPP #include #include #include BOOST_HANA_NAMESPACE_BEGIN //! Returns the first `n` elements of a sequence, or the whole sequence //! if the sequence has less than `n` elements. //! @ingroup group-Sequence //! //! Given a `Sequence` `xs` and an `IntegralConstant` `n`, `take_front(xs, n)` //! is a new sequence containing the first `n` elements of `xs`, in the //! same order. If `length(xs) <= n`, the whole sequence is returned and //! no error is triggered. //! //! //! @param xs //! The sequence to take the elements from. //! //! @param n //! A non-negative `IntegralConstant` representing the number of elements //! to keep in the resulting sequence. //! //! //! Example //! ------- //! @include example/take_front.cpp #ifdef BOOST_HANA_DOXYGEN_INVOKED constexpr auto take_front = [](auto&& xs, auto const& n) { return tag-dispatched; }; #else template struct take_front_impl : take_front_impl> { }; struct take_front_t { template constexpr auto operator()(Xs&& xs, N const& n) const; }; constexpr take_front_t take_front{}; #endif //! Equivalent to `take_front`; provided for convenience. //! @ingroup group-Sequence //! //! //! Example //! ------- //! @include example/take_front_c.cpp #ifdef BOOST_HANA_DOXYGEN_INVOKED template constexpr auto take_front_c = [](auto&& xs) { return hana::take_front(forwarded(xs), hana::size_c); }; #else template struct take_front_c_t; template constexpr take_front_c_t take_front_c{}; #endif BOOST_HANA_NAMESPACE_END #endif // !BOOST_HANA_FWD_TAKE_FRONT_HPP