diff options
-rw-r--r-- | lib/Sema/AnalysisBasedWarnings.cpp | 11 | ||||
-rw-r--r-- | test/SemaCXX/warn-missing-noreturn.cpp | 15 |
2 files changed, 25 insertions, 1 deletions
diff --git a/lib/Sema/AnalysisBasedWarnings.cpp b/lib/Sema/AnalysisBasedWarnings.cpp index 3ded735f59..4463d3fea5 100644 --- a/lib/Sema/AnalysisBasedWarnings.cpp +++ b/lib/Sema/AnalysisBasedWarnings.cpp @@ -136,7 +136,16 @@ static ControlFlowKind CheckFallThrough(AnalysisContext &AC) { HasPlainEdge = true; continue; } - + if (CFGMemberDtor MD = CE.getAs<CFGMemberDtor>()) { + // A member destructor. + HasPlainEdge = true; + continue; + } + if (CFGBaseDtor BD = CE.getAs<CFGBaseDtor>()) { + // A base destructor. + HasPlainEdge = true; + continue; + } CFGStmt CS = CE.getAs<CFGStmt>(); if (!CS.isValid()) continue; diff --git a/test/SemaCXX/warn-missing-noreturn.cpp b/test/SemaCXX/warn-missing-noreturn.cpp index 251117fb77..54485fb5b1 100644 --- a/test/SemaCXX/warn-missing-noreturn.cpp +++ b/test/SemaCXX/warn-missing-noreturn.cpp @@ -65,5 +65,20 @@ namespace test2 { A(char) : f(j()) { } A(bool b) : f(b ? h() : j()) { } }; +} + +namespace test3 { + struct A { + ~A(); + }; + struct B { + ~B() { } + + A a; + }; + + struct C : A { + ~C() { } + }; } |