diff options
| author | Sebastian Redl <sebastian.redl@getdesigned.at> | 2009-10-25 17:03:50 +0000 |
|---|---|---|
| committer | Sebastian Redl <sebastian.redl@getdesigned.at> | 2009-10-25 17:03:50 +0000 |
| commit | 1054faed320dd781a31338493d7368b3789c141f (patch) | |
| tree | 400255b6a9c0a6e1f82318dc1eecad040c40e861 /clang/lib/Frontend/ASTConsumers.cpp | |
| parent | c45c03c9dd5be775803cd14784f3bc49db363917 (diff) | |
| download | bcm5719-llvm-1054faed320dd781a31338493d7368b3789c141f.tar.gz bcm5719-llvm-1054faed320dd781a31338493d7368b3789c141f.zip | |
Audit the code for places where it is assumed that every base specifier refers to a RecordType. Add assertions or conditions as appropriate. This fixes another crash in the Apache stdlib vector.
llvm-svn: 85055
Diffstat (limited to 'clang/lib/Frontend/ASTConsumers.cpp')
| -rw-r--r-- | clang/lib/Frontend/ASTConsumers.cpp | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/clang/lib/Frontend/ASTConsumers.cpp b/clang/lib/Frontend/ASTConsumers.cpp index 446678ab6d5..9a30f59465f 100644 --- a/clang/lib/Frontend/ASTConsumers.cpp +++ b/clang/lib/Frontend/ASTConsumers.cpp @@ -452,6 +452,8 @@ class RecordLayoutDumper : public ASTConsumer { // Dump (non-virtual) bases for (CXXRecordDecl::base_class_const_iterator I = RD->bases_begin(), E = RD->bases_end(); I != E; ++I) { + assert(!I->getType()->isDependentType() && + "Cannot layout class with dependent bases."); if (I->isVirtual()) continue; |

