//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // template // Iter next(Iter x, Iter::difference_type n = 1); // constexpr in C++17 // LWG #2353 relaxed the requirement on next from ForwardIterator to InputIterator #include #include #include #include "test_macros.h" #include "test_iterators.h" template TEST_CONSTEXPR_CXX17 void check_next_n(It it, typename std::iterator_traits::difference_type n, It result) { static_assert(std::is_same::value, ""); assert(std::next(it, n) == result); It (*next_ptr)(It, typename std::iterator_traits::difference_type) = std::next; assert(next_ptr(it, n) == result); } template TEST_CONSTEXPR_CXX17 void check_next_1(It it, It result) { static_assert(std::is_same::value, ""); assert(std::next(it) == result); } TEST_CONSTEXPR_CXX17 bool tests() { const char* s = "1234567890"; check_next_n(cpp17_input_iterator(s), 10, cpp17_input_iterator(s+10)); check_next_n(forward_iterator(s), 10, forward_iterator(s+10)); check_next_n(bidirectional_iterator(s), 10, bidirectional_iterator(s+10)); check_next_n(bidirectional_iterator(s+10), -10, bidirectional_iterator(s)); check_next_n(random_access_iterator(s), 10, random_access_iterator(s+10)); check_next_n(random_access_iterator(s+10), -10, random_access_iterator(s)); check_next_n(s, 10, s+10); check_next_1(cpp17_input_iterator(s), cpp17_input_iterator(s+1)); check_next_1(forward_iterator(s), forward_iterator(s+1)); check_next_1(bidirectional_iterator(s), bidirectional_iterator(s+1)); check_next_1(random_access_iterator(s), random_access_iterator(s+1)); check_next_1(s, s+1); return true; } int main(int, char**) { tests(); #if TEST_STD_VER >= 17 static_assert(tests(), ""); #endif return 0; }