Author: rsmith Date: Thu Mar 24 20:17:43 2016 New Revision: 264377 URL: http://llvm.org/viewvc/llvm-project?rev=264377&view=rev Log: [modules] Store a local offset to DeclContext lexical and visible contents. Saves a few bytes for each primary DeclContext.
Modified: cfe/trunk/lib/Serialization/ASTReaderDecl.cpp cfe/trunk/lib/Serialization/ASTWriterDecl.cpp Modified: cfe/trunk/lib/Serialization/ASTReaderDecl.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Serialization/ASTReaderDecl.cpp?rev=264377&r1=264376&r2=264377&view=diff ============================================================================== --- cfe/trunk/lib/Serialization/ASTReaderDecl.cpp (original) +++ cfe/trunk/lib/Serialization/ASTReaderDecl.cpp Thu Mar 24 20:17:43 2016 @@ -53,6 +53,12 @@ namespace clang { uint64_t GetCurrentCursorOffset(); + uint64_t ReadLocalOffset(const RecordData &R, unsigned &I) { + uint64_t LocalOffset = R[I++]; + assert(LocalOffset < Offset && "offset point after current record"); + return LocalOffset ? Offset - LocalOffset : 0; + } + SourceLocation ReadSourceLocation(const RecordData &R, unsigned &I) { return Reader.ReadSourceLocation(F, R, I); } @@ -2189,8 +2195,8 @@ void ASTDeclReader::VisitEmptyDecl(Empty std::pair<uint64_t, uint64_t> ASTDeclReader::VisitDeclContext(DeclContext *DC) { - uint64_t LexicalOffset = Record[Idx++]; - uint64_t VisibleOffset = Record[Idx++]; + uint64_t LexicalOffset = ReadLocalOffset(Record, Idx); + uint64_t VisibleOffset = ReadLocalOffset(Record, Idx); return std::make_pair(LexicalOffset, VisibleOffset); } @@ -2225,10 +2231,7 @@ ASTDeclReader::VisitRedeclarable(Redecla for (unsigned I = 0; I != N - 1; ++I) MergeWith = ReadDecl(Record, Idx/*, MergeWith*/); - RedeclOffset = Record[Idx++]; - // RedeclOffset is a delta relative to the start of this record. - if (RedeclOffset) - RedeclOffset = Offset - RedeclOffset; + RedeclOffset = ReadLocalOffset(Record, Idx); } else { // This declaration was not the first local declaration. Read the first // local declaration now, to trigger the import of other redeclarations. Modified: cfe/trunk/lib/Serialization/ASTWriterDecl.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Serialization/ASTWriterDecl.cpp?rev=264377&r1=264376&r2=264377&view=diff ============================================================================== --- cfe/trunk/lib/Serialization/ASTWriterDecl.cpp (original) +++ cfe/trunk/lib/Serialization/ASTWriterDecl.cpp Thu Mar 24 20:17:43 2016 @@ -136,6 +136,12 @@ namespace clang { void VisitOMPDeclareReductionDecl(OMPDeclareReductionDecl *D); void VisitOMPCapturedExprDecl(OMPCapturedExprDecl *D); + void AddLocalOffset(uint64_t LocalOffset) { + uint64_t Offset = Writer.Stream.GetCurrentBitNo(); + assert(LocalOffset < Offset && "invalid offset"); + Record.push_back(LocalOffset ? Offset - LocalOffset : 0); + } + /// Add an Objective-C type parameter list to the given record. void AddObjCTypeParamList(ObjCTypeParamList *typeParams) { // Empty type parameter list. @@ -1555,8 +1561,8 @@ void ASTDeclWriter::VisitStaticAssertDec /// contexts. void ASTDeclWriter::VisitDeclContext(DeclContext *DC, uint64_t LexicalOffset, uint64_t VisibleOffset) { - Record.push_back(LexicalOffset); - Record.push_back(VisibleOffset); + AddLocalOffset(LexicalOffset); + AddLocalOffset(VisibleOffset); } const Decl *ASTWriter::getFirstLocalDecl(const Decl *D) { @@ -1626,7 +1632,7 @@ void ASTDeclWriter::VisitRedeclarable(Re else { auto Start = Writer.Stream.GetCurrentBitNo(); Writer.Stream.EmitRecord(LOCAL_REDECLARATIONS, LocalRedecls); - Record.push_back(Writer.Stream.GetCurrentBitNo() - Start); + AddLocalOffset(Start); } } else { Record.push_back(0); _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits