//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11, c++14, c++17 // constexpr const I& base() const &; // constexpr I base() &&; #include #include "test_macros.h" #include "test_iterators.h" struct InputOrOutputArchetype { using difference_type = int; int *ptr; int operator*() { return *ptr; } void operator++(int) { ++ptr; } InputOrOutputArchetype& operator++() { ++ptr; return *this; } }; constexpr bool test() { int buffer[8] = {1, 2, 3, 4, 5, 6, 7, 8}; { std::counted_iterator iter(cpp20_input_iterator{buffer}, 8); assert(base(iter.base()) == buffer); assert(base(std::move(iter).base()) == buffer); ASSERT_NOEXCEPT(iter.base()); ASSERT_SAME_TYPE(decltype(iter.base()), const cpp20_input_iterator&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), cpp20_input_iterator); } { std::counted_iterator iter(forward_iterator{buffer}, 8); assert(base(iter.base()) == buffer); assert(base(std::move(iter).base()) == buffer); ASSERT_SAME_TYPE(decltype(iter.base()), const forward_iterator&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), forward_iterator); } { std::counted_iterator iter(contiguous_iterator{buffer}, 8); assert(base(iter.base()) == buffer); assert(base(std::move(iter).base()) == buffer); ASSERT_SAME_TYPE(decltype(iter.base()), const contiguous_iterator&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), contiguous_iterator); } { std::counted_iterator iter(InputOrOutputArchetype{buffer}, 6); assert(iter.base().ptr == buffer); assert(std::move(iter).base().ptr == buffer); ASSERT_SAME_TYPE(decltype(iter.base()), const InputOrOutputArchetype&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), InputOrOutputArchetype); } { const std::counted_iterator iter(cpp20_input_iterator{buffer}, 8); assert(base(iter.base()) == buffer); assert(base(std::move(iter).base()) == buffer); ASSERT_SAME_TYPE(decltype(iter.base()), const cpp20_input_iterator&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), const cpp20_input_iterator&); } { const std::counted_iterator iter(forward_iterator{buffer}, 7); assert(base(iter.base()) == buffer); assert(base(std::move(iter).base()) == buffer); ASSERT_SAME_TYPE(decltype(iter.base()), const forward_iterator&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), const forward_iterator&); } { const std::counted_iterator iter(contiguous_iterator{buffer}, 6); assert(base(iter.base()) == buffer); assert(base(std::move(iter).base()) == buffer); ASSERT_SAME_TYPE(decltype(iter.base()), const contiguous_iterator&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), const contiguous_iterator&); } { const std::counted_iterator iter(InputOrOutputArchetype{buffer}, 6); assert(iter.base().ptr == buffer); assert(std::move(iter).base().ptr == buffer); ASSERT_SAME_TYPE(decltype(iter.base()), const InputOrOutputArchetype&); ASSERT_SAME_TYPE(decltype(std::move(iter).base()), const InputOrOutputArchetype&); } return true; } int main(int, char**) { test(); static_assert(test()); return 0; }