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