From 2b943c46873a6411c5a79dcd708d8c72ce5b3675 Mon Sep 17 00:00:00 2001 From: Mark de Wever Date: Thu, 7 Nov 2019 21:22:03 +0100 Subject: [PATCH] [Sema] Fixes a crash with a templated destructor The issue was introduced by D33189 which fixed PR33189. Fixes PR38671: "destructor cannot be declared as a template" leads to segfault in Sema::LookupSpecialMember Differential Revision: https://reviews.llvm.org/D69225 --- clang/lib/Sema/SemaLookup.cpp | 7 +++---- clang/test/SemaTemplate/destructor-template.cpp | 10 ++++++++++ 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/clang/lib/Sema/SemaLookup.cpp b/clang/lib/Sema/SemaLookup.cpp index 44c9d276c3e7..df817e6bcef1 100644 --- a/clang/lib/Sema/SemaLookup.cpp +++ b/clang/lib/Sema/SemaLookup.cpp @@ -3112,11 +3112,10 @@ Sema::SpecialMemberOverloadResult Sema::LookupSpecialMember(CXXRecordDecl *RD, }); } CXXDestructorDecl *DD = RD->getDestructor(); - assert(DD && "record without a destructor"); Result->setMethod(DD); - Result->setKind(DD->isDeleted() ? - SpecialMemberOverloadResult::NoMemberOrDeleted : - SpecialMemberOverloadResult::Success); + Result->setKind(DD && !DD->isDeleted() + ? SpecialMemberOverloadResult::Success + : SpecialMemberOverloadResult::NoMemberOrDeleted); return *Result; } diff --git a/clang/test/SemaTemplate/destructor-template.cpp b/clang/test/SemaTemplate/destructor-template.cpp index 6570b6456406..0d28ec816c6e 100644 --- a/clang/test/SemaTemplate/destructor-template.cpp +++ b/clang/test/SemaTemplate/destructor-template.cpp @@ -92,3 +92,13 @@ class PR33189 template ~PR33189() { } // expected-error{{destructor cannot be declared as a template}} }; + +namespace PR38671 { +struct S { + template + ~S(); // expected-error{{destructor cannot be declared as a template}} +}; +struct T : S { // expected-note{{destructor of 'T' is implicitly deleted because base class 'PR38671::S' has no destructor}} + ~T() = default; // expected-warning{{explicitly defaulted destructor is implicitly deleted}} +}; +} // namespace PR38671