diff --git a/clang/lib/AST/ItaniumMangle.cpp b/clang/lib/AST/ItaniumMangle.cpp index b1678479888eb..20f1ec969155a 100644 --- a/clang/lib/AST/ItaniumMangle.cpp +++ b/clang/lib/AST/ItaniumMangle.cpp @@ -2128,6 +2128,7 @@ void CXXNameMangler::mangleLambda(const CXXRecordDecl *Lambda) { } void CXXNameMangler::mangleLambdaSig(const CXXRecordDecl *Lambda) { + FunctionTypeDepthState saved = FunctionTypeDepth.push(); // Proposed on https://github.com/itanium-cxx-abi/cxx-abi/issues/31. for (auto *D : Lambda->getLambdaExplicitTemplateParameters()) mangleTemplateParamDecl(D); @@ -2140,6 +2141,7 @@ void CXXNameMangler::mangleLambdaSig(const CXXRecordDecl *Lambda) { Lambda->getLambdaTypeInfo()->getType()->castAs(); mangleBareFunctionType(Proto, /*MangleReturnType=*/false, Lambda->getLambdaStaticInvoker()); + FunctionTypeDepth.pop(saved); } void CXXNameMangler::manglePrefix(NestedNameSpecifier *qualifier) { diff --git a/clang/test/AST/mangle-lambda-expression-no-crash.cpp b/clang/test/AST/mangle-lambda-expression-no-crash.cpp new file mode 100644 index 0000000000000..79340797de355 --- /dev/null +++ b/clang/test/AST/mangle-lambda-expression-no-crash.cpp @@ -0,0 +1,4 @@ +// RUN: %clang_cc1 -std=c++20 -verify %s +// expected-no-diagnostics + +auto ICE = [](auto a) { return [=]() { return 1; }; };