#ifndef SPROUT_RANGE_ALGORITHM_FIND_FIRST_OF_HPP #define SPROUT_RANGE_ALGORITHM_FIND_FIRST_OF_HPP #include #include #include #include #include namespace sprout { namespace range { // Copyright (C) 2011 RiSK (sscrisk) // 25.2.7 Find first template inline SPROUT_CONSTEXPR typename sprout::range::range_return::type find_first_of(InputRange1&& range1, InputRange2&& range2) { return sprout::range::range_return::pack( sprout::find_first_of( sprout::begin(sprout::forward(range1)), sprout::end(sprout::forward(range1)), sprout::begin(sprout::forward(range2)), sprout::end(sprout::forward(range2)) ), sprout::forward(range1) ); } template inline SPROUT_CONSTEXPR typename sprout::range::range_return::type find_first_of(InputRange1&& range1, InputRange2&& range2, BinaryPredicate pred) { return sprout::range::range_return::pack( sprout::find_first_of( sprout::begin(sprout::forward(range1)), sprout::end(sprout::forward(range1)), sprout::begin(sprout::forward(range2)), sprout::end(sprout::forward(range2)), pred ), sprout::forward(range1) ); } template inline SPROUT_CONSTEXPR typename sprout::range::range_return::type find_first_of(InputRange1&& range1, InputRange2&& range2) { return sprout::range::range_return::pack( sprout::find_first_of( sprout::begin(sprout::forward(range1)), sprout::end(sprout::forward(range1)), sprout::begin(sprout::forward(range2)), sprout::end(sprout::forward(range2)) ), sprout::forward(range1) ); } template inline SPROUT_CONSTEXPR typename sprout::range::range_return::type find_first_of(InputRange1&& range1, InputRange2&& range2, BinaryPredicate pred) { return sprout::range::range_return::pack( sprout::find_first_of( sprout::begin(sprout::forward(range1)), sprout::end(sprout::forward(range1)), sprout::begin(sprout::forward(range2)), sprout::end(sprout::forward(range2)), pred ), sprout::forward(range1) ); } } // namespace range } // namespace sprout #endif // #ifndef SPROUT_RANGE_ALGORITHM_FIND_FIRST_OF_HPP