diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-01-09 18:51:29 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-01-09 18:51:29 +0000 |
commit | a8cc8ce044e5d2589128f0c1a84e586cce743b27 (patch) | |
tree | 4adb92ceade9162327c38ca3335c964676b8357f | |
parent | 1b95a6546d1f3847da29da0d1e8dc5d77b1a7fbb (diff) |
Make sure that ScopedDecls passed to DeclContext::addDecl are added into their lexical context
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@61998 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/clang/AST/Decl.h | 14 | ||||
-rw-r--r-- | lib/AST/Decl.cpp | 7 | ||||
-rw-r--r-- | lib/AST/DeclBase.cpp | 2 | ||||
-rw-r--r-- | lib/Sema/SemaDecl.cpp | 8 |
4 files changed, 28 insertions, 3 deletions
diff --git a/include/clang/AST/Decl.h b/include/clang/AST/Decl.h index 828c1be925..96bd8842b3 100644 --- a/include/clang/AST/Decl.h +++ b/include/clang/AST/Decl.h @@ -144,11 +144,15 @@ class ScopedDecl : public NamedDecl { protected: ScopedDecl(Kind DK, DeclContext *DC, SourceLocation L, DeclarationName N, ScopedDecl *PrevDecl = 0) - : NamedDecl(DK, L, N), NextDeclarator(PrevDecl), + : NamedDecl(DK, L, N), NextDeclarator(PrevDecl), DeclCtx(reinterpret_cast<uintptr_t>(DC)) {} virtual ~ScopedDecl(); - + + /// setDeclContext - Set both the semantic and lexical DeclContext + /// to DC. + void setDeclContext(DeclContext *DC); + public: const DeclContext *getDeclContext() const { if (isInSemaDC()) @@ -532,6 +536,12 @@ public: QualType getOriginalType() const; + /// setOwningFunction - Sets the function declaration that owns this + /// ParmVarDecl. Since ParmVarDecls are often created before the + /// FunctionDecls that own them, this routine is required to update + /// the DeclContext appropriately. + void setOwningFunction(DeclContext *FD) { setDeclContext(FD); } + // Implement isa/cast/dyncast/etc. static bool classof(const Decl *D) { return (D->getKind() == ParmVar || diff --git a/lib/AST/Decl.cpp b/lib/AST/Decl.cpp index 8521b9b44e..f29417ed13 100644 --- a/lib/AST/Decl.cpp +++ b/lib/AST/Decl.cpp @@ -164,6 +164,13 @@ FileScopeAsmDecl *FileScopeAsmDecl::Create(ASTContext &C, // ScopedDecl Implementation //===----------------------------------------------------------------------===// +void ScopedDecl::setDeclContext(DeclContext *DC) { + if (isOutOfSemaDC()) + delete getMultipleDC(); + + DeclCtx = reinterpret_cast<uintptr_t>(DC); +} + void ScopedDecl::setLexicalDeclContext(DeclContext *DC) { if (DC == getLexicalDeclContext()) return; diff --git a/lib/AST/DeclBase.cpp b/lib/AST/DeclBase.cpp index f1ce3f3d0d..d9765ac4b4 100644 --- a/lib/AST/DeclBase.cpp +++ b/lib/AST/DeclBase.cpp @@ -514,6 +514,7 @@ DeclContext *DeclContext::getNextContext() { } void DeclContext::addDecl(ASTContext &Context, ScopedDecl *D, bool AllowLookup) { + assert(D->getLexicalDeclContext() == this && "Decl inserted into wrong lexical context"); Decls.push_back(D); if (AllowLookup) D->getDeclContext()->insert(Context, D); @@ -599,7 +600,6 @@ void DeclContext::insert(ASTContext &Context, ScopedDecl *D) { if (LookupPtr.getPointer()) insertImpl(D); - // If we are a transparent context, insert into our parent context, // too. This operation is recursive. if (isTransparentContext()) diff --git a/lib/Sema/SemaDecl.cpp b/lib/Sema/SemaDecl.cpp index d9436ebdc7..ecf6de9d96 100644 --- a/lib/Sema/SemaDecl.cpp +++ b/lib/Sema/SemaDecl.cpp @@ -441,7 +441,13 @@ ScopedDecl *Sema::LazilyCreateBuiltin(IdentifierInfo *II, unsigned bid, // TUScope is the translation-unit scope to insert this function into. + // FIXME: This is hideous. We need to teach PushOnScopeChains to + // relate Scopes to DeclContexts, and probably eliminate CurContext + // entirely, but we're not there yet. + DeclContext *SavedContext = CurContext; + CurContext = Context.getTranslationUnitDecl(); PushOnScopeChains(New, TUScope); + CurContext = SavedContext; return New; } @@ -2705,6 +2711,8 @@ Sema::DeclTy *Sema::ActOnStartOfFunctionDef(Scope *FnBodyScope, DeclTy *D) { // Introduce our parameters into the function scope for (unsigned p = 0, NumParams = FD->getNumParams(); p < NumParams; ++p) { ParmVarDecl *Param = FD->getParamDecl(p); + Param->setOwningFunction(FD); + // If this has an identifier, add it to the scope stack. if (Param->getIdentifier()) PushOnScopeChains(Param, FnBodyScope); |