10e09a41bSzoecarver //===----------------------------------------------------------------------===//
20e09a41bSzoecarver //
30e09a41bSzoecarver // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40e09a41bSzoecarver // See https://llvm.org/LICENSE.txt for license information.
50e09a41bSzoecarver // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60e09a41bSzoecarver //
70e09a41bSzoecarver //===----------------------------------------------------------------------===//
80e09a41bSzoecarver
90e09a41bSzoecarver // UNSUPPORTED: c++03, c++11, c++14, c++17
1071909de3SMark de Wever // UNSUPPORTED: libcpp-has-no-incomplete-ranges
110e09a41bSzoecarver
120e09a41bSzoecarver // constexpr iterator<false> begin();
130e09a41bSzoecarver // constexpr iterator<true> begin() const
140e09a41bSzoecarver // requires range<const V> &&
150e09a41bSzoecarver // regular_invocable<const F&, range_reference_t<const V>>;
160e09a41bSzoecarver
170e09a41bSzoecarver #include <ranges>
180e09a41bSzoecarver
190e09a41bSzoecarver #include "test_macros.h"
200e09a41bSzoecarver #include "types.h"
210e09a41bSzoecarver
220e09a41bSzoecarver template<class T>
230e09a41bSzoecarver concept BeginInvocable = requires(T t) { t.begin(); };
240e09a41bSzoecarver
test()250e09a41bSzoecarver constexpr bool test() {
260e09a41bSzoecarver int buff[8] = {0, 1, 2, 3, 4, 5, 6, 7};
270e09a41bSzoecarver
280e09a41bSzoecarver {
29610ac8dbSArthur O'Dwyer std::ranges::transform_view transformView(MoveOnlyView{buff}, PlusOneMutable{});
300e09a41bSzoecarver assert(transformView.begin().base() == buff);
310e09a41bSzoecarver assert(*transformView.begin() == 1);
320e09a41bSzoecarver }
330e09a41bSzoecarver
340e09a41bSzoecarver {
359de882fdSLouis Dionne std::ranges::transform_view transformView(ForwardView{buff}, PlusOneMutable{});
36*5f26d863SMark de Wever assert(base(transformView.begin().base()) == buff);
370e09a41bSzoecarver assert(*transformView.begin() == 1);
380e09a41bSzoecarver }
390e09a41bSzoecarver
400e09a41bSzoecarver {
419de882fdSLouis Dionne std::ranges::transform_view transformView(InputView{buff}, PlusOneMutable{});
42*5f26d863SMark de Wever assert(base(transformView.begin().base()) == buff);
430e09a41bSzoecarver assert(*transformView.begin() == 1);
440e09a41bSzoecarver }
450e09a41bSzoecarver
460e09a41bSzoecarver {
47610ac8dbSArthur O'Dwyer const std::ranges::transform_view transformView(MoveOnlyView{buff}, PlusOne{});
480e09a41bSzoecarver assert(*transformView.begin() == 1);
490e09a41bSzoecarver }
500e09a41bSzoecarver
51610ac8dbSArthur O'Dwyer static_assert(!BeginInvocable<const std::ranges::transform_view<MoveOnlyView, PlusOneMutable>>);
520e09a41bSzoecarver
530e09a41bSzoecarver return true;
540e09a41bSzoecarver }
550e09a41bSzoecarver
main(int,char **)560e09a41bSzoecarver int main(int, char**) {
570e09a41bSzoecarver test();
580e09a41bSzoecarver static_assert(test());
590e09a41bSzoecarver
600e09a41bSzoecarver return 0;
610e09a41bSzoecarver }
62