]> granicus.if.org Git - clang/commitdiff
Introduce FunctionDecl::getFirstDeclaration() and VarDecl::getFirstDeclaration().
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>
Tue, 14 Jul 2009 03:19:57 +0000 (03:19 +0000)
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>
Tue, 14 Jul 2009 03:19:57 +0000 (03:19 +0000)
For multiple redeclarations they return the first one.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@75602 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/AST/Decl.h
lib/AST/Decl.cpp

index d033c24046d23ba208a4bdf1ba0bb3a6acd9a081..e83833f7d941f20735fb38c2002830997c26f652 100644 (file)
@@ -413,6 +413,10 @@ public:
     PreviousDeclaration = PrevDecl;
   }
 
+  /// \brief For multiple redeclarations returns the first one, otherwise
+  /// returns itself.
+  const VarDecl *getFirstDeclaration() const;
+
   virtual Decl *getPrimaryDecl() const;
 
   /// hasLocalStorage - Returns true if a variable with function scope
@@ -811,6 +815,10 @@ public:
     return PreviousDeclaration;
   }
 
+  /// \brief For multiple redeclarations returns the first one, otherwise
+  /// returns itself.
+  const FunctionDecl *getFirstDeclaration() const;
+
   void setPreviousDeclaration(FunctionDecl * PrevDecl);
 
   virtual Decl *getPrimaryDecl() const;
index fe9885ef261437c8960f778b2227d6b3c3ee22fb..5ef0c090936455bad98472c08adbd8e997f118d2 100644 (file)
@@ -358,12 +358,16 @@ 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();
+const VarDecl *VarDecl::getFirstDeclaration() const {
+  const VarDecl *First = this;
+  while (First->getPreviousDeclaration())
+    First = First->getPreviousDeclaration();
+
+  return First;
+}
 
-  return const_cast<VarDecl *>(Prim);
+Decl *VarDecl::getPrimaryDecl() const {
+  return const_cast<VarDecl *>(getFirstDeclaration());
 }
 
 //===----------------------------------------------------------------------===//
@@ -577,12 +581,16 @@ FunctionDecl::setPreviousDeclaration(FunctionDecl *PrevDecl) {
   }
 }
 
-Decl *FunctionDecl::getPrimaryDecl() const {
-  const FunctionDecl *Prim = this;
-  while (Prim->getPreviousDeclaration())
-    Prim = Prim->getPreviousDeclaration();
+const FunctionDecl *FunctionDecl::getFirstDeclaration() const {
+  const FunctionDecl *First = this;
+  while (First->getPreviousDeclaration())
+    First = First->getPreviousDeclaration();
+
+  return First;
+}
 
-  return const_cast<FunctionDecl *>(Prim);
+Decl *FunctionDecl::getPrimaryDecl() const {
+  return const_cast<FunctionDecl *>(getFirstDeclaration());
 }
 
 /// getOverloadedOperator - Which C++ overloaded operator this