[clang] [Clang] prevent assertion failure from an invalid template instantiation pattern when adding instantiated params to the scope in friend functions with defaulted params (PR #113777)
Younan Zhang via cfe-commits
cfe-commits at lists.llvm.org
Thu Oct 31 20:01:28 PDT 2024
================
@@ -3437,10 +3437,10 @@ bool Sema::SubstDefaultArgument(
// template<typename T> void f(T a, int = decltype(a)());
// void g() { f(0); }
LIS = std::make_unique<LocalInstantiationScope>(*this);
- FunctionDecl *PatternFD = FD->getTemplateInstantiationPattern(
- /*ForDefinition*/ false);
- if (addInstantiatedParametersToScope(FD, PatternFD, *LIS, TemplateArgs))
- return true;
+ if (FunctionDecl *PatternFD =
+ FD->getTemplateInstantiationPattern(/*ForDefinition*/ false))
+ if (addInstantiatedParametersToScope(FD, PatternFD, *LIS, TemplateArgs))
+ return true;
----------------
zyn0217 wrote:
How about lifting the check for PatternFD to ForCallExpr?
```cpp
if (FunctionDecl *PatternFD = FD->getTemplateInstantiationPattern(); ForCallExpr && ForCallExpr)
...
```
So we don't need to construct an extra LocalInstantiationScope if the pattern isn't present.
https://github.com/llvm/llvm-project/pull/113777
More information about the cfe-commits
mailing list