From 865697f9b9add3030c1a2637aac6f755c573f781 Mon Sep 17 00:00:00 2001 From: Richard Smith Date: Mon, 9 Sep 2019 23:07:25 +0000 Subject: [PATCH] Fix incorrect demangling of call operator of lambda with explicit template parameters due to registering template parameters twice. llvm-svn: 371469 --- libcxxabi/src/demangle/ItaniumDemangle.h | 4 ---- libcxxabi/test/test_demangle.pass.cpp | 7 ++++++- llvm/include/llvm/Demangle/ItaniumDemangle.h | 4 ---- 3 files changed, 6 insertions(+), 9 deletions(-) diff --git a/libcxxabi/src/demangle/ItaniumDemangle.h b/libcxxabi/src/demangle/ItaniumDemangle.h index edba17d..7784e84 100644 --- a/libcxxabi/src/demangle/ItaniumDemangle.h +++ b/libcxxabi/src/demangle/ItaniumDemangle.h @@ -2358,9 +2358,6 @@ template struct AbstractManglingParser { assert(Parser->TemplateParams.size() >= OldNumTemplateParamLists); Parser->TemplateParams.dropBack(OldNumTemplateParamLists); } - void push_back(Node *Param) { - Params.push_back(Param); - } }; // Template parameter table. Like the above, but referenced like "T42_". @@ -2702,7 +2699,6 @@ AbstractManglingParser::parseUnnamedTypeName(NameState *State) { Node *T = parseTemplateParamDecl(); if (!T) return nullptr; - LambdaTemplateParams.push_back(T); Names.push_back(T); } NodeArray TempParams = popTrailingNodeArray(ParamsBegin); diff --git a/libcxxabi/test/test_demangle.pass.cpp b/libcxxabi/test/test_demangle.pass.cpp index c84447f..8cfe6ae 100644 --- a/libcxxabi/test/test_demangle.pass.cpp +++ b/libcxxabi/test/test_demangle.pass.cpp @@ -29784,9 +29784,14 @@ const char* cases[][2] = {"_ZNK1xMUlTyT_E_clIiEEDaS_", "auto x::'lambda'($T)::operator()(x) const"}, {"_ZNK1xMUlTnPA3_ivE_clILS0_0EEEDav", "auto x::'lambda'()::operator()<(int [3])0>() const"}, {"_ZNK1xMUlTyTtTyTnT_TpTnPA3_TL0__ETpTyvE_clIi1XJfEEEDav", "auto x::'lambda' typename $TT, typename ...$T1>()::operator()() const"}, - {"_ZN1AIiE1fIfEEvDTLUlTyTtTyTnTL1__ETL0_1_T_TL0__E_EE", "void A::f(decltype([] typename $TT>($TT, float, $T){...}))"}, + {"_ZN1AIiE1fIfEEvDTLUlTyTtTyTnTL1__ETL0_1_T_TL0__E_EE", "void A::f(decltype([] typename $TT>(auto, float, $T){...}))"}, {"_ZN1S1fILb1EEEv1XILUlvE_EE", "void S::f(X<[](){...}>)"}, {"_ZN1S1fILb1EEEv1XILUlvE0_EE", "void S::f(X<[](){...}>)"}, + // FIXME: Consider special-casing the call operator of a lambda and + // producing something like + // "auto inline_func()::'lambda'(int, int) const" + {"_ZZ11inline_funcvENKUlTyTyT_T0_E_clIiiEEDaS_S0_", "auto inline_func()::'lambda'($T, $T0)::operator()($T, $T0) const"}, + {"_ZZ11inline_funcvENKUlTyTyT_T1_T0_E_clIiiiEEDaS_S0_S1_", "auto inline_func()::'lambda'($T, auto, $T0)::operator()($T, auto, $T0) const"}, }; const unsigned N = sizeof(cases) / sizeof(cases[0]); diff --git a/llvm/include/llvm/Demangle/ItaniumDemangle.h b/llvm/include/llvm/Demangle/ItaniumDemangle.h index edba17d..7784e84 100644 --- a/llvm/include/llvm/Demangle/ItaniumDemangle.h +++ b/llvm/include/llvm/Demangle/ItaniumDemangle.h @@ -2358,9 +2358,6 @@ template struct AbstractManglingParser { assert(Parser->TemplateParams.size() >= OldNumTemplateParamLists); Parser->TemplateParams.dropBack(OldNumTemplateParamLists); } - void push_back(Node *Param) { - Params.push_back(Param); - } }; // Template parameter table. Like the above, but referenced like "T42_". @@ -2702,7 +2699,6 @@ AbstractManglingParser::parseUnnamedTypeName(NameState *State) { Node *T = parseTemplateParamDecl(); if (!T) return nullptr; - LambdaTemplateParams.push_back(T); Names.push_back(T); } NodeArray TempParams = popTrailingNodeArray(ParamsBegin); -- 2.7.4