//===----------------------------------------------------------------------===// // // 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 // //===----------------------------------------------------------------------===// // constexpr bool operator[](size_t pos) const; // constexpr since C++23 #include #include #include #include #include "../bitset_test_cases.h" #include "test_macros.h" template TEST_CONSTEXPR_CXX23 void test_index_const() { std::vector > const cases = get_test_cases(); for (std::size_t c = 0; c != cases.size(); ++c) { std::bitset const v = cases[c]; if (v.size() > 0) { assert(v[N / 2] == v.test(N / 2)); } } #if !defined(_LIBCPP_VERSION) || defined(_LIBCPP_ABI_BITSET_VECTOR_BOOL_CONST_SUBSCRIPT_RETURN_BOOL) ASSERT_SAME_TYPE(decltype(cases[0][0]), bool); #else ASSERT_SAME_TYPE(decltype(cases[0][0]), typename std::bitset::__const_reference); #endif } TEST_CONSTEXPR_CXX23 bool test() { test_index_const<0>(); test_index_const<1>(); test_index_const<31>(); test_index_const<32>(); test_index_const<33>(); test_index_const<63>(); test_index_const<64>(); test_index_const<65>(); std::bitset<1> set_; set_[0] = false; const auto& set = set_; auto b = set[0]; set_[0] = true; #if !defined(_LIBCPP_VERSION) || defined(_LIBCPP_ABI_BITSET_VECTOR_BOOL_CONST_SUBSCRIPT_RETURN_BOOL) assert(!b); #else assert(b); #endif return true; } int main(int, char**) { test(); test_index_const<1000>(); // not in constexpr because of constexpr evaluation step limits #if TEST_STD_VER > 20 static_assert(test()); #endif return 0; }