diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-07-02 11:55:37 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2010-07-02 11:55:37 +0000 |
commit | 7d530487714b300be95fd71de68a3287078a814f (patch) | |
tree | be29e28cb6b566305e4d5e08e71288ce13bb57f0 /lib/Frontend | |
parent | 37ffed3b7f229844cae2463ff82b527506c86c74 (diff) |
Fix reading ClassTemplateDecl's ClassTemplateSpecializationDecls and ClassTemplatePartialSpecializationDecls.
Store/read also their template arguments because they may be initializing and not be able to provide them.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@107476 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Frontend')
-rw-r--r-- | lib/Frontend/PCHReaderDecl.cpp | 16 | ||||
-rw-r--r-- | lib/Frontend/PCHWriterDecl.cpp | 18 |
2 files changed, 23 insertions, 11 deletions
diff --git a/lib/Frontend/PCHReaderDecl.cpp b/lib/Frontend/PCHReaderDecl.cpp index ea99ff249d..c05f864bc1 100644 --- a/lib/Frontend/PCHReaderDecl.cpp +++ b/lib/Frontend/PCHReaderDecl.cpp @@ -768,11 +768,12 @@ void PCHDeclReader::VisitClassTemplateDecl(ClassTemplateDecl *D) { while (size--) { ClassTemplateSpecializationDecl *CTSD = cast<ClassTemplateSpecializationDecl>(Reader.GetDecl(Record[Idx++])); + llvm::SmallVector<TemplateArgument, 8> TemplArgs; + Reader.ReadTemplateArgumentList(TemplArgs, Record, Idx); llvm::FoldingSetNodeID ID; void *InsertPos = 0; - ClassTemplateSpecializationDecl::Profile(ID, - CTSD->getTemplateArgs().getFlatArgumentList(), - CTSD->getTemplateArgs().flat_size(), + ClassTemplateSpecializationDecl::Profile(ID, TemplArgs.data(), + TemplArgs.size(), *Reader.getContext()); D->getSpecializations().FindNodeOrInsertPos(ID, InsertPos); D->getSpecializations().InsertNode(CTSD, InsertPos); @@ -783,12 +784,13 @@ void PCHDeclReader::VisitClassTemplateDecl(ClassTemplateDecl *D) { ClassTemplatePartialSpecializationDecl *CTSD = cast<ClassTemplatePartialSpecializationDecl>( Reader.GetDecl(Record[Idx++])); + llvm::SmallVector<TemplateArgument, 8> TemplArgs; + Reader.ReadTemplateArgumentList(TemplArgs, Record, Idx); llvm::FoldingSetNodeID ID; void *InsertPos = 0; - ClassTemplatePartialSpecializationDecl::Profile(ID, - CTSD->getTemplateArgs().getFlatArgumentList(), - CTSD->getTemplateArgs().flat_size(), - *Reader.getContext()); + ClassTemplatePartialSpecializationDecl::Profile(ID, TemplArgs.data(), + TemplArgs.size(), + *Reader.getContext()); D->getPartialSpecializations().FindNodeOrInsertPos(ID, InsertPos); D->getPartialSpecializations().InsertNode(CTSD, InsertPos); } diff --git a/lib/Frontend/PCHWriterDecl.cpp b/lib/Frontend/PCHWriterDecl.cpp index 86af50b0bc..d43ba7a27f 100644 --- a/lib/Frontend/PCHWriterDecl.cpp +++ b/lib/Frontend/PCHWriterDecl.cpp @@ -751,14 +751,24 @@ void PCHDeclWriter::VisitClassTemplateDecl(ClassTemplateDecl *D) { typedef llvm::FoldingSet<ClassTemplateSpecializationDecl> CTSDSetTy; CTSDSetTy &CTSDSet = D->getSpecializations(); Record.push_back(CTSDSet.size()); - for (CTSDSetTy::iterator I=CTSDSet.begin(), E = CTSDSet.end(); I!=E; ++I) - Writer.AddDeclRef(&*I, Record); + for (CTSDSetTy::iterator I=CTSDSet.begin(), E = CTSDSet.end(); I!=E; ++I) { + ClassTemplateSpecializationDecl *CTSD = &*I; + Writer.AddDeclRef(CTSD, Record); + // Write the argument list here because we may get it uninitialized when + // reading it back. + Writer.AddTemplateArgumentList(&CTSD->getTemplateArgs(), Record); + } typedef llvm::FoldingSet<ClassTemplatePartialSpecializationDecl> CTPSDSetTy; CTPSDSetTy &CTPSDSet = D->getPartialSpecializations(); Record.push_back(CTPSDSet.size()); - for (CTPSDSetTy::iterator I=CTPSDSet.begin(), E = CTPSDSet.end(); I!=E; ++I) - Writer.AddDeclRef(&*I, Record); + for (CTPSDSetTy::iterator I=CTPSDSet.begin(), E=CTPSDSet.end(); I!=E; ++I) { + ClassTemplatePartialSpecializationDecl *CTPSD = &*I; + Writer.AddDeclRef(CTPSD, Record); + // Write the argument list here because we may get it uninitialized when + // reading it back. + Writer.AddTemplateArgumentList(&CTPSD->getTemplateArgs(), Record); + } // InjectedClassNameType is computed, no need to write it. |