aboutsummaryrefslogtreecommitdiff
path: root/Basic/IdentifierTable.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2007-11-10 02:11:55 +0000
committerTed Kremenek <kremenek@apple.com>2007-11-10 02:11:55 +0000
commiteae5cd010e41c90da72a2f9d49cff579e6adba35 (patch)
tree0841ad86cd174949e05c359db3cfb8990668c7e3 /Basic/IdentifierTable.cpp
parent7a1f4dbb9c57b0109082660213f52238a65d68db (diff)
Changed the serialization of IdentifierTable to only serialize out entries
that are referenced in the ASTs. This assumes that we serialize out the decls/stmts first, and use the pointer-tracking logic in the Serializer to determine if an IdentifierInfo (or its string key) is ever referenced. This is a significant space optimization for serialized ASTs. Consider the following program: void foo(int x,int y) { return x > y ? x : y+1; } Here are the sizes of the files for the serialized ASTs: Full IdentifierTable: 23676 bytes Only-referenced Identifiers: 304 bytes. For this simple program, this is a 77% reduction in the file size of the serialized ASTs. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43975 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'Basic/IdentifierTable.cpp')
-rw-r--r--Basic/IdentifierTable.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/Basic/IdentifierTable.cpp b/Basic/IdentifierTable.cpp
index 48fb086852..f7f008220f 100644
--- a/Basic/IdentifierTable.cpp
+++ b/Basic/IdentifierTable.cpp
@@ -415,8 +415,8 @@ void IdentifierTable::Emit(llvm::Serializer& S) const {
const char* Key = I->getKeyData();
const IdentifierInfo* Info = &I->getValue();
- bool KeyRegistered = true; // FIXME: S.isRegistered(Key);
- bool InfoRegistered = true; // FIXME: S.isRegistered(Info);
+ bool KeyRegistered = S.isRegistered(Key);
+ bool InfoRegistered = S.isRegistered(Info);
if (KeyRegistered || InfoRegistered) {
// These acrobatics are so that we don't incur the cost of registering