<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/60488>60488</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[C++20] [Modules] ADL does not work properly for dependent expressions
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
davidstone
</td>
</tr>
</table>
<pre>
Given the following two valid files:
```cpp
module;
namespace n {
struct s { };
void operator+(s, int) {
}
} // namespace n
export module a;
export template<typename T>
void a(T x) {
n::s() + x;
}
```
```cpp
module;
export module b;
import a;
void b() {
a(0);
}
```
When compiled with
```shell
clang++ -std=c++20 -x c++-module a.cpp --precompile -o a.pcm
clang++ -std=c++20 -x c++-module b.cpp --precompile -o b.pcm -fmodule-file=a.pcm
```
causes clang to fail with
```
In file included from b.cpp:1:
a.cpp:16:9: error: invalid operands to binary expression ('n::s' and 'int')
n::s() + x;
~~~~~~ ^ ~
b.cpp:8:2: note: in instantiation of function template specialization 'a<int>' requested here
a(0);
^
1 error generated.
```
In practice, this comes up with code like `std::string() + some_custom_to_string(my_type)`. Calling code needs to `#include <string>` in their module, even though they know nothing about `std::string` in the called function.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJyclV1v6ygTxz_N5GaUyIE4Ti5ykZf20ZGevTvSXlYYxjFbDF7ATbMX57OvwHGbdrtHq2NVjWHwzI-Z-YMIQZ8t0Q7KA5SnmRhi6_xOiRetQnSWZrVT193_9AtZjC1h44xxF23PGC8OX4TRChttKADfQ3GCYvq_LsY_2ffjTOfUYAj44X6ZFR2FXkhCi1B9MIXoBxkxpHmE6vTpyxenFbqevIjOAzsA2wRgR9Q2AtveOatOH7iqEwJ7BPaId7HvV9Br73zEERfFp7A3a6SuNyIS8GO89pRc4XfgD3dsAtjmO75-hCm2NiWK7wOwTTaxA76-x3iDndL3Czn9uIH6k1V32fp5Xxm5nqDueNM2CmDb_8j4e0sWpet6bUjhRcf2yx2ElowZ56QR9pwLeMB5iAr4SY5DVuD8FW-D-VSQhex7nM97T7cwOHcoFr3sfslf_aW_OvnDeTMumqcOB366i_Ll5qUYAgXMBBgdNkKbf8_BOPxms35QW2kGRQob77qRCvh--SYrMc2sge-3wPdI3jufXrQddZjVYFVIoWtthb8ivfaeQtDOYq5t9d5-FQqrEFiVFVOlEudAeHt-2qjToh_5QSgf8Mdomcg3wPcs0VmXZJIoUdsQhY1axATkGmwGK_P7pCcMPUktjP5rXAOsEsCPCZE_JGZPfw4UIilsydNHmH-06mSA8ibM5Zg0PJNNBwepxU-q-c1i74WMWlI6WGKrQ-psCjj0uaoonSI0-pkwtXRqtZyx6HXqwLe0BdfRkxxCdN1TdE9v9u76lA6PRLwuFngUxqSDNXu1RGMhExTjt-5A4Mfb5_wB1kVKamxJ-5vaEyeNR7Ubzm2yXfHZukuqQpuci9oN8SvcN2cohUnanWqzmKkdV1u-FTPaLddVydfrgvFZu2uaZiW3y7JkirNGyqVgYiNLElRuV4otZ3rHCsYLVrDlllUFX5QrqlnRNCVj5aYUAlYFdUKbhTEv3cL580yHMNBuXaw2m5kRNZmQrybGLF0wG4GxdFP5XfpmXg_nAKvC6BDDu5eoo8l32nFSPpQnhPLwW05TSKP96f-oHIWUGrw4_4y9TwoyV2ycR0U9WUU23mkozAZvdm2Mfb7u8jVy1rEd6oV0HbDHBHD7mffe_UEyAnvM2AHYY97W3wEAAP__5QMsAg">