Hristo Hristov 18e9b48c4c
[libc++][tuple] Applied [[nodiscard]] (#172008)
`[[nodiscard]]` should be applied to functions where discarding the
return value is most likely a correctness issue.

- https://libcxx.llvm.org/CodingGuidelines.html
- https://wg21.link/tuple
2025-12-16 16:56:10 +02:00

57 lines
2.2 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
// Make sure that we don't blow up the template instantiation recursion depth
// for tuples of size <= 512.
#include <tuple>
#include <cassert>
#include <utility>
#include "test_macros.h"
template <std::size_t... I>
constexpr void CreateTuple(std::index_sequence<I...>) {
using LargeTuple = std::tuple<std::integral_constant<std::size_t, I>...>;
using TargetTuple = std::tuple<decltype(I)...>;
LargeTuple tuple(std::integral_constant<std::size_t, I>{}...);
auto e1 = std::get<0>(tuple);
assert(e1.value == 0);
auto e2 = std::get<sizeof...(I) - 1>(tuple);
assert(e2.value == sizeof...(I) - 1);
TargetTuple t1 = tuple; // converting copy constructor from &
TargetTuple t2 = static_cast<LargeTuple const&>(tuple); // converting copy constructor from const&
TargetTuple t3 = std::move(tuple); // converting rvalue constructor
TargetTuple t4 = static_cast<LargeTuple const&&>(tuple); // converting const rvalue constructor
TargetTuple t5; // default constructor
(void)t1; (void)t2; (void)t3; (void)t4; (void)t5;
#if TEST_STD_VER >= 20
t1 = tuple; // converting assignment from &
t1 = static_cast<LargeTuple const&>(tuple); // converting assignment from const&
t1 = std::move(tuple); // converting assignment from &&
t1 = static_cast<LargeTuple const&&>(tuple); // converting assignment from const&&
swap(t1, t2); // swap
#endif
// t1 == tuple; // comparison does not work yet (we blow the constexpr stack)
}
constexpr bool test() {
CreateTuple(std::make_index_sequence<512>{});
return true;
}
int main(int, char**) {
test();
static_assert(test(), "");
return 0;
}