-
Notifications
You must be signed in to change notification settings - Fork 1.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
<utility>: Remove self swap check from pair. (#4674)
Co-authored-by: Stephan T. Lavavej <stl@nuwen.net>
- Loading branch information
1 parent
d1489f2
commit c8f45be
Showing
4 changed files
with
99 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
# Copyright (c) Microsoft Corporation. | ||
# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | ||
|
||
RUNALL_INCLUDE ..\usual_matrix.lst |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
// Copyright (c) Microsoft Corporation. | ||
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | ||
|
||
#include <cassert> | ||
#include <utility> | ||
|
||
struct swap_counter { | ||
unsigned int* pcnt_ = nullptr; | ||
|
||
friend _CONSTEXPR20 void swap(swap_counter& lhs, swap_counter& rhs) noexcept { | ||
assert(lhs.pcnt_ != nullptr); | ||
assert(rhs.pcnt_ != nullptr); | ||
std::swap(lhs.pcnt_, rhs.pcnt_); | ||
++*lhs.pcnt_; | ||
++*rhs.pcnt_; | ||
} | ||
|
||
_CONSTEXPR20 bool operator==(unsigned int x) const { | ||
assert(pcnt_ != nullptr); | ||
return *pcnt_ == x; | ||
} | ||
}; | ||
|
||
|
||
// Test GH-4597 "<utility>: Side effects in self-swaps of pair are skipped" | ||
_CONSTEXPR20 bool test_gh_4597() { | ||
{ | ||
unsigned int cnt{}; | ||
std::pair<swap_counter, int> pr{swap_counter{&cnt}, 10}; | ||
pr.swap(pr); | ||
assert(cnt == 2u); | ||
assert(pr.first == 2u); | ||
assert(pr.second == 10); | ||
} | ||
|
||
{ | ||
unsigned int cnt{}; | ||
std::pair<swap_counter, int> p1{swap_counter{&cnt}, 10}; | ||
std::pair<swap_counter, int> p2{swap_counter{&cnt}, 11}; | ||
p1.swap(p2); | ||
assert(cnt == 2u); | ||
assert(p1.first == 2u); | ||
assert(p1.second == 11); | ||
assert(p2.first == 2u); | ||
assert(p2.second == 10); | ||
} | ||
|
||
{ | ||
unsigned int c1{}; | ||
unsigned int c2{2}; | ||
std::pair<swap_counter, int> p1{swap_counter{&c1}, 11}; | ||
std::pair<swap_counter, int> p2{swap_counter{&c2}, 13}; | ||
p1.swap(p2); | ||
assert(c1 == 1u); | ||
assert(c2 == 3u); | ||
assert(p1.first == 3u); | ||
assert(p1.second == 13); | ||
assert(p2.first == 1u); | ||
assert(p2.second == 11); | ||
} | ||
|
||
#if _HAS_CXX23 | ||
{ | ||
unsigned int c1{}; | ||
unsigned int c2{2}; | ||
int i1 = 11; | ||
int i2 = 13; | ||
swap_counter s1{&c1}; | ||
swap_counter s2{&c2}; | ||
const std::pair<swap_counter&, int&> p1{s1, i1}; | ||
const std::pair<swap_counter&, int&> p2{s2, i2}; | ||
p1.swap(p2); | ||
assert(c1 == 1u); | ||
assert(c2 == 3u); | ||
assert(p1.first == 3u); | ||
assert(p1.second == 13); | ||
assert(p2.first == 1u); | ||
assert(p2.second == 11); | ||
} | ||
#endif // _HAS_CXX23 | ||
|
||
return true; | ||
} | ||
|
||
int main() { | ||
#if _HAS_CXX20 | ||
static_assert(test_gh_4597()); | ||
#endif // _HAS_CXX20 | ||
assert(test_gh_4597()); | ||
} |