#include <array>
#include <cassert>
#include <concepts>
#include <ranges>
#include <utility>
#include "test_macros.h"
static_assert(std::convertible_to<std::ranges::subrange<int*>, std::pair<int*, int*>>);
static_assert(std::convertible_to<std::ranges::subrange<int*>, std::tuple<int*, int*>>);
static_assert(!std::convertible_to<std::ranges::subrange<int*>, std::pair<long*, int*>>);
static_assert(!std::convertible_to<std::ranges::subrange<int*>, std::pair<int*, long*>>);
static_assert(!std::convertible_to<std::ranges::subrange<int*>, std::pair<long*, long*>>);
static_assert(!std::convertible_to<std::ranges::subrange<int*>, std::array<int*, 2>>);
constexpr bool test() {
{
int data[] = {1, 2, 3, 4, 5};
const std::ranges::subrange a(data);
{
std::pair<int*, int*> p(a);
assert(p.first == data + 0);
assert(p.second == data + 5);
}
{
std::pair<int*, int*> p{a};
assert(p.first == data + 0);
assert(p.second == data + 5);
}
{
std::pair<int*, int*> p = a;
assert(p.first == data + 0);
assert(p.second == data + 5);
}
}
{
int data[] = {1, 2, 3, 4, 5};
const std::ranges::subrange a(data);
{
std::tuple<int*, int*> p(a);
assert(std::get<0>(p) == data + 0);
assert(std::get<1>(p) == data + 5);
}
{
std::tuple<int*, int*> p{a};
assert(std::get<0>(p) == data + 0);
assert(std::get<1>(p) == data + 5);
}
{
std::tuple<int*, int*> p = a;
assert(std::get<0>(p) == data + 0);
assert(std::get<1>(p) == data + 5);
}
}
return true;
}
int main(int, char**) {
test();
static_assert(test());
return 0;
}