<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/81129>81129</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
comparison operators for std::pair are not SFINAE-friendly in C++17 mode
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
EwgenijGawrilow-TomTom
</td>
</tr>
</table>
<pre>
operator==, operator< and other comparison operators defined for std::pair accept two arbitrary pairs as operands, even if their members are in fact not comparable. The inconsistency is detected only during the instantiation, which thwarts any generic application code relying on SFINAE.
An example:
```
bool compare_pairs(const std::pair<long,long>& p1, const std::pair<std::pair<long,long>, long>& p2) { return p1 < p2; }
```
rightfully fails to compile, while
```
auto compare_pairs(const std::pair<long,long>& p1, const std::pair<std::pair<long,long>, long>& p2)
-> decltype(p1 < p2);
```
is silently accepted.
This bug is specific for C++17 compilation mode, because starting with C++20, the three-way comparison operator has a properly crafted return type declaration deducing it from argument types. Still, this should be fixed since there are many software projects around which can't migrate to C++20 yet for various reasons.
The fix is very easy: instead of
```
bool operator<(const pair<_T1, _T2>& __x, const pair<_U1, _U2>& __y)
```
it should be declared as
```
auto operator<(const pair<_T1, _T2>& __x, const pair<_U1, _U2>& __y)
-> decltype(__x.first < __y.first && __x.second < __y.second)
```
and the same for all other comparisons.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzEVcFu4zgM_RrlQiRw5LRJDj4kbbPYy14mcw5oibY1kCVDopv67xey3aYzk2JPiwGCGLIoku_pPRNjNLUjKsTDUTw8L7Dnxofi5VqTMz_-wmsw1l-XZ9-efbsovR4K31FA9kHkz-knn-D25gnQafDcUADl2w6Did59BETQVBlHGiofILIW-UHkhw5NAFSKOga-esBQGg4YBkg7ETBOGZyOqRy9kgNTATdkArTUlpSCAoFxUKFicJ7n8lhaWgGcm7SpvIsmMjk1gEm9MCkmDd7ZAXQfjKtTUjAuMjo2yMa7VPHaGNUAN1cMHAHdADU5CkYBdp01agwE5TVBIDukPN7Bt9Pf_xxeViJ7Ftlh-j84oDdsO0sJ-bTxmM2_cVl6b-fe6TLCF3KXGuef-RL5k_WuFnJ65C9CPkK3Tt3ej_6v00_wOZEUcg9ie4RA3AcH3RrS7XZS5EcQ2-e7vQdTN1z11g5QobER2I9QjKWZRUt3D2I_R_550FNDAEuRv4AmZXnoSMjdjQC5F_nxLgwTIRpLju0wy5n0T9d_bkyEsq-T-mJHylRGjVZ4EvIo5HG9nfmaBNV6PRJXksI-EkTGwElcV8PN-xmZpZAkW24C0fKKwz3rQYMRELqQXtgBVMAqaX--34RyhIthqq1J9yrVMgxV8C1gqPuWHI-hcQXwjY21U-0Ep_G91VASVOaNNETjVGqJAo3WbJNroq_4mlZd8D9IJS8F3zs9G0yhE3LL0Jo6IFOSzwdIGIhHql4xGN9HCITRu_gLv2P5RO8rhQEI4yDyw2hoQg2--tpznz5iH-KbVXM5jxK7nOWslMvl7aa596DvU9D3W9DwoadfhcKf-JpYJw0YvzbH_9rd72q_XN5WlQmRR9FfLsP7Sj7OFVaRlHf6Y39afgU4TYUk0YgtjbeI1v42JuJqoYtc7_M9LqhYb7Ntvn-U2XrRFOphs8GdlAr1_pGIcFuhLqss29JuK_f7hSlkJjeZzHZrucnlerXb5tlOquxBZTrTMhObjFo0dmXta7vyoV6YGHsqduu13C8slmTjOASldHSFcVNImWZiKNKZZdnXUWwyayLHWxY2bKm4O-vuzLhA42yaJsOyCoactkOaW7cvQHL9og-2aJi7mE7Lk5Cn2nDTlyvlWyFPqfz8WM5eEvI0Nh2FPI2g_g0AAP__MU996g">