diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-04-13 21:20:57 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-04-13 21:20:57 +0000 |
commit | 8c70006581a9b9e9485570ca727a6c5f7be63521 (patch) | |
tree | f8f45010e3c0b032611c2c6a8aa5c4b0d66551bc /lib/Frontend | |
parent | b11fa0d25d86169f0e0a29d5398116c0212bb787 (diff) |
PCH support for record decls/types and their fields. Now that we can
handle the definition of __builtin_va_list on x86-64, eliminate the
forced -triple in PCH tests to get better coverage.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@68988 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Frontend')
-rw-r--r-- | lib/Frontend/PCHReader.cpp | 41 | ||||
-rw-r--r-- | lib/Frontend/PCHWriter.cpp | 19 |
2 files changed, 54 insertions, 6 deletions
diff --git a/lib/Frontend/PCHReader.cpp b/lib/Frontend/PCHReader.cpp index f735dd97ac..adb4e5f6d7 100644 --- a/lib/Frontend/PCHReader.cpp +++ b/lib/Frontend/PCHReader.cpp @@ -50,8 +50,10 @@ namespace { void VisitTypedefDecl(TypedefDecl *TD); void VisitTagDecl(TagDecl *TD); void VisitEnumDecl(EnumDecl *ED); + void VisitRecordDecl(RecordDecl *RD); void VisitValueDecl(ValueDecl *VD); void VisitEnumConstantDecl(EnumConstantDecl *ECD); + void VisitFieldDecl(FieldDecl *FD); void VisitVarDecl(VarDecl *VD); std::pair<uint64_t, uint64_t> VisitDeclContext(DeclContext *DC); @@ -106,6 +108,12 @@ void PCHDeclReader::VisitEnumDecl(EnumDecl *ED) { ED->setIntegerType(Reader.GetType(Record[Idx++])); } +void PCHDeclReader::VisitRecordDecl(RecordDecl *RD) { + VisitTagDecl(RD); + RD->setHasFlexibleArrayMember(Record[Idx++]); + RD->setAnonymousStructOrUnion(Record[Idx++]); +} + void PCHDeclReader::VisitValueDecl(ValueDecl *VD) { VisitNamedDecl(VD); VD->setType(Reader.GetType(Record[Idx++])); @@ -113,10 +121,16 @@ void PCHDeclReader::VisitValueDecl(ValueDecl *VD) { void PCHDeclReader::VisitEnumConstantDecl(EnumConstantDecl *ECD) { VisitValueDecl(ECD); - // FIXME: initialization expression + // FIXME: read the initialization expression ECD->setInitVal(Reader.ReadAPSInt(Record, Idx)); } +void PCHDeclReader::VisitFieldDecl(FieldDecl *FD) { + VisitValueDecl(FD); + FD->setMutable(Record[Idx++]); + // FIXME: Read the bit width. +} + void PCHDeclReader::VisitVarDecl(VarDecl *VD) { VisitValueDecl(VD); VD->setStorageClass((VarDecl::StorageClass)Record[Idx++]); @@ -911,9 +925,8 @@ QualType PCHReader::ReadTypeRecord(uint64_t Offset) { } case pch::TYPE_RECORD: - // FIXME: Deserialize RecordType - assert(false && "Cannot de-serialize record types yet"); - return QualType(); + assert(Record.size() == 1 && "Incorrect encoding of record type"); + return Context.getTypeDeclType(cast<RecordDecl>(GetDecl(Record[0]))); case pch::TYPE_ENUM: assert(Record.size() == 1 && "Incorrect encoding of enum type"); @@ -989,6 +1002,15 @@ Decl *PCHReader::ReadDeclRecord(uint64_t Offset, unsigned Index) { break; } + case pch::DECL_RECORD: { + RecordDecl *Record = RecordDecl::Create(Context, TagDecl::TK_struct, + 0, SourceLocation(), 0, 0); + LoadedDecl(Index, Record); + Reader.VisitRecordDecl(Record); + D = Record; + break; + } + case pch::DECL_ENUM_CONSTANT: { EnumConstantDecl *ECD = EnumConstantDecl::Create(Context, 0, SourceLocation(), 0, @@ -1000,6 +1022,15 @@ Decl *PCHReader::ReadDeclRecord(uint64_t Offset, unsigned Index) { break; } + case pch::DECL_FIELD: { + FieldDecl *Field = FieldDecl::Create(Context, 0, SourceLocation(), 0, + QualType(), 0, false); + LoadedDecl(Index, Field); + Reader.VisitFieldDecl(Field); + D = Field; + break; + } + case pch::DECL_VAR: { VarDecl *Var = VarDecl::Create(Context, 0, SourceLocation(), 0, QualType(), VarDecl::None, SourceLocation()); @@ -1132,12 +1163,10 @@ bool PCHReader::ReadDeclsVisibleInContext(DeclContext *DC, Decls.clear(); unsigned Idx = 0; - // llvm::SmallVector<uintptr_t, 16> DeclIDs; while (Idx < Record.size()) { Decls.push_back(VisibleDeclaration()); Decls.back().Name = ReadDeclarationName(Record, Idx); - // FIXME: Don't actually read anything here! unsigned Size = Record[Idx++]; llvm::SmallVector<unsigned, 4> & LoadedDecls = Decls.back().Declarations; diff --git a/lib/Frontend/PCHWriter.cpp b/lib/Frontend/PCHWriter.cpp index 2ba8e9eeb6..6758a50699 100644 --- a/lib/Frontend/PCHWriter.cpp +++ b/lib/Frontend/PCHWriter.cpp @@ -254,8 +254,10 @@ namespace { void VisitTypedefDecl(TypedefDecl *D); void VisitTagDecl(TagDecl *D); void VisitEnumDecl(EnumDecl *D); + void VisitRecordDecl(RecordDecl *D); void VisitValueDecl(ValueDecl *D); void VisitEnumConstantDecl(EnumConstantDecl *D); + void VisitFieldDecl(FieldDecl *D); void VisitVarDecl(VarDecl *D); void VisitDeclContext(DeclContext *DC, uint64_t LexicalOffset, uint64_t VisibleOffset); @@ -306,6 +308,13 @@ void PCHDeclWriter::VisitEnumDecl(EnumDecl *D) { Code = pch::DECL_ENUM; } +void PCHDeclWriter::VisitRecordDecl(RecordDecl *D) { + VisitTagDecl(D); + Record.push_back(D->hasFlexibleArrayMember()); + Record.push_back(D->isAnonymousStructOrUnion()); + Code = pch::DECL_RECORD; +} + void PCHDeclWriter::VisitValueDecl(ValueDecl *D) { VisitNamedDecl(D); Writer.AddTypeRef(D->getType(), Record); @@ -318,6 +327,13 @@ void PCHDeclWriter::VisitEnumConstantDecl(EnumConstantDecl *D) { Code = pch::DECL_ENUM_CONSTANT; } +void PCHDeclWriter::VisitFieldDecl(FieldDecl *D) { + VisitValueDecl(D); + Record.push_back(D->isMutable()); + // FIXME: Writer.AddExprRef(D->getBitWidth()); + Code = pch::DECL_FIELD; +} + void PCHDeclWriter::VisitVarDecl(VarDecl *D) { VisitValueDecl(D); Record.push_back(D->getStorageClass()); @@ -798,6 +814,9 @@ uint64_t PCHWriter::WriteDeclContextVisibleBlock(ASTContext &Context, uint64_t Offset = S.GetCurrentBitNo(); RecordData Record; StoredDeclsMap *Map = static_cast<StoredDeclsMap*>(DC->getLookupPtr()); + if (!Map) + return 0; + for (StoredDeclsMap::iterator D = Map->begin(), DEnd = Map->end(); D != DEnd; ++D) { AddDeclarationName(D->first, Record); |