Index: llvm/trunk/include/llvm/Demangle/MicrosoftDemangle.h =================================================================== --- llvm/trunk/include/llvm/Demangle/MicrosoftDemangle.h +++ llvm/trunk/include/llvm/Demangle/MicrosoftDemangle.h @@ -245,7 +245,7 @@ FuncClass demangleFunctionClass(StringView &MangledName); CallingConv demangleCallingConvention(StringView &MangledName); StorageClass demangleVariableStorageClass(StringView &MangledName); - void demangleThrowSpecification(StringView &MangledName); + bool demangleThrowSpecification(StringView &MangledName); wchar_t demangleWcharLiteral(StringView &MangledName); uint8_t demangleCharLiteral(StringView &MangledName); Index: llvm/trunk/include/llvm/Demangle/MicrosoftDemangleNodes.h =================================================================== --- llvm/trunk/include/llvm/Demangle/MicrosoftDemangleNodes.h +++ llvm/trunk/include/llvm/Demangle/MicrosoftDemangleNodes.h @@ -323,6 +323,9 @@ // Function parameters NodeArrayNode *Params = nullptr; + + // True if the function type is noexcept + bool IsNoexcept = false; }; struct IdentifierNode : public Node { Index: llvm/trunk/lib/Demangle/MicrosoftDemangle.cpp =================================================================== --- llvm/trunk/lib/Demangle/MicrosoftDemangle.cpp +++ llvm/trunk/lib/Demangle/MicrosoftDemangle.cpp @@ -1681,11 +1681,14 @@ return Ty; } -void Demangler::demangleThrowSpecification(StringView &MangledName) { +bool Demangler::demangleThrowSpecification(StringView &MangledName) { + if (MangledName.consumeFront("_E")) + return true; if (MangledName.consumeFront('Z')) - return; + return false; Error = true; + return false; } FunctionSignatureNode *Demangler::demangleFunctionType(StringView &MangledName, @@ -1709,7 +1712,7 @@ FTy->Params = demangleFunctionParameterList(MangledName); - demangleThrowSpecification(MangledName); + FTy->IsNoexcept = demangleThrowSpecification(MangledName); return FTy; } Index: llvm/trunk/lib/Demangle/MicrosoftDemangleNodes.cpp =================================================================== --- llvm/trunk/lib/Demangle/MicrosoftDemangleNodes.cpp +++ llvm/trunk/lib/Demangle/MicrosoftDemangleNodes.cpp @@ -423,6 +423,9 @@ if (Quals & Q_Unaligned) OS << " __unaligned"; + if (IsNoexcept) + OS << " noexcept"; + if (RefQualifier == FunctionRefQualifier::Reference) OS << " &"; else if (RefQualifier == FunctionRefQualifier::RValueReference) Index: llvm/trunk/test/Demangle/ms-cxx17-noexcept.test =================================================================== --- llvm/trunk/test/Demangle/ms-cxx17-noexcept.test +++ llvm/trunk/test/Demangle/ms-cxx17-noexcept.test @@ -0,0 +1,25 @@ +; RUN: llvm-undname < %s | FileCheck %s + +; CHECK-NOT: Invalid mangled name + +?nochange@@YAXXZ +; CHECK: void __cdecl nochange(void) + +?a@@YAXP6AHXZ@Z +; CHECK: void __cdecl a(int (__cdecl *)(void)) +?a@@YAXP6AHX_E@Z +; CHECK: void __cdecl a(int (__cdecl *)(void) noexcept) + +?b@@YAXP6AHXZ@Z +; CHECK: void __cdecl b(int (__cdecl *)(void)) + +?c@@YAXP6AHXZ@Z +; CHECK: void __cdecl c(int (__cdecl *)(void)) +?c@@YAXP6AHX_E@Z +; CHECK: void __cdecl c(int (__cdecl *)(void) noexcept) + +?ee@?$e@$$A6AXXZ@@EEAAXXZ +; CHECK: private: virtual void __cdecl e::ee(void) + +?ee@?$e@$$A6AXX_E@@EEAAXXZ +; CHECK: private: virtual void __cdecl e::ee(void)