<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/91564>91564</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[clang][C++] Bad error recovery when classes are defined inside template aliases
</td>
</tr>
<tr>
<th>Labels</th>
<td>
clang
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
mizvekov
</td>
</tr>
</table>
<pre>
When classes are defined inside template aliases, they are currently recovered as non templated classes, as if they were defined in the template alias' context. However, these classes let escape any references to the template parameters.
Consider this example:
```C++
template <class T> using A = struct B {
template <class> void f() requires (T()); // BAD: T aliases f's unnamed template parameter.
};
template void B::f<void>();
```
Produces:
```
test.cc:1:37: error: 'B' cannot be defined in a type alias template
1 | template <class T> using A = struct B {
| ^
test.cc:2:39: error: atomic constraint must be of type 'bool' (found 'void')
2 | template <class> void f() requires (T());
```
This can easily lead to crashes as well:
```C++
template <class T> using A = struct B {
using C = T;
};
template <class> void f() requires (B::C());
template void f<void>();
```
asserts in the constexpr evaluator:
```
Assertion failed: (!isValueDependent() && "Expression evaluator can't be called on a dependent expression."), function EvaluateAsConstantExpr, file ExprConstant.cpp, line 15953.
```
---
Probably a good strategy to fix this issue is to mark the alias' template parameters as invalid, and make sure their resulting type is something sensible for error recovery.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy0VU2P4jgQ_TXmUmoEDiHkwIGPbu1xD63dc8WugLcdO-ty6GZ__coOYbY_NJrRalAExPZzvVf1XEZmc3JEW1HuRXmc4RDPPmw788-FXvxl1nh93f55JgfKIjMxYCDQ1BpHGoxjowkidb3FSIDWIBMLeYB4pmteq4YQyEV7hUDKXyiQBmRw3t1xeto8AZHBtCP8ld7FSoMfYglZgfIu0lucw2_-lS4UbtGZ7pQtRSBW2BOgSzxaCuQUMUT_ftMeA3YUKfBcLI5isRu_Dz4LDRDPhoHesOstieI2K9aL8TkIuU9PHr3vKYpDJgLPoniEgY07wQ5EcQSOYVAR9iCqGwjgEyyBLt5oaIXcCFlDoL8HE4hByM3zOJaeYg9CPgn5BPvdURQ7eJ7KkZAVw-AcdqS_EDtprY6i-Mg-h94nrcWuFcUhvYvi8RZ3Wn5PwX-z9nvwelDEnxM1xeA4V0oUu6UodkWVSFMIPqQ_Qlb7XF10zkdo3hkBIV77mwXueqYMAixBVIfPmfyxAqRPgovy8SNNmWjW72hi9J1RyYMcAxoXoRs40_XtSFLIqvHeJi1Cblo_OJ3Gch5llZJ4Dyxz4P_lge-U4zl5V6EDQjb2CpZQpwOgAvI5HWyGV7L219h6nD_k-edvPL9y3A-Jvjny8Fn7e-f-pGVTvwiRp2aTy0pvfQC6oB0w5qJ_id9lpPEOWjSW9OjhjZBLw3-gHehIPTlNLt7UCLkWcg1Cyse3PhBzwt7DpEIJWWUnKbSWNPjkez3tAnRHzYWUOQkHaAenMonHcSPacepdEV1MUfISYwnSyzQxV32fJqxxBMuyLov5dzL08PDw4Yw32NgrIJy816n2GOl0TcZqzdvYMA3zQGByu-0wvOTc3vv3F803XwLugjadkQOg09DhCwEPgRLYBAjEg43JVPmUGQb2HcVzGmFybBpL0PowHtXp7rnOZ3pb6LqocUbbZbUsZbGuq2p23m6KSq0bqXSpm3VZylVZ4kZtWmoa3daympmtXMjVolzUi_VKltV8U67loqwXUqq6rapKrBbUobFzay_d3IfTLAvf1styvZpZbMhyvmelVBbdKZWtPM7CNq1_aIYTi9XCGo78bYdoos2X84goj6LcT-exPMIe9QeB8PqTl_VsCHZ7jrHPfTrfICcTz0MzV74T8ilRuf089MH_RSoK-ZSVsZBPWdy_AQAA__8dsI1E">