From: Argyrios Kyrtzidis Date: Fri, 2 Jul 2010 11:55:37 +0000 (+0000) Subject: Fix reading ClassTemplateDecl's ClassTemplateSpecializationDecls and ClassTemplatePar... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7d530487714b300be95fd71de68a3287078a814f;p=clang 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 --- 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(Reader.GetDecl(Record[Idx++])); + llvm::SmallVector 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( Reader.GetDecl(Record[Idx++])); + llvm::SmallVector 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 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 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.