]> granicus.if.org Git - clang/commitdiff
Store latest redeclaration for each redeclarable template declaration
authorPeter Collingbourne <peter@pcc.me.uk>
Thu, 29 Jul 2010 16:12:01 +0000 (16:12 +0000)
committerPeter Collingbourne <peter@pcc.me.uk>
Thu, 29 Jul 2010 16:12:01 +0000 (16:12 +0000)
This patch adds a Latest field to RedeclarableTemplateDecl's CommonBase
class which is used to store the latest redeclaration.

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

include/clang/AST/DeclTemplate.h
lib/AST/DeclTemplate.cpp
lib/Frontend/PCHReaderDecl.cpp
lib/Frontend/PCHWriterDecl.cpp

index 3c678cc3fff7d8791640f2d7fcafb923b179910e..8d3cfad8179dc0834a40d4013e865e6d6903f457 100644 (file)
@@ -492,10 +492,7 @@ class RedeclarableTemplateDecl : public TemplateDecl {
 
   RedeclarableTemplateDecl *getCanonicalDeclImpl();
 
-  void setPreviousDeclarationImpl(RedeclarableTemplateDecl *Prev) {
-    if (Prev)
-      CommonOrPrev = Prev;
-  }
+  void setPreviousDeclarationImpl(RedeclarableTemplateDecl *Prev);
 
   RedeclarableTemplateDecl *getInstantiatedFromMemberTemplateImpl() {
     return getCommonPtr()->InstantiatedFromMember.getPointer();
@@ -517,6 +514,9 @@ protected:
     /// was explicitly specialized.
     llvm::PointerIntPair<RedeclarableTemplateDecl*, 1, bool>
       InstantiatedFromMember;
+
+    /// \brief The latest declaration of this template.
+    RedeclarableTemplateDecl *Latest;
   };
 
   /// \brief A pointer to the previous declaration (if this is a redeclaration)
@@ -602,6 +602,7 @@ public:
   }
 
   friend class PCHDeclReader;
+  friend class PCHDeclWriter;
 };
 
 template <class decl_type>
index de175689421b20ca025eaaf1b60c43b5630faad6..0ca2837627f1e9dc043c6cff35e717ba292ded10 100644 (file)
@@ -94,6 +94,7 @@ RedeclarableTemplateDecl::CommonBase *RedeclarableTemplateDecl::getCommonPtr() {
   if (First->CommonOrPrev.isNull()) {
     CommonBase *CommonPtr = First->newCommon();
     First->CommonOrPrev = CommonPtr;
+    CommonPtr->Latest = First;
   }
   return First->CommonOrPrev.get<CommonBase*>();
 }
@@ -106,6 +107,18 @@ RedeclarableTemplateDecl *RedeclarableTemplateDecl::getCanonicalDeclImpl() {
   return Tmpl;
 }
 
+void RedeclarableTemplateDecl::setPreviousDeclarationImpl(
+                                               RedeclarableTemplateDecl *Prev) {
+  if (Prev) {
+    CommonBase *Common = Prev->getCommonPtr();
+    Prev = Common->Latest;
+    Common->Latest = this;
+    CommonOrPrev = Prev;
+  } else {
+    assert(CommonOrPrev.is<CommonBase*>() && "Cannot reset TemplateDecl Prev");
+  }
+}
+
 //===----------------------------------------------------------------------===//
 // FunctionTemplateDecl Implementation
 //===----------------------------------------------------------------------===//
index 94485d2d8f8eadf7e476721827d36f1fbe364b56..03e7e1a0938eded69db7a6222623fa2fe477be07 100644 (file)
@@ -915,6 +915,11 @@ void PCHDeclReader::VisitRedeclarableTemplateDecl(RedeclarableTemplateDecl *D) {
       if (Record[Idx++])
         D->setMemberSpecialization();
     }
+
+    RedeclarableTemplateDecl *LatestDecl = 
+        cast_or_null<RedeclarableTemplateDecl>(Reader.GetDecl(Record[Idx++]));
+    assert(LatestDecl->getKind() == D->getKind() && "Latest kind mismatch");
+    D->getCommonPtr()->Latest = LatestDecl;
   }
 }
 
index 3ac49584a52c9d63b224235d06315da8320dbc77..75045eb32a8acdc4e56d3254a936b471276348d1 100644 (file)
@@ -852,6 +852,8 @@ void PCHDeclWriter::VisitRedeclarableTemplateDecl(RedeclarableTemplateDecl *D) {
     Writer.AddDeclRef(D->getInstantiatedFromMemberTemplate(), Record);
     if (D->getInstantiatedFromMemberTemplate())
       Record.push_back(D->isMemberSpecialization());
+
+    Writer.AddDeclRef(D->getCommonPtr()->Latest, Record);
   }
 }