diff options
| author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-05 22:21:56 +0000 |
|---|---|---|
| committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2009-07-05 22:21:56 +0000 |
| commit | 02dd4f9389836a2f554c6c92bc62b0122808bd6f (patch) | |
| tree | 27050135c2618b76c2e68011892c95ce594eebc9 | |
| parent | cdfe1f210ba7e0dd51f08abc25865b4b376bf3c9 (diff) | |
| download | bcm5719-llvm-02dd4f9389836a2f554c6c92bc62b0122808bd6f.tar.gz bcm5719-llvm-02dd4f9389836a2f554c6c92bc62b0122808bd6f.zip | |
Introduce the virtual method Decl::getPrimaryDecl().
When a Decl subclass can have multiple re-declarations in the same declaration context (like FunctionDecl),
getPrimaryDecl() will return a particular Decl that all of them will point to as the "primary" declaration.
llvm-svn: 74800
| -rw-r--r-- | clang/include/clang/AST/Decl.h | 4 | ||||
| -rw-r--r-- | clang/include/clang/AST/DeclBase.h | 7 | ||||
| -rw-r--r-- | clang/lib/AST/Decl.cpp | 16 |
3 files changed, 27 insertions, 0 deletions
diff --git a/clang/include/clang/AST/Decl.h b/clang/include/clang/AST/Decl.h index 69a52869d81..e7c7496d8b4 100644 --- a/clang/include/clang/AST/Decl.h +++ b/clang/include/clang/AST/Decl.h @@ -413,6 +413,8 @@ public: PreviousDeclaration = PrevDecl; } + virtual Decl *getPrimaryDecl() const; + /// hasLocalStorage - Returns true if a variable with function scope /// is a non-static local variable. bool hasLocalStorage() const { @@ -811,6 +813,8 @@ public: void setPreviousDeclaration(FunctionDecl * PrevDecl); + virtual Decl *getPrimaryDecl() const; + unsigned getBuiltinID(ASTContext &Context) const; unsigned getNumParmVarDeclsFromType() const; diff --git a/clang/include/clang/AST/DeclBase.h b/clang/include/clang/AST/DeclBase.h index 0bce2f84c7b..019a0fe965b 100644 --- a/clang/include/clang/AST/DeclBase.h +++ b/clang/include/clang/AST/DeclBase.h @@ -311,6 +311,13 @@ public: // be defined inside or outside a function etc). bool isDefinedOutsideFunctionOrMethod() const; + /// \brief When there are multiple re-declarations (e.g. for functions), + /// this will return the primary one which all of them point to. + virtual Decl *getPrimaryDecl() const { return const_cast<Decl*>(this); } + + /// \brief Whether this particular Decl is a primary one. + bool isPrimaryDecl() const { return getPrimaryDecl() == this; } + /// getBody - If this Decl represents a declaration for a body of code, /// such as a function or method definition, this method returns the /// top-level Stmt* of that body. Otherwise this method returns null. diff --git a/clang/lib/AST/Decl.cpp b/clang/lib/AST/Decl.cpp index 3d02150b65b..bcbf091a195 100644 --- a/clang/lib/AST/Decl.cpp +++ b/clang/lib/AST/Decl.cpp @@ -358,6 +358,14 @@ const Expr *VarDecl::getDefinition(const VarDecl *&Def) const { return Def? Def->getInit() : 0; } +Decl *VarDecl::getPrimaryDecl() const { + const VarDecl *Prim = this; + while (Prim->getPreviousDeclaration()) + Prim = Prim->getPreviousDeclaration(); + + return const_cast<VarDecl *>(Prim); +} + //===----------------------------------------------------------------------===// // FunctionDecl Implementation //===----------------------------------------------------------------------===// @@ -569,6 +577,14 @@ FunctionDecl::setPreviousDeclaration(FunctionDecl *PrevDecl) { } } +Decl *FunctionDecl::getPrimaryDecl() const { + const FunctionDecl *Prim = this; + while (Prim->getPreviousDeclaration()) + Prim = Prim->getPreviousDeclaration(); + + return const_cast<FunctionDecl *>(Prim); +} + /// getOverloadedOperator - Which C++ overloaded operator this /// function represents, if any. OverloadedOperatorKind FunctionDecl::getOverloadedOperator() const { |

