Index: lib/Demangle/Demangle.cpp =================================================================== --- lib/Demangle/Demangle.cpp +++ lib/Demangle/Demangle.cpp @@ -13,9 +13,16 @@ #include "llvm/Demangle/Demangle.h" +static bool isItaniumEncoding(const std::string &MangledName) { + std::size_t FirstNonUnderscore = MangledName.find_first_not_of('_'); + // A valid Itanium encoding requires 1-4 leading underscores, followed by 'Z'. + return FirstNonUnderscore > 0 && FirstNonUnderscore <= 4 && + MangledName[FirstNonUnderscore] == 'Z'; +} + std::string llvm::demangle(const std::string &MangledName) { char *Demangled; - if (MangledName.compare(0, 2, "_Z") == 0) + if (isItaniumEncoding(MangledName)) Demangled = itaniumDemangle(MangledName.c_str(), nullptr, nullptr, nullptr); else Demangled = Index: unittests/Demangle/DemangleTest.cpp =================================================================== --- unittests/Demangle/DemangleTest.cpp +++ unittests/Demangle/DemangleTest.cpp @@ -13,7 +13,13 @@ using namespace llvm; TEST(Demangle, demangleTest) { + EXPECT_EQ(demangle("_"), "_"); EXPECT_EQ(demangle("_Z3fooi"), "foo(int)"); + EXPECT_EQ(demangle("__Z3fooi"), "foo(int)"); + EXPECT_EQ(demangle("___Z3fooi_block_invoke"), + "invocation function for block in foo(int)"); + EXPECT_EQ(demangle("____Z3fooi_block_invoke"), + "invocation function for block in foo(int)"); EXPECT_EQ(demangle("?foo@@YAXH@Z"), "void __cdecl foo(int)"); EXPECT_EQ(demangle("foo"), "foo"); }