Files
clang-p2996/libcxx/test/std/ranges/range.factories/range.single.view/data.pass.cpp
Louis Dionne b8cb1dc9ea [libc++] Make <ranges> non-experimental
When we ship LLVM 16, <ranges> won't be considered experimental anymore.
We might as well do this sooner rather than later.

Differential Revision: https://reviews.llvm.org/D132151
2022-08-18 16:59:58 -04:00

73 lines
1.7 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
//
//===----------------------------------------------------------------------===//
// UNSUPPORTED: c++03, c++11, c++14, c++17
// constexpr T* data() noexcept;
// constexpr const T* data() const noexcept;
#include <ranges>
#include <cassert>
#include "test_macros.h"
struct Empty {};
struct BigType { char buffer[64] = {10}; };
constexpr bool test() {
{
auto sv = std::ranges::single_view<int>(42);
assert(*sv.data() == 42);
ASSERT_SAME_TYPE(decltype(sv.data()), int*);
static_assert(noexcept(sv.data()));
}
{
const auto sv = std::ranges::single_view<int>(42);
assert(*sv.data() == 42);
ASSERT_SAME_TYPE(decltype(sv.data()), const int*);
static_assert(noexcept(sv.data()));
}
{
auto sv = std::ranges::single_view<Empty>(Empty());
assert(sv.data() != nullptr);
ASSERT_SAME_TYPE(decltype(sv.data()), Empty*);
}
{
const auto sv = std::ranges::single_view<Empty>(Empty());
assert(sv.data() != nullptr);
ASSERT_SAME_TYPE(decltype(sv.data()), const Empty*);
}
{
auto sv = std::ranges::single_view<BigType>(BigType());
assert(sv.data()->buffer[0] == 10);
ASSERT_SAME_TYPE(decltype(sv.data()), BigType*);
}
{
const auto sv = std::ranges::single_view<BigType>(BigType());
assert(sv.data()->buffer[0] == 10);
ASSERT_SAME_TYPE(decltype(sv.data()), const BigType*);
}
return true;
}
int main(int, char**) {
test();
static_assert(test());
return 0;
}