diff options
author | Alexander Kornienko <alexfh@google.com> | 2017-05-12 11:24:25 +0000 |
---|---|---|
committer | Alexander Kornienko <alexfh@google.com> | 2017-05-12 11:24:25 +0000 |
commit | 0647a5673f1407a0f3c4bf66c1398df8c7252e13 (patch) | |
tree | 78c8ea657d175a4a79b92e9193cad93ba65afa27 | |
parent | 6aa8fdcd35f4cd4a0b3b0cf0ee48b87c08a11f7e (diff) |
Fix an assertion failure (PR33020).
Adding a test separately (tools/extra/test/clang-tidy/misc-use-after-move.cpp).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@302889 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/AST/DeclCXX.cpp | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/lib/AST/DeclCXX.cpp b/lib/AST/DeclCXX.cpp index dd8f768c57..9f87fe12a9 100644 --- a/lib/AST/DeclCXX.cpp +++ b/lib/AST/DeclCXX.cpp @@ -1432,8 +1432,9 @@ bool CXXRecordDecl::isAnyDestructorNoReturn() const { // Check base classes destructor for noreturn. for (const auto &Base : bases()) - if (Base.getType()->getAsCXXRecordDecl()->isAnyDestructorNoReturn()) - return true; + if (const CXXRecordDecl *RD = Base.getType()->getAsCXXRecordDecl()) + if (RD->isAnyDestructorNoReturn()) + return true; // Check fields for noreturn. for (const auto *Field : fields()) |