[clang] [clang] Don't use `VarDecl` of local variables as `ManglingContextDecl` for lambdas (PR #179035)

Jan Kokemüller via cfe-commits cfe-commits at lists.llvm.org
Mon Feb 2 04:12:16 PST 2026


================
@@ -294,6 +294,13 @@ Sema::getCurrentMangleNumberContext(const DeclContext *DC) {
   bool IsInNonspecializedTemplate =
       inTemplateInstantiation() || CurContext->isDependentContext();
 
+  // If we must allocate mangling numbers but the `ManglingContextDecl`
+  // is a local variable, use the `DeclContext` containing the lambda expression
+  // instead.
+  if (VarDecl *Var = dyn_cast_or_null<VarDecl>(ManglingContextDecl);
+      Var && Var->isLocalVarDecl())
+    ManglingContextDecl = const_cast<Decl *>(cast<Decl>(DC));
----------------
jiixyj wrote:

Good idea, I refactored the check so that is only applies in the modules case.

https://github.com/llvm/llvm-project/pull/179035


More information about the cfe-commits mailing list