//===----------------------------------------------------------------------===// // // 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 // UNSUPPORTED: libcpp-has-no-incomplete-ranges // constexpr iterator(iterator i) // requires Const && // convertible_­to, OuterIter> && // convertible_­to, InnerIter>; #include #include #include "test_macros.h" #include "../types.h" using ConstCompatibleInner = BufferView; using ConstIncompatibleInner = BufferView, forward_iterator, bidirectional_iterator, bidirectional_iterator>; template using ConstCompatibleOuter = BufferView; template using ConstIncompatibleOuter = BufferView, forward_iterator, bidirectional_iterator, bidirectional_iterator>; constexpr bool test() { int buffer[4][4] = {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}, {13, 14, 15, 16}}; { CopyableChild children[4] = {CopyableChild(buffer[0]), CopyableChild(buffer[1]), CopyableChild(buffer[2]), CopyableChild(buffer[3])}; std::ranges::join_view jv(CopyableParent{children}); auto iter1 = jv.begin(); using iterator = decltype(iter1); using const_iterator = decltype(std::as_const(jv).begin()); static_assert(!std::is_same_v); const_iterator iter2 = iter1; assert(iter1 == iter2); // We cannot create a non-const iterator from a const iterator. static_assert(!std::constructible_from); } // !convertible_to>; { ConstIncompatibleInner inners[2] = {buffer[0], buffer[1]}; ConstCompatibleOuter outer{inners}; std::ranges::join_view jv(outer); using iterator = decltype(jv.begin()); using const_iterator = decltype(std::as_const(jv).begin()); static_assert(!std::is_same_v); static_assert(!std::constructible_from); static_assert(!std::constructible_from); } // !convertible_to>; { ConstCompatibleInner inners[2] = {buffer[0], buffer[1]}; ConstIncompatibleOuter outer{inners}; std::ranges::join_view jv(outer); using iterator = decltype(jv.begin()); using const_iterator = decltype(std::as_const(jv).begin()); static_assert(!std::is_same_v); static_assert(!std::constructible_from); static_assert(!std::constructible_from); } return true; } int main(int, char**) { test(); static_assert(test()); return 0; }