Index: libcxxabi/src/demangle/ItaniumDemangle.h =================================================================== --- libcxxabi/src/demangle/ItaniumDemangle.h +++ libcxxabi/src/demangle/ItaniumDemangle.h @@ -4423,7 +4423,11 @@ ++First; const auto *Op = parseOperatorEncoding(); - if (!Op || Op->getKind() != OperatorInfo::Binary) + if (!Op) + return nullptr; + if (!(Op->getKind() == OperatorInfo::Binary + || (Op->getKind() == OperatorInfo::Member + && Op->getName().back() == '*'))) return nullptr; Node *Pack = getDerived().parseExpr(); Index: libcxxabi/test/test_demangle.pass.cpp =================================================================== --- libcxxabi/test/test_demangle.pass.cpp +++ libcxxabi/test/test_demangle.pass.cpp @@ -29958,6 +29958,8 @@ "void Partial<1, 2>::foldr<3, 4>(A<1 + (2 + ((3, 4) + ... + (1 + (2 + ((3, 4) + ...)))))>)"}, {"_ZN7PartialIJLi1ELi2EEE5foldrIJLi3ELi4EEEEv1AIXplplLi1ELi2EfRplT_plplLi1ELi2EflplT_EE", "void Partial<1, 2>::foldr<3, 4>(A<1 + 2 + ((3, 4) + ... + (1 + 2 + (... + (3, 4))))>)"}, + {"_Z1fIXfLpm1x1yEEvv", "void f<(x ->* ... ->* (y...))>()"}, + {"_Z1fIXfLds1x1yEEvv", "void f<(x .* ... .* (y...))>()"}, // reference collapsing: {"_Z1fIR1SEiOT_", "int f(S&)"}, @@ -30168,6 +30170,9 @@ "_ZN1fIiEEvNTUt_E", "_ZNDTUt_Ev", + "_Z1fIXfLpt1x1yEEvv", + "_Z1fIXfLdt1x1yEEvv", + "_ZN1fIXawLi0EEEEvv", "_ZNWUt_3FOOEv", Index: llvm/include/llvm/Demangle/ItaniumDemangle.h =================================================================== --- llvm/include/llvm/Demangle/ItaniumDemangle.h +++ llvm/include/llvm/Demangle/ItaniumDemangle.h @@ -4423,7 +4423,11 @@ ++First; const auto *Op = parseOperatorEncoding(); - if (!Op || Op->getKind() != OperatorInfo::Binary) + if (!Op) + return nullptr; + if (!(Op->getKind() == OperatorInfo::Binary + || (Op->getKind() == OperatorInfo::Member + && Op->getName().back() == '*'))) return nullptr; Node *Pack = getDerived().parseExpr();