diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-04-22 22:02:47 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-04-22 22:02:47 +0000 |
commit | d4df8657b4fda675907987aa1742b6244f625de2 (patch) | |
tree | 93687d86225e3a9074f39298b6f47cd066e4fde7 /clang/lib/Frontend/PCHReader.cpp | |
parent | 48db39dc90c9cc6fbef608b6601d31b36e6c2f40 (diff) | |
download | bcm5719-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.cpp | 14 |
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) { |