summaryrefslogtreecommitdiffstats
path: root/clang/lib/Frontend/PCHReader.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2009-04-22 22:02:47 +0000
committerDouglas Gregor <dgregor@apple.com>2009-04-22 22:02:47 +0000
commitd4df8657b4fda675907987aa1742b6244f625de2 (patch)
tree93687d86225e3a9074f39298b6f47cd066e4fde7 /clang/lib/Frontend/PCHReader.cpp
parent48db39dc90c9cc6fbef608b6601d31b36e6c2f40 (diff)
downloadbcm5719-llvm-d4df8657b4fda675907987aa1742b6244f625de2.tar.gz
bcm5719-llvm-d4df8657b4fda675907987aa1742b6244f625de2.zip
Support tentative definitions in precompiled headers. This isn't likely
to happen (ever), but at least we'll do the right thing when it does. llvm-svn: 69829
Diffstat (limited to 'clang/lib/Frontend/PCHReader.cpp')
-rw-r--r--clang/lib/Frontend/PCHReader.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/clang/lib/Frontend/PCHReader.cpp b/clang/lib/Frontend/PCHReader.cpp
index 6de13045bb4..28cca4d0ff2 100644
--- a/clang/lib/Frontend/PCHReader.cpp
+++ b/clang/lib/Frontend/PCHReader.cpp
@@ -1713,6 +1713,13 @@ PCHReader::ReadPCHBlock(uint64_t &PreprocessorBlockOffset) {
TotalNumMacros = Record[1];
break;
+ case pch::TENTATIVE_DEFINITIONS:
+ if (!TentativeDefinitions.empty()) {
+ Error("Duplicate TENTATIVE_DEFINITIONS record in PCH file");
+ return Failure;
+ }
+ TentativeDefinitions.swap(Record);
+ break;
}
}
@@ -2523,6 +2530,13 @@ void PCHReader::InitializeSema(Sema &S) {
SemaObj->IdResolver.AddDecl(PreloadedDecls[I]);
}
PreloadedDecls.clear();
+
+ // If there were any tentative definitions, deserialize them and add
+ // them to Sema's table of tentative definitions.
+ for (unsigned I = 0, N = TentativeDefinitions.size(); I != N; ++I) {
+ VarDecl *Var = cast<VarDecl>(GetDecl(TentativeDefinitions[I]));
+ SemaObj->TentativeDefinitions[Var->getDeclName()] = Var;
+ }
}
IdentifierInfo* PCHReader::get(const char *NameStart, const char *NameEnd) {
OpenPOWER on IntegriCloud