2022-01-25 18:21:47 +08:00
|
|
|
// -*- C++ -*-
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef _LIBCPP___ALGORITHM_IN_IN_OUT_RESULT_H
|
|
|
|
#define _LIBCPP___ALGORITHM_IN_IN_OUT_RESULT_H
|
|
|
|
|
|
|
|
#include <__concepts/convertible_to.h>
|
|
|
|
#include <__config>
|
|
|
|
#include <__utility/move.h>
|
|
|
|
|
2022-02-02 09:06:30 +08:00
|
|
|
#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
|
2022-02-02 09:16:40 +08:00
|
|
|
# pragma GCC system_header
|
2022-02-02 09:06:30 +08:00
|
|
|
#endif
|
|
|
|
|
2022-01-25 18:21:47 +08:00
|
|
|
_LIBCPP_BEGIN_NAMESPACE_STD
|
|
|
|
|
[libc++] Guard much of std::ranges under _LIBCPP_HAS_NO_INCOMPLETE_RANGES.
The logic here is that we are disabling *only* things in `std::ranges::`.
Everything in `std::` is permitted, including `default_sentinel`, `contiguous_iterator`,
`common_iterator`, `projected`, `swappable`, and so on. Then, we include
anything from `std::ranges::` that is required in order to make those things
work: `ranges::swap`, `ranges::swap_ranges`, `input_range`, `ranges::begin`,
`ranges::iter_move`, and so on. But then that's all. Everything else (including
notably all of the "views" and the `std::views` namespace itself) is still
locked up behind `_LIBCPP_HAS_NO_INCOMPLETE_RANGES`.
Differential Revision: https://reviews.llvm.org/D118736
2022-02-02 05:52:02 +08:00
|
|
|
#if !defined(_LIBCPP_HAS_NO_CONCEPTS) && !defined(_LIBCPP_HAS_NO_INCOMPLETE_RANGES)
|
2022-01-25 18:21:47 +08:00
|
|
|
|
|
|
|
namespace ranges {
|
2022-02-02 09:06:30 +08:00
|
|
|
|
2022-01-25 18:21:47 +08:00
|
|
|
template <class _I1, class _I2, class _O1>
|
|
|
|
struct in_in_out_result {
|
2022-02-10 19:23:40 +08:00
|
|
|
_LIBCPP_NO_UNIQUE_ADDRESS _I1 in1;
|
|
|
|
_LIBCPP_NO_UNIQUE_ADDRESS _I2 in2;
|
|
|
|
_LIBCPP_NO_UNIQUE_ADDRESS _O1 out;
|
2022-01-25 18:21:47 +08:00
|
|
|
|
|
|
|
template <class _II1, class _II2, class _OO1>
|
|
|
|
requires convertible_to<const _I1&, _II1> && convertible_to<const _I2&, _II2> && convertible_to<const _O1&, _OO1>
|
|
|
|
_LIBCPP_HIDE_FROM_ABI constexpr
|
|
|
|
operator in_in_out_result<_II1, _II2, _OO1>() const& {
|
|
|
|
return {in1, in2, out};
|
|
|
|
}
|
|
|
|
|
|
|
|
template <class _II1, class _II2, class _OO1>
|
|
|
|
requires convertible_to<_I1, _II1> && convertible_to<_I2, _II2> && convertible_to<_O1, _OO1>
|
|
|
|
_LIBCPP_HIDE_FROM_ABI constexpr
|
|
|
|
operator in_in_out_result<_II1, _II2, _OO1>() && {
|
|
|
|
return {_VSTD::move(in1), _VSTD::move(in2), _VSTD::move(out)};
|
|
|
|
}
|
|
|
|
};
|
2022-02-02 09:06:30 +08:00
|
|
|
|
2022-01-25 18:21:47 +08:00
|
|
|
} // namespace ranges
|
|
|
|
|
[libc++] Guard much of std::ranges under _LIBCPP_HAS_NO_INCOMPLETE_RANGES.
The logic here is that we are disabling *only* things in `std::ranges::`.
Everything in `std::` is permitted, including `default_sentinel`, `contiguous_iterator`,
`common_iterator`, `projected`, `swappable`, and so on. Then, we include
anything from `std::ranges::` that is required in order to make those things
work: `ranges::swap`, `ranges::swap_ranges`, `input_range`, `ranges::begin`,
`ranges::iter_move`, and so on. But then that's all. Everything else (including
notably all of the "views" and the `std::views` namespace itself) is still
locked up behind `_LIBCPP_HAS_NO_INCOMPLETE_RANGES`.
Differential Revision: https://reviews.llvm.org/D118736
2022-02-02 05:52:02 +08:00
|
|
|
#endif // !defined(_LIBCPP_HAS_NO_CONCEPTS) && !defined(_LIBCPP_HAS_NO_INCOMPLETE_RANGES)
|
2022-01-25 18:21:47 +08:00
|
|
|
|
|
|
|
_LIBCPP_END_NAMESPACE_STD
|
|
|
|
|
2022-02-02 09:06:30 +08:00
|
|
|
#endif // _LIBCPP___ALGORITHM_IN_IN_OUT_RESULT_H
|