//===----------------------------------------------------------------------===// // // 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 V base() const & requires copy_constructible { return base_; } // constexpr V base() && { return std::move(base_); } #include #include #include #include #include #include "MoveOnly.h" struct View : std::ranges::view_base { int i; std::tuple* begin() const; std::tuple* end() const; }; struct MoveOnlyView : View { MoveOnly mo; }; template concept HasBase = requires(T&& t) { std::forward(t).base(); }; static_assert(HasBase const&>); static_assert(HasBase&&>); static_assert(!HasBase const&>); static_assert(HasBase&&>); constexpr bool test() { // const & { const std::ranges::elements_view ev{View{{}, 5}}; std::same_as decltype(auto) v = ev.base(); assert(v.i == 5); } // & { std::ranges::elements_view ev{View{{}, 5}}; std::same_as decltype(auto) v = ev.base(); assert(v.i == 5); } // && { std::ranges::elements_view ev{View{{}, 5}}; std::same_as decltype(auto) v = std::move(ev).base(); assert(v.i == 5); } // const && { const std::ranges::elements_view ev{View{{}, 5}}; std::same_as decltype(auto) v = std::move(ev).base(); assert(v.i == 5); } // move only { std::ranges::elements_view ev{MoveOnlyView{{}, 5}}; std::same_as decltype(auto) v = std::move(ev).base(); assert(v.mo.get() == 5); } return true; } int main(int, char**) { test(); static_assert(test()); return 0; }