Files
clang-p2996/libcxx/test/support/test_range.h
Christopher Di Bella 3903438860 [libcxx] adds ranges::fold_left_with_iter and ranges::fold_left (#75259)
Notable things in this commit:

* refactors `__indirect_binary_left_foldable`, making it slightly
different (but equivalent) to _`indirect-binary-left-foldable`_, which
improves readability (a [patch to the Working Paper][patch] was made)
* omits `__cpo` namespace, since it is not required for implementing
niebloids (a cleanup should happen in 2024)
* puts tests ensuring invocable robustness and dangling correctness
inside the correctness testing to ensure that the algorithms' results
are still correct

[patch]: https://github.com/cplusplus/draft/pull/6734
2023-12-19 21:57:50 -08:00

86 lines
2.4 KiB
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 LIBCXX_TEST_SUPPORT_TEST_RANGE_H
#define LIBCXX_TEST_SUPPORT_TEST_RANGE_H
#include <iterator>
#include <ranges>
#include "test_iterators.h"
#if TEST_STD_VER < 17
# error "test/support/test_range.h" can only be included in builds supporting ranges
#endif
struct sentinel {
bool operator==(std::input_or_output_iterator auto const&) const;
};
template <template <class...> class I, class T = int>
requires std::input_or_output_iterator<I<T*> >
struct test_range {
I<T*> begin();
I<T const*> begin() const;
sentinel end();
sentinel end() const;
};
template <template <class...> class I, class T = int>
requires std::input_or_output_iterator<I<T*> >
struct test_non_const_range {
I<T*> begin();
sentinel end();
};
template <template <class...> class I, class T = int>
requires std::input_or_output_iterator<I<T*> >
struct test_common_range {
I<T*> begin();
I<T const*> begin() const;
I<T*> end();
I<T const*> end() const;
};
template <template <class...> class I, class T = int>
requires std::input_or_output_iterator<I<T*> >
struct test_non_const_common_range {
I<T*> begin();
I<T*> end();
};
template <template <class...> class I, class T = int>
requires std::input_or_output_iterator<I<T*> >
struct test_view : std::ranges::view_base {
I<T*> begin();
I<T const*> begin() const;
sentinel end();
sentinel end() const;
};
template <class T = int>
struct BorrowedRange {
T* begin() const;
T* end() const;
BorrowedRange(BorrowedRange&&) = delete;
};
template <class T>
inline constexpr bool std::ranges::enable_borrowed_range<BorrowedRange<T>> = true;
static_assert(!std::ranges::view<BorrowedRange<>>);
static_assert(std::ranges::borrowed_range<BorrowedRange<>>);
using BorrowedView = std::ranges::empty_view<int>;
static_assert(std::ranges::view<BorrowedView>);
static_assert(std::ranges::borrowed_range<BorrowedView>);
using NonBorrowedView = std::ranges::single_view<int>;
static_assert(std::ranges::view<NonBorrowedView>);
static_assert(!std::ranges::borrowed_range<NonBorrowedView>);
#endif // LIBCXX_TEST_SUPPORT_TEST_RANGE_H