#include <ranges>
#include <array>
#include <cassert>
#include <concepts>
#include "test_iterators.h"
#include "test_macros.h"
template <class T>
concept HasData = requires (T t) {
t.data();
};
constexpr bool test()
{
{
struct ContiguousIters {
contiguous_iterator<int*> begin();
sentinel_wrapper<contiguous_iterator<int*>> end();
};
using OwningView = std::ranges::owning_view<ContiguousIters>;
static_assert(std::ranges::contiguous_range<OwningView&>);
static_assert(!std::ranges::range<const OwningView&>);
static_assert(HasData<OwningView&>);
static_assert(HasData<OwningView&&>);
static_assert(!HasData<const OwningView&>);
static_assert(!HasData<const OwningView&&>);
}
{
struct NoData {
random_access_iterator<int*> begin();
random_access_iterator<int*> end();
};
using OwningView = std::ranges::owning_view<NoData>;
static_assert(!HasData<OwningView&>);
static_assert(!HasData<OwningView&&>);
static_assert(!HasData<const OwningView&>);
static_assert(!HasData<const OwningView&&>);
}
{
int a[] = {1};
auto ov = std::ranges::owning_view(std::ranges::subrange(a, a+1));
assert(ov.data() == a);
assert(std::as_const(ov).data() == a);
}
{
std::array<int, 2> a = {1, 2};
auto ov = std::ranges::owning_view(std::move(a));
assert(ov.data() != a.data());
assert(std::as_const(ov).data() != a.data());
}
return true;
}
int main(int, char**) {
test();
static_assert(test());
return 0;
}