diff options
author | Anders Carlsson <andersca@mac.com> | 2009-08-29 20:47:47 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-08-29 20:47:47 +0000 |
commit | 35eda446cdf5b4e95a80ffacbf6c7f7478c6d927 (patch) | |
tree | d7ff95b5d4f37304da25c757875963c2ffc0d5c8 /lib/AST/DeclBase.cpp | |
parent | 018e9fead456a6bdcde68dba7cc1aa4a7ee8d639 (diff) |
Add a workaround for decls that come from friend decls pointing to undeclared classes.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@80438 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AST/DeclBase.cpp')
-rw-r--r-- | lib/AST/DeclBase.cpp | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/lib/AST/DeclBase.cpp b/lib/AST/DeclBase.cpp index 3ced0eff4c..3a010b0cdf 100644 --- a/lib/AST/DeclBase.cpp +++ b/lib/AST/DeclBase.cpp @@ -379,8 +379,18 @@ SourceLocation Decl::getBodyRBrace() const { #ifndef NDEBUG void Decl::CheckAccessDeclContext() const { - assert((Access != AS_none || isa<TranslationUnitDecl>(this) || - !isa<CXXRecordDecl>(getDeclContext())) && + // If the decl is the toplevel translation unit or if we're not in a + // record decl context, we don't need to check anything. + if (isa<TranslationUnitDecl>(this) || + !isa<CXXRecordDecl>(getDeclContext())) + return; + + // FIXME: This check should not be necessary - If a friend decl refers to an + // undeclared decl, then that decl shouldn't be in any decl context. + if (getFriendObjectKind() == FOK_Undeclared) + return; + + assert(Access != AS_none && "Access specifier is AS_none inside a record decl"); } |