blob: 3f99d8a3b47a2ef531eeeed290aafbdf6d25d505 [file] [log] [blame]
//===----------------------------------------------------------------------===//
//
// 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, c++20
// <mdspan>
// template <class... Integrals>
// explicit extents(Integrals...) -> see below;
// Constraints: (is_convertible_v<Integrals, size_t> && ...) is true.
//
// Remarks: The deduced type is dextents<size_t, sizeof...(Integrals)>.
#include <mdspan>
#include <cassert>
#include "../ConvertibleToIntegral.h"
#include "test_macros.h"
struct NoDefaultCtorIndex {
size_t value;
constexpr NoDefaultCtorIndex() = delete;
constexpr NoDefaultCtorIndex(size_t val) : value(val) {}
constexpr operator size_t() const noexcept { return value; }
};
template <class E, class Expected>
constexpr void test(E e, Expected expected) {
ASSERT_SAME_TYPE(E, Expected);
assert(e == expected);
}
constexpr bool test() {
constexpr std::size_t D = std::dynamic_extent;
test(std::extents(), std::extents<size_t>());
test(std::extents(1), std::extents<std::size_t, D>(1));
test(std::extents(1, 2u), std::extents<std::size_t, D, D>(1, 2u));
test(std::extents(1, 2u, 3, 4, 5, 6, 7, 8, 9),
std::extents<std::size_t, D, D, D, D, D, D, D, D, D>(1, 2u, 3, 4, 5, 6, 7, 8, 9));
test(std::extents(NoDefaultCtorIndex{1}, NoDefaultCtorIndex{2}), std::extents<std::size_t, D, D>(1, 2));
return true;
}
int main(int, char**) {
test();
static_assert(test());
return 0;
}