From: Daniel Dunbar Date: Wed, 29 Feb 2012 02:39:13 +0000 (+0000) Subject: ASTWriter: Cache some DenseMaps we use repeatedly. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c52d9057241b7857c8400ab6cfee0a1c554e0982;p=clang ASTWriter: Cache some DenseMaps we use repeatedly. - This reduces our total # of allocations building a PCH for Cocoa.h by almost a whopping 50%. - A SmallPtrMap would be cleaner, but since we don't have one yet... git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151697 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Serialization/ASTWriter.h b/include/clang/Serialization/ASTWriter.h index f6a2c4817a..a0ea220b2d 100644 --- a/include/clang/Serialization/ASTWriter.h +++ b/include/clang/Serialization/ASTWriter.h @@ -207,6 +207,18 @@ private: /// IdentifierInfo. llvm::DenseMap IdentifierIDs; + /// @name FlushStmt Caches + /// @{ + + /// \brief Set of parent Stmts for the currently serializing sub stmt. + llvm::DenseSet ParentStmts; + + /// \brief Offsets of sub stmts already serialized. The offset points + /// just after the stmt record. + llvm::DenseMap SubStmtEntries; + + /// @} + /// \brief Offsets of each of the identifier IDs into the identifier /// table. std::vector IdentifierOffsets; diff --git a/lib/Serialization/ASTWriterStmt.cpp b/lib/Serialization/ASTWriterStmt.cpp index 4f766d9b92..22fdfe162a 100644 --- a/lib/Serialization/ASTWriterStmt.cpp +++ b/lib/Serialization/ASTWriterStmt.cpp @@ -1586,11 +1586,10 @@ void ASTWriter::WriteSubStmt(Stmt *S, void ASTWriter::FlushStmts() { RecordData Record; - /// \brief Set of parent Stmts for the currently serializing sub stmt. - llvm::DenseSet ParentStmts; - /// \brief Offsets of sub stmts already serialized. The offset points - /// just after the stmt record. - llvm::DenseMap SubStmtEntries; + // We expect to be the only consumer of the two temporary statement maps, + // assert that they are empty. + assert(SubStmtEntries.empty() && "unexpected entries in sub stmt map"); + assert(ParentStmts.empty() && "unexpected entries in parent stmt map"); for (unsigned I = 0, N = StmtsToEmit.size(); I != N; ++I) { WriteSubStmt(StmtsToEmit[I], SubStmtEntries, ParentStmts);