Skip to content

Commit 355e08c

Browse files
committed
Simplify flip() for std::bit_set
1 parent 6230f1b commit 355e08c

File tree

3 files changed

+151
-129
lines changed

3 files changed

+151
-129
lines changed

libcxx/include/bitset

Lines changed: 2 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -329,9 +329,7 @@ _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX23 void __bitset<_N_words, _Siz
329329
// do last partial word
330330
if (__n > 0) {
331331
__storage_type __m = ~__storage_type(0) >> (__bits_per_word - __n);
332-
__storage_type __b = *__p & __m;
333-
*__p &= ~__m;
334-
*__p |= ~__b & __m;
332+
*__p ^= __m;
335333
}
336334
}
337335

@@ -515,8 +513,7 @@ __bitset<1, _Size>::operator^=(const __bitset& __v) _NOEXCEPT {
515513
template <size_t _Size>
516514
inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX23 void __bitset<1, _Size>::flip() _NOEXCEPT {
517515
__storage_type __m = ~__storage_type(0) >> (__bits_per_word - _Size);
518-
__first_ = ~__first_;
519-
__first_ &= __m;
516+
__first_ ^= __m;
520517
}
521518

522519
template <size_t _Size>

libcxx/test/std/utilities/template.bitset/bitset.members/flip_all.pass.cpp

Lines changed: 10 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -18,19 +18,21 @@
1818

1919
template <std::size_t N>
2020
TEST_CONSTEXPR_CXX23 void test_flip_all() {
21-
std::vector<std::bitset<N> > const cases = get_test_cases<N>();
22-
for (std::size_t c = 0; c != cases.size(); ++c) {
23-
std::bitset<N> v1 = cases[c];
24-
std::bitset<N> v2 = v1;
25-
v2.flip();
26-
for (std::size_t i = 0; i < v1.size(); ++i)
27-
assert(v2[i] == ~v1[i]);
28-
}
21+
std::vector<std::bitset<N> > const cases = get_test_cases<N>();
22+
for (std::size_t c = 0; c != cases.size(); ++c) {
23+
std::bitset<N> v1 = cases[c];
24+
std::bitset<N> v2 = v1;
25+
v2.flip();
26+
for (std::size_t i = 0; i < v1.size(); ++i)
27+
assert(v2[i] == ~v1[i]);
28+
}
2929
}
3030

3131
TEST_CONSTEXPR_CXX23 bool test() {
3232
test_flip_all<0>();
3333
test_flip_all<1>();
34+
test_flip_all<2>();
35+
test_flip_all<5>();
3436
test_flip_all<31>();
3537
test_flip_all<32>();
3638
test_flip_all<33>();

0 commit comments

Comments
 (0)