• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //===-- ASTReader.cpp - AST File Reader ----------------------------------===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 //  This file defines the ASTReader class, which reads AST files.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #include "clang/Serialization/ASTReader.h"
15 #include "ASTCommon.h"
16 #include "ASTReaderInternals.h"
17 #include "clang/AST/ASTConsumer.h"
18 #include "clang/AST/ASTContext.h"
19 #include "clang/AST/DeclTemplate.h"
20 #include "clang/AST/Expr.h"
21 #include "clang/AST/ExprCXX.h"
22 #include "clang/Frontend/PCHContainerOperations.h"
23 #include "clang/AST/ASTMutationListener.h"
24 #include "clang/AST/NestedNameSpecifier.h"
25 #include "clang/AST/Type.h"
26 #include "clang/AST/TypeLocVisitor.h"
27 #include "clang/Basic/DiagnosticOptions.h"
28 #include "clang/Basic/FileManager.h"
29 #include "clang/Basic/SourceManager.h"
30 #include "clang/Basic/SourceManagerInternals.h"
31 #include "clang/Basic/TargetInfo.h"
32 #include "clang/Basic/TargetOptions.h"
33 #include "clang/Basic/Version.h"
34 #include "clang/Basic/VersionTuple.h"
35 #include "clang/Frontend/Utils.h"
36 #include "clang/Lex/HeaderSearch.h"
37 #include "clang/Lex/HeaderSearchOptions.h"
38 #include "clang/Lex/MacroInfo.h"
39 #include "clang/Lex/PreprocessingRecord.h"
40 #include "clang/Lex/Preprocessor.h"
41 #include "clang/Lex/PreprocessorOptions.h"
42 #include "clang/Sema/Scope.h"
43 #include "clang/Sema/Sema.h"
44 #include "clang/Serialization/ASTDeserializationListener.h"
45 #include "clang/Serialization/GlobalModuleIndex.h"
46 #include "clang/Serialization/ModuleManager.h"
47 #include "clang/Serialization/SerializationDiagnostic.h"
48 #include "llvm/ADT/Hashing.h"
49 #include "llvm/ADT/StringExtras.h"
50 #include "llvm/Bitcode/BitstreamReader.h"
51 #include "llvm/Support/Compression.h"
52 #include "llvm/Support/ErrorHandling.h"
53 #include "llvm/Support/FileSystem.h"
54 #include "llvm/Support/MemoryBuffer.h"
55 #include "llvm/Support/Path.h"
56 #include "llvm/Support/SaveAndRestore.h"
57 #include "llvm/Support/raw_ostream.h"
58 #include <algorithm>
59 #include <cstdio>
60 #include <iterator>
61 #include <system_error>
62 
63 using namespace clang;
64 using namespace clang::serialization;
65 using namespace clang::serialization::reader;
66 using llvm::BitstreamCursor;
67 
68 
69 //===----------------------------------------------------------------------===//
70 // ChainedASTReaderListener implementation
71 //===----------------------------------------------------------------------===//
72 
73 bool
ReadFullVersionInformation(StringRef FullVersion)74 ChainedASTReaderListener::ReadFullVersionInformation(StringRef FullVersion) {
75   return First->ReadFullVersionInformation(FullVersion) ||
76          Second->ReadFullVersionInformation(FullVersion);
77 }
ReadModuleName(StringRef ModuleName)78 void ChainedASTReaderListener::ReadModuleName(StringRef ModuleName) {
79   First->ReadModuleName(ModuleName);
80   Second->ReadModuleName(ModuleName);
81 }
ReadModuleMapFile(StringRef ModuleMapPath)82 void ChainedASTReaderListener::ReadModuleMapFile(StringRef ModuleMapPath) {
83   First->ReadModuleMapFile(ModuleMapPath);
84   Second->ReadModuleMapFile(ModuleMapPath);
85 }
86 bool
ReadLanguageOptions(const LangOptions & LangOpts,bool Complain,bool AllowCompatibleDifferences)87 ChainedASTReaderListener::ReadLanguageOptions(const LangOptions &LangOpts,
88                                               bool Complain,
89                                               bool AllowCompatibleDifferences) {
90   return First->ReadLanguageOptions(LangOpts, Complain,
91                                     AllowCompatibleDifferences) ||
92          Second->ReadLanguageOptions(LangOpts, Complain,
93                                      AllowCompatibleDifferences);
94 }
ReadTargetOptions(const TargetOptions & TargetOpts,bool Complain,bool AllowCompatibleDifferences)95 bool ChainedASTReaderListener::ReadTargetOptions(
96     const TargetOptions &TargetOpts, bool Complain,
97     bool AllowCompatibleDifferences) {
98   return First->ReadTargetOptions(TargetOpts, Complain,
99                                   AllowCompatibleDifferences) ||
100          Second->ReadTargetOptions(TargetOpts, Complain,
101                                    AllowCompatibleDifferences);
102 }
ReadDiagnosticOptions(IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts,bool Complain)103 bool ChainedASTReaderListener::ReadDiagnosticOptions(
104     IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts, bool Complain) {
105   return First->ReadDiagnosticOptions(DiagOpts, Complain) ||
106          Second->ReadDiagnosticOptions(DiagOpts, Complain);
107 }
108 bool
ReadFileSystemOptions(const FileSystemOptions & FSOpts,bool Complain)109 ChainedASTReaderListener::ReadFileSystemOptions(const FileSystemOptions &FSOpts,
110                                                 bool Complain) {
111   return First->ReadFileSystemOptions(FSOpts, Complain) ||
112          Second->ReadFileSystemOptions(FSOpts, Complain);
113 }
114 
ReadHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,bool Complain)115 bool ChainedASTReaderListener::ReadHeaderSearchOptions(
116     const HeaderSearchOptions &HSOpts, StringRef SpecificModuleCachePath,
117     bool Complain) {
118   return First->ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
119                                         Complain) ||
120          Second->ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
121                                          Complain);
122 }
ReadPreprocessorOptions(const PreprocessorOptions & PPOpts,bool Complain,std::string & SuggestedPredefines)123 bool ChainedASTReaderListener::ReadPreprocessorOptions(
124     const PreprocessorOptions &PPOpts, bool Complain,
125     std::string &SuggestedPredefines) {
126   return First->ReadPreprocessorOptions(PPOpts, Complain,
127                                         SuggestedPredefines) ||
128          Second->ReadPreprocessorOptions(PPOpts, Complain, SuggestedPredefines);
129 }
ReadCounter(const serialization::ModuleFile & M,unsigned Value)130 void ChainedASTReaderListener::ReadCounter(const serialization::ModuleFile &M,
131                                            unsigned Value) {
132   First->ReadCounter(M, Value);
133   Second->ReadCounter(M, Value);
134 }
needsInputFileVisitation()135 bool ChainedASTReaderListener::needsInputFileVisitation() {
136   return First->needsInputFileVisitation() ||
137          Second->needsInputFileVisitation();
138 }
needsSystemInputFileVisitation()139 bool ChainedASTReaderListener::needsSystemInputFileVisitation() {
140   return First->needsSystemInputFileVisitation() ||
141   Second->needsSystemInputFileVisitation();
142 }
visitModuleFile(StringRef Filename,ModuleKind Kind)143 void ChainedASTReaderListener::visitModuleFile(StringRef Filename,
144                                                ModuleKind Kind) {
145   First->visitModuleFile(Filename, Kind);
146   Second->visitModuleFile(Filename, Kind);
147 }
visitInputFile(StringRef Filename,bool isSystem,bool isOverridden,bool isExplicitModule)148 bool ChainedASTReaderListener::visitInputFile(StringRef Filename,
149                                               bool isSystem,
150                                               bool isOverridden,
151                                               bool isExplicitModule) {
152   bool Continue = false;
153   if (First->needsInputFileVisitation() &&
154       (!isSystem || First->needsSystemInputFileVisitation()))
155     Continue |= First->visitInputFile(Filename, isSystem, isOverridden,
156                                       isExplicitModule);
157   if (Second->needsInputFileVisitation() &&
158       (!isSystem || Second->needsSystemInputFileVisitation()))
159     Continue |= Second->visitInputFile(Filename, isSystem, isOverridden,
160                                        isExplicitModule);
161   return Continue;
162 }
163 
readModuleFileExtension(const ModuleFileExtensionMetadata & Metadata)164 void ChainedASTReaderListener::readModuleFileExtension(
165        const ModuleFileExtensionMetadata &Metadata) {
166   First->readModuleFileExtension(Metadata);
167   Second->readModuleFileExtension(Metadata);
168 }
169 
170 //===----------------------------------------------------------------------===//
171 // PCH validator implementation
172 //===----------------------------------------------------------------------===//
173 
~ASTReaderListener()174 ASTReaderListener::~ASTReaderListener() {}
175 
176 /// \brief Compare the given set of language options against an existing set of
177 /// language options.
178 ///
179 /// \param Diags If non-NULL, diagnostics will be emitted via this engine.
180 /// \param AllowCompatibleDifferences If true, differences between compatible
181 ///        language options will be permitted.
182 ///
183 /// \returns true if the languagae options mis-match, false otherwise.
checkLanguageOptions(const LangOptions & LangOpts,const LangOptions & ExistingLangOpts,DiagnosticsEngine * Diags,bool AllowCompatibleDifferences=true)184 static bool checkLanguageOptions(const LangOptions &LangOpts,
185                                  const LangOptions &ExistingLangOpts,
186                                  DiagnosticsEngine *Diags,
187                                  bool AllowCompatibleDifferences = true) {
188 #define LANGOPT(Name, Bits, Default, Description)                 \
189   if (ExistingLangOpts.Name != LangOpts.Name) {                   \
190     if (Diags)                                                    \
191       Diags->Report(diag::err_pch_langopt_mismatch)               \
192         << Description << LangOpts.Name << ExistingLangOpts.Name; \
193     return true;                                                  \
194   }
195 
196 #define VALUE_LANGOPT(Name, Bits, Default, Description)   \
197   if (ExistingLangOpts.Name != LangOpts.Name) {           \
198     if (Diags)                                            \
199       Diags->Report(diag::err_pch_langopt_value_mismatch) \
200         << Description;                                   \
201     return true;                                          \
202   }
203 
204 #define ENUM_LANGOPT(Name, Type, Bits, Default, Description)   \
205   if (ExistingLangOpts.get##Name() != LangOpts.get##Name()) {  \
206     if (Diags)                                                 \
207       Diags->Report(diag::err_pch_langopt_value_mismatch)      \
208         << Description;                                        \
209     return true;                                               \
210   }
211 
212 #define COMPATIBLE_LANGOPT(Name, Bits, Default, Description)  \
213   if (!AllowCompatibleDifferences)                            \
214     LANGOPT(Name, Bits, Default, Description)
215 
216 #define COMPATIBLE_ENUM_LANGOPT(Name, Bits, Default, Description)  \
217   if (!AllowCompatibleDifferences)                                 \
218     ENUM_LANGOPT(Name, Bits, Default, Description)
219 
220 #define COMPATIBLE_VALUE_LANGOPT(Name, Bits, Default, Description) \
221   if (!AllowCompatibleDifferences)                                 \
222     VALUE_LANGOPT(Name, Bits, Default, Description)
223 
224 #define BENIGN_LANGOPT(Name, Bits, Default, Description)
225 #define BENIGN_ENUM_LANGOPT(Name, Type, Bits, Default, Description)
226 #define BENIGN_VALUE_LANGOPT(Name, Type, Bits, Default, Description)
227 #include "clang/Basic/LangOptions.def"
228 
229   if (ExistingLangOpts.ModuleFeatures != LangOpts.ModuleFeatures) {
230     if (Diags)
231       Diags->Report(diag::err_pch_langopt_value_mismatch) << "module features";
232     return true;
233   }
234 
235   if (ExistingLangOpts.ObjCRuntime != LangOpts.ObjCRuntime) {
236     if (Diags)
237       Diags->Report(diag::err_pch_langopt_value_mismatch)
238       << "target Objective-C runtime";
239     return true;
240   }
241 
242   if (ExistingLangOpts.CommentOpts.BlockCommandNames !=
243       LangOpts.CommentOpts.BlockCommandNames) {
244     if (Diags)
245       Diags->Report(diag::err_pch_langopt_value_mismatch)
246         << "block command names";
247     return true;
248   }
249 
250   return false;
251 }
252 
253 /// \brief Compare the given set of target options against an existing set of
254 /// target options.
255 ///
256 /// \param Diags If non-NULL, diagnostics will be emitted via this engine.
257 ///
258 /// \returns true if the target options mis-match, false otherwise.
checkTargetOptions(const TargetOptions & TargetOpts,const TargetOptions & ExistingTargetOpts,DiagnosticsEngine * Diags,bool AllowCompatibleDifferences=true)259 static bool checkTargetOptions(const TargetOptions &TargetOpts,
260                                const TargetOptions &ExistingTargetOpts,
261                                DiagnosticsEngine *Diags,
262                                bool AllowCompatibleDifferences = true) {
263 #define CHECK_TARGET_OPT(Field, Name)                             \
264   if (TargetOpts.Field != ExistingTargetOpts.Field) {             \
265     if (Diags)                                                    \
266       Diags->Report(diag::err_pch_targetopt_mismatch)             \
267         << Name << TargetOpts.Field << ExistingTargetOpts.Field;  \
268     return true;                                                  \
269   }
270 
271   // The triple and ABI must match exactly.
272   CHECK_TARGET_OPT(Triple, "target");
273   CHECK_TARGET_OPT(ABI, "target ABI");
274 
275   // We can tolerate different CPUs in many cases, notably when one CPU
276   // supports a strict superset of another. When allowing compatible
277   // differences skip this check.
278   if (!AllowCompatibleDifferences)
279     CHECK_TARGET_OPT(CPU, "target CPU");
280 
281 #undef CHECK_TARGET_OPT
282 
283   // Compare feature sets.
284   SmallVector<StringRef, 4> ExistingFeatures(
285                                              ExistingTargetOpts.FeaturesAsWritten.begin(),
286                                              ExistingTargetOpts.FeaturesAsWritten.end());
287   SmallVector<StringRef, 4> ReadFeatures(TargetOpts.FeaturesAsWritten.begin(),
288                                          TargetOpts.FeaturesAsWritten.end());
289   std::sort(ExistingFeatures.begin(), ExistingFeatures.end());
290   std::sort(ReadFeatures.begin(), ReadFeatures.end());
291 
292   // We compute the set difference in both directions explicitly so that we can
293   // diagnose the differences differently.
294   SmallVector<StringRef, 4> UnmatchedExistingFeatures, UnmatchedReadFeatures;
295   std::set_difference(
296       ExistingFeatures.begin(), ExistingFeatures.end(), ReadFeatures.begin(),
297       ReadFeatures.end(), std::back_inserter(UnmatchedExistingFeatures));
298   std::set_difference(ReadFeatures.begin(), ReadFeatures.end(),
299                       ExistingFeatures.begin(), ExistingFeatures.end(),
300                       std::back_inserter(UnmatchedReadFeatures));
301 
302   // If we are allowing compatible differences and the read feature set is
303   // a strict subset of the existing feature set, there is nothing to diagnose.
304   if (AllowCompatibleDifferences && UnmatchedReadFeatures.empty())
305     return false;
306 
307   if (Diags) {
308     for (StringRef Feature : UnmatchedReadFeatures)
309       Diags->Report(diag::err_pch_targetopt_feature_mismatch)
310           << /* is-existing-feature */ false << Feature;
311     for (StringRef Feature : UnmatchedExistingFeatures)
312       Diags->Report(diag::err_pch_targetopt_feature_mismatch)
313           << /* is-existing-feature */ true << Feature;
314   }
315 
316   return !UnmatchedReadFeatures.empty() || !UnmatchedExistingFeatures.empty();
317 }
318 
319 bool
ReadLanguageOptions(const LangOptions & LangOpts,bool Complain,bool AllowCompatibleDifferences)320 PCHValidator::ReadLanguageOptions(const LangOptions &LangOpts,
321                                   bool Complain,
322                                   bool AllowCompatibleDifferences) {
323   const LangOptions &ExistingLangOpts = PP.getLangOpts();
324   return checkLanguageOptions(LangOpts, ExistingLangOpts,
325                               Complain ? &Reader.Diags : nullptr,
326                               AllowCompatibleDifferences);
327 }
328 
ReadTargetOptions(const TargetOptions & TargetOpts,bool Complain,bool AllowCompatibleDifferences)329 bool PCHValidator::ReadTargetOptions(const TargetOptions &TargetOpts,
330                                      bool Complain,
331                                      bool AllowCompatibleDifferences) {
332   const TargetOptions &ExistingTargetOpts = PP.getTargetInfo().getTargetOpts();
333   return checkTargetOptions(TargetOpts, ExistingTargetOpts,
334                             Complain ? &Reader.Diags : nullptr,
335                             AllowCompatibleDifferences);
336 }
337 
338 namespace {
339   typedef llvm::StringMap<std::pair<StringRef, bool /*IsUndef*/> >
340     MacroDefinitionsMap;
341   typedef llvm::DenseMap<DeclarationName, SmallVector<NamedDecl *, 8> >
342     DeclsMap;
343 }
344 
checkDiagnosticGroupMappings(DiagnosticsEngine & StoredDiags,DiagnosticsEngine & Diags,bool Complain)345 static bool checkDiagnosticGroupMappings(DiagnosticsEngine &StoredDiags,
346                                          DiagnosticsEngine &Diags,
347                                          bool Complain) {
348   typedef DiagnosticsEngine::Level Level;
349 
350   // Check current mappings for new -Werror mappings, and the stored mappings
351   // for cases that were explicitly mapped to *not* be errors that are now
352   // errors because of options like -Werror.
353   DiagnosticsEngine *MappingSources[] = { &Diags, &StoredDiags };
354 
355   for (DiagnosticsEngine *MappingSource : MappingSources) {
356     for (auto DiagIDMappingPair : MappingSource->getDiagnosticMappings()) {
357       diag::kind DiagID = DiagIDMappingPair.first;
358       Level CurLevel = Diags.getDiagnosticLevel(DiagID, SourceLocation());
359       if (CurLevel < DiagnosticsEngine::Error)
360         continue; // not significant
361       Level StoredLevel =
362           StoredDiags.getDiagnosticLevel(DiagID, SourceLocation());
363       if (StoredLevel < DiagnosticsEngine::Error) {
364         if (Complain)
365           Diags.Report(diag::err_pch_diagopt_mismatch) << "-Werror=" +
366               Diags.getDiagnosticIDs()->getWarningOptionForDiag(DiagID).str();
367         return true;
368       }
369     }
370   }
371 
372   return false;
373 }
374 
isExtHandlingFromDiagsError(DiagnosticsEngine & Diags)375 static bool isExtHandlingFromDiagsError(DiagnosticsEngine &Diags) {
376   diag::Severity Ext = Diags.getExtensionHandlingBehavior();
377   if (Ext == diag::Severity::Warning && Diags.getWarningsAsErrors())
378     return true;
379   return Ext >= diag::Severity::Error;
380 }
381 
checkDiagnosticMappings(DiagnosticsEngine & StoredDiags,DiagnosticsEngine & Diags,bool IsSystem,bool Complain)382 static bool checkDiagnosticMappings(DiagnosticsEngine &StoredDiags,
383                                     DiagnosticsEngine &Diags,
384                                     bool IsSystem, bool Complain) {
385   // Top-level options
386   if (IsSystem) {
387     if (Diags.getSuppressSystemWarnings())
388       return false;
389     // If -Wsystem-headers was not enabled before, be conservative
390     if (StoredDiags.getSuppressSystemWarnings()) {
391       if (Complain)
392         Diags.Report(diag::err_pch_diagopt_mismatch) << "-Wsystem-headers";
393       return true;
394     }
395   }
396 
397   if (Diags.getWarningsAsErrors() && !StoredDiags.getWarningsAsErrors()) {
398     if (Complain)
399       Diags.Report(diag::err_pch_diagopt_mismatch) << "-Werror";
400     return true;
401   }
402 
403   if (Diags.getWarningsAsErrors() && Diags.getEnableAllWarnings() &&
404       !StoredDiags.getEnableAllWarnings()) {
405     if (Complain)
406       Diags.Report(diag::err_pch_diagopt_mismatch) << "-Weverything -Werror";
407     return true;
408   }
409 
410   if (isExtHandlingFromDiagsError(Diags) &&
411       !isExtHandlingFromDiagsError(StoredDiags)) {
412     if (Complain)
413       Diags.Report(diag::err_pch_diagopt_mismatch) << "-pedantic-errors";
414     return true;
415   }
416 
417   return checkDiagnosticGroupMappings(StoredDiags, Diags, Complain);
418 }
419 
ReadDiagnosticOptions(IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts,bool Complain)420 bool PCHValidator::ReadDiagnosticOptions(
421     IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts, bool Complain) {
422   DiagnosticsEngine &ExistingDiags = PP.getDiagnostics();
423   IntrusiveRefCntPtr<DiagnosticIDs> DiagIDs(ExistingDiags.getDiagnosticIDs());
424   IntrusiveRefCntPtr<DiagnosticsEngine> Diags(
425       new DiagnosticsEngine(DiagIDs, DiagOpts.get()));
426   // This should never fail, because we would have processed these options
427   // before writing them to an ASTFile.
428   ProcessWarningOptions(*Diags, *DiagOpts, /*Report*/false);
429 
430   ModuleManager &ModuleMgr = Reader.getModuleManager();
431   assert(ModuleMgr.size() >= 1 && "what ASTFile is this then");
432 
433   // If the original import came from a file explicitly generated by the user,
434   // don't check the diagnostic mappings.
435   // FIXME: currently this is approximated by checking whether this is not a
436   // module import of an implicitly-loaded module file.
437   // Note: ModuleMgr.rbegin() may not be the current module, but it must be in
438   // the transitive closure of its imports, since unrelated modules cannot be
439   // imported until after this module finishes validation.
440   ModuleFile *TopImport = *ModuleMgr.rbegin();
441   while (!TopImport->ImportedBy.empty())
442     TopImport = TopImport->ImportedBy[0];
443   if (TopImport->Kind != MK_ImplicitModule)
444     return false;
445 
446   StringRef ModuleName = TopImport->ModuleName;
447   assert(!ModuleName.empty() && "diagnostic options read before module name");
448 
449   Module *M = PP.getHeaderSearchInfo().lookupModule(ModuleName);
450   assert(M && "missing module");
451 
452   // FIXME: if the diagnostics are incompatible, save a DiagnosticOptions that
453   // contains the union of their flags.
454   return checkDiagnosticMappings(*Diags, ExistingDiags, M->IsSystem, Complain);
455 }
456 
457 /// \brief Collect the macro definitions provided by the given preprocessor
458 /// options.
459 static void
collectMacroDefinitions(const PreprocessorOptions & PPOpts,MacroDefinitionsMap & Macros,SmallVectorImpl<StringRef> * MacroNames=nullptr)460 collectMacroDefinitions(const PreprocessorOptions &PPOpts,
461                         MacroDefinitionsMap &Macros,
462                         SmallVectorImpl<StringRef> *MacroNames = nullptr) {
463   for (unsigned I = 0, N = PPOpts.Macros.size(); I != N; ++I) {
464     StringRef Macro = PPOpts.Macros[I].first;
465     bool IsUndef = PPOpts.Macros[I].second;
466 
467     std::pair<StringRef, StringRef> MacroPair = Macro.split('=');
468     StringRef MacroName = MacroPair.first;
469     StringRef MacroBody = MacroPair.second;
470 
471     // For an #undef'd macro, we only care about the name.
472     if (IsUndef) {
473       if (MacroNames && !Macros.count(MacroName))
474         MacroNames->push_back(MacroName);
475 
476       Macros[MacroName] = std::make_pair("", true);
477       continue;
478     }
479 
480     // For a #define'd macro, figure out the actual definition.
481     if (MacroName.size() == Macro.size())
482       MacroBody = "1";
483     else {
484       // Note: GCC drops anything following an end-of-line character.
485       StringRef::size_type End = MacroBody.find_first_of("\n\r");
486       MacroBody = MacroBody.substr(0, End);
487     }
488 
489     if (MacroNames && !Macros.count(MacroName))
490       MacroNames->push_back(MacroName);
491     Macros[MacroName] = std::make_pair(MacroBody, false);
492   }
493 }
494 
495 /// \brief Check the preprocessor options deserialized from the control block
496 /// against the preprocessor options in an existing preprocessor.
497 ///
498 /// \param Diags If non-null, produce diagnostics for any mismatches incurred.
checkPreprocessorOptions(const PreprocessorOptions & PPOpts,const PreprocessorOptions & ExistingPPOpts,DiagnosticsEngine * Diags,FileManager & FileMgr,std::string & SuggestedPredefines,const LangOptions & LangOpts)499 static bool checkPreprocessorOptions(const PreprocessorOptions &PPOpts,
500                                      const PreprocessorOptions &ExistingPPOpts,
501                                      DiagnosticsEngine *Diags,
502                                      FileManager &FileMgr,
503                                      std::string &SuggestedPredefines,
504                                      const LangOptions &LangOpts) {
505   // Check macro definitions.
506   MacroDefinitionsMap ASTFileMacros;
507   collectMacroDefinitions(PPOpts, ASTFileMacros);
508   MacroDefinitionsMap ExistingMacros;
509   SmallVector<StringRef, 4> ExistingMacroNames;
510   collectMacroDefinitions(ExistingPPOpts, ExistingMacros, &ExistingMacroNames);
511 
512   for (unsigned I = 0, N = ExistingMacroNames.size(); I != N; ++I) {
513     // Dig out the macro definition in the existing preprocessor options.
514     StringRef MacroName = ExistingMacroNames[I];
515     std::pair<StringRef, bool> Existing = ExistingMacros[MacroName];
516 
517     // Check whether we know anything about this macro name or not.
518     llvm::StringMap<std::pair<StringRef, bool /*IsUndef*/> >::iterator Known
519       = ASTFileMacros.find(MacroName);
520     if (Known == ASTFileMacros.end()) {
521       // FIXME: Check whether this identifier was referenced anywhere in the
522       // AST file. If so, we should reject the AST file. Unfortunately, this
523       // information isn't in the control block. What shall we do about it?
524 
525       if (Existing.second) {
526         SuggestedPredefines += "#undef ";
527         SuggestedPredefines += MacroName.str();
528         SuggestedPredefines += '\n';
529       } else {
530         SuggestedPredefines += "#define ";
531         SuggestedPredefines += MacroName.str();
532         SuggestedPredefines += ' ';
533         SuggestedPredefines += Existing.first.str();
534         SuggestedPredefines += '\n';
535       }
536       continue;
537     }
538 
539     // If the macro was defined in one but undef'd in the other, we have a
540     // conflict.
541     if (Existing.second != Known->second.second) {
542       if (Diags) {
543         Diags->Report(diag::err_pch_macro_def_undef)
544           << MacroName << Known->second.second;
545       }
546       return true;
547     }
548 
549     // If the macro was #undef'd in both, or if the macro bodies are identical,
550     // it's fine.
551     if (Existing.second || Existing.first == Known->second.first)
552       continue;
553 
554     // The macro bodies differ; complain.
555     if (Diags) {
556       Diags->Report(diag::err_pch_macro_def_conflict)
557         << MacroName << Known->second.first << Existing.first;
558     }
559     return true;
560   }
561 
562   // Check whether we're using predefines.
563   if (PPOpts.UsePredefines != ExistingPPOpts.UsePredefines) {
564     if (Diags) {
565       Diags->Report(diag::err_pch_undef) << ExistingPPOpts.UsePredefines;
566     }
567     return true;
568   }
569 
570   // Detailed record is important since it is used for the module cache hash.
571   if (LangOpts.Modules &&
572       PPOpts.DetailedRecord != ExistingPPOpts.DetailedRecord) {
573     if (Diags) {
574       Diags->Report(diag::err_pch_pp_detailed_record) << PPOpts.DetailedRecord;
575     }
576     return true;
577   }
578 
579   // Compute the #include and #include_macros lines we need.
580   for (unsigned I = 0, N = ExistingPPOpts.Includes.size(); I != N; ++I) {
581     StringRef File = ExistingPPOpts.Includes[I];
582     if (File == ExistingPPOpts.ImplicitPCHInclude)
583       continue;
584 
585     if (std::find(PPOpts.Includes.begin(), PPOpts.Includes.end(), File)
586           != PPOpts.Includes.end())
587       continue;
588 
589     SuggestedPredefines += "#include \"";
590     SuggestedPredefines += File;
591     SuggestedPredefines += "\"\n";
592   }
593 
594   for (unsigned I = 0, N = ExistingPPOpts.MacroIncludes.size(); I != N; ++I) {
595     StringRef File = ExistingPPOpts.MacroIncludes[I];
596     if (std::find(PPOpts.MacroIncludes.begin(), PPOpts.MacroIncludes.end(),
597                   File)
598         != PPOpts.MacroIncludes.end())
599       continue;
600 
601     SuggestedPredefines += "#__include_macros \"";
602     SuggestedPredefines += File;
603     SuggestedPredefines += "\"\n##\n";
604   }
605 
606   return false;
607 }
608 
ReadPreprocessorOptions(const PreprocessorOptions & PPOpts,bool Complain,std::string & SuggestedPredefines)609 bool PCHValidator::ReadPreprocessorOptions(const PreprocessorOptions &PPOpts,
610                                            bool Complain,
611                                            std::string &SuggestedPredefines) {
612   const PreprocessorOptions &ExistingPPOpts = PP.getPreprocessorOpts();
613 
614   return checkPreprocessorOptions(PPOpts, ExistingPPOpts,
615                                   Complain? &Reader.Diags : nullptr,
616                                   PP.getFileManager(),
617                                   SuggestedPredefines,
618                                   PP.getLangOpts());
619 }
620 
621 /// Check the header search options deserialized from the control block
622 /// against the header search options in an existing preprocessor.
623 ///
624 /// \param Diags If non-null, produce diagnostics for any mismatches incurred.
checkHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,StringRef ExistingModuleCachePath,DiagnosticsEngine * Diags,const LangOptions & LangOpts)625 static bool checkHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
626                                      StringRef SpecificModuleCachePath,
627                                      StringRef ExistingModuleCachePath,
628                                      DiagnosticsEngine *Diags,
629                                      const LangOptions &LangOpts) {
630   if (LangOpts.Modules) {
631     if (SpecificModuleCachePath != ExistingModuleCachePath) {
632       if (Diags)
633         Diags->Report(diag::err_pch_modulecache_mismatch)
634           << SpecificModuleCachePath << ExistingModuleCachePath;
635       return true;
636     }
637   }
638 
639   return false;
640 }
641 
ReadHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,bool Complain)642 bool PCHValidator::ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
643                                            StringRef SpecificModuleCachePath,
644                                            bool Complain) {
645   return checkHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
646                                   PP.getHeaderSearchInfo().getModuleCachePath(),
647                                   Complain ? &Reader.Diags : nullptr,
648                                   PP.getLangOpts());
649 }
650 
ReadCounter(const ModuleFile & M,unsigned Value)651 void PCHValidator::ReadCounter(const ModuleFile &M, unsigned Value) {
652   PP.setCounterValue(Value);
653 }
654 
655 //===----------------------------------------------------------------------===//
656 // AST reader implementation
657 //===----------------------------------------------------------------------===//
658 
setDeserializationListener(ASTDeserializationListener * Listener,bool TakeOwnership)659 void ASTReader::setDeserializationListener(ASTDeserializationListener *Listener,
660                                            bool TakeOwnership) {
661   DeserializationListener = Listener;
662   OwnsDeserializationListener = TakeOwnership;
663 }
664 
665 
666 
ComputeHash(Selector Sel)667 unsigned ASTSelectorLookupTrait::ComputeHash(Selector Sel) {
668   return serialization::ComputeHash(Sel);
669 }
670 
671 
672 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)673 ASTSelectorLookupTrait::ReadKeyDataLength(const unsigned char*& d) {
674   using namespace llvm::support;
675   unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
676   unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
677   return std::make_pair(KeyLen, DataLen);
678 }
679 
680 ASTSelectorLookupTrait::internal_key_type
ReadKey(const unsigned char * d,unsigned)681 ASTSelectorLookupTrait::ReadKey(const unsigned char* d, unsigned) {
682   using namespace llvm::support;
683   SelectorTable &SelTable = Reader.getContext().Selectors;
684   unsigned N = endian::readNext<uint16_t, little, unaligned>(d);
685   IdentifierInfo *FirstII = Reader.getLocalIdentifier(
686       F, endian::readNext<uint32_t, little, unaligned>(d));
687   if (N == 0)
688     return SelTable.getNullarySelector(FirstII);
689   else if (N == 1)
690     return SelTable.getUnarySelector(FirstII);
691 
692   SmallVector<IdentifierInfo *, 16> Args;
693   Args.push_back(FirstII);
694   for (unsigned I = 1; I != N; ++I)
695     Args.push_back(Reader.getLocalIdentifier(
696         F, endian::readNext<uint32_t, little, unaligned>(d)));
697 
698   return SelTable.getSelector(N, Args.data());
699 }
700 
701 ASTSelectorLookupTrait::data_type
ReadData(Selector,const unsigned char * d,unsigned DataLen)702 ASTSelectorLookupTrait::ReadData(Selector, const unsigned char* d,
703                                  unsigned DataLen) {
704   using namespace llvm::support;
705 
706   data_type Result;
707 
708   Result.ID = Reader.getGlobalSelectorID(
709       F, endian::readNext<uint32_t, little, unaligned>(d));
710   unsigned FullInstanceBits = endian::readNext<uint16_t, little, unaligned>(d);
711   unsigned FullFactoryBits = endian::readNext<uint16_t, little, unaligned>(d);
712   Result.InstanceBits = FullInstanceBits & 0x3;
713   Result.InstanceHasMoreThanOneDecl = (FullInstanceBits >> 2) & 0x1;
714   Result.FactoryBits = FullFactoryBits & 0x3;
715   Result.FactoryHasMoreThanOneDecl = (FullFactoryBits >> 2) & 0x1;
716   unsigned NumInstanceMethods = FullInstanceBits >> 3;
717   unsigned NumFactoryMethods = FullFactoryBits >> 3;
718 
719   // Load instance methods
720   for (unsigned I = 0; I != NumInstanceMethods; ++I) {
721     if (ObjCMethodDecl *Method = Reader.GetLocalDeclAs<ObjCMethodDecl>(
722             F, endian::readNext<uint32_t, little, unaligned>(d)))
723       Result.Instance.push_back(Method);
724   }
725 
726   // Load factory methods
727   for (unsigned I = 0; I != NumFactoryMethods; ++I) {
728     if (ObjCMethodDecl *Method = Reader.GetLocalDeclAs<ObjCMethodDecl>(
729             F, endian::readNext<uint32_t, little, unaligned>(d)))
730       Result.Factory.push_back(Method);
731   }
732 
733   return Result;
734 }
735 
ComputeHash(const internal_key_type & a)736 unsigned ASTIdentifierLookupTraitBase::ComputeHash(const internal_key_type& a) {
737   return llvm::HashString(a);
738 }
739 
740 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)741 ASTIdentifierLookupTraitBase::ReadKeyDataLength(const unsigned char*& d) {
742   using namespace llvm::support;
743   unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
744   unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
745   return std::make_pair(KeyLen, DataLen);
746 }
747 
748 ASTIdentifierLookupTraitBase::internal_key_type
ReadKey(const unsigned char * d,unsigned n)749 ASTIdentifierLookupTraitBase::ReadKey(const unsigned char* d, unsigned n) {
750   assert(n >= 2 && d[n-1] == '\0');
751   return StringRef((const char*) d, n-1);
752 }
753 
754 /// \brief Whether the given identifier is "interesting".
isInterestingIdentifier(ASTReader & Reader,IdentifierInfo & II,bool IsModule)755 static bool isInterestingIdentifier(ASTReader &Reader, IdentifierInfo &II,
756                                     bool IsModule) {
757   return II.hadMacroDefinition() ||
758          II.isPoisoned() ||
759          (IsModule ? II.hasRevertedBuiltin() : II.getObjCOrBuiltinID()) ||
760          II.hasRevertedTokenIDToIdentifier() ||
761          (!(IsModule && Reader.getContext().getLangOpts().CPlusPlus) &&
762           II.getFETokenInfo<void>());
763 }
764 
readBit(unsigned & Bits)765 static bool readBit(unsigned &Bits) {
766   bool Value = Bits & 0x1;
767   Bits >>= 1;
768   return Value;
769 }
770 
ReadIdentifierID(const unsigned char * d)771 IdentID ASTIdentifierLookupTrait::ReadIdentifierID(const unsigned char *d) {
772   using namespace llvm::support;
773   unsigned RawID = endian::readNext<uint32_t, little, unaligned>(d);
774   return Reader.getGlobalIdentifierID(F, RawID >> 1);
775 }
776 
markIdentifierFromAST(ASTReader & Reader,IdentifierInfo & II)777 static void markIdentifierFromAST(ASTReader &Reader, IdentifierInfo &II) {
778   if (!II.isFromAST()) {
779     II.setIsFromAST();
780     bool IsModule = Reader.getPreprocessor().getCurrentModule() != nullptr;
781     if (isInterestingIdentifier(Reader, II, IsModule))
782       II.setChangedSinceDeserialization();
783   }
784 }
785 
ReadData(const internal_key_type & k,const unsigned char * d,unsigned DataLen)786 IdentifierInfo *ASTIdentifierLookupTrait::ReadData(const internal_key_type& k,
787                                                    const unsigned char* d,
788                                                    unsigned DataLen) {
789   using namespace llvm::support;
790   unsigned RawID = endian::readNext<uint32_t, little, unaligned>(d);
791   bool IsInteresting = RawID & 0x01;
792 
793   // Wipe out the "is interesting" bit.
794   RawID = RawID >> 1;
795 
796   // Build the IdentifierInfo and link the identifier ID with it.
797   IdentifierInfo *II = KnownII;
798   if (!II) {
799     II = &Reader.getIdentifierTable().getOwn(k);
800     KnownII = II;
801   }
802   markIdentifierFromAST(Reader, *II);
803   Reader.markIdentifierUpToDate(II);
804 
805   IdentID ID = Reader.getGlobalIdentifierID(F, RawID);
806   if (!IsInteresting) {
807     // For uninteresting identifiers, there's nothing else to do. Just notify
808     // the reader that we've finished loading this identifier.
809     Reader.SetIdentifierInfo(ID, II);
810     return II;
811   }
812 
813   unsigned ObjCOrBuiltinID = endian::readNext<uint16_t, little, unaligned>(d);
814   unsigned Bits = endian::readNext<uint16_t, little, unaligned>(d);
815   bool CPlusPlusOperatorKeyword = readBit(Bits);
816   bool HasRevertedTokenIDToIdentifier = readBit(Bits);
817   bool HasRevertedBuiltin = readBit(Bits);
818   bool Poisoned = readBit(Bits);
819   bool ExtensionToken = readBit(Bits);
820   bool HadMacroDefinition = readBit(Bits);
821 
822   assert(Bits == 0 && "Extra bits in the identifier?");
823   DataLen -= 8;
824 
825   // Set or check the various bits in the IdentifierInfo structure.
826   // Token IDs are read-only.
827   if (HasRevertedTokenIDToIdentifier && II->getTokenID() != tok::identifier)
828     II->revertTokenIDToIdentifier();
829   if (!F.isModule())
830     II->setObjCOrBuiltinID(ObjCOrBuiltinID);
831   else if (HasRevertedBuiltin && II->getBuiltinID()) {
832     II->revertBuiltin();
833     assert((II->hasRevertedBuiltin() ||
834             II->getObjCOrBuiltinID() == ObjCOrBuiltinID) &&
835            "Incorrect ObjC keyword or builtin ID");
836   }
837   assert(II->isExtensionToken() == ExtensionToken &&
838          "Incorrect extension token flag");
839   (void)ExtensionToken;
840   if (Poisoned)
841     II->setIsPoisoned(true);
842   assert(II->isCPlusPlusOperatorKeyword() == CPlusPlusOperatorKeyword &&
843          "Incorrect C++ operator keyword flag");
844   (void)CPlusPlusOperatorKeyword;
845 
846   // If this identifier is a macro, deserialize the macro
847   // definition.
848   if (HadMacroDefinition) {
849     uint32_t MacroDirectivesOffset =
850         endian::readNext<uint32_t, little, unaligned>(d);
851     DataLen -= 4;
852 
853     Reader.addPendingMacro(II, &F, MacroDirectivesOffset);
854   }
855 
856   Reader.SetIdentifierInfo(ID, II);
857 
858   // Read all of the declarations visible at global scope with this
859   // name.
860   if (DataLen > 0) {
861     SmallVector<uint32_t, 4> DeclIDs;
862     for (; DataLen > 0; DataLen -= 4)
863       DeclIDs.push_back(Reader.getGlobalDeclID(
864           F, endian::readNext<uint32_t, little, unaligned>(d)));
865     Reader.SetGloballyVisibleDecls(II, DeclIDs);
866   }
867 
868   return II;
869 }
870 
DeclarationNameKey(DeclarationName Name)871 DeclarationNameKey::DeclarationNameKey(DeclarationName Name)
872     : Kind(Name.getNameKind()) {
873   switch (Kind) {
874   case DeclarationName::Identifier:
875     Data = (uint64_t)Name.getAsIdentifierInfo();
876     break;
877   case DeclarationName::ObjCZeroArgSelector:
878   case DeclarationName::ObjCOneArgSelector:
879   case DeclarationName::ObjCMultiArgSelector:
880     Data = (uint64_t)Name.getObjCSelector().getAsOpaquePtr();
881     break;
882   case DeclarationName::CXXOperatorName:
883     Data = Name.getCXXOverloadedOperator();
884     break;
885   case DeclarationName::CXXLiteralOperatorName:
886     Data = (uint64_t)Name.getCXXLiteralIdentifier();
887     break;
888   case DeclarationName::CXXConstructorName:
889   case DeclarationName::CXXDestructorName:
890   case DeclarationName::CXXConversionFunctionName:
891   case DeclarationName::CXXUsingDirective:
892     Data = 0;
893     break;
894   }
895 }
896 
getHash() const897 unsigned DeclarationNameKey::getHash() const {
898   llvm::FoldingSetNodeID ID;
899   ID.AddInteger(Kind);
900 
901   switch (Kind) {
902   case DeclarationName::Identifier:
903   case DeclarationName::CXXLiteralOperatorName:
904     ID.AddString(((IdentifierInfo*)Data)->getName());
905     break;
906   case DeclarationName::ObjCZeroArgSelector:
907   case DeclarationName::ObjCOneArgSelector:
908   case DeclarationName::ObjCMultiArgSelector:
909     ID.AddInteger(serialization::ComputeHash(Selector(Data)));
910     break;
911   case DeclarationName::CXXOperatorName:
912     ID.AddInteger((OverloadedOperatorKind)Data);
913     break;
914   case DeclarationName::CXXConstructorName:
915   case DeclarationName::CXXDestructorName:
916   case DeclarationName::CXXConversionFunctionName:
917   case DeclarationName::CXXUsingDirective:
918     break;
919   }
920 
921   return ID.ComputeHash();
922 }
923 
924 ModuleFile *
ReadFileRef(const unsigned char * & d)925 ASTDeclContextNameLookupTrait::ReadFileRef(const unsigned char *&d) {
926   using namespace llvm::support;
927   uint32_t ModuleFileID = endian::readNext<uint32_t, little, unaligned>(d);
928   return Reader.getLocalModuleFile(F, ModuleFileID);
929 }
930 
931 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)932 ASTDeclContextNameLookupTrait::ReadKeyDataLength(const unsigned char *&d) {
933   using namespace llvm::support;
934   unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
935   unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
936   return std::make_pair(KeyLen, DataLen);
937 }
938 
939 ASTDeclContextNameLookupTrait::internal_key_type
ReadKey(const unsigned char * d,unsigned)940 ASTDeclContextNameLookupTrait::ReadKey(const unsigned char *d, unsigned) {
941   using namespace llvm::support;
942 
943   auto Kind = (DeclarationName::NameKind)*d++;
944   uint64_t Data;
945   switch (Kind) {
946   case DeclarationName::Identifier:
947     Data = (uint64_t)Reader.getLocalIdentifier(
948         F, endian::readNext<uint32_t, little, unaligned>(d));
949     break;
950   case DeclarationName::ObjCZeroArgSelector:
951   case DeclarationName::ObjCOneArgSelector:
952   case DeclarationName::ObjCMultiArgSelector:
953     Data =
954         (uint64_t)Reader.getLocalSelector(
955                              F, endian::readNext<uint32_t, little, unaligned>(
956                                     d)).getAsOpaquePtr();
957     break;
958   case DeclarationName::CXXOperatorName:
959     Data = *d++; // OverloadedOperatorKind
960     break;
961   case DeclarationName::CXXLiteralOperatorName:
962     Data = (uint64_t)Reader.getLocalIdentifier(
963         F, endian::readNext<uint32_t, little, unaligned>(d));
964     break;
965   case DeclarationName::CXXConstructorName:
966   case DeclarationName::CXXDestructorName:
967   case DeclarationName::CXXConversionFunctionName:
968   case DeclarationName::CXXUsingDirective:
969     Data = 0;
970     break;
971   }
972 
973   return DeclarationNameKey(Kind, Data);
974 }
975 
ReadDataInto(internal_key_type,const unsigned char * d,unsigned DataLen,data_type_builder & Val)976 void ASTDeclContextNameLookupTrait::ReadDataInto(internal_key_type,
977                                                  const unsigned char *d,
978                                                  unsigned DataLen,
979                                                  data_type_builder &Val) {
980   using namespace llvm::support;
981   for (unsigned NumDecls = DataLen / 4; NumDecls; --NumDecls) {
982     uint32_t LocalID = endian::readNext<uint32_t, little, unaligned>(d);
983     Val.insert(Reader.getGlobalDeclID(F, LocalID));
984   }
985 }
986 
ReadLexicalDeclContextStorage(ModuleFile & M,BitstreamCursor & Cursor,uint64_t Offset,DeclContext * DC)987 bool ASTReader::ReadLexicalDeclContextStorage(ModuleFile &M,
988                                               BitstreamCursor &Cursor,
989                                               uint64_t Offset,
990                                               DeclContext *DC) {
991   assert(Offset != 0);
992 
993   SavedStreamPosition SavedPosition(Cursor);
994   Cursor.JumpToBit(Offset);
995 
996   RecordData Record;
997   StringRef Blob;
998   unsigned Code = Cursor.ReadCode();
999   unsigned RecCode = Cursor.readRecord(Code, Record, &Blob);
1000   if (RecCode != DECL_CONTEXT_LEXICAL) {
1001     Error("Expected lexical block");
1002     return true;
1003   }
1004 
1005   assert(!isa<TranslationUnitDecl>(DC) &&
1006          "expected a TU_UPDATE_LEXICAL record for TU");
1007   // If we are handling a C++ class template instantiation, we can see multiple
1008   // lexical updates for the same record. It's important that we select only one
1009   // of them, so that field numbering works properly. Just pick the first one we
1010   // see.
1011   auto &Lex = LexicalDecls[DC];
1012   if (!Lex.first) {
1013     Lex = std::make_pair(
1014         &M, llvm::makeArrayRef(
1015                 reinterpret_cast<const llvm::support::unaligned_uint32_t *>(
1016                     Blob.data()),
1017                 Blob.size() / 4));
1018   }
1019   DC->setHasExternalLexicalStorage(true);
1020   return false;
1021 }
1022 
ReadVisibleDeclContextStorage(ModuleFile & M,BitstreamCursor & Cursor,uint64_t Offset,DeclID ID)1023 bool ASTReader::ReadVisibleDeclContextStorage(ModuleFile &M,
1024                                               BitstreamCursor &Cursor,
1025                                               uint64_t Offset,
1026                                               DeclID ID) {
1027   assert(Offset != 0);
1028 
1029   SavedStreamPosition SavedPosition(Cursor);
1030   Cursor.JumpToBit(Offset);
1031 
1032   RecordData Record;
1033   StringRef Blob;
1034   unsigned Code = Cursor.ReadCode();
1035   unsigned RecCode = Cursor.readRecord(Code, Record, &Blob);
1036   if (RecCode != DECL_CONTEXT_VISIBLE) {
1037     Error("Expected visible lookup table block");
1038     return true;
1039   }
1040 
1041   // We can't safely determine the primary context yet, so delay attaching the
1042   // lookup table until we're done with recursive deserialization.
1043   auto *Data = (const unsigned char*)Blob.data();
1044   PendingVisibleUpdates[ID].push_back(PendingVisibleUpdate{&M, Data});
1045   return false;
1046 }
1047 
Error(StringRef Msg)1048 void ASTReader::Error(StringRef Msg) {
1049   Error(diag::err_fe_pch_malformed, Msg);
1050   if (Context.getLangOpts().Modules && !Diags.isDiagnosticInFlight() &&
1051       !PP.getHeaderSearchInfo().getModuleCachePath().empty()) {
1052     Diag(diag::note_module_cache_path)
1053       << PP.getHeaderSearchInfo().getModuleCachePath();
1054   }
1055 }
1056 
Error(unsigned DiagID,StringRef Arg1,StringRef Arg2)1057 void ASTReader::Error(unsigned DiagID,
1058                       StringRef Arg1, StringRef Arg2) {
1059   if (Diags.isDiagnosticInFlight())
1060     Diags.SetDelayedDiagnostic(DiagID, Arg1, Arg2);
1061   else
1062     Diag(DiagID) << Arg1 << Arg2;
1063 }
1064 
1065 //===----------------------------------------------------------------------===//
1066 // Source Manager Deserialization
1067 //===----------------------------------------------------------------------===//
1068 
1069 /// \brief Read the line table in the source manager block.
1070 /// \returns true if there was an error.
ParseLineTable(ModuleFile & F,const RecordData & Record)1071 bool ASTReader::ParseLineTable(ModuleFile &F,
1072                                const RecordData &Record) {
1073   unsigned Idx = 0;
1074   LineTableInfo &LineTable = SourceMgr.getLineTable();
1075 
1076   // Parse the file names
1077   std::map<int, int> FileIDs;
1078   for (unsigned I = 0; Record[Idx]; ++I) {
1079     // Extract the file name
1080     auto Filename = ReadPath(F, Record, Idx);
1081     FileIDs[I] = LineTable.getLineTableFilenameID(Filename);
1082   }
1083   ++Idx;
1084 
1085   // Parse the line entries
1086   std::vector<LineEntry> Entries;
1087   while (Idx < Record.size()) {
1088     int FID = Record[Idx++];
1089     assert(FID >= 0 && "Serialized line entries for non-local file.");
1090     // Remap FileID from 1-based old view.
1091     FID += F.SLocEntryBaseID - 1;
1092 
1093     // Extract the line entries
1094     unsigned NumEntries = Record[Idx++];
1095     assert(NumEntries && "no line entries for file ID");
1096     Entries.clear();
1097     Entries.reserve(NumEntries);
1098     for (unsigned I = 0; I != NumEntries; ++I) {
1099       unsigned FileOffset = Record[Idx++];
1100       unsigned LineNo = Record[Idx++];
1101       int FilenameID = FileIDs[Record[Idx++]];
1102       SrcMgr::CharacteristicKind FileKind
1103         = (SrcMgr::CharacteristicKind)Record[Idx++];
1104       unsigned IncludeOffset = Record[Idx++];
1105       Entries.push_back(LineEntry::get(FileOffset, LineNo, FilenameID,
1106                                        FileKind, IncludeOffset));
1107     }
1108     LineTable.AddEntry(FileID::get(FID), Entries);
1109   }
1110 
1111   return false;
1112 }
1113 
1114 /// \brief Read a source manager block
ReadSourceManagerBlock(ModuleFile & F)1115 bool ASTReader::ReadSourceManagerBlock(ModuleFile &F) {
1116   using namespace SrcMgr;
1117 
1118   BitstreamCursor &SLocEntryCursor = F.SLocEntryCursor;
1119 
1120   // Set the source-location entry cursor to the current position in
1121   // the stream. This cursor will be used to read the contents of the
1122   // source manager block initially, and then lazily read
1123   // source-location entries as needed.
1124   SLocEntryCursor = F.Stream;
1125 
1126   // The stream itself is going to skip over the source manager block.
1127   if (F.Stream.SkipBlock()) {
1128     Error("malformed block record in AST file");
1129     return true;
1130   }
1131 
1132   // Enter the source manager block.
1133   if (SLocEntryCursor.EnterSubBlock(SOURCE_MANAGER_BLOCK_ID)) {
1134     Error("malformed source manager block record in AST file");
1135     return true;
1136   }
1137 
1138   RecordData Record;
1139   while (true) {
1140     llvm::BitstreamEntry E = SLocEntryCursor.advanceSkippingSubblocks();
1141 
1142     switch (E.Kind) {
1143     case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1144     case llvm::BitstreamEntry::Error:
1145       Error("malformed block record in AST file");
1146       return true;
1147     case llvm::BitstreamEntry::EndBlock:
1148       return false;
1149     case llvm::BitstreamEntry::Record:
1150       // The interesting case.
1151       break;
1152     }
1153 
1154     // Read a record.
1155     Record.clear();
1156     StringRef Blob;
1157     switch (SLocEntryCursor.readRecord(E.ID, Record, &Blob)) {
1158     default:  // Default behavior: ignore.
1159       break;
1160 
1161     case SM_SLOC_FILE_ENTRY:
1162     case SM_SLOC_BUFFER_ENTRY:
1163     case SM_SLOC_EXPANSION_ENTRY:
1164       // Once we hit one of the source location entries, we're done.
1165       return false;
1166     }
1167   }
1168 }
1169 
1170 /// \brief If a header file is not found at the path that we expect it to be
1171 /// and the PCH file was moved from its original location, try to resolve the
1172 /// file by assuming that header+PCH were moved together and the header is in
1173 /// the same place relative to the PCH.
1174 static std::string
resolveFileRelativeToOriginalDir(const std::string & Filename,const std::string & OriginalDir,const std::string & CurrDir)1175 resolveFileRelativeToOriginalDir(const std::string &Filename,
1176                                  const std::string &OriginalDir,
1177                                  const std::string &CurrDir) {
1178   assert(OriginalDir != CurrDir &&
1179          "No point trying to resolve the file if the PCH dir didn't change");
1180   using namespace llvm::sys;
1181   SmallString<128> filePath(Filename);
1182   fs::make_absolute(filePath);
1183   assert(path::is_absolute(OriginalDir));
1184   SmallString<128> currPCHPath(CurrDir);
1185 
1186   path::const_iterator fileDirI = path::begin(path::parent_path(filePath)),
1187                        fileDirE = path::end(path::parent_path(filePath));
1188   path::const_iterator origDirI = path::begin(OriginalDir),
1189                        origDirE = path::end(OriginalDir);
1190   // Skip the common path components from filePath and OriginalDir.
1191   while (fileDirI != fileDirE && origDirI != origDirE &&
1192          *fileDirI == *origDirI) {
1193     ++fileDirI;
1194     ++origDirI;
1195   }
1196   for (; origDirI != origDirE; ++origDirI)
1197     path::append(currPCHPath, "..");
1198   path::append(currPCHPath, fileDirI, fileDirE);
1199   path::append(currPCHPath, path::filename(Filename));
1200   return currPCHPath.str();
1201 }
1202 
ReadSLocEntry(int ID)1203 bool ASTReader::ReadSLocEntry(int ID) {
1204   if (ID == 0)
1205     return false;
1206 
1207   if (unsigned(-ID) - 2 >= getTotalNumSLocs() || ID > 0) {
1208     Error("source location entry ID out-of-range for AST file");
1209     return true;
1210   }
1211 
1212   // Local helper to read the (possibly-compressed) buffer data following the
1213   // entry record.
1214   auto ReadBuffer = [this](
1215       BitstreamCursor &SLocEntryCursor,
1216       StringRef Name) -> std::unique_ptr<llvm::MemoryBuffer> {
1217     RecordData Record;
1218     StringRef Blob;
1219     unsigned Code = SLocEntryCursor.ReadCode();
1220     unsigned RecCode = SLocEntryCursor.readRecord(Code, Record, &Blob);
1221 
1222     if (RecCode == SM_SLOC_BUFFER_BLOB_COMPRESSED) {
1223       SmallString<0> Uncompressed;
1224       if (llvm::zlib::uncompress(Blob, Uncompressed, Record[0]) !=
1225           llvm::zlib::StatusOK) {
1226         Error("could not decompress embedded file contents");
1227         return nullptr;
1228       }
1229       return llvm::MemoryBuffer::getMemBufferCopy(Uncompressed, Name);
1230     } else if (RecCode == SM_SLOC_BUFFER_BLOB) {
1231       return llvm::MemoryBuffer::getMemBuffer(Blob.drop_back(1), Name, true);
1232     } else {
1233       Error("AST record has invalid code");
1234       return nullptr;
1235     }
1236   };
1237 
1238   ModuleFile *F = GlobalSLocEntryMap.find(-ID)->second;
1239   F->SLocEntryCursor.JumpToBit(F->SLocEntryOffsets[ID - F->SLocEntryBaseID]);
1240   BitstreamCursor &SLocEntryCursor = F->SLocEntryCursor;
1241   unsigned BaseOffset = F->SLocEntryBaseOffset;
1242 
1243   ++NumSLocEntriesRead;
1244   llvm::BitstreamEntry Entry = SLocEntryCursor.advance();
1245   if (Entry.Kind != llvm::BitstreamEntry::Record) {
1246     Error("incorrectly-formatted source location entry in AST file");
1247     return true;
1248   }
1249 
1250   RecordData Record;
1251   StringRef Blob;
1252   switch (SLocEntryCursor.readRecord(Entry.ID, Record, &Blob)) {
1253   default:
1254     Error("incorrectly-formatted source location entry in AST file");
1255     return true;
1256 
1257   case SM_SLOC_FILE_ENTRY: {
1258     // We will detect whether a file changed and return 'Failure' for it, but
1259     // we will also try to fail gracefully by setting up the SLocEntry.
1260     unsigned InputID = Record[4];
1261     InputFile IF = getInputFile(*F, InputID);
1262     const FileEntry *File = IF.getFile();
1263     bool OverriddenBuffer = IF.isOverridden();
1264 
1265     // Note that we only check if a File was returned. If it was out-of-date
1266     // we have complained but we will continue creating a FileID to recover
1267     // gracefully.
1268     if (!File)
1269       return true;
1270 
1271     SourceLocation IncludeLoc = ReadSourceLocation(*F, Record[1]);
1272     if (IncludeLoc.isInvalid() && F->Kind != MK_MainFile) {
1273       // This is the module's main file.
1274       IncludeLoc = getImportLocation(F);
1275     }
1276     SrcMgr::CharacteristicKind
1277       FileCharacter = (SrcMgr::CharacteristicKind)Record[2];
1278     FileID FID = SourceMgr.createFileID(File, IncludeLoc, FileCharacter,
1279                                         ID, BaseOffset + Record[0]);
1280     SrcMgr::FileInfo &FileInfo =
1281           const_cast<SrcMgr::FileInfo&>(SourceMgr.getSLocEntry(FID).getFile());
1282     FileInfo.NumCreatedFIDs = Record[5];
1283     if (Record[3])
1284       FileInfo.setHasLineDirectives();
1285 
1286     const DeclID *FirstDecl = F->FileSortedDecls + Record[6];
1287     unsigned NumFileDecls = Record[7];
1288     if (NumFileDecls) {
1289       assert(F->FileSortedDecls && "FILE_SORTED_DECLS not encountered yet ?");
1290       FileDeclIDs[FID] = FileDeclsInfo(F, llvm::makeArrayRef(FirstDecl,
1291                                                              NumFileDecls));
1292     }
1293 
1294     const SrcMgr::ContentCache *ContentCache
1295       = SourceMgr.getOrCreateContentCache(File,
1296                               /*isSystemFile=*/FileCharacter != SrcMgr::C_User);
1297     if (OverriddenBuffer && !ContentCache->BufferOverridden &&
1298         ContentCache->ContentsEntry == ContentCache->OrigEntry &&
1299         !ContentCache->getRawBuffer()) {
1300       auto Buffer = ReadBuffer(SLocEntryCursor, File->getName());
1301       if (!Buffer)
1302         return true;
1303       SourceMgr.overrideFileContents(File, std::move(Buffer));
1304     }
1305 
1306     break;
1307   }
1308 
1309   case SM_SLOC_BUFFER_ENTRY: {
1310     const char *Name = Blob.data();
1311     unsigned Offset = Record[0];
1312     SrcMgr::CharacteristicKind
1313       FileCharacter = (SrcMgr::CharacteristicKind)Record[2];
1314     SourceLocation IncludeLoc = ReadSourceLocation(*F, Record[1]);
1315     if (IncludeLoc.isInvalid() &&
1316         (F->Kind == MK_ImplicitModule || F->Kind == MK_ExplicitModule)) {
1317       IncludeLoc = getImportLocation(F);
1318     }
1319 
1320     auto Buffer = ReadBuffer(SLocEntryCursor, Name);
1321     if (!Buffer)
1322       return true;
1323     SourceMgr.createFileID(std::move(Buffer), FileCharacter, ID,
1324                            BaseOffset + Offset, IncludeLoc);
1325     break;
1326   }
1327 
1328   case SM_SLOC_EXPANSION_ENTRY: {
1329     SourceLocation SpellingLoc = ReadSourceLocation(*F, Record[1]);
1330     SourceMgr.createExpansionLoc(SpellingLoc,
1331                                      ReadSourceLocation(*F, Record[2]),
1332                                      ReadSourceLocation(*F, Record[3]),
1333                                      Record[4],
1334                                      ID,
1335                                      BaseOffset + Record[0]);
1336     break;
1337   }
1338   }
1339 
1340   return false;
1341 }
1342 
getModuleImportLoc(int ID)1343 std::pair<SourceLocation, StringRef> ASTReader::getModuleImportLoc(int ID) {
1344   if (ID == 0)
1345     return std::make_pair(SourceLocation(), "");
1346 
1347   if (unsigned(-ID) - 2 >= getTotalNumSLocs() || ID > 0) {
1348     Error("source location entry ID out-of-range for AST file");
1349     return std::make_pair(SourceLocation(), "");
1350   }
1351 
1352   // Find which module file this entry lands in.
1353   ModuleFile *M = GlobalSLocEntryMap.find(-ID)->second;
1354   if (M->Kind != MK_ImplicitModule && M->Kind != MK_ExplicitModule)
1355     return std::make_pair(SourceLocation(), "");
1356 
1357   // FIXME: Can we map this down to a particular submodule? That would be
1358   // ideal.
1359   return std::make_pair(M->ImportLoc, StringRef(M->ModuleName));
1360 }
1361 
1362 /// \brief Find the location where the module F is imported.
getImportLocation(ModuleFile * F)1363 SourceLocation ASTReader::getImportLocation(ModuleFile *F) {
1364   if (F->ImportLoc.isValid())
1365     return F->ImportLoc;
1366 
1367   // Otherwise we have a PCH. It's considered to be "imported" at the first
1368   // location of its includer.
1369   if (F->ImportedBy.empty() || !F->ImportedBy[0]) {
1370     // Main file is the importer.
1371     assert(SourceMgr.getMainFileID().isValid() && "missing main file");
1372     return SourceMgr.getLocForStartOfFile(SourceMgr.getMainFileID());
1373   }
1374   return F->ImportedBy[0]->FirstLoc;
1375 }
1376 
1377 /// ReadBlockAbbrevs - Enter a subblock of the specified BlockID with the
1378 /// specified cursor.  Read the abbreviations that are at the top of the block
1379 /// and then leave the cursor pointing into the block.
ReadBlockAbbrevs(BitstreamCursor & Cursor,unsigned BlockID)1380 bool ASTReader::ReadBlockAbbrevs(BitstreamCursor &Cursor, unsigned BlockID) {
1381   if (Cursor.EnterSubBlock(BlockID))
1382     return true;
1383 
1384   while (true) {
1385     uint64_t Offset = Cursor.GetCurrentBitNo();
1386     unsigned Code = Cursor.ReadCode();
1387 
1388     // We expect all abbrevs to be at the start of the block.
1389     if (Code != llvm::bitc::DEFINE_ABBREV) {
1390       Cursor.JumpToBit(Offset);
1391       return false;
1392     }
1393     Cursor.ReadAbbrevRecord();
1394   }
1395 }
1396 
ReadToken(ModuleFile & F,const RecordDataImpl & Record,unsigned & Idx)1397 Token ASTReader::ReadToken(ModuleFile &F, const RecordDataImpl &Record,
1398                            unsigned &Idx) {
1399   Token Tok;
1400   Tok.startToken();
1401   Tok.setLocation(ReadSourceLocation(F, Record, Idx));
1402   Tok.setLength(Record[Idx++]);
1403   if (IdentifierInfo *II = getLocalIdentifier(F, Record[Idx++]))
1404     Tok.setIdentifierInfo(II);
1405   Tok.setKind((tok::TokenKind)Record[Idx++]);
1406   Tok.setFlag((Token::TokenFlags)Record[Idx++]);
1407   return Tok;
1408 }
1409 
ReadMacroRecord(ModuleFile & F,uint64_t Offset)1410 MacroInfo *ASTReader::ReadMacroRecord(ModuleFile &F, uint64_t Offset) {
1411   BitstreamCursor &Stream = F.MacroCursor;
1412 
1413   // Keep track of where we are in the stream, then jump back there
1414   // after reading this macro.
1415   SavedStreamPosition SavedPosition(Stream);
1416 
1417   Stream.JumpToBit(Offset);
1418   RecordData Record;
1419   SmallVector<IdentifierInfo*, 16> MacroArgs;
1420   MacroInfo *Macro = nullptr;
1421 
1422   while (true) {
1423     // Advance to the next record, but if we get to the end of the block, don't
1424     // pop it (removing all the abbreviations from the cursor) since we want to
1425     // be able to reseek within the block and read entries.
1426     unsigned Flags = BitstreamCursor::AF_DontPopBlockAtEnd;
1427     llvm::BitstreamEntry Entry = Stream.advanceSkippingSubblocks(Flags);
1428 
1429     switch (Entry.Kind) {
1430     case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1431     case llvm::BitstreamEntry::Error:
1432       Error("malformed block record in AST file");
1433       return Macro;
1434     case llvm::BitstreamEntry::EndBlock:
1435       return Macro;
1436     case llvm::BitstreamEntry::Record:
1437       // The interesting case.
1438       break;
1439     }
1440 
1441     // Read a record.
1442     Record.clear();
1443     PreprocessorRecordTypes RecType =
1444       (PreprocessorRecordTypes)Stream.readRecord(Entry.ID, Record);
1445     switch (RecType) {
1446     case PP_MODULE_MACRO:
1447     case PP_MACRO_DIRECTIVE_HISTORY:
1448       return Macro;
1449 
1450     case PP_MACRO_OBJECT_LIKE:
1451     case PP_MACRO_FUNCTION_LIKE: {
1452       // If we already have a macro, that means that we've hit the end
1453       // of the definition of the macro we were looking for. We're
1454       // done.
1455       if (Macro)
1456         return Macro;
1457 
1458       unsigned NextIndex = 1; // Skip identifier ID.
1459       SubmoduleID SubModID = getGlobalSubmoduleID(F, Record[NextIndex++]);
1460       SourceLocation Loc = ReadSourceLocation(F, Record, NextIndex);
1461       MacroInfo *MI = PP.AllocateDeserializedMacroInfo(Loc, SubModID);
1462       MI->setDefinitionEndLoc(ReadSourceLocation(F, Record, NextIndex));
1463       MI->setIsUsed(Record[NextIndex++]);
1464       MI->setUsedForHeaderGuard(Record[NextIndex++]);
1465 
1466       if (RecType == PP_MACRO_FUNCTION_LIKE) {
1467         // Decode function-like macro info.
1468         bool isC99VarArgs = Record[NextIndex++];
1469         bool isGNUVarArgs = Record[NextIndex++];
1470         bool hasCommaPasting = Record[NextIndex++];
1471         MacroArgs.clear();
1472         unsigned NumArgs = Record[NextIndex++];
1473         for (unsigned i = 0; i != NumArgs; ++i)
1474           MacroArgs.push_back(getLocalIdentifier(F, Record[NextIndex++]));
1475 
1476         // Install function-like macro info.
1477         MI->setIsFunctionLike();
1478         if (isC99VarArgs) MI->setIsC99Varargs();
1479         if (isGNUVarArgs) MI->setIsGNUVarargs();
1480         if (hasCommaPasting) MI->setHasCommaPasting();
1481         MI->setArgumentList(MacroArgs, PP.getPreprocessorAllocator());
1482       }
1483 
1484       // Remember that we saw this macro last so that we add the tokens that
1485       // form its body to it.
1486       Macro = MI;
1487 
1488       if (NextIndex + 1 == Record.size() && PP.getPreprocessingRecord() &&
1489           Record[NextIndex]) {
1490         // We have a macro definition. Register the association
1491         PreprocessedEntityID
1492             GlobalID = getGlobalPreprocessedEntityID(F, Record[NextIndex]);
1493         PreprocessingRecord &PPRec = *PP.getPreprocessingRecord();
1494         PreprocessingRecord::PPEntityID PPID =
1495             PPRec.getPPEntityID(GlobalID - 1, /*isLoaded=*/true);
1496         MacroDefinitionRecord *PPDef = cast_or_null<MacroDefinitionRecord>(
1497             PPRec.getPreprocessedEntity(PPID));
1498         if (PPDef)
1499           PPRec.RegisterMacroDefinition(Macro, PPDef);
1500       }
1501 
1502       ++NumMacrosRead;
1503       break;
1504     }
1505 
1506     case PP_TOKEN: {
1507       // If we see a TOKEN before a PP_MACRO_*, then the file is
1508       // erroneous, just pretend we didn't see this.
1509       if (!Macro) break;
1510 
1511       unsigned Idx = 0;
1512       Token Tok = ReadToken(F, Record, Idx);
1513       Macro->AddTokenToBody(Tok);
1514       break;
1515     }
1516     }
1517   }
1518 }
1519 
1520 PreprocessedEntityID
getGlobalPreprocessedEntityID(ModuleFile & M,unsigned LocalID) const1521 ASTReader::getGlobalPreprocessedEntityID(ModuleFile &M, unsigned LocalID) const {
1522   ContinuousRangeMap<uint32_t, int, 2>::const_iterator
1523     I = M.PreprocessedEntityRemap.find(LocalID - NUM_PREDEF_PP_ENTITY_IDS);
1524   assert(I != M.PreprocessedEntityRemap.end()
1525          && "Invalid index into preprocessed entity index remap");
1526 
1527   return LocalID + I->second;
1528 }
1529 
ComputeHash(internal_key_ref ikey)1530 unsigned HeaderFileInfoTrait::ComputeHash(internal_key_ref ikey) {
1531   return llvm::hash_combine(ikey.Size, ikey.ModTime);
1532 }
1533 
1534 HeaderFileInfoTrait::internal_key_type
GetInternalKey(const FileEntry * FE)1535 HeaderFileInfoTrait::GetInternalKey(const FileEntry *FE) {
1536   internal_key_type ikey = {FE->getSize(),
1537                             M.HasTimestamps ? FE->getModificationTime() : 0,
1538                             FE->getName(), /*Imported*/ false};
1539   return ikey;
1540 }
1541 
EqualKey(internal_key_ref a,internal_key_ref b)1542 bool HeaderFileInfoTrait::EqualKey(internal_key_ref a, internal_key_ref b) {
1543   if (a.Size != b.Size || (a.ModTime && b.ModTime && a.ModTime != b.ModTime))
1544     return false;
1545 
1546   if (llvm::sys::path::is_absolute(a.Filename) &&
1547       strcmp(a.Filename, b.Filename) == 0)
1548     return true;
1549 
1550   // Determine whether the actual files are equivalent.
1551   FileManager &FileMgr = Reader.getFileManager();
1552   auto GetFile = [&](const internal_key_type &Key) -> const FileEntry* {
1553     if (!Key.Imported)
1554       return FileMgr.getFile(Key.Filename);
1555 
1556     std::string Resolved = Key.Filename;
1557     Reader.ResolveImportedPath(M, Resolved);
1558     return FileMgr.getFile(Resolved);
1559   };
1560 
1561   const FileEntry *FEA = GetFile(a);
1562   const FileEntry *FEB = GetFile(b);
1563   return FEA && FEA == FEB;
1564 }
1565 
1566 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)1567 HeaderFileInfoTrait::ReadKeyDataLength(const unsigned char*& d) {
1568   using namespace llvm::support;
1569   unsigned KeyLen = (unsigned) endian::readNext<uint16_t, little, unaligned>(d);
1570   unsigned DataLen = (unsigned) *d++;
1571   return std::make_pair(KeyLen, DataLen);
1572 }
1573 
1574 HeaderFileInfoTrait::internal_key_type
ReadKey(const unsigned char * d,unsigned)1575 HeaderFileInfoTrait::ReadKey(const unsigned char *d, unsigned) {
1576   using namespace llvm::support;
1577   internal_key_type ikey;
1578   ikey.Size = off_t(endian::readNext<uint64_t, little, unaligned>(d));
1579   ikey.ModTime = time_t(endian::readNext<uint64_t, little, unaligned>(d));
1580   ikey.Filename = (const char *)d;
1581   ikey.Imported = true;
1582   return ikey;
1583 }
1584 
1585 HeaderFileInfoTrait::data_type
ReadData(internal_key_ref key,const unsigned char * d,unsigned DataLen)1586 HeaderFileInfoTrait::ReadData(internal_key_ref key, const unsigned char *d,
1587                               unsigned DataLen) {
1588   const unsigned char *End = d + DataLen;
1589   using namespace llvm::support;
1590   HeaderFileInfo HFI;
1591   unsigned Flags = *d++;
1592   // FIXME: Refactor with mergeHeaderFileInfo in HeaderSearch.cpp.
1593   HFI.isImport |= (Flags >> 4) & 0x01;
1594   HFI.isPragmaOnce |= (Flags >> 3) & 0x01;
1595   HFI.DirInfo = (Flags >> 1) & 0x03;
1596   HFI.IndexHeaderMapHeader = Flags & 0x01;
1597   // FIXME: Find a better way to handle this. Maybe just store a
1598   // "has been included" flag?
1599   HFI.NumIncludes = std::max(endian::readNext<uint16_t, little, unaligned>(d),
1600                              HFI.NumIncludes);
1601   HFI.ControllingMacroID = Reader.getGlobalIdentifierID(
1602       M, endian::readNext<uint32_t, little, unaligned>(d));
1603   if (unsigned FrameworkOffset =
1604           endian::readNext<uint32_t, little, unaligned>(d)) {
1605     // The framework offset is 1 greater than the actual offset,
1606     // since 0 is used as an indicator for "no framework name".
1607     StringRef FrameworkName(FrameworkStrings + FrameworkOffset - 1);
1608     HFI.Framework = HS->getUniqueFrameworkName(FrameworkName);
1609   }
1610 
1611   assert((End - d) % 4 == 0 &&
1612          "Wrong data length in HeaderFileInfo deserialization");
1613   while (d != End) {
1614     uint32_t LocalSMID = endian::readNext<uint32_t, little, unaligned>(d);
1615     auto HeaderRole = static_cast<ModuleMap::ModuleHeaderRole>(LocalSMID & 3);
1616     LocalSMID >>= 2;
1617 
1618     // This header is part of a module. Associate it with the module to enable
1619     // implicit module import.
1620     SubmoduleID GlobalSMID = Reader.getGlobalSubmoduleID(M, LocalSMID);
1621     Module *Mod = Reader.getSubmodule(GlobalSMID);
1622     FileManager &FileMgr = Reader.getFileManager();
1623     ModuleMap &ModMap =
1624         Reader.getPreprocessor().getHeaderSearchInfo().getModuleMap();
1625 
1626     std::string Filename = key.Filename;
1627     if (key.Imported)
1628       Reader.ResolveImportedPath(M, Filename);
1629     // FIXME: This is not always the right filename-as-written, but we're not
1630     // going to use this information to rebuild the module, so it doesn't make
1631     // a lot of difference.
1632     Module::Header H = { key.Filename, FileMgr.getFile(Filename) };
1633     ModMap.addHeader(Mod, H, HeaderRole, /*Imported*/true);
1634     HFI.isModuleHeader |= !(HeaderRole & ModuleMap::TextualHeader);
1635   }
1636 
1637   // This HeaderFileInfo was externally loaded.
1638   HFI.External = true;
1639   HFI.IsValid = true;
1640   return HFI;
1641 }
1642 
addPendingMacro(IdentifierInfo * II,ModuleFile * M,uint64_t MacroDirectivesOffset)1643 void ASTReader::addPendingMacro(IdentifierInfo *II,
1644                                 ModuleFile *M,
1645                                 uint64_t MacroDirectivesOffset) {
1646   assert(NumCurrentElementsDeserializing > 0 &&"Missing deserialization guard");
1647   PendingMacroIDs[II].push_back(PendingMacroInfo(M, MacroDirectivesOffset));
1648 }
1649 
ReadDefinedMacros()1650 void ASTReader::ReadDefinedMacros() {
1651   // Note that we are loading defined macros.
1652   Deserializing Macros(this);
1653 
1654   for (auto &I : llvm::reverse(ModuleMgr)) {
1655     BitstreamCursor &MacroCursor = I->MacroCursor;
1656 
1657     // If there was no preprocessor block, skip this file.
1658     if (!MacroCursor.getBitStreamReader())
1659       continue;
1660 
1661     BitstreamCursor Cursor = MacroCursor;
1662     Cursor.JumpToBit(I->MacroStartOffset);
1663 
1664     RecordData Record;
1665     while (true) {
1666       llvm::BitstreamEntry E = Cursor.advanceSkippingSubblocks();
1667 
1668       switch (E.Kind) {
1669       case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1670       case llvm::BitstreamEntry::Error:
1671         Error("malformed block record in AST file");
1672         return;
1673       case llvm::BitstreamEntry::EndBlock:
1674         goto NextCursor;
1675 
1676       case llvm::BitstreamEntry::Record:
1677         Record.clear();
1678         switch (Cursor.readRecord(E.ID, Record)) {
1679         default:  // Default behavior: ignore.
1680           break;
1681 
1682         case PP_MACRO_OBJECT_LIKE:
1683         case PP_MACRO_FUNCTION_LIKE: {
1684           IdentifierInfo *II = getLocalIdentifier(*I, Record[0]);
1685           if (II->isOutOfDate())
1686             updateOutOfDateIdentifier(*II);
1687           break;
1688         }
1689 
1690         case PP_TOKEN:
1691           // Ignore tokens.
1692           break;
1693         }
1694         break;
1695       }
1696     }
1697     NextCursor:  ;
1698   }
1699 }
1700 
1701 namespace {
1702   /// \brief Visitor class used to look up identifirs in an AST file.
1703   class IdentifierLookupVisitor {
1704     StringRef Name;
1705     unsigned NameHash;
1706     unsigned PriorGeneration;
1707     unsigned &NumIdentifierLookups;
1708     unsigned &NumIdentifierLookupHits;
1709     IdentifierInfo *Found;
1710 
1711   public:
IdentifierLookupVisitor(StringRef Name,unsigned PriorGeneration,unsigned & NumIdentifierLookups,unsigned & NumIdentifierLookupHits)1712     IdentifierLookupVisitor(StringRef Name, unsigned PriorGeneration,
1713                             unsigned &NumIdentifierLookups,
1714                             unsigned &NumIdentifierLookupHits)
1715       : Name(Name), NameHash(ASTIdentifierLookupTrait::ComputeHash(Name)),
1716         PriorGeneration(PriorGeneration),
1717         NumIdentifierLookups(NumIdentifierLookups),
1718         NumIdentifierLookupHits(NumIdentifierLookupHits),
1719         Found()
1720     {
1721     }
1722 
operator ()(ModuleFile & M)1723     bool operator()(ModuleFile &M) {
1724       // If we've already searched this module file, skip it now.
1725       if (M.Generation <= PriorGeneration)
1726         return true;
1727 
1728       ASTIdentifierLookupTable *IdTable
1729         = (ASTIdentifierLookupTable *)M.IdentifierLookupTable;
1730       if (!IdTable)
1731         return false;
1732 
1733       ASTIdentifierLookupTrait Trait(IdTable->getInfoObj().getReader(), M,
1734                                      Found);
1735       ++NumIdentifierLookups;
1736       ASTIdentifierLookupTable::iterator Pos =
1737           IdTable->find_hashed(Name, NameHash, &Trait);
1738       if (Pos == IdTable->end())
1739         return false;
1740 
1741       // Dereferencing the iterator has the effect of building the
1742       // IdentifierInfo node and populating it with the various
1743       // declarations it needs.
1744       ++NumIdentifierLookupHits;
1745       Found = *Pos;
1746       return true;
1747     }
1748 
1749     // \brief Retrieve the identifier info found within the module
1750     // files.
getIdentifierInfo() const1751     IdentifierInfo *getIdentifierInfo() const { return Found; }
1752   };
1753 }
1754 
updateOutOfDateIdentifier(IdentifierInfo & II)1755 void ASTReader::updateOutOfDateIdentifier(IdentifierInfo &II) {
1756   // Note that we are loading an identifier.
1757   Deserializing AnIdentifier(this);
1758 
1759   unsigned PriorGeneration = 0;
1760   if (getContext().getLangOpts().Modules)
1761     PriorGeneration = IdentifierGeneration[&II];
1762 
1763   // If there is a global index, look there first to determine which modules
1764   // provably do not have any results for this identifier.
1765   GlobalModuleIndex::HitSet Hits;
1766   GlobalModuleIndex::HitSet *HitsPtr = nullptr;
1767   if (!loadGlobalIndex()) {
1768     if (GlobalIndex->lookupIdentifier(II.getName(), Hits)) {
1769       HitsPtr = &Hits;
1770     }
1771   }
1772 
1773   IdentifierLookupVisitor Visitor(II.getName(), PriorGeneration,
1774                                   NumIdentifierLookups,
1775                                   NumIdentifierLookupHits);
1776   ModuleMgr.visit(Visitor, HitsPtr);
1777   markIdentifierUpToDate(&II);
1778 }
1779 
markIdentifierUpToDate(IdentifierInfo * II)1780 void ASTReader::markIdentifierUpToDate(IdentifierInfo *II) {
1781   if (!II)
1782     return;
1783 
1784   II->setOutOfDate(false);
1785 
1786   // Update the generation for this identifier.
1787   if (getContext().getLangOpts().Modules)
1788     IdentifierGeneration[II] = getGeneration();
1789 }
1790 
resolvePendingMacro(IdentifierInfo * II,const PendingMacroInfo & PMInfo)1791 void ASTReader::resolvePendingMacro(IdentifierInfo *II,
1792                                     const PendingMacroInfo &PMInfo) {
1793   ModuleFile &M = *PMInfo.M;
1794 
1795   BitstreamCursor &Cursor = M.MacroCursor;
1796   SavedStreamPosition SavedPosition(Cursor);
1797   Cursor.JumpToBit(PMInfo.MacroDirectivesOffset);
1798 
1799   struct ModuleMacroRecord {
1800     SubmoduleID SubModID;
1801     MacroInfo *MI;
1802     SmallVector<SubmoduleID, 8> Overrides;
1803   };
1804   llvm::SmallVector<ModuleMacroRecord, 8> ModuleMacros;
1805 
1806   // We expect to see a sequence of PP_MODULE_MACRO records listing exported
1807   // macros, followed by a PP_MACRO_DIRECTIVE_HISTORY record with the complete
1808   // macro histroy.
1809   RecordData Record;
1810   while (true) {
1811     llvm::BitstreamEntry Entry =
1812         Cursor.advance(BitstreamCursor::AF_DontPopBlockAtEnd);
1813     if (Entry.Kind != llvm::BitstreamEntry::Record) {
1814       Error("malformed block record in AST file");
1815       return;
1816     }
1817 
1818     Record.clear();
1819     switch ((PreprocessorRecordTypes)Cursor.readRecord(Entry.ID, Record)) {
1820     case PP_MACRO_DIRECTIVE_HISTORY:
1821       break;
1822 
1823     case PP_MODULE_MACRO: {
1824       ModuleMacros.push_back(ModuleMacroRecord());
1825       auto &Info = ModuleMacros.back();
1826       Info.SubModID = getGlobalSubmoduleID(M, Record[0]);
1827       Info.MI = getMacro(getGlobalMacroID(M, Record[1]));
1828       for (int I = 2, N = Record.size(); I != N; ++I)
1829         Info.Overrides.push_back(getGlobalSubmoduleID(M, Record[I]));
1830       continue;
1831     }
1832 
1833     default:
1834       Error("malformed block record in AST file");
1835       return;
1836     }
1837 
1838     // We found the macro directive history; that's the last record
1839     // for this macro.
1840     break;
1841   }
1842 
1843   // Module macros are listed in reverse dependency order.
1844   {
1845     std::reverse(ModuleMacros.begin(), ModuleMacros.end());
1846     llvm::SmallVector<ModuleMacro*, 8> Overrides;
1847     for (auto &MMR : ModuleMacros) {
1848       Overrides.clear();
1849       for (unsigned ModID : MMR.Overrides) {
1850         Module *Mod = getSubmodule(ModID);
1851         auto *Macro = PP.getModuleMacro(Mod, II);
1852         assert(Macro && "missing definition for overridden macro");
1853         Overrides.push_back(Macro);
1854       }
1855 
1856       bool Inserted = false;
1857       Module *Owner = getSubmodule(MMR.SubModID);
1858       PP.addModuleMacro(Owner, II, MMR.MI, Overrides, Inserted);
1859     }
1860   }
1861 
1862   // Don't read the directive history for a module; we don't have anywhere
1863   // to put it.
1864   if (M.Kind == MK_ImplicitModule || M.Kind == MK_ExplicitModule)
1865     return;
1866 
1867   // Deserialize the macro directives history in reverse source-order.
1868   MacroDirective *Latest = nullptr, *Earliest = nullptr;
1869   unsigned Idx = 0, N = Record.size();
1870   while (Idx < N) {
1871     MacroDirective *MD = nullptr;
1872     SourceLocation Loc = ReadSourceLocation(M, Record, Idx);
1873     MacroDirective::Kind K = (MacroDirective::Kind)Record[Idx++];
1874     switch (K) {
1875     case MacroDirective::MD_Define: {
1876       MacroInfo *MI = getMacro(getGlobalMacroID(M, Record[Idx++]));
1877       MD = PP.AllocateDefMacroDirective(MI, Loc);
1878       break;
1879     }
1880     case MacroDirective::MD_Undefine: {
1881       MD = PP.AllocateUndefMacroDirective(Loc);
1882       break;
1883     }
1884     case MacroDirective::MD_Visibility:
1885       bool isPublic = Record[Idx++];
1886       MD = PP.AllocateVisibilityMacroDirective(Loc, isPublic);
1887       break;
1888     }
1889 
1890     if (!Latest)
1891       Latest = MD;
1892     if (Earliest)
1893       Earliest->setPrevious(MD);
1894     Earliest = MD;
1895   }
1896 
1897   if (Latest)
1898     PP.setLoadedMacroDirective(II, Latest);
1899 }
1900 
1901 ASTReader::InputFileInfo
readInputFileInfo(ModuleFile & F,unsigned ID)1902 ASTReader::readInputFileInfo(ModuleFile &F, unsigned ID) {
1903   // Go find this input file.
1904   BitstreamCursor &Cursor = F.InputFilesCursor;
1905   SavedStreamPosition SavedPosition(Cursor);
1906   Cursor.JumpToBit(F.InputFileOffsets[ID-1]);
1907 
1908   unsigned Code = Cursor.ReadCode();
1909   RecordData Record;
1910   StringRef Blob;
1911 
1912   unsigned Result = Cursor.readRecord(Code, Record, &Blob);
1913   assert(static_cast<InputFileRecordTypes>(Result) == INPUT_FILE &&
1914          "invalid record type for input file");
1915   (void)Result;
1916 
1917   assert(Record[0] == ID && "Bogus stored ID or offset");
1918   InputFileInfo R;
1919   R.StoredSize = static_cast<off_t>(Record[1]);
1920   R.StoredTime = static_cast<time_t>(Record[2]);
1921   R.Overridden = static_cast<bool>(Record[3]);
1922   R.Transient = static_cast<bool>(Record[4]);
1923   R.Filename = Blob;
1924   ResolveImportedPath(F, R.Filename);
1925   return R;
1926 }
1927 
getInputFile(ModuleFile & F,unsigned ID,bool Complain)1928 InputFile ASTReader::getInputFile(ModuleFile &F, unsigned ID, bool Complain) {
1929   // If this ID is bogus, just return an empty input file.
1930   if (ID == 0 || ID > F.InputFilesLoaded.size())
1931     return InputFile();
1932 
1933   // If we've already loaded this input file, return it.
1934   if (F.InputFilesLoaded[ID-1].getFile())
1935     return F.InputFilesLoaded[ID-1];
1936 
1937   if (F.InputFilesLoaded[ID-1].isNotFound())
1938     return InputFile();
1939 
1940   // Go find this input file.
1941   BitstreamCursor &Cursor = F.InputFilesCursor;
1942   SavedStreamPosition SavedPosition(Cursor);
1943   Cursor.JumpToBit(F.InputFileOffsets[ID-1]);
1944 
1945   InputFileInfo FI = readInputFileInfo(F, ID);
1946   off_t StoredSize = FI.StoredSize;
1947   time_t StoredTime = FI.StoredTime;
1948   bool Overridden = FI.Overridden;
1949   bool Transient = FI.Transient;
1950   StringRef Filename = FI.Filename;
1951 
1952   const FileEntry *File = FileMgr.getFile(Filename, /*OpenFile=*/false);
1953 
1954   // If we didn't find the file, resolve it relative to the
1955   // original directory from which this AST file was created.
1956   if (File == nullptr && !F.OriginalDir.empty() && !CurrentDir.empty() &&
1957       F.OriginalDir != CurrentDir) {
1958     std::string Resolved = resolveFileRelativeToOriginalDir(Filename,
1959                                                             F.OriginalDir,
1960                                                             CurrentDir);
1961     if (!Resolved.empty())
1962       File = FileMgr.getFile(Resolved);
1963   }
1964 
1965   // For an overridden file, create a virtual file with the stored
1966   // size/timestamp.
1967   if ((Overridden || Transient) && File == nullptr)
1968     File = FileMgr.getVirtualFile(Filename, StoredSize, StoredTime);
1969 
1970   if (File == nullptr) {
1971     if (Complain) {
1972       std::string ErrorStr = "could not find file '";
1973       ErrorStr += Filename;
1974       ErrorStr += "' referenced by AST file '";
1975       ErrorStr += F.FileName;
1976       ErrorStr += "'";
1977       Error(ErrorStr.c_str());
1978     }
1979     // Record that we didn't find the file.
1980     F.InputFilesLoaded[ID-1] = InputFile::getNotFound();
1981     return InputFile();
1982   }
1983 
1984   // Check if there was a request to override the contents of the file
1985   // that was part of the precompiled header. Overridding such a file
1986   // can lead to problems when lexing using the source locations from the
1987   // PCH.
1988   SourceManager &SM = getSourceManager();
1989   // FIXME: Reject if the overrides are different.
1990   if ((!Overridden && !Transient) && SM.isFileOverridden(File)) {
1991     if (Complain)
1992       Error(diag::err_fe_pch_file_overridden, Filename);
1993     // After emitting the diagnostic, recover by disabling the override so
1994     // that the original file will be used.
1995     //
1996     // FIXME: This recovery is just as broken as the original state; there may
1997     // be another precompiled module that's using the overridden contents, or
1998     // we might be half way through parsing it. Instead, we should treat the
1999     // overridden contents as belonging to a separate FileEntry.
2000     SM.disableFileContentsOverride(File);
2001     // The FileEntry is a virtual file entry with the size of the contents
2002     // that would override the original contents. Set it to the original's
2003     // size/time.
2004     FileMgr.modifyFileEntry(const_cast<FileEntry*>(File),
2005                             StoredSize, StoredTime);
2006   }
2007 
2008   bool IsOutOfDate = false;
2009 
2010   // For an overridden file, there is nothing to validate.
2011   if (!Overridden && //
2012       (StoredSize != File->getSize() ||
2013        (StoredTime && StoredTime != File->getModificationTime() &&
2014         !DisableValidation)
2015        )) {
2016     if (Complain) {
2017       // Build a list of the PCH imports that got us here (in reverse).
2018       SmallVector<ModuleFile *, 4> ImportStack(1, &F);
2019       while (ImportStack.back()->ImportedBy.size() > 0)
2020         ImportStack.push_back(ImportStack.back()->ImportedBy[0]);
2021 
2022       // The top-level PCH is stale.
2023       StringRef TopLevelPCHName(ImportStack.back()->FileName);
2024       Error(diag::err_fe_pch_file_modified, Filename, TopLevelPCHName);
2025 
2026       // Print the import stack.
2027       if (ImportStack.size() > 1 && !Diags.isDiagnosticInFlight()) {
2028         Diag(diag::note_pch_required_by)
2029           << Filename << ImportStack[0]->FileName;
2030         for (unsigned I = 1; I < ImportStack.size(); ++I)
2031           Diag(diag::note_pch_required_by)
2032             << ImportStack[I-1]->FileName << ImportStack[I]->FileName;
2033       }
2034 
2035       if (!Diags.isDiagnosticInFlight())
2036         Diag(diag::note_pch_rebuild_required) << TopLevelPCHName;
2037     }
2038 
2039     IsOutOfDate = true;
2040   }
2041   // FIXME: If the file is overridden and we've already opened it,
2042   // issue an error (or split it into a separate FileEntry).
2043 
2044   InputFile IF = InputFile(File, Overridden || Transient, IsOutOfDate);
2045 
2046   // Note that we've loaded this input file.
2047   F.InputFilesLoaded[ID-1] = IF;
2048   return IF;
2049 }
2050 
2051 /// \brief If we are loading a relocatable PCH or module file, and the filename
2052 /// is not an absolute path, add the system or module root to the beginning of
2053 /// the file name.
ResolveImportedPath(ModuleFile & M,std::string & Filename)2054 void ASTReader::ResolveImportedPath(ModuleFile &M, std::string &Filename) {
2055   // Resolve relative to the base directory, if we have one.
2056   if (!M.BaseDirectory.empty())
2057     return ResolveImportedPath(Filename, M.BaseDirectory);
2058 }
2059 
ResolveImportedPath(std::string & Filename,StringRef Prefix)2060 void ASTReader::ResolveImportedPath(std::string &Filename, StringRef Prefix) {
2061   if (Filename.empty() || llvm::sys::path::is_absolute(Filename))
2062     return;
2063 
2064   SmallString<128> Buffer;
2065   llvm::sys::path::append(Buffer, Prefix, Filename);
2066   Filename.assign(Buffer.begin(), Buffer.end());
2067 }
2068 
isDiagnosedResult(ASTReader::ASTReadResult ARR,unsigned Caps)2069 static bool isDiagnosedResult(ASTReader::ASTReadResult ARR, unsigned Caps) {
2070   switch (ARR) {
2071   case ASTReader::Failure: return true;
2072   case ASTReader::Missing: return !(Caps & ASTReader::ARR_Missing);
2073   case ASTReader::OutOfDate: return !(Caps & ASTReader::ARR_OutOfDate);
2074   case ASTReader::VersionMismatch: return !(Caps & ASTReader::ARR_VersionMismatch);
2075   case ASTReader::ConfigurationMismatch:
2076     return !(Caps & ASTReader::ARR_ConfigurationMismatch);
2077   case ASTReader::HadErrors: return true;
2078   case ASTReader::Success: return false;
2079   }
2080 
2081   llvm_unreachable("unknown ASTReadResult");
2082 }
2083 
ReadOptionsBlock(BitstreamCursor & Stream,unsigned ClientLoadCapabilities,bool AllowCompatibleConfigurationMismatch,ASTReaderListener & Listener,std::string & SuggestedPredefines)2084 ASTReader::ASTReadResult ASTReader::ReadOptionsBlock(
2085     BitstreamCursor &Stream, unsigned ClientLoadCapabilities,
2086     bool AllowCompatibleConfigurationMismatch, ASTReaderListener &Listener,
2087     std::string &SuggestedPredefines) {
2088   if (Stream.EnterSubBlock(OPTIONS_BLOCK_ID))
2089     return Failure;
2090 
2091   // Read all of the records in the options block.
2092   RecordData Record;
2093   ASTReadResult Result = Success;
2094   while (1) {
2095     llvm::BitstreamEntry Entry = Stream.advance();
2096 
2097     switch (Entry.Kind) {
2098     case llvm::BitstreamEntry::Error:
2099     case llvm::BitstreamEntry::SubBlock:
2100       return Failure;
2101 
2102     case llvm::BitstreamEntry::EndBlock:
2103       return Result;
2104 
2105     case llvm::BitstreamEntry::Record:
2106       // The interesting case.
2107       break;
2108     }
2109 
2110     // Read and process a record.
2111     Record.clear();
2112     switch ((OptionsRecordTypes)Stream.readRecord(Entry.ID, Record)) {
2113     case LANGUAGE_OPTIONS: {
2114       bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2115       if (ParseLanguageOptions(Record, Complain, Listener,
2116                                AllowCompatibleConfigurationMismatch))
2117         Result = ConfigurationMismatch;
2118       break;
2119     }
2120 
2121     case TARGET_OPTIONS: {
2122       bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2123       if (ParseTargetOptions(Record, Complain, Listener,
2124                              AllowCompatibleConfigurationMismatch))
2125         Result = ConfigurationMismatch;
2126       break;
2127     }
2128 
2129     case DIAGNOSTIC_OPTIONS: {
2130       bool Complain = (ClientLoadCapabilities & ARR_OutOfDate) == 0;
2131       if (!AllowCompatibleConfigurationMismatch &&
2132           ParseDiagnosticOptions(Record, Complain, Listener))
2133         return OutOfDate;
2134       break;
2135     }
2136 
2137     case FILE_SYSTEM_OPTIONS: {
2138       bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2139       if (!AllowCompatibleConfigurationMismatch &&
2140           ParseFileSystemOptions(Record, Complain, Listener))
2141         Result = ConfigurationMismatch;
2142       break;
2143     }
2144 
2145     case HEADER_SEARCH_OPTIONS: {
2146       bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2147       if (!AllowCompatibleConfigurationMismatch &&
2148           ParseHeaderSearchOptions(Record, Complain, Listener))
2149         Result = ConfigurationMismatch;
2150       break;
2151     }
2152 
2153     case PREPROCESSOR_OPTIONS:
2154       bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2155       if (!AllowCompatibleConfigurationMismatch &&
2156           ParsePreprocessorOptions(Record, Complain, Listener,
2157                                    SuggestedPredefines))
2158         Result = ConfigurationMismatch;
2159       break;
2160     }
2161   }
2162 }
2163 
2164 ASTReader::ASTReadResult
ReadControlBlock(ModuleFile & F,SmallVectorImpl<ImportedModule> & Loaded,const ModuleFile * ImportedBy,unsigned ClientLoadCapabilities)2165 ASTReader::ReadControlBlock(ModuleFile &F,
2166                             SmallVectorImpl<ImportedModule> &Loaded,
2167                             const ModuleFile *ImportedBy,
2168                             unsigned ClientLoadCapabilities) {
2169   BitstreamCursor &Stream = F.Stream;
2170   ASTReadResult Result = Success;
2171 
2172   if (Stream.EnterSubBlock(CONTROL_BLOCK_ID)) {
2173     Error("malformed block record in AST file");
2174     return Failure;
2175   }
2176 
2177   // Read all of the records and blocks in the control block.
2178   RecordData Record;
2179   unsigned NumInputs = 0;
2180   unsigned NumUserInputs = 0;
2181   while (1) {
2182     llvm::BitstreamEntry Entry = Stream.advance();
2183 
2184     switch (Entry.Kind) {
2185     case llvm::BitstreamEntry::Error:
2186       Error("malformed block record in AST file");
2187       return Failure;
2188     case llvm::BitstreamEntry::EndBlock: {
2189       // Validate input files.
2190       const HeaderSearchOptions &HSOpts =
2191           PP.getHeaderSearchInfo().getHeaderSearchOpts();
2192 
2193       // All user input files reside at the index range [0, NumUserInputs), and
2194       // system input files reside at [NumUserInputs, NumInputs). For explicitly
2195       // loaded module files, ignore missing inputs.
2196       if (!DisableValidation && F.Kind != MK_ExplicitModule) {
2197         bool Complain = (ClientLoadCapabilities & ARR_OutOfDate) == 0;
2198 
2199         // If we are reading a module, we will create a verification timestamp,
2200         // so we verify all input files.  Otherwise, verify only user input
2201         // files.
2202 
2203         unsigned N = NumUserInputs;
2204         if (ValidateSystemInputs ||
2205             (HSOpts.ModulesValidateOncePerBuildSession &&
2206              F.InputFilesValidationTimestamp <= HSOpts.BuildSessionTimestamp &&
2207              F.Kind == MK_ImplicitModule))
2208           N = NumInputs;
2209 
2210         for (unsigned I = 0; I < N; ++I) {
2211           InputFile IF = getInputFile(F, I+1, Complain);
2212           if (!IF.getFile() || IF.isOutOfDate())
2213             return OutOfDate;
2214         }
2215       }
2216 
2217       if (Listener)
2218         Listener->visitModuleFile(F.FileName, F.Kind);
2219 
2220       if (Listener && Listener->needsInputFileVisitation()) {
2221         unsigned N = Listener->needsSystemInputFileVisitation() ? NumInputs
2222                                                                 : NumUserInputs;
2223         for (unsigned I = 0; I < N; ++I) {
2224           bool IsSystem = I >= NumUserInputs;
2225           InputFileInfo FI = readInputFileInfo(F, I+1);
2226           Listener->visitInputFile(FI.Filename, IsSystem, FI.Overridden,
2227                                    F.Kind == MK_ExplicitModule);
2228         }
2229       }
2230 
2231       return Result;
2232     }
2233 
2234     case llvm::BitstreamEntry::SubBlock:
2235       switch (Entry.ID) {
2236       case INPUT_FILES_BLOCK_ID:
2237         F.InputFilesCursor = Stream;
2238         if (Stream.SkipBlock() || // Skip with the main cursor
2239             // Read the abbreviations
2240             ReadBlockAbbrevs(F.InputFilesCursor, INPUT_FILES_BLOCK_ID)) {
2241           Error("malformed block record in AST file");
2242           return Failure;
2243         }
2244         continue;
2245 
2246       case OPTIONS_BLOCK_ID:
2247         // If we're reading the first module for this group, check its options
2248         // are compatible with ours. For modules it imports, no further checking
2249         // is required, because we checked them when we built it.
2250         if (Listener && !ImportedBy) {
2251           // Should we allow the configuration of the module file to differ from
2252           // the configuration of the current translation unit in a compatible
2253           // way?
2254           //
2255           // FIXME: Allow this for files explicitly specified with -include-pch.
2256           bool AllowCompatibleConfigurationMismatch =
2257               F.Kind == MK_ExplicitModule;
2258 
2259           Result = ReadOptionsBlock(Stream, ClientLoadCapabilities,
2260                                     AllowCompatibleConfigurationMismatch,
2261                                     *Listener, SuggestedPredefines);
2262           if (Result == Failure) {
2263             Error("malformed block record in AST file");
2264             return Result;
2265           }
2266 
2267           if (DisableValidation ||
2268               (AllowConfigurationMismatch && Result == ConfigurationMismatch))
2269             Result = Success;
2270 
2271           // If we can't load the module, exit early since we likely
2272           // will rebuild the module anyway. The stream may be in the
2273           // middle of a block.
2274           if (Result != Success)
2275             return Result;
2276         } else if (Stream.SkipBlock()) {
2277           Error("malformed block record in AST file");
2278           return Failure;
2279         }
2280         continue;
2281 
2282       default:
2283         if (Stream.SkipBlock()) {
2284           Error("malformed block record in AST file");
2285           return Failure;
2286         }
2287         continue;
2288       }
2289 
2290     case llvm::BitstreamEntry::Record:
2291       // The interesting case.
2292       break;
2293     }
2294 
2295     // Read and process a record.
2296     Record.clear();
2297     StringRef Blob;
2298     switch ((ControlRecordTypes)Stream.readRecord(Entry.ID, Record, &Blob)) {
2299     case METADATA: {
2300       if (Record[0] != VERSION_MAJOR && !DisableValidation) {
2301         if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
2302           Diag(Record[0] < VERSION_MAJOR? diag::err_pch_version_too_old
2303                                         : diag::err_pch_version_too_new);
2304         return VersionMismatch;
2305       }
2306 
2307       bool hasErrors = Record[6];
2308       if (hasErrors && !DisableValidation && !AllowASTWithCompilerErrors) {
2309         Diag(diag::err_pch_with_compiler_errors);
2310         return HadErrors;
2311       }
2312       if (hasErrors) {
2313         Diags.ErrorOccurred = true;
2314         Diags.UncompilableErrorOccurred = true;
2315         Diags.UnrecoverableErrorOccurred = true;
2316       }
2317 
2318       F.RelocatablePCH = Record[4];
2319       // Relative paths in a relocatable PCH are relative to our sysroot.
2320       if (F.RelocatablePCH)
2321         F.BaseDirectory = isysroot.empty() ? "/" : isysroot;
2322 
2323       F.HasTimestamps = Record[5];
2324 
2325       const std::string &CurBranch = getClangFullRepositoryVersion();
2326       StringRef ASTBranch = Blob;
2327       if (StringRef(CurBranch) != ASTBranch && !DisableValidation) {
2328         if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
2329           Diag(diag::err_pch_different_branch) << ASTBranch << CurBranch;
2330         return VersionMismatch;
2331       }
2332       break;
2333     }
2334 
2335     case SIGNATURE:
2336       assert((!F.Signature || F.Signature == Record[0]) && "signature changed");
2337       F.Signature = Record[0];
2338       break;
2339 
2340     case IMPORTS: {
2341       // Load each of the imported PCH files.
2342       unsigned Idx = 0, N = Record.size();
2343       while (Idx < N) {
2344         // Read information about the AST file.
2345         ModuleKind ImportedKind = (ModuleKind)Record[Idx++];
2346         // The import location will be the local one for now; we will adjust
2347         // all import locations of module imports after the global source
2348         // location info are setup, in ReadAST.
2349         SourceLocation ImportLoc =
2350             ReadUntranslatedSourceLocation(Record[Idx++]);
2351         off_t StoredSize = (off_t)Record[Idx++];
2352         time_t StoredModTime = (time_t)Record[Idx++];
2353         ASTFileSignature StoredSignature = Record[Idx++];
2354         auto ImportedFile = ReadPath(F, Record, Idx);
2355 
2356         // If our client can't cope with us being out of date, we can't cope with
2357         // our dependency being missing.
2358         unsigned Capabilities = ClientLoadCapabilities;
2359         if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
2360           Capabilities &= ~ARR_Missing;
2361 
2362         // Load the AST file.
2363         auto Result = ReadASTCore(ImportedFile, ImportedKind, ImportLoc, &F,
2364                                   Loaded, StoredSize, StoredModTime,
2365                                   StoredSignature, Capabilities);
2366 
2367         // If we diagnosed a problem, produce a backtrace.
2368         if (isDiagnosedResult(Result, Capabilities))
2369           Diag(diag::note_module_file_imported_by)
2370               << F.FileName << !F.ModuleName.empty() << F.ModuleName;
2371 
2372         switch (Result) {
2373         case Failure: return Failure;
2374           // If we have to ignore the dependency, we'll have to ignore this too.
2375         case Missing:
2376         case OutOfDate: return OutOfDate;
2377         case VersionMismatch: return VersionMismatch;
2378         case ConfigurationMismatch: return ConfigurationMismatch;
2379         case HadErrors: return HadErrors;
2380         case Success: break;
2381         }
2382       }
2383       break;
2384     }
2385 
2386     case ORIGINAL_FILE:
2387       F.OriginalSourceFileID = FileID::get(Record[0]);
2388       F.ActualOriginalSourceFileName = Blob;
2389       F.OriginalSourceFileName = F.ActualOriginalSourceFileName;
2390       ResolveImportedPath(F, F.OriginalSourceFileName);
2391       break;
2392 
2393     case ORIGINAL_FILE_ID:
2394       F.OriginalSourceFileID = FileID::get(Record[0]);
2395       break;
2396 
2397     case ORIGINAL_PCH_DIR:
2398       F.OriginalDir = Blob;
2399       break;
2400 
2401     case MODULE_NAME:
2402       F.ModuleName = Blob;
2403       if (Listener)
2404         Listener->ReadModuleName(F.ModuleName);
2405       break;
2406 
2407     case MODULE_DIRECTORY: {
2408       assert(!F.ModuleName.empty() &&
2409              "MODULE_DIRECTORY found before MODULE_NAME");
2410       // If we've already loaded a module map file covering this module, we may
2411       // have a better path for it (relative to the current build).
2412       Module *M = PP.getHeaderSearchInfo().lookupModule(F.ModuleName);
2413       if (M && M->Directory) {
2414         // If we're implicitly loading a module, the base directory can't
2415         // change between the build and use.
2416         if (F.Kind != MK_ExplicitModule) {
2417           const DirectoryEntry *BuildDir =
2418               PP.getFileManager().getDirectory(Blob);
2419           if (!BuildDir || BuildDir != M->Directory) {
2420             if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
2421               Diag(diag::err_imported_module_relocated)
2422                   << F.ModuleName << Blob << M->Directory->getName();
2423             return OutOfDate;
2424           }
2425         }
2426         F.BaseDirectory = M->Directory->getName();
2427       } else {
2428         F.BaseDirectory = Blob;
2429       }
2430       break;
2431     }
2432 
2433     case MODULE_MAP_FILE:
2434       if (ASTReadResult Result =
2435               ReadModuleMapFileBlock(Record, F, ImportedBy, ClientLoadCapabilities))
2436         return Result;
2437       break;
2438 
2439     case INPUT_FILE_OFFSETS:
2440       NumInputs = Record[0];
2441       NumUserInputs = Record[1];
2442       F.InputFileOffsets =
2443           (const llvm::support::unaligned_uint64_t *)Blob.data();
2444       F.InputFilesLoaded.resize(NumInputs);
2445       break;
2446     }
2447   }
2448 }
2449 
2450 ASTReader::ASTReadResult
ReadASTBlock(ModuleFile & F,unsigned ClientLoadCapabilities)2451 ASTReader::ReadASTBlock(ModuleFile &F, unsigned ClientLoadCapabilities) {
2452   BitstreamCursor &Stream = F.Stream;
2453 
2454   if (Stream.EnterSubBlock(AST_BLOCK_ID)) {
2455     Error("malformed block record in AST file");
2456     return Failure;
2457   }
2458 
2459   // Read all of the records and blocks for the AST file.
2460   RecordData Record;
2461   while (1) {
2462     llvm::BitstreamEntry Entry = Stream.advance();
2463 
2464     switch (Entry.Kind) {
2465     case llvm::BitstreamEntry::Error:
2466       Error("error at end of module block in AST file");
2467       return Failure;
2468     case llvm::BitstreamEntry::EndBlock: {
2469       // Outside of C++, we do not store a lookup map for the translation unit.
2470       // Instead, mark it as needing a lookup map to be built if this module
2471       // contains any declarations lexically within it (which it always does!).
2472       // This usually has no cost, since we very rarely need the lookup map for
2473       // the translation unit outside C++.
2474       DeclContext *DC = Context.getTranslationUnitDecl();
2475       if (DC->hasExternalLexicalStorage() &&
2476           !getContext().getLangOpts().CPlusPlus)
2477         DC->setMustBuildLookupTable();
2478 
2479       return Success;
2480     }
2481     case llvm::BitstreamEntry::SubBlock:
2482       switch (Entry.ID) {
2483       case DECLTYPES_BLOCK_ID:
2484         // We lazily load the decls block, but we want to set up the
2485         // DeclsCursor cursor to point into it.  Clone our current bitcode
2486         // cursor to it, enter the block and read the abbrevs in that block.
2487         // With the main cursor, we just skip over it.
2488         F.DeclsCursor = Stream;
2489         if (Stream.SkipBlock() ||  // Skip with the main cursor.
2490             // Read the abbrevs.
2491             ReadBlockAbbrevs(F.DeclsCursor, DECLTYPES_BLOCK_ID)) {
2492           Error("malformed block record in AST file");
2493           return Failure;
2494         }
2495         break;
2496 
2497       case PREPROCESSOR_BLOCK_ID:
2498         F.MacroCursor = Stream;
2499         if (!PP.getExternalSource())
2500           PP.setExternalSource(this);
2501 
2502         if (Stream.SkipBlock() ||
2503             ReadBlockAbbrevs(F.MacroCursor, PREPROCESSOR_BLOCK_ID)) {
2504           Error("malformed block record in AST file");
2505           return Failure;
2506         }
2507         F.MacroStartOffset = F.MacroCursor.GetCurrentBitNo();
2508         break;
2509 
2510       case PREPROCESSOR_DETAIL_BLOCK_ID:
2511         F.PreprocessorDetailCursor = Stream;
2512         if (Stream.SkipBlock() ||
2513             ReadBlockAbbrevs(F.PreprocessorDetailCursor,
2514                              PREPROCESSOR_DETAIL_BLOCK_ID)) {
2515               Error("malformed preprocessor detail record in AST file");
2516               return Failure;
2517             }
2518         F.PreprocessorDetailStartOffset
2519         = F.PreprocessorDetailCursor.GetCurrentBitNo();
2520 
2521         if (!PP.getPreprocessingRecord())
2522           PP.createPreprocessingRecord();
2523         if (!PP.getPreprocessingRecord()->getExternalSource())
2524           PP.getPreprocessingRecord()->SetExternalSource(*this);
2525         break;
2526 
2527       case SOURCE_MANAGER_BLOCK_ID:
2528         if (ReadSourceManagerBlock(F))
2529           return Failure;
2530         break;
2531 
2532       case SUBMODULE_BLOCK_ID:
2533         if (ASTReadResult Result = ReadSubmoduleBlock(F, ClientLoadCapabilities))
2534           return Result;
2535         break;
2536 
2537       case COMMENTS_BLOCK_ID: {
2538         BitstreamCursor C = Stream;
2539         if (Stream.SkipBlock() ||
2540             ReadBlockAbbrevs(C, COMMENTS_BLOCK_ID)) {
2541           Error("malformed comments block in AST file");
2542           return Failure;
2543         }
2544         CommentsCursors.push_back(std::make_pair(C, &F));
2545         break;
2546       }
2547 
2548       default:
2549         if (Stream.SkipBlock()) {
2550           Error("malformed block record in AST file");
2551           return Failure;
2552         }
2553         break;
2554       }
2555       continue;
2556 
2557     case llvm::BitstreamEntry::Record:
2558       // The interesting case.
2559       break;
2560     }
2561 
2562     // Read and process a record.
2563     Record.clear();
2564     StringRef Blob;
2565     switch ((ASTRecordTypes)Stream.readRecord(Entry.ID, Record, &Blob)) {
2566     default:  // Default behavior: ignore.
2567       break;
2568 
2569     case TYPE_OFFSET: {
2570       if (F.LocalNumTypes != 0) {
2571         Error("duplicate TYPE_OFFSET record in AST file");
2572         return Failure;
2573       }
2574       F.TypeOffsets = (const uint32_t *)Blob.data();
2575       F.LocalNumTypes = Record[0];
2576       unsigned LocalBaseTypeIndex = Record[1];
2577       F.BaseTypeIndex = getTotalNumTypes();
2578 
2579       if (F.LocalNumTypes > 0) {
2580         // Introduce the global -> local mapping for types within this module.
2581         GlobalTypeMap.insert(std::make_pair(getTotalNumTypes(), &F));
2582 
2583         // Introduce the local -> global mapping for types within this module.
2584         F.TypeRemap.insertOrReplace(
2585           std::make_pair(LocalBaseTypeIndex,
2586                          F.BaseTypeIndex - LocalBaseTypeIndex));
2587 
2588         TypesLoaded.resize(TypesLoaded.size() + F.LocalNumTypes);
2589       }
2590       break;
2591     }
2592 
2593     case DECL_OFFSET: {
2594       if (F.LocalNumDecls != 0) {
2595         Error("duplicate DECL_OFFSET record in AST file");
2596         return Failure;
2597       }
2598       F.DeclOffsets = (const DeclOffset *)Blob.data();
2599       F.LocalNumDecls = Record[0];
2600       unsigned LocalBaseDeclID = Record[1];
2601       F.BaseDeclID = getTotalNumDecls();
2602 
2603       if (F.LocalNumDecls > 0) {
2604         // Introduce the global -> local mapping for declarations within this
2605         // module.
2606         GlobalDeclMap.insert(
2607           std::make_pair(getTotalNumDecls() + NUM_PREDEF_DECL_IDS, &F));
2608 
2609         // Introduce the local -> global mapping for declarations within this
2610         // module.
2611         F.DeclRemap.insertOrReplace(
2612           std::make_pair(LocalBaseDeclID, F.BaseDeclID - LocalBaseDeclID));
2613 
2614         // Introduce the global -> local mapping for declarations within this
2615         // module.
2616         F.GlobalToLocalDeclIDs[&F] = LocalBaseDeclID;
2617 
2618         DeclsLoaded.resize(DeclsLoaded.size() + F.LocalNumDecls);
2619       }
2620       break;
2621     }
2622 
2623     case TU_UPDATE_LEXICAL: {
2624       DeclContext *TU = Context.getTranslationUnitDecl();
2625       LexicalContents Contents(
2626           reinterpret_cast<const llvm::support::unaligned_uint32_t *>(
2627               Blob.data()),
2628           static_cast<unsigned int>(Blob.size() / 4));
2629       TULexicalDecls.push_back(std::make_pair(&F, Contents));
2630       TU->setHasExternalLexicalStorage(true);
2631       break;
2632     }
2633 
2634     case UPDATE_VISIBLE: {
2635       unsigned Idx = 0;
2636       serialization::DeclID ID = ReadDeclID(F, Record, Idx);
2637       auto *Data = (const unsigned char*)Blob.data();
2638       PendingVisibleUpdates[ID].push_back(PendingVisibleUpdate{&F, Data});
2639       // If we've already loaded the decl, perform the updates when we finish
2640       // loading this block.
2641       if (Decl *D = GetExistingDecl(ID))
2642         PendingUpdateRecords.push_back(std::make_pair(ID, D));
2643       break;
2644     }
2645 
2646     case IDENTIFIER_TABLE:
2647       F.IdentifierTableData = Blob.data();
2648       if (Record[0]) {
2649         F.IdentifierLookupTable = ASTIdentifierLookupTable::Create(
2650             (const unsigned char *)F.IdentifierTableData + Record[0],
2651             (const unsigned char *)F.IdentifierTableData + sizeof(uint32_t),
2652             (const unsigned char *)F.IdentifierTableData,
2653             ASTIdentifierLookupTrait(*this, F));
2654 
2655         PP.getIdentifierTable().setExternalIdentifierLookup(this);
2656       }
2657       break;
2658 
2659     case IDENTIFIER_OFFSET: {
2660       if (F.LocalNumIdentifiers != 0) {
2661         Error("duplicate IDENTIFIER_OFFSET record in AST file");
2662         return Failure;
2663       }
2664       F.IdentifierOffsets = (const uint32_t *)Blob.data();
2665       F.LocalNumIdentifiers = Record[0];
2666       unsigned LocalBaseIdentifierID = Record[1];
2667       F.BaseIdentifierID = getTotalNumIdentifiers();
2668 
2669       if (F.LocalNumIdentifiers > 0) {
2670         // Introduce the global -> local mapping for identifiers within this
2671         // module.
2672         GlobalIdentifierMap.insert(std::make_pair(getTotalNumIdentifiers() + 1,
2673                                                   &F));
2674 
2675         // Introduce the local -> global mapping for identifiers within this
2676         // module.
2677         F.IdentifierRemap.insertOrReplace(
2678           std::make_pair(LocalBaseIdentifierID,
2679                          F.BaseIdentifierID - LocalBaseIdentifierID));
2680 
2681         IdentifiersLoaded.resize(IdentifiersLoaded.size()
2682                                  + F.LocalNumIdentifiers);
2683       }
2684       break;
2685     }
2686 
2687     case INTERESTING_IDENTIFIERS:
2688       F.PreloadIdentifierOffsets.assign(Record.begin(), Record.end());
2689       break;
2690 
2691     case EAGERLY_DESERIALIZED_DECLS:
2692       // FIXME: Skip reading this record if our ASTConsumer doesn't care
2693       // about "interesting" decls (for instance, if we're building a module).
2694       for (unsigned I = 0, N = Record.size(); I != N; ++I)
2695         EagerlyDeserializedDecls.push_back(getGlobalDeclID(F, Record[I]));
2696       break;
2697 
2698     case SPECIAL_TYPES:
2699       if (SpecialTypes.empty()) {
2700         for (unsigned I = 0, N = Record.size(); I != N; ++I)
2701           SpecialTypes.push_back(getGlobalTypeID(F, Record[I]));
2702         break;
2703       }
2704 
2705       if (SpecialTypes.size() != Record.size()) {
2706         Error("invalid special-types record");
2707         return Failure;
2708       }
2709 
2710       for (unsigned I = 0, N = Record.size(); I != N; ++I) {
2711         serialization::TypeID ID = getGlobalTypeID(F, Record[I]);
2712         if (!SpecialTypes[I])
2713           SpecialTypes[I] = ID;
2714         // FIXME: If ID && SpecialTypes[I] != ID, do we need a separate
2715         // merge step?
2716       }
2717       break;
2718 
2719     case STATISTICS:
2720       TotalNumStatements += Record[0];
2721       TotalNumMacros += Record[1];
2722       TotalLexicalDeclContexts += Record[2];
2723       TotalVisibleDeclContexts += Record[3];
2724       break;
2725 
2726     case UNUSED_FILESCOPED_DECLS:
2727       for (unsigned I = 0, N = Record.size(); I != N; ++I)
2728         UnusedFileScopedDecls.push_back(getGlobalDeclID(F, Record[I]));
2729       break;
2730 
2731     case DELEGATING_CTORS:
2732       for (unsigned I = 0, N = Record.size(); I != N; ++I)
2733         DelegatingCtorDecls.push_back(getGlobalDeclID(F, Record[I]));
2734       break;
2735 
2736     case WEAK_UNDECLARED_IDENTIFIERS:
2737       if (Record.size() % 4 != 0) {
2738         Error("invalid weak identifiers record");
2739         return Failure;
2740       }
2741 
2742       // FIXME: Ignore weak undeclared identifiers from non-original PCH
2743       // files. This isn't the way to do it :)
2744       WeakUndeclaredIdentifiers.clear();
2745 
2746       // Translate the weak, undeclared identifiers into global IDs.
2747       for (unsigned I = 0, N = Record.size(); I < N; /* in loop */) {
2748         WeakUndeclaredIdentifiers.push_back(
2749           getGlobalIdentifierID(F, Record[I++]));
2750         WeakUndeclaredIdentifiers.push_back(
2751           getGlobalIdentifierID(F, Record[I++]));
2752         WeakUndeclaredIdentifiers.push_back(
2753           ReadSourceLocation(F, Record, I).getRawEncoding());
2754         WeakUndeclaredIdentifiers.push_back(Record[I++]);
2755       }
2756       break;
2757 
2758     case SELECTOR_OFFSETS: {
2759       F.SelectorOffsets = (const uint32_t *)Blob.data();
2760       F.LocalNumSelectors = Record[0];
2761       unsigned LocalBaseSelectorID = Record[1];
2762       F.BaseSelectorID = getTotalNumSelectors();
2763 
2764       if (F.LocalNumSelectors > 0) {
2765         // Introduce the global -> local mapping for selectors within this
2766         // module.
2767         GlobalSelectorMap.insert(std::make_pair(getTotalNumSelectors()+1, &F));
2768 
2769         // Introduce the local -> global mapping for selectors within this
2770         // module.
2771         F.SelectorRemap.insertOrReplace(
2772           std::make_pair(LocalBaseSelectorID,
2773                          F.BaseSelectorID - LocalBaseSelectorID));
2774 
2775         SelectorsLoaded.resize(SelectorsLoaded.size() + F.LocalNumSelectors);
2776       }
2777       break;
2778     }
2779 
2780     case METHOD_POOL:
2781       F.SelectorLookupTableData = (const unsigned char *)Blob.data();
2782       if (Record[0])
2783         F.SelectorLookupTable
2784           = ASTSelectorLookupTable::Create(
2785                         F.SelectorLookupTableData + Record[0],
2786                         F.SelectorLookupTableData,
2787                         ASTSelectorLookupTrait(*this, F));
2788       TotalNumMethodPoolEntries += Record[1];
2789       break;
2790 
2791     case REFERENCED_SELECTOR_POOL:
2792       if (!Record.empty()) {
2793         for (unsigned Idx = 0, N = Record.size() - 1; Idx < N; /* in loop */) {
2794           ReferencedSelectorsData.push_back(getGlobalSelectorID(F,
2795                                                                 Record[Idx++]));
2796           ReferencedSelectorsData.push_back(ReadSourceLocation(F, Record, Idx).
2797                                               getRawEncoding());
2798         }
2799       }
2800       break;
2801 
2802     case PP_COUNTER_VALUE:
2803       if (!Record.empty() && Listener)
2804         Listener->ReadCounter(F, Record[0]);
2805       break;
2806 
2807     case FILE_SORTED_DECLS:
2808       F.FileSortedDecls = (const DeclID *)Blob.data();
2809       F.NumFileSortedDecls = Record[0];
2810       break;
2811 
2812     case SOURCE_LOCATION_OFFSETS: {
2813       F.SLocEntryOffsets = (const uint32_t *)Blob.data();
2814       F.LocalNumSLocEntries = Record[0];
2815       unsigned SLocSpaceSize = Record[1];
2816       std::tie(F.SLocEntryBaseID, F.SLocEntryBaseOffset) =
2817           SourceMgr.AllocateLoadedSLocEntries(F.LocalNumSLocEntries,
2818                                               SLocSpaceSize);
2819       if (!F.SLocEntryBaseID) {
2820         Error("ran out of source locations");
2821         break;
2822       }
2823       // Make our entry in the range map. BaseID is negative and growing, so
2824       // we invert it. Because we invert it, though, we need the other end of
2825       // the range.
2826       unsigned RangeStart =
2827           unsigned(-F.SLocEntryBaseID) - F.LocalNumSLocEntries + 1;
2828       GlobalSLocEntryMap.insert(std::make_pair(RangeStart, &F));
2829       F.FirstLoc = SourceLocation::getFromRawEncoding(F.SLocEntryBaseOffset);
2830 
2831       // SLocEntryBaseOffset is lower than MaxLoadedOffset and decreasing.
2832       assert((F.SLocEntryBaseOffset & (1U << 31U)) == 0);
2833       GlobalSLocOffsetMap.insert(
2834           std::make_pair(SourceManager::MaxLoadedOffset - F.SLocEntryBaseOffset
2835                            - SLocSpaceSize,&F));
2836 
2837       // Initialize the remapping table.
2838       // Invalid stays invalid.
2839       F.SLocRemap.insertOrReplace(std::make_pair(0U, 0));
2840       // This module. Base was 2 when being compiled.
2841       F.SLocRemap.insertOrReplace(std::make_pair(2U,
2842                                   static_cast<int>(F.SLocEntryBaseOffset - 2)));
2843 
2844       TotalNumSLocEntries += F.LocalNumSLocEntries;
2845       break;
2846     }
2847 
2848     case MODULE_OFFSET_MAP: {
2849       // Additional remapping information.
2850       const unsigned char *Data = (const unsigned char*)Blob.data();
2851       const unsigned char *DataEnd = Data + Blob.size();
2852 
2853       // If we see this entry before SOURCE_LOCATION_OFFSETS, add placeholders.
2854       if (F.SLocRemap.find(0) == F.SLocRemap.end()) {
2855         F.SLocRemap.insert(std::make_pair(0U, 0));
2856         F.SLocRemap.insert(std::make_pair(2U, 1));
2857       }
2858 
2859       // Continuous range maps we may be updating in our module.
2860       typedef ContinuousRangeMap<uint32_t, int, 2>::Builder
2861           RemapBuilder;
2862       RemapBuilder SLocRemap(F.SLocRemap);
2863       RemapBuilder IdentifierRemap(F.IdentifierRemap);
2864       RemapBuilder MacroRemap(F.MacroRemap);
2865       RemapBuilder PreprocessedEntityRemap(F.PreprocessedEntityRemap);
2866       RemapBuilder SubmoduleRemap(F.SubmoduleRemap);
2867       RemapBuilder SelectorRemap(F.SelectorRemap);
2868       RemapBuilder DeclRemap(F.DeclRemap);
2869       RemapBuilder TypeRemap(F.TypeRemap);
2870 
2871       while (Data < DataEnd) {
2872         using namespace llvm::support;
2873         uint16_t Len = endian::readNext<uint16_t, little, unaligned>(Data);
2874         StringRef Name = StringRef((const char*)Data, Len);
2875         Data += Len;
2876         ModuleFile *OM = ModuleMgr.lookup(Name);
2877         if (!OM) {
2878           Error("SourceLocation remap refers to unknown module");
2879           return Failure;
2880         }
2881 
2882         uint32_t SLocOffset =
2883             endian::readNext<uint32_t, little, unaligned>(Data);
2884         uint32_t IdentifierIDOffset =
2885             endian::readNext<uint32_t, little, unaligned>(Data);
2886         uint32_t MacroIDOffset =
2887             endian::readNext<uint32_t, little, unaligned>(Data);
2888         uint32_t PreprocessedEntityIDOffset =
2889             endian::readNext<uint32_t, little, unaligned>(Data);
2890         uint32_t SubmoduleIDOffset =
2891             endian::readNext<uint32_t, little, unaligned>(Data);
2892         uint32_t SelectorIDOffset =
2893             endian::readNext<uint32_t, little, unaligned>(Data);
2894         uint32_t DeclIDOffset =
2895             endian::readNext<uint32_t, little, unaligned>(Data);
2896         uint32_t TypeIndexOffset =
2897             endian::readNext<uint32_t, little, unaligned>(Data);
2898 
2899         uint32_t None = std::numeric_limits<uint32_t>::max();
2900 
2901         auto mapOffset = [&](uint32_t Offset, uint32_t BaseOffset,
2902                              RemapBuilder &Remap) {
2903           if (Offset != None)
2904             Remap.insert(std::make_pair(Offset,
2905                                         static_cast<int>(BaseOffset - Offset)));
2906         };
2907         mapOffset(SLocOffset, OM->SLocEntryBaseOffset, SLocRemap);
2908         mapOffset(IdentifierIDOffset, OM->BaseIdentifierID, IdentifierRemap);
2909         mapOffset(MacroIDOffset, OM->BaseMacroID, MacroRemap);
2910         mapOffset(PreprocessedEntityIDOffset, OM->BasePreprocessedEntityID,
2911                   PreprocessedEntityRemap);
2912         mapOffset(SubmoduleIDOffset, OM->BaseSubmoduleID, SubmoduleRemap);
2913         mapOffset(SelectorIDOffset, OM->BaseSelectorID, SelectorRemap);
2914         mapOffset(DeclIDOffset, OM->BaseDeclID, DeclRemap);
2915         mapOffset(TypeIndexOffset, OM->BaseTypeIndex, TypeRemap);
2916 
2917         // Global -> local mappings.
2918         F.GlobalToLocalDeclIDs[OM] = DeclIDOffset;
2919       }
2920       break;
2921     }
2922 
2923     case SOURCE_MANAGER_LINE_TABLE:
2924       if (ParseLineTable(F, Record))
2925         return Failure;
2926       break;
2927 
2928     case SOURCE_LOCATION_PRELOADS: {
2929       // Need to transform from the local view (1-based IDs) to the global view,
2930       // which is based off F.SLocEntryBaseID.
2931       if (!F.PreloadSLocEntries.empty()) {
2932         Error("Multiple SOURCE_LOCATION_PRELOADS records in AST file");
2933         return Failure;
2934       }
2935 
2936       F.PreloadSLocEntries.swap(Record);
2937       break;
2938     }
2939 
2940     case EXT_VECTOR_DECLS:
2941       for (unsigned I = 0, N = Record.size(); I != N; ++I)
2942         ExtVectorDecls.push_back(getGlobalDeclID(F, Record[I]));
2943       break;
2944 
2945     case VTABLE_USES:
2946       if (Record.size() % 3 != 0) {
2947         Error("Invalid VTABLE_USES record");
2948         return Failure;
2949       }
2950 
2951       // Later tables overwrite earlier ones.
2952       // FIXME: Modules will have some trouble with this. This is clearly not
2953       // the right way to do this.
2954       VTableUses.clear();
2955 
2956       for (unsigned Idx = 0, N = Record.size(); Idx != N; /* In loop */) {
2957         VTableUses.push_back(getGlobalDeclID(F, Record[Idx++]));
2958         VTableUses.push_back(
2959           ReadSourceLocation(F, Record, Idx).getRawEncoding());
2960         VTableUses.push_back(Record[Idx++]);
2961       }
2962       break;
2963 
2964     case PENDING_IMPLICIT_INSTANTIATIONS:
2965       if (PendingInstantiations.size() % 2 != 0) {
2966         Error("Invalid existing PendingInstantiations");
2967         return Failure;
2968       }
2969 
2970       if (Record.size() % 2 != 0) {
2971         Error("Invalid PENDING_IMPLICIT_INSTANTIATIONS block");
2972         return Failure;
2973       }
2974 
2975       for (unsigned I = 0, N = Record.size(); I != N; /* in loop */) {
2976         PendingInstantiations.push_back(getGlobalDeclID(F, Record[I++]));
2977         PendingInstantiations.push_back(
2978           ReadSourceLocation(F, Record, I).getRawEncoding());
2979       }
2980       break;
2981 
2982     case SEMA_DECL_REFS:
2983       if (Record.size() != 2) {
2984         Error("Invalid SEMA_DECL_REFS block");
2985         return Failure;
2986       }
2987       for (unsigned I = 0, N = Record.size(); I != N; ++I)
2988         SemaDeclRefs.push_back(getGlobalDeclID(F, Record[I]));
2989       break;
2990 
2991     case PPD_ENTITIES_OFFSETS: {
2992       F.PreprocessedEntityOffsets = (const PPEntityOffset *)Blob.data();
2993       assert(Blob.size() % sizeof(PPEntityOffset) == 0);
2994       F.NumPreprocessedEntities = Blob.size() / sizeof(PPEntityOffset);
2995 
2996       unsigned LocalBasePreprocessedEntityID = Record[0];
2997 
2998       unsigned StartingID;
2999       if (!PP.getPreprocessingRecord())
3000         PP.createPreprocessingRecord();
3001       if (!PP.getPreprocessingRecord()->getExternalSource())
3002         PP.getPreprocessingRecord()->SetExternalSource(*this);
3003       StartingID
3004         = PP.getPreprocessingRecord()
3005             ->allocateLoadedEntities(F.NumPreprocessedEntities);
3006       F.BasePreprocessedEntityID = StartingID;
3007 
3008       if (F.NumPreprocessedEntities > 0) {
3009         // Introduce the global -> local mapping for preprocessed entities in
3010         // this module.
3011         GlobalPreprocessedEntityMap.insert(std::make_pair(StartingID, &F));
3012 
3013         // Introduce the local -> global mapping for preprocessed entities in
3014         // this module.
3015         F.PreprocessedEntityRemap.insertOrReplace(
3016           std::make_pair(LocalBasePreprocessedEntityID,
3017             F.BasePreprocessedEntityID - LocalBasePreprocessedEntityID));
3018       }
3019 
3020       break;
3021     }
3022 
3023     case DECL_UPDATE_OFFSETS: {
3024       if (Record.size() % 2 != 0) {
3025         Error("invalid DECL_UPDATE_OFFSETS block in AST file");
3026         return Failure;
3027       }
3028       for (unsigned I = 0, N = Record.size(); I != N; I += 2) {
3029         GlobalDeclID ID = getGlobalDeclID(F, Record[I]);
3030         DeclUpdateOffsets[ID].push_back(std::make_pair(&F, Record[I + 1]));
3031 
3032         // If we've already loaded the decl, perform the updates when we finish
3033         // loading this block.
3034         if (Decl *D = GetExistingDecl(ID))
3035           PendingUpdateRecords.push_back(std::make_pair(ID, D));
3036       }
3037       break;
3038     }
3039 
3040     case OBJC_CATEGORIES_MAP: {
3041       if (F.LocalNumObjCCategoriesInMap != 0) {
3042         Error("duplicate OBJC_CATEGORIES_MAP record in AST file");
3043         return Failure;
3044       }
3045 
3046       F.LocalNumObjCCategoriesInMap = Record[0];
3047       F.ObjCCategoriesMap = (const ObjCCategoriesInfo *)Blob.data();
3048       break;
3049     }
3050 
3051     case OBJC_CATEGORIES:
3052       F.ObjCCategories.swap(Record);
3053       break;
3054 
3055     case DIAG_PRAGMA_MAPPINGS:
3056       if (F.PragmaDiagMappings.empty())
3057         F.PragmaDiagMappings.swap(Record);
3058       else
3059         F.PragmaDiagMappings.insert(F.PragmaDiagMappings.end(),
3060                                     Record.begin(), Record.end());
3061       break;
3062 
3063     case CUDA_SPECIAL_DECL_REFS:
3064       // Later tables overwrite earlier ones.
3065       // FIXME: Modules will have trouble with this.
3066       CUDASpecialDeclRefs.clear();
3067       for (unsigned I = 0, N = Record.size(); I != N; ++I)
3068         CUDASpecialDeclRefs.push_back(getGlobalDeclID(F, Record[I]));
3069       break;
3070 
3071     case HEADER_SEARCH_TABLE: {
3072       F.HeaderFileInfoTableData = Blob.data();
3073       F.LocalNumHeaderFileInfos = Record[1];
3074       if (Record[0]) {
3075         F.HeaderFileInfoTable
3076           = HeaderFileInfoLookupTable::Create(
3077                    (const unsigned char *)F.HeaderFileInfoTableData + Record[0],
3078                    (const unsigned char *)F.HeaderFileInfoTableData,
3079                    HeaderFileInfoTrait(*this, F,
3080                                        &PP.getHeaderSearchInfo(),
3081                                        Blob.data() + Record[2]));
3082 
3083         PP.getHeaderSearchInfo().SetExternalSource(this);
3084         if (!PP.getHeaderSearchInfo().getExternalLookup())
3085           PP.getHeaderSearchInfo().SetExternalLookup(this);
3086       }
3087       break;
3088     }
3089 
3090     case FP_PRAGMA_OPTIONS:
3091       // Later tables overwrite earlier ones.
3092       FPPragmaOptions.swap(Record);
3093       break;
3094 
3095     case OPENCL_EXTENSIONS:
3096       // Later tables overwrite earlier ones.
3097       OpenCLExtensions.swap(Record);
3098       break;
3099 
3100     case TENTATIVE_DEFINITIONS:
3101       for (unsigned I = 0, N = Record.size(); I != N; ++I)
3102         TentativeDefinitions.push_back(getGlobalDeclID(F, Record[I]));
3103       break;
3104 
3105     case KNOWN_NAMESPACES:
3106       for (unsigned I = 0, N = Record.size(); I != N; ++I)
3107         KnownNamespaces.push_back(getGlobalDeclID(F, Record[I]));
3108       break;
3109 
3110     case UNDEFINED_BUT_USED:
3111       if (UndefinedButUsed.size() % 2 != 0) {
3112         Error("Invalid existing UndefinedButUsed");
3113         return Failure;
3114       }
3115 
3116       if (Record.size() % 2 != 0) {
3117         Error("invalid undefined-but-used record");
3118         return Failure;
3119       }
3120       for (unsigned I = 0, N = Record.size(); I != N; /* in loop */) {
3121         UndefinedButUsed.push_back(getGlobalDeclID(F, Record[I++]));
3122         UndefinedButUsed.push_back(
3123             ReadSourceLocation(F, Record, I).getRawEncoding());
3124       }
3125       break;
3126     case DELETE_EXPRS_TO_ANALYZE:
3127       for (unsigned I = 0, N = Record.size(); I != N;) {
3128         DelayedDeleteExprs.push_back(getGlobalDeclID(F, Record[I++]));
3129         const uint64_t Count = Record[I++];
3130         DelayedDeleteExprs.push_back(Count);
3131         for (uint64_t C = 0; C < Count; ++C) {
3132           DelayedDeleteExprs.push_back(ReadSourceLocation(F, Record, I).getRawEncoding());
3133           bool IsArrayForm = Record[I++] == 1;
3134           DelayedDeleteExprs.push_back(IsArrayForm);
3135         }
3136       }
3137       break;
3138 
3139     case IMPORTED_MODULES: {
3140       if (F.Kind != MK_ImplicitModule && F.Kind != MK_ExplicitModule) {
3141         // If we aren't loading a module (which has its own exports), make
3142         // all of the imported modules visible.
3143         // FIXME: Deal with macros-only imports.
3144         for (unsigned I = 0, N = Record.size(); I != N; /**/) {
3145           unsigned GlobalID = getGlobalSubmoduleID(F, Record[I++]);
3146           SourceLocation Loc = ReadSourceLocation(F, Record, I);
3147           if (GlobalID)
3148             ImportedModules.push_back(ImportedSubmodule(GlobalID, Loc));
3149         }
3150       }
3151       break;
3152     }
3153 
3154     case MACRO_OFFSET: {
3155       if (F.LocalNumMacros != 0) {
3156         Error("duplicate MACRO_OFFSET record in AST file");
3157         return Failure;
3158       }
3159       F.MacroOffsets = (const uint32_t *)Blob.data();
3160       F.LocalNumMacros = Record[0];
3161       unsigned LocalBaseMacroID = Record[1];
3162       F.BaseMacroID = getTotalNumMacros();
3163 
3164       if (F.LocalNumMacros > 0) {
3165         // Introduce the global -> local mapping for macros within this module.
3166         GlobalMacroMap.insert(std::make_pair(getTotalNumMacros() + 1, &F));
3167 
3168         // Introduce the local -> global mapping for macros within this module.
3169         F.MacroRemap.insertOrReplace(
3170           std::make_pair(LocalBaseMacroID,
3171                          F.BaseMacroID - LocalBaseMacroID));
3172 
3173         MacrosLoaded.resize(MacrosLoaded.size() + F.LocalNumMacros);
3174       }
3175       break;
3176     }
3177 
3178     case LATE_PARSED_TEMPLATE: {
3179       LateParsedTemplates.append(Record.begin(), Record.end());
3180       break;
3181     }
3182 
3183     case OPTIMIZE_PRAGMA_OPTIONS:
3184       if (Record.size() != 1) {
3185         Error("invalid pragma optimize record");
3186         return Failure;
3187       }
3188       OptimizeOffPragmaLocation = ReadSourceLocation(F, Record[0]);
3189       break;
3190 
3191     case MSSTRUCT_PRAGMA_OPTIONS:
3192       if (Record.size() != 1) {
3193         Error("invalid pragma ms_struct record");
3194         return Failure;
3195       }
3196       PragmaMSStructState = Record[0];
3197       break;
3198 
3199     case POINTERS_TO_MEMBERS_PRAGMA_OPTIONS:
3200       if (Record.size() != 2) {
3201         Error("invalid pragma ms_struct record");
3202         return Failure;
3203       }
3204       PragmaMSPointersToMembersState = Record[0];
3205       PointersToMembersPragmaLocation = ReadSourceLocation(F, Record[1]);
3206       break;
3207 
3208     case UNUSED_LOCAL_TYPEDEF_NAME_CANDIDATES:
3209       for (unsigned I = 0, N = Record.size(); I != N; ++I)
3210         UnusedLocalTypedefNameCandidates.push_back(
3211             getGlobalDeclID(F, Record[I]));
3212       break;
3213     }
3214   }
3215 }
3216 
3217 ASTReader::ASTReadResult
ReadModuleMapFileBlock(RecordData & Record,ModuleFile & F,const ModuleFile * ImportedBy,unsigned ClientLoadCapabilities)3218 ASTReader::ReadModuleMapFileBlock(RecordData &Record, ModuleFile &F,
3219                                   const ModuleFile *ImportedBy,
3220                                   unsigned ClientLoadCapabilities) {
3221   unsigned Idx = 0;
3222   F.ModuleMapPath = ReadPath(F, Record, Idx);
3223 
3224   if (F.Kind == MK_ExplicitModule) {
3225     // For an explicitly-loaded module, we don't care whether the original
3226     // module map file exists or matches.
3227     return Success;
3228   }
3229 
3230   // Try to resolve ModuleName in the current header search context and
3231   // verify that it is found in the same module map file as we saved. If the
3232   // top-level AST file is a main file, skip this check because there is no
3233   // usable header search context.
3234   assert(!F.ModuleName.empty() &&
3235          "MODULE_NAME should come before MODULE_MAP_FILE");
3236   if (F.Kind == MK_ImplicitModule &&
3237       (*ModuleMgr.begin())->Kind != MK_MainFile) {
3238     // An implicitly-loaded module file should have its module listed in some
3239     // module map file that we've already loaded.
3240     Module *M = PP.getHeaderSearchInfo().lookupModule(F.ModuleName);
3241     auto &Map = PP.getHeaderSearchInfo().getModuleMap();
3242     const FileEntry *ModMap = M ? Map.getModuleMapFileForUniquing(M) : nullptr;
3243     if (!ModMap) {
3244       assert(ImportedBy && "top-level import should be verified");
3245       if ((ClientLoadCapabilities & ARR_OutOfDate) == 0) {
3246         if (auto *ASTFE = M ? M->getASTFile() : nullptr)
3247           // This module was defined by an imported (explicit) module.
3248           Diag(diag::err_module_file_conflict) << F.ModuleName << F.FileName
3249                                                << ASTFE->getName();
3250         else
3251           // This module was built with a different module map.
3252           Diag(diag::err_imported_module_not_found)
3253               << F.ModuleName << F.FileName << ImportedBy->FileName
3254               << F.ModuleMapPath;
3255       }
3256       return OutOfDate;
3257     }
3258 
3259     assert(M->Name == F.ModuleName && "found module with different name");
3260 
3261     // Check the primary module map file.
3262     const FileEntry *StoredModMap = FileMgr.getFile(F.ModuleMapPath);
3263     if (StoredModMap == nullptr || StoredModMap != ModMap) {
3264       assert(ModMap && "found module is missing module map file");
3265       assert(ImportedBy && "top-level import should be verified");
3266       if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3267         Diag(diag::err_imported_module_modmap_changed)
3268           << F.ModuleName << ImportedBy->FileName
3269           << ModMap->getName() << F.ModuleMapPath;
3270       return OutOfDate;
3271     }
3272 
3273     llvm::SmallPtrSet<const FileEntry *, 1> AdditionalStoredMaps;
3274     for (unsigned I = 0, N = Record[Idx++]; I < N; ++I) {
3275       // FIXME: we should use input files rather than storing names.
3276       std::string Filename = ReadPath(F, Record, Idx);
3277       const FileEntry *F =
3278           FileMgr.getFile(Filename, false, false);
3279       if (F == nullptr) {
3280         if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3281           Error("could not find file '" + Filename +"' referenced by AST file");
3282         return OutOfDate;
3283       }
3284       AdditionalStoredMaps.insert(F);
3285     }
3286 
3287     // Check any additional module map files (e.g. module.private.modulemap)
3288     // that are not in the pcm.
3289     if (auto *AdditionalModuleMaps = Map.getAdditionalModuleMapFiles(M)) {
3290       for (const FileEntry *ModMap : *AdditionalModuleMaps) {
3291         // Remove files that match
3292         // Note: SmallPtrSet::erase is really remove
3293         if (!AdditionalStoredMaps.erase(ModMap)) {
3294           if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3295             Diag(diag::err_module_different_modmap)
3296               << F.ModuleName << /*new*/0 << ModMap->getName();
3297           return OutOfDate;
3298         }
3299       }
3300     }
3301 
3302     // Check any additional module map files that are in the pcm, but not
3303     // found in header search. Cases that match are already removed.
3304     for (const FileEntry *ModMap : AdditionalStoredMaps) {
3305       if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3306         Diag(diag::err_module_different_modmap)
3307           << F.ModuleName << /*not new*/1 << ModMap->getName();
3308       return OutOfDate;
3309     }
3310   }
3311 
3312   if (Listener)
3313     Listener->ReadModuleMapFile(F.ModuleMapPath);
3314   return Success;
3315 }
3316 
3317 
3318 /// \brief Move the given method to the back of the global list of methods.
moveMethodToBackOfGlobalList(Sema & S,ObjCMethodDecl * Method)3319 static void moveMethodToBackOfGlobalList(Sema &S, ObjCMethodDecl *Method) {
3320   // Find the entry for this selector in the method pool.
3321   Sema::GlobalMethodPool::iterator Known
3322     = S.MethodPool.find(Method->getSelector());
3323   if (Known == S.MethodPool.end())
3324     return;
3325 
3326   // Retrieve the appropriate method list.
3327   ObjCMethodList &Start = Method->isInstanceMethod()? Known->second.first
3328                                                     : Known->second.second;
3329   bool Found = false;
3330   for (ObjCMethodList *List = &Start; List; List = List->getNext()) {
3331     if (!Found) {
3332       if (List->getMethod() == Method) {
3333         Found = true;
3334       } else {
3335         // Keep searching.
3336         continue;
3337       }
3338     }
3339 
3340     if (List->getNext())
3341       List->setMethod(List->getNext()->getMethod());
3342     else
3343       List->setMethod(Method);
3344   }
3345 }
3346 
makeNamesVisible(const HiddenNames & Names,Module * Owner)3347 void ASTReader::makeNamesVisible(const HiddenNames &Names, Module *Owner) {
3348   assert(Owner->NameVisibility != Module::Hidden && "nothing to make visible?");
3349   for (Decl *D : Names) {
3350     bool wasHidden = D->Hidden;
3351     D->Hidden = false;
3352 
3353     if (wasHidden && SemaObj) {
3354       if (ObjCMethodDecl *Method = dyn_cast<ObjCMethodDecl>(D)) {
3355         moveMethodToBackOfGlobalList(*SemaObj, Method);
3356       }
3357     }
3358   }
3359 }
3360 
makeModuleVisible(Module * Mod,Module::NameVisibilityKind NameVisibility,SourceLocation ImportLoc)3361 void ASTReader::makeModuleVisible(Module *Mod,
3362                                   Module::NameVisibilityKind NameVisibility,
3363                                   SourceLocation ImportLoc) {
3364   llvm::SmallPtrSet<Module *, 4> Visited;
3365   SmallVector<Module *, 4> Stack;
3366   Stack.push_back(Mod);
3367   while (!Stack.empty()) {
3368     Mod = Stack.pop_back_val();
3369 
3370     if (NameVisibility <= Mod->NameVisibility) {
3371       // This module already has this level of visibility (or greater), so
3372       // there is nothing more to do.
3373       continue;
3374     }
3375 
3376     if (!Mod->isAvailable()) {
3377       // Modules that aren't available cannot be made visible.
3378       continue;
3379     }
3380 
3381     // Update the module's name visibility.
3382     Mod->NameVisibility = NameVisibility;
3383 
3384     // If we've already deserialized any names from this module,
3385     // mark them as visible.
3386     HiddenNamesMapType::iterator Hidden = HiddenNamesMap.find(Mod);
3387     if (Hidden != HiddenNamesMap.end()) {
3388       auto HiddenNames = std::move(*Hidden);
3389       HiddenNamesMap.erase(Hidden);
3390       makeNamesVisible(HiddenNames.second, HiddenNames.first);
3391       assert(HiddenNamesMap.find(Mod) == HiddenNamesMap.end() &&
3392              "making names visible added hidden names");
3393     }
3394 
3395     // Push any exported modules onto the stack to be marked as visible.
3396     SmallVector<Module *, 16> Exports;
3397     Mod->getExportedModules(Exports);
3398     for (SmallVectorImpl<Module *>::iterator
3399            I = Exports.begin(), E = Exports.end(); I != E; ++I) {
3400       Module *Exported = *I;
3401       if (Visited.insert(Exported).second)
3402         Stack.push_back(Exported);
3403     }
3404   }
3405 }
3406 
loadGlobalIndex()3407 bool ASTReader::loadGlobalIndex() {
3408   if (GlobalIndex)
3409     return false;
3410 
3411   if (TriedLoadingGlobalIndex || !UseGlobalIndex ||
3412       !Context.getLangOpts().Modules)
3413     return true;
3414 
3415   // Try to load the global index.
3416   TriedLoadingGlobalIndex = true;
3417   StringRef ModuleCachePath
3418     = getPreprocessor().getHeaderSearchInfo().getModuleCachePath();
3419   std::pair<GlobalModuleIndex *, GlobalModuleIndex::ErrorCode> Result
3420     = GlobalModuleIndex::readIndex(ModuleCachePath);
3421   if (!Result.first)
3422     return true;
3423 
3424   GlobalIndex.reset(Result.first);
3425   ModuleMgr.setGlobalIndex(GlobalIndex.get());
3426   return false;
3427 }
3428 
isGlobalIndexUnavailable() const3429 bool ASTReader::isGlobalIndexUnavailable() const {
3430   return Context.getLangOpts().Modules && UseGlobalIndex &&
3431          !hasGlobalIndex() && TriedLoadingGlobalIndex;
3432 }
3433 
updateModuleTimestamp(ModuleFile & MF)3434 static void updateModuleTimestamp(ModuleFile &MF) {
3435   // Overwrite the timestamp file contents so that file's mtime changes.
3436   std::string TimestampFilename = MF.getTimestampFilename();
3437   std::error_code EC;
3438   llvm::raw_fd_ostream OS(TimestampFilename, EC, llvm::sys::fs::F_Text);
3439   if (EC)
3440     return;
3441   OS << "Timestamp file\n";
3442 }
3443 
3444 /// \brief Given a cursor at the start of an AST file, scan ahead and drop the
3445 /// cursor into the start of the given block ID, returning false on success and
3446 /// true on failure.
SkipCursorToBlock(BitstreamCursor & Cursor,unsigned BlockID)3447 static bool SkipCursorToBlock(BitstreamCursor &Cursor, unsigned BlockID) {
3448   while (1) {
3449     llvm::BitstreamEntry Entry = Cursor.advance();
3450     switch (Entry.Kind) {
3451     case llvm::BitstreamEntry::Error:
3452     case llvm::BitstreamEntry::EndBlock:
3453       return true;
3454 
3455     case llvm::BitstreamEntry::Record:
3456       // Ignore top-level records.
3457       Cursor.skipRecord(Entry.ID);
3458       break;
3459 
3460     case llvm::BitstreamEntry::SubBlock:
3461       if (Entry.ID == BlockID) {
3462         if (Cursor.EnterSubBlock(BlockID))
3463           return true;
3464         // Found it!
3465         return false;
3466       }
3467 
3468       if (Cursor.SkipBlock())
3469         return true;
3470     }
3471   }
3472 }
3473 
ReadAST(StringRef FileName,ModuleKind Type,SourceLocation ImportLoc,unsigned ClientLoadCapabilities)3474 ASTReader::ASTReadResult ASTReader::ReadAST(StringRef FileName,
3475                                             ModuleKind Type,
3476                                             SourceLocation ImportLoc,
3477                                             unsigned ClientLoadCapabilities) {
3478   llvm::SaveAndRestore<SourceLocation>
3479     SetCurImportLocRAII(CurrentImportLoc, ImportLoc);
3480 
3481   // Defer any pending actions until we get to the end of reading the AST file.
3482   Deserializing AnASTFile(this);
3483 
3484   // Bump the generation number.
3485   unsigned PreviousGeneration = incrementGeneration(Context);
3486 
3487   unsigned NumModules = ModuleMgr.size();
3488   SmallVector<ImportedModule, 4> Loaded;
3489   switch(ASTReadResult ReadResult = ReadASTCore(FileName, Type, ImportLoc,
3490                                                 /*ImportedBy=*/nullptr, Loaded,
3491                                                 0, 0, 0,
3492                                                 ClientLoadCapabilities)) {
3493   case Failure:
3494   case Missing:
3495   case OutOfDate:
3496   case VersionMismatch:
3497   case ConfigurationMismatch:
3498   case HadErrors: {
3499     llvm::SmallPtrSet<ModuleFile *, 4> LoadedSet;
3500     for (const ImportedModule &IM : Loaded)
3501       LoadedSet.insert(IM.Mod);
3502 
3503     ModuleMgr.removeModules(ModuleMgr.begin() + NumModules, ModuleMgr.end(),
3504                             LoadedSet,
3505                             Context.getLangOpts().Modules
3506                               ? &PP.getHeaderSearchInfo().getModuleMap()
3507                               : nullptr);
3508 
3509     // If we find that any modules are unusable, the global index is going
3510     // to be out-of-date. Just remove it.
3511     GlobalIndex.reset();
3512     ModuleMgr.setGlobalIndex(nullptr);
3513     return ReadResult;
3514   }
3515   case Success:
3516     break;
3517   }
3518 
3519   // Here comes stuff that we only do once the entire chain is loaded.
3520 
3521   // Load the AST blocks of all of the modules that we loaded.
3522   for (SmallVectorImpl<ImportedModule>::iterator M = Loaded.begin(),
3523                                               MEnd = Loaded.end();
3524        M != MEnd; ++M) {
3525     ModuleFile &F = *M->Mod;
3526 
3527     // Read the AST block.
3528     if (ASTReadResult Result = ReadASTBlock(F, ClientLoadCapabilities))
3529       return Result;
3530 
3531     // Read the extension blocks.
3532     while (!SkipCursorToBlock(F.Stream, EXTENSION_BLOCK_ID)) {
3533       if (ASTReadResult Result = ReadExtensionBlock(F))
3534         return Result;
3535     }
3536 
3537     // Once read, set the ModuleFile bit base offset and update the size in
3538     // bits of all files we've seen.
3539     F.GlobalBitOffset = TotalModulesSizeInBits;
3540     TotalModulesSizeInBits += F.SizeInBits;
3541     GlobalBitOffsetsMap.insert(std::make_pair(F.GlobalBitOffset, &F));
3542 
3543     // Preload SLocEntries.
3544     for (unsigned I = 0, N = F.PreloadSLocEntries.size(); I != N; ++I) {
3545       int Index = int(F.PreloadSLocEntries[I] - 1) + F.SLocEntryBaseID;
3546       // Load it through the SourceManager and don't call ReadSLocEntry()
3547       // directly because the entry may have already been loaded in which case
3548       // calling ReadSLocEntry() directly would trigger an assertion in
3549       // SourceManager.
3550       SourceMgr.getLoadedSLocEntryByID(Index);
3551     }
3552 
3553     // Preload all the pending interesting identifiers by marking them out of
3554     // date.
3555     for (auto Offset : F.PreloadIdentifierOffsets) {
3556       const unsigned char *Data = reinterpret_cast<const unsigned char *>(
3557           F.IdentifierTableData + Offset);
3558 
3559       ASTIdentifierLookupTrait Trait(*this, F);
3560       auto KeyDataLen = Trait.ReadKeyDataLength(Data);
3561       auto Key = Trait.ReadKey(Data, KeyDataLen.first);
3562       auto &II = PP.getIdentifierTable().getOwn(Key);
3563       II.setOutOfDate(true);
3564 
3565       // Mark this identifier as being from an AST file so that we can track
3566       // whether we need to serialize it.
3567       markIdentifierFromAST(*this, II);
3568 
3569       // Associate the ID with the identifier so that the writer can reuse it.
3570       auto ID = Trait.ReadIdentifierID(Data + KeyDataLen.first);
3571       SetIdentifierInfo(ID, &II);
3572     }
3573   }
3574 
3575   // Setup the import locations and notify the module manager that we've
3576   // committed to these module files.
3577   for (SmallVectorImpl<ImportedModule>::iterator M = Loaded.begin(),
3578                                               MEnd = Loaded.end();
3579        M != MEnd; ++M) {
3580     ModuleFile &F = *M->Mod;
3581 
3582     ModuleMgr.moduleFileAccepted(&F);
3583 
3584     // Set the import location.
3585     F.DirectImportLoc = ImportLoc;
3586     // FIXME: We assume that locations from PCH / preamble do not need
3587     // any translation.
3588     if (!M->ImportedBy)
3589       F.ImportLoc = M->ImportLoc;
3590     else
3591       F.ImportLoc = TranslateSourceLocation(*M->ImportedBy, M->ImportLoc);
3592   }
3593 
3594   if (!Context.getLangOpts().CPlusPlus ||
3595       (Type != MK_ImplicitModule && Type != MK_ExplicitModule)) {
3596     // Mark all of the identifiers in the identifier table as being out of date,
3597     // so that various accessors know to check the loaded modules when the
3598     // identifier is used.
3599     //
3600     // For C++ modules, we don't need information on many identifiers (just
3601     // those that provide macros or are poisoned), so we mark all of
3602     // the interesting ones via PreloadIdentifierOffsets.
3603     for (IdentifierTable::iterator Id = PP.getIdentifierTable().begin(),
3604                                 IdEnd = PP.getIdentifierTable().end();
3605          Id != IdEnd; ++Id)
3606       Id->second->setOutOfDate(true);
3607   }
3608   // Mark selectors as out of date.
3609   for (auto Sel : SelectorGeneration)
3610     SelectorOutOfDate[Sel.first] = true;
3611 
3612   // Resolve any unresolved module exports.
3613   for (unsigned I = 0, N = UnresolvedModuleRefs.size(); I != N; ++I) {
3614     UnresolvedModuleRef &Unresolved = UnresolvedModuleRefs[I];
3615     SubmoduleID GlobalID = getGlobalSubmoduleID(*Unresolved.File,Unresolved.ID);
3616     Module *ResolvedMod = getSubmodule(GlobalID);
3617 
3618     switch (Unresolved.Kind) {
3619     case UnresolvedModuleRef::Conflict:
3620       if (ResolvedMod) {
3621         Module::Conflict Conflict;
3622         Conflict.Other = ResolvedMod;
3623         Conflict.Message = Unresolved.String.str();
3624         Unresolved.Mod->Conflicts.push_back(Conflict);
3625       }
3626       continue;
3627 
3628     case UnresolvedModuleRef::Import:
3629       if (ResolvedMod)
3630         Unresolved.Mod->Imports.insert(ResolvedMod);
3631       continue;
3632 
3633     case UnresolvedModuleRef::Export:
3634       if (ResolvedMod || Unresolved.IsWildcard)
3635         Unresolved.Mod->Exports.push_back(
3636           Module::ExportDecl(ResolvedMod, Unresolved.IsWildcard));
3637       continue;
3638     }
3639   }
3640   UnresolvedModuleRefs.clear();
3641 
3642   // FIXME: How do we load the 'use'd modules? They may not be submodules.
3643   // Might be unnecessary as use declarations are only used to build the
3644   // module itself.
3645 
3646   InitializeContext();
3647 
3648   if (SemaObj)
3649     UpdateSema();
3650 
3651   if (DeserializationListener)
3652     DeserializationListener->ReaderInitialized(this);
3653 
3654   ModuleFile &PrimaryModule = ModuleMgr.getPrimaryModule();
3655   if (PrimaryModule.OriginalSourceFileID.isValid()) {
3656     PrimaryModule.OriginalSourceFileID
3657       = FileID::get(PrimaryModule.SLocEntryBaseID
3658                     + PrimaryModule.OriginalSourceFileID.getOpaqueValue() - 1);
3659 
3660     // If this AST file is a precompiled preamble, then set the
3661     // preamble file ID of the source manager to the file source file
3662     // from which the preamble was built.
3663     if (Type == MK_Preamble) {
3664       SourceMgr.setPreambleFileID(PrimaryModule.OriginalSourceFileID);
3665     } else if (Type == MK_MainFile) {
3666       SourceMgr.setMainFileID(PrimaryModule.OriginalSourceFileID);
3667     }
3668   }
3669 
3670   // For any Objective-C class definitions we have already loaded, make sure
3671   // that we load any additional categories.
3672   for (unsigned I = 0, N = ObjCClassesLoaded.size(); I != N; ++I) {
3673     loadObjCCategories(ObjCClassesLoaded[I]->getGlobalID(),
3674                        ObjCClassesLoaded[I],
3675                        PreviousGeneration);
3676   }
3677 
3678   if (PP.getHeaderSearchInfo()
3679           .getHeaderSearchOpts()
3680           .ModulesValidateOncePerBuildSession) {
3681     // Now we are certain that the module and all modules it depends on are
3682     // up to date.  Create or update timestamp files for modules that are
3683     // located in the module cache (not for PCH files that could be anywhere
3684     // in the filesystem).
3685     for (unsigned I = 0, N = Loaded.size(); I != N; ++I) {
3686       ImportedModule &M = Loaded[I];
3687       if (M.Mod->Kind == MK_ImplicitModule) {
3688         updateModuleTimestamp(*M.Mod);
3689       }
3690     }
3691   }
3692 
3693   return Success;
3694 }
3695 
3696 static ASTFileSignature readASTFileSignature(llvm::BitstreamReader &StreamFile);
3697 
3698 /// \brief Whether \p Stream starts with the AST/PCH file magic number 'CPCH'.
startsWithASTFileMagic(BitstreamCursor & Stream)3699 static bool startsWithASTFileMagic(BitstreamCursor &Stream) {
3700   return Stream.Read(8) == 'C' &&
3701          Stream.Read(8) == 'P' &&
3702          Stream.Read(8) == 'C' &&
3703          Stream.Read(8) == 'H';
3704 }
3705 
moduleKindForDiagnostic(ModuleKind Kind)3706 static unsigned moduleKindForDiagnostic(ModuleKind Kind) {
3707   switch (Kind) {
3708   case MK_PCH:
3709     return 0; // PCH
3710   case MK_ImplicitModule:
3711   case MK_ExplicitModule:
3712     return 1; // module
3713   case MK_MainFile:
3714   case MK_Preamble:
3715     return 2; // main source file
3716   }
3717   llvm_unreachable("unknown module kind");
3718 }
3719 
3720 ASTReader::ASTReadResult
ReadASTCore(StringRef FileName,ModuleKind Type,SourceLocation ImportLoc,ModuleFile * ImportedBy,SmallVectorImpl<ImportedModule> & Loaded,off_t ExpectedSize,time_t ExpectedModTime,ASTFileSignature ExpectedSignature,unsigned ClientLoadCapabilities)3721 ASTReader::ReadASTCore(StringRef FileName,
3722                        ModuleKind Type,
3723                        SourceLocation ImportLoc,
3724                        ModuleFile *ImportedBy,
3725                        SmallVectorImpl<ImportedModule> &Loaded,
3726                        off_t ExpectedSize, time_t ExpectedModTime,
3727                        ASTFileSignature ExpectedSignature,
3728                        unsigned ClientLoadCapabilities) {
3729   ModuleFile *M;
3730   std::string ErrorStr;
3731   ModuleManager::AddModuleResult AddResult
3732     = ModuleMgr.addModule(FileName, Type, ImportLoc, ImportedBy,
3733                           getGeneration(), ExpectedSize, ExpectedModTime,
3734                           ExpectedSignature, readASTFileSignature,
3735                           M, ErrorStr);
3736 
3737   switch (AddResult) {
3738   case ModuleManager::AlreadyLoaded:
3739     return Success;
3740 
3741   case ModuleManager::NewlyLoaded:
3742     // Load module file below.
3743     break;
3744 
3745   case ModuleManager::Missing:
3746     // The module file was missing; if the client can handle that, return
3747     // it.
3748     if (ClientLoadCapabilities & ARR_Missing)
3749       return Missing;
3750 
3751     // Otherwise, return an error.
3752     Diag(diag::err_module_file_not_found) << moduleKindForDiagnostic(Type)
3753                                           << FileName << ErrorStr.empty()
3754                                           << ErrorStr;
3755     return Failure;
3756 
3757   case ModuleManager::OutOfDate:
3758     // We couldn't load the module file because it is out-of-date. If the
3759     // client can handle out-of-date, return it.
3760     if (ClientLoadCapabilities & ARR_OutOfDate)
3761       return OutOfDate;
3762 
3763     // Otherwise, return an error.
3764     Diag(diag::err_module_file_out_of_date) << moduleKindForDiagnostic(Type)
3765                                             << FileName << ErrorStr.empty()
3766                                             << ErrorStr;
3767     return Failure;
3768   }
3769 
3770   assert(M && "Missing module file");
3771 
3772   // FIXME: This seems rather a hack. Should CurrentDir be part of the
3773   // module?
3774   if (FileName != "-") {
3775     CurrentDir = llvm::sys::path::parent_path(FileName);
3776     if (CurrentDir.empty()) CurrentDir = ".";
3777   }
3778 
3779   ModuleFile &F = *M;
3780   BitstreamCursor &Stream = F.Stream;
3781   PCHContainerRdr.ExtractPCH(F.Buffer->getMemBufferRef(), F.StreamFile);
3782   Stream.init(&F.StreamFile);
3783   F.SizeInBits = F.Buffer->getBufferSize() * 8;
3784 
3785   // Sniff for the signature.
3786   if (!startsWithASTFileMagic(Stream)) {
3787     Diag(diag::err_module_file_invalid) << moduleKindForDiagnostic(Type)
3788                                         << FileName;
3789     return Failure;
3790   }
3791 
3792   // This is used for compatibility with older PCH formats.
3793   bool HaveReadControlBlock = false;
3794   while (1) {
3795     llvm::BitstreamEntry Entry = Stream.advance();
3796 
3797     switch (Entry.Kind) {
3798     case llvm::BitstreamEntry::Error:
3799     case llvm::BitstreamEntry::Record:
3800     case llvm::BitstreamEntry::EndBlock:
3801       Error("invalid record at top-level of AST file");
3802       return Failure;
3803 
3804     case llvm::BitstreamEntry::SubBlock:
3805       break;
3806     }
3807 
3808     switch (Entry.ID) {
3809     case CONTROL_BLOCK_ID:
3810       HaveReadControlBlock = true;
3811       switch (ReadControlBlock(F, Loaded, ImportedBy, ClientLoadCapabilities)) {
3812       case Success:
3813         // Check that we didn't try to load a non-module AST file as a module.
3814         //
3815         // FIXME: Should we also perform the converse check? Loading a module as
3816         // a PCH file sort of works, but it's a bit wonky.
3817         if ((Type == MK_ImplicitModule || Type == MK_ExplicitModule) &&
3818             F.ModuleName.empty()) {
3819           auto Result = (Type == MK_ImplicitModule) ? OutOfDate : Failure;
3820           if (Result != OutOfDate ||
3821               (ClientLoadCapabilities & ARR_OutOfDate) == 0)
3822             Diag(diag::err_module_file_not_module) << FileName;
3823           return Result;
3824         }
3825         break;
3826 
3827       case Failure: return Failure;
3828       case Missing: return Missing;
3829       case OutOfDate: return OutOfDate;
3830       case VersionMismatch: return VersionMismatch;
3831       case ConfigurationMismatch: return ConfigurationMismatch;
3832       case HadErrors: return HadErrors;
3833       }
3834       break;
3835 
3836     case AST_BLOCK_ID:
3837       if (!HaveReadControlBlock) {
3838         if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
3839           Diag(diag::err_pch_version_too_old);
3840         return VersionMismatch;
3841       }
3842 
3843       // Record that we've loaded this module.
3844       Loaded.push_back(ImportedModule(M, ImportedBy, ImportLoc));
3845       return Success;
3846 
3847     default:
3848       if (Stream.SkipBlock()) {
3849         Error("malformed block record in AST file");
3850         return Failure;
3851       }
3852       break;
3853     }
3854   }
3855 
3856   return Success;
3857 }
3858 
3859 /// Parse a record and blob containing module file extension metadata.
parseModuleFileExtensionMetadata(const SmallVectorImpl<uint64_t> & Record,StringRef Blob,ModuleFileExtensionMetadata & Metadata)3860 static bool parseModuleFileExtensionMetadata(
3861               const SmallVectorImpl<uint64_t> &Record,
3862               StringRef Blob,
3863               ModuleFileExtensionMetadata &Metadata) {
3864   if (Record.size() < 4) return true;
3865 
3866   Metadata.MajorVersion = Record[0];
3867   Metadata.MinorVersion = Record[1];
3868 
3869   unsigned BlockNameLen = Record[2];
3870   unsigned UserInfoLen = Record[3];
3871 
3872   if (BlockNameLen + UserInfoLen > Blob.size()) return true;
3873 
3874   Metadata.BlockName = std::string(Blob.data(), Blob.data() + BlockNameLen);
3875   Metadata.UserInfo = std::string(Blob.data() + BlockNameLen,
3876                                   Blob.data() + BlockNameLen + UserInfoLen);
3877   return false;
3878 }
3879 
ReadExtensionBlock(ModuleFile & F)3880 ASTReader::ASTReadResult ASTReader::ReadExtensionBlock(ModuleFile &F) {
3881   BitstreamCursor &Stream = F.Stream;
3882 
3883   RecordData Record;
3884   while (true) {
3885     llvm::BitstreamEntry Entry = Stream.advance();
3886     switch (Entry.Kind) {
3887     case llvm::BitstreamEntry::SubBlock:
3888       if (Stream.SkipBlock())
3889         return Failure;
3890 
3891       continue;
3892 
3893     case llvm::BitstreamEntry::EndBlock:
3894       return Success;
3895 
3896     case llvm::BitstreamEntry::Error:
3897       return HadErrors;
3898 
3899     case llvm::BitstreamEntry::Record:
3900       break;
3901     }
3902 
3903     Record.clear();
3904     StringRef Blob;
3905     unsigned RecCode = Stream.readRecord(Entry.ID, Record, &Blob);
3906     switch (RecCode) {
3907     case EXTENSION_METADATA: {
3908       ModuleFileExtensionMetadata Metadata;
3909       if (parseModuleFileExtensionMetadata(Record, Blob, Metadata))
3910         return Failure;
3911 
3912       // Find a module file extension with this block name.
3913       auto Known = ModuleFileExtensions.find(Metadata.BlockName);
3914       if (Known == ModuleFileExtensions.end()) break;
3915 
3916       // Form a reader.
3917       if (auto Reader = Known->second->createExtensionReader(Metadata, *this,
3918                                                              F, Stream)) {
3919         F.ExtensionReaders.push_back(std::move(Reader));
3920       }
3921 
3922       break;
3923     }
3924     }
3925   }
3926 
3927   return Success;
3928 }
3929 
InitializeContext()3930 void ASTReader::InitializeContext() {
3931   // If there's a listener, notify them that we "read" the translation unit.
3932   if (DeserializationListener)
3933     DeserializationListener->DeclRead(PREDEF_DECL_TRANSLATION_UNIT_ID,
3934                                       Context.getTranslationUnitDecl());
3935 
3936   // FIXME: Find a better way to deal with collisions between these
3937   // built-in types. Right now, we just ignore the problem.
3938 
3939   // Load the special types.
3940   if (SpecialTypes.size() >= NumSpecialTypeIDs) {
3941     if (unsigned String = SpecialTypes[SPECIAL_TYPE_CF_CONSTANT_STRING]) {
3942       if (!Context.CFConstantStringTypeDecl)
3943         Context.setCFConstantStringType(GetType(String));
3944     }
3945 
3946     if (unsigned File = SpecialTypes[SPECIAL_TYPE_FILE]) {
3947       QualType FileType = GetType(File);
3948       if (FileType.isNull()) {
3949         Error("FILE type is NULL");
3950         return;
3951       }
3952 
3953       if (!Context.FILEDecl) {
3954         if (const TypedefType *Typedef = FileType->getAs<TypedefType>())
3955           Context.setFILEDecl(Typedef->getDecl());
3956         else {
3957           const TagType *Tag = FileType->getAs<TagType>();
3958           if (!Tag) {
3959             Error("Invalid FILE type in AST file");
3960             return;
3961           }
3962           Context.setFILEDecl(Tag->getDecl());
3963         }
3964       }
3965     }
3966 
3967     if (unsigned Jmp_buf = SpecialTypes[SPECIAL_TYPE_JMP_BUF]) {
3968       QualType Jmp_bufType = GetType(Jmp_buf);
3969       if (Jmp_bufType.isNull()) {
3970         Error("jmp_buf type is NULL");
3971         return;
3972       }
3973 
3974       if (!Context.jmp_bufDecl) {
3975         if (const TypedefType *Typedef = Jmp_bufType->getAs<TypedefType>())
3976           Context.setjmp_bufDecl(Typedef->getDecl());
3977         else {
3978           const TagType *Tag = Jmp_bufType->getAs<TagType>();
3979           if (!Tag) {
3980             Error("Invalid jmp_buf type in AST file");
3981             return;
3982           }
3983           Context.setjmp_bufDecl(Tag->getDecl());
3984         }
3985       }
3986     }
3987 
3988     if (unsigned Sigjmp_buf = SpecialTypes[SPECIAL_TYPE_SIGJMP_BUF]) {
3989       QualType Sigjmp_bufType = GetType(Sigjmp_buf);
3990       if (Sigjmp_bufType.isNull()) {
3991         Error("sigjmp_buf type is NULL");
3992         return;
3993       }
3994 
3995       if (!Context.sigjmp_bufDecl) {
3996         if (const TypedefType *Typedef = Sigjmp_bufType->getAs<TypedefType>())
3997           Context.setsigjmp_bufDecl(Typedef->getDecl());
3998         else {
3999           const TagType *Tag = Sigjmp_bufType->getAs<TagType>();
4000           assert(Tag && "Invalid sigjmp_buf type in AST file");
4001           Context.setsigjmp_bufDecl(Tag->getDecl());
4002         }
4003       }
4004     }
4005 
4006     if (unsigned ObjCIdRedef
4007           = SpecialTypes[SPECIAL_TYPE_OBJC_ID_REDEFINITION]) {
4008       if (Context.ObjCIdRedefinitionType.isNull())
4009         Context.ObjCIdRedefinitionType = GetType(ObjCIdRedef);
4010     }
4011 
4012     if (unsigned ObjCClassRedef
4013           = SpecialTypes[SPECIAL_TYPE_OBJC_CLASS_REDEFINITION]) {
4014       if (Context.ObjCClassRedefinitionType.isNull())
4015         Context.ObjCClassRedefinitionType = GetType(ObjCClassRedef);
4016     }
4017 
4018     if (unsigned ObjCSelRedef
4019           = SpecialTypes[SPECIAL_TYPE_OBJC_SEL_REDEFINITION]) {
4020       if (Context.ObjCSelRedefinitionType.isNull())
4021         Context.ObjCSelRedefinitionType = GetType(ObjCSelRedef);
4022     }
4023 
4024     if (unsigned Ucontext_t = SpecialTypes[SPECIAL_TYPE_UCONTEXT_T]) {
4025       QualType Ucontext_tType = GetType(Ucontext_t);
4026       if (Ucontext_tType.isNull()) {
4027         Error("ucontext_t type is NULL");
4028         return;
4029       }
4030 
4031       if (!Context.ucontext_tDecl) {
4032         if (const TypedefType *Typedef = Ucontext_tType->getAs<TypedefType>())
4033           Context.setucontext_tDecl(Typedef->getDecl());
4034         else {
4035           const TagType *Tag = Ucontext_tType->getAs<TagType>();
4036           assert(Tag && "Invalid ucontext_t type in AST file");
4037           Context.setucontext_tDecl(Tag->getDecl());
4038         }
4039       }
4040     }
4041   }
4042 
4043   ReadPragmaDiagnosticMappings(Context.getDiagnostics());
4044 
4045   // If there were any CUDA special declarations, deserialize them.
4046   if (!CUDASpecialDeclRefs.empty()) {
4047     assert(CUDASpecialDeclRefs.size() == 1 && "More decl refs than expected!");
4048     Context.setcudaConfigureCallDecl(
4049                            cast<FunctionDecl>(GetDecl(CUDASpecialDeclRefs[0])));
4050   }
4051 
4052   // Re-export any modules that were imported by a non-module AST file.
4053   // FIXME: This does not make macro-only imports visible again.
4054   for (auto &Import : ImportedModules) {
4055     if (Module *Imported = getSubmodule(Import.ID)) {
4056       makeModuleVisible(Imported, Module::AllVisible,
4057                         /*ImportLoc=*/Import.ImportLoc);
4058       if (Import.ImportLoc.isValid())
4059         PP.makeModuleVisible(Imported, Import.ImportLoc);
4060       // FIXME: should we tell Sema to make the module visible too?
4061     }
4062   }
4063   ImportedModules.clear();
4064 }
4065 
finalizeForWriting()4066 void ASTReader::finalizeForWriting() {
4067   // Nothing to do for now.
4068 }
4069 
4070 /// \brief Reads and return the signature record from \p StreamFile's control
4071 /// block, or else returns 0.
readASTFileSignature(llvm::BitstreamReader & StreamFile)4072 static ASTFileSignature readASTFileSignature(llvm::BitstreamReader &StreamFile){
4073   BitstreamCursor Stream(StreamFile);
4074   if (!startsWithASTFileMagic(Stream))
4075     return 0;
4076 
4077   // Scan for the CONTROL_BLOCK_ID block.
4078   if (SkipCursorToBlock(Stream, CONTROL_BLOCK_ID))
4079     return 0;
4080 
4081   // Scan for SIGNATURE inside the control block.
4082   ASTReader::RecordData Record;
4083   while (1) {
4084     llvm::BitstreamEntry Entry = Stream.advanceSkippingSubblocks();
4085     if (Entry.Kind == llvm::BitstreamEntry::EndBlock ||
4086         Entry.Kind != llvm::BitstreamEntry::Record)
4087       return 0;
4088 
4089     Record.clear();
4090     StringRef Blob;
4091     if (SIGNATURE == Stream.readRecord(Entry.ID, Record, &Blob))
4092       return Record[0];
4093   }
4094 }
4095 
4096 /// \brief Retrieve the name of the original source file name
4097 /// directly from the AST file, without actually loading the AST
4098 /// file.
getOriginalSourceFile(const std::string & ASTFileName,FileManager & FileMgr,const PCHContainerReader & PCHContainerRdr,DiagnosticsEngine & Diags)4099 std::string ASTReader::getOriginalSourceFile(
4100     const std::string &ASTFileName, FileManager &FileMgr,
4101     const PCHContainerReader &PCHContainerRdr, DiagnosticsEngine &Diags) {
4102   // Open the AST file.
4103   auto Buffer = FileMgr.getBufferForFile(ASTFileName);
4104   if (!Buffer) {
4105     Diags.Report(diag::err_fe_unable_to_read_pch_file)
4106         << ASTFileName << Buffer.getError().message();
4107     return std::string();
4108   }
4109 
4110   // Initialize the stream
4111   llvm::BitstreamReader StreamFile;
4112   PCHContainerRdr.ExtractPCH((*Buffer)->getMemBufferRef(), StreamFile);
4113   BitstreamCursor Stream(StreamFile);
4114 
4115   // Sniff for the signature.
4116   if (!startsWithASTFileMagic(Stream)) {
4117     Diags.Report(diag::err_fe_not_a_pch_file) << ASTFileName;
4118     return std::string();
4119   }
4120 
4121   // Scan for the CONTROL_BLOCK_ID block.
4122   if (SkipCursorToBlock(Stream, CONTROL_BLOCK_ID)) {
4123     Diags.Report(diag::err_fe_pch_malformed_block) << ASTFileName;
4124     return std::string();
4125   }
4126 
4127   // Scan for ORIGINAL_FILE inside the control block.
4128   RecordData Record;
4129   while (1) {
4130     llvm::BitstreamEntry Entry = Stream.advanceSkippingSubblocks();
4131     if (Entry.Kind == llvm::BitstreamEntry::EndBlock)
4132       return std::string();
4133 
4134     if (Entry.Kind != llvm::BitstreamEntry::Record) {
4135       Diags.Report(diag::err_fe_pch_malformed_block) << ASTFileName;
4136       return std::string();
4137     }
4138 
4139     Record.clear();
4140     StringRef Blob;
4141     if (Stream.readRecord(Entry.ID, Record, &Blob) == ORIGINAL_FILE)
4142       return Blob.str();
4143   }
4144 }
4145 
4146 namespace {
4147   class SimplePCHValidator : public ASTReaderListener {
4148     const LangOptions &ExistingLangOpts;
4149     const TargetOptions &ExistingTargetOpts;
4150     const PreprocessorOptions &ExistingPPOpts;
4151     std::string ExistingModuleCachePath;
4152     FileManager &FileMgr;
4153 
4154   public:
SimplePCHValidator(const LangOptions & ExistingLangOpts,const TargetOptions & ExistingTargetOpts,const PreprocessorOptions & ExistingPPOpts,StringRef ExistingModuleCachePath,FileManager & FileMgr)4155     SimplePCHValidator(const LangOptions &ExistingLangOpts,
4156                        const TargetOptions &ExistingTargetOpts,
4157                        const PreprocessorOptions &ExistingPPOpts,
4158                        StringRef ExistingModuleCachePath,
4159                        FileManager &FileMgr)
4160       : ExistingLangOpts(ExistingLangOpts),
4161         ExistingTargetOpts(ExistingTargetOpts),
4162         ExistingPPOpts(ExistingPPOpts),
4163         ExistingModuleCachePath(ExistingModuleCachePath),
4164         FileMgr(FileMgr)
4165     {
4166     }
4167 
ReadLanguageOptions(const LangOptions & LangOpts,bool Complain,bool AllowCompatibleDifferences)4168     bool ReadLanguageOptions(const LangOptions &LangOpts, bool Complain,
4169                              bool AllowCompatibleDifferences) override {
4170       return checkLanguageOptions(ExistingLangOpts, LangOpts, nullptr,
4171                                   AllowCompatibleDifferences);
4172     }
ReadTargetOptions(const TargetOptions & TargetOpts,bool Complain,bool AllowCompatibleDifferences)4173     bool ReadTargetOptions(const TargetOptions &TargetOpts, bool Complain,
4174                            bool AllowCompatibleDifferences) override {
4175       return checkTargetOptions(ExistingTargetOpts, TargetOpts, nullptr,
4176                                 AllowCompatibleDifferences);
4177     }
ReadHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,bool Complain)4178     bool ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
4179                                  StringRef SpecificModuleCachePath,
4180                                  bool Complain) override {
4181       return checkHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
4182                                       ExistingModuleCachePath,
4183                                       nullptr, ExistingLangOpts);
4184     }
ReadPreprocessorOptions(const PreprocessorOptions & PPOpts,bool Complain,std::string & SuggestedPredefines)4185     bool ReadPreprocessorOptions(const PreprocessorOptions &PPOpts,
4186                                  bool Complain,
4187                                  std::string &SuggestedPredefines) override {
4188       return checkPreprocessorOptions(ExistingPPOpts, PPOpts, nullptr, FileMgr,
4189                                       SuggestedPredefines, ExistingLangOpts);
4190     }
4191   };
4192 }
4193 
readASTFileControlBlock(StringRef Filename,FileManager & FileMgr,const PCHContainerReader & PCHContainerRdr,bool FindModuleFileExtensions,ASTReaderListener & Listener)4194 bool ASTReader::readASTFileControlBlock(
4195     StringRef Filename, FileManager &FileMgr,
4196     const PCHContainerReader &PCHContainerRdr,
4197     bool FindModuleFileExtensions,
4198     ASTReaderListener &Listener) {
4199   // Open the AST file.
4200   // FIXME: This allows use of the VFS; we do not allow use of the
4201   // VFS when actually loading a module.
4202   auto Buffer = FileMgr.getBufferForFile(Filename);
4203   if (!Buffer) {
4204     return true;
4205   }
4206 
4207   // Initialize the stream
4208   llvm::BitstreamReader StreamFile;
4209   PCHContainerRdr.ExtractPCH((*Buffer)->getMemBufferRef(), StreamFile);
4210   BitstreamCursor Stream(StreamFile);
4211 
4212   // Sniff for the signature.
4213   if (!startsWithASTFileMagic(Stream))
4214     return true;
4215 
4216   // Scan for the CONTROL_BLOCK_ID block.
4217   if (SkipCursorToBlock(Stream, CONTROL_BLOCK_ID))
4218     return true;
4219 
4220   bool NeedsInputFiles = Listener.needsInputFileVisitation();
4221   bool NeedsSystemInputFiles = Listener.needsSystemInputFileVisitation();
4222   bool NeedsImports = Listener.needsImportVisitation();
4223   BitstreamCursor InputFilesCursor;
4224 
4225   RecordData Record;
4226   std::string ModuleDir;
4227   bool DoneWithControlBlock = false;
4228   while (!DoneWithControlBlock) {
4229     llvm::BitstreamEntry Entry = Stream.advance();
4230 
4231     switch (Entry.Kind) {
4232     case llvm::BitstreamEntry::SubBlock: {
4233       switch (Entry.ID) {
4234       case OPTIONS_BLOCK_ID: {
4235         std::string IgnoredSuggestedPredefines;
4236         if (ReadOptionsBlock(Stream, ARR_ConfigurationMismatch | ARR_OutOfDate,
4237                              /*AllowCompatibleConfigurationMismatch*/ false,
4238                              Listener, IgnoredSuggestedPredefines) != Success)
4239           return true;
4240         break;
4241       }
4242 
4243       case INPUT_FILES_BLOCK_ID:
4244         InputFilesCursor = Stream;
4245         if (Stream.SkipBlock() ||
4246             (NeedsInputFiles &&
4247              ReadBlockAbbrevs(InputFilesCursor, INPUT_FILES_BLOCK_ID)))
4248           return true;
4249         break;
4250 
4251       default:
4252         if (Stream.SkipBlock())
4253           return true;
4254         break;
4255       }
4256 
4257       continue;
4258     }
4259 
4260     case llvm::BitstreamEntry::EndBlock:
4261       DoneWithControlBlock = true;
4262       break;
4263 
4264     case llvm::BitstreamEntry::Error:
4265       return true;
4266 
4267     case llvm::BitstreamEntry::Record:
4268       break;
4269     }
4270 
4271     if (DoneWithControlBlock) break;
4272 
4273     Record.clear();
4274     StringRef Blob;
4275     unsigned RecCode = Stream.readRecord(Entry.ID, Record, &Blob);
4276     switch ((ControlRecordTypes)RecCode) {
4277     case METADATA: {
4278       if (Record[0] != VERSION_MAJOR)
4279         return true;
4280 
4281       if (Listener.ReadFullVersionInformation(Blob))
4282         return true;
4283 
4284       break;
4285     }
4286     case MODULE_NAME:
4287       Listener.ReadModuleName(Blob);
4288       break;
4289     case MODULE_DIRECTORY:
4290       ModuleDir = Blob;
4291       break;
4292     case MODULE_MAP_FILE: {
4293       unsigned Idx = 0;
4294       auto Path = ReadString(Record, Idx);
4295       ResolveImportedPath(Path, ModuleDir);
4296       Listener.ReadModuleMapFile(Path);
4297       break;
4298     }
4299     case INPUT_FILE_OFFSETS: {
4300       if (!NeedsInputFiles)
4301         break;
4302 
4303       unsigned NumInputFiles = Record[0];
4304       unsigned NumUserFiles = Record[1];
4305       const uint64_t *InputFileOffs = (const uint64_t *)Blob.data();
4306       for (unsigned I = 0; I != NumInputFiles; ++I) {
4307         // Go find this input file.
4308         bool isSystemFile = I >= NumUserFiles;
4309 
4310         if (isSystemFile && !NeedsSystemInputFiles)
4311           break; // the rest are system input files
4312 
4313         BitstreamCursor &Cursor = InputFilesCursor;
4314         SavedStreamPosition SavedPosition(Cursor);
4315         Cursor.JumpToBit(InputFileOffs[I]);
4316 
4317         unsigned Code = Cursor.ReadCode();
4318         RecordData Record;
4319         StringRef Blob;
4320         bool shouldContinue = false;
4321         switch ((InputFileRecordTypes)Cursor.readRecord(Code, Record, &Blob)) {
4322         case INPUT_FILE:
4323           bool Overridden = static_cast<bool>(Record[3]);
4324           std::string Filename = Blob;
4325           ResolveImportedPath(Filename, ModuleDir);
4326           shouldContinue = Listener.visitInputFile(
4327               Filename, isSystemFile, Overridden, /*IsExplicitModule*/false);
4328           break;
4329         }
4330         if (!shouldContinue)
4331           break;
4332       }
4333       break;
4334     }
4335 
4336     case IMPORTS: {
4337       if (!NeedsImports)
4338         break;
4339 
4340       unsigned Idx = 0, N = Record.size();
4341       while (Idx < N) {
4342         // Read information about the AST file.
4343         Idx += 5; // ImportLoc, Size, ModTime, Signature
4344         std::string Filename = ReadString(Record, Idx);
4345         ResolveImportedPath(Filename, ModuleDir);
4346         Listener.visitImport(Filename);
4347       }
4348       break;
4349     }
4350 
4351     default:
4352       // No other validation to perform.
4353       break;
4354     }
4355   }
4356 
4357   // Look for module file extension blocks, if requested.
4358   if (FindModuleFileExtensions) {
4359     while (!SkipCursorToBlock(Stream, EXTENSION_BLOCK_ID)) {
4360       bool DoneWithExtensionBlock = false;
4361       while (!DoneWithExtensionBlock) {
4362        llvm::BitstreamEntry Entry = Stream.advance();
4363 
4364        switch (Entry.Kind) {
4365        case llvm::BitstreamEntry::SubBlock:
4366          if (Stream.SkipBlock())
4367            return true;
4368 
4369          continue;
4370 
4371        case llvm::BitstreamEntry::EndBlock:
4372          DoneWithExtensionBlock = true;
4373          continue;
4374 
4375        case llvm::BitstreamEntry::Error:
4376          return true;
4377 
4378        case llvm::BitstreamEntry::Record:
4379          break;
4380        }
4381 
4382        Record.clear();
4383        StringRef Blob;
4384        unsigned RecCode = Stream.readRecord(Entry.ID, Record, &Blob);
4385        switch (RecCode) {
4386        case EXTENSION_METADATA: {
4387          ModuleFileExtensionMetadata Metadata;
4388          if (parseModuleFileExtensionMetadata(Record, Blob, Metadata))
4389            return true;
4390 
4391          Listener.readModuleFileExtension(Metadata);
4392          break;
4393        }
4394        }
4395       }
4396     }
4397   }
4398 
4399   return false;
4400 }
4401 
isAcceptableASTFile(StringRef Filename,FileManager & FileMgr,const PCHContainerReader & PCHContainerRdr,const LangOptions & LangOpts,const TargetOptions & TargetOpts,const PreprocessorOptions & PPOpts,std::string ExistingModuleCachePath)4402 bool ASTReader::isAcceptableASTFile(
4403     StringRef Filename, FileManager &FileMgr,
4404     const PCHContainerReader &PCHContainerRdr, const LangOptions &LangOpts,
4405     const TargetOptions &TargetOpts, const PreprocessorOptions &PPOpts,
4406     std::string ExistingModuleCachePath) {
4407   SimplePCHValidator validator(LangOpts, TargetOpts, PPOpts,
4408                                ExistingModuleCachePath, FileMgr);
4409   return !readASTFileControlBlock(Filename, FileMgr, PCHContainerRdr,
4410                                   /*FindModuleFileExtensions=*/false,
4411                                   validator);
4412 }
4413 
4414 ASTReader::ASTReadResult
ReadSubmoduleBlock(ModuleFile & F,unsigned ClientLoadCapabilities)4415 ASTReader::ReadSubmoduleBlock(ModuleFile &F, unsigned ClientLoadCapabilities) {
4416   // Enter the submodule block.
4417   if (F.Stream.EnterSubBlock(SUBMODULE_BLOCK_ID)) {
4418     Error("malformed submodule block record in AST file");
4419     return Failure;
4420   }
4421 
4422   ModuleMap &ModMap = PP.getHeaderSearchInfo().getModuleMap();
4423   bool First = true;
4424   Module *CurrentModule = nullptr;
4425   RecordData Record;
4426   while (true) {
4427     llvm::BitstreamEntry Entry = F.Stream.advanceSkippingSubblocks();
4428 
4429     switch (Entry.Kind) {
4430     case llvm::BitstreamEntry::SubBlock: // Handled for us already.
4431     case llvm::BitstreamEntry::Error:
4432       Error("malformed block record in AST file");
4433       return Failure;
4434     case llvm::BitstreamEntry::EndBlock:
4435       return Success;
4436     case llvm::BitstreamEntry::Record:
4437       // The interesting case.
4438       break;
4439     }
4440 
4441     // Read a record.
4442     StringRef Blob;
4443     Record.clear();
4444     auto Kind = F.Stream.readRecord(Entry.ID, Record, &Blob);
4445 
4446     if ((Kind == SUBMODULE_METADATA) != First) {
4447       Error("submodule metadata record should be at beginning of block");
4448       return Failure;
4449     }
4450     First = false;
4451 
4452     // Submodule information is only valid if we have a current module.
4453     // FIXME: Should we error on these cases?
4454     if (!CurrentModule && Kind != SUBMODULE_METADATA &&
4455         Kind != SUBMODULE_DEFINITION)
4456       continue;
4457 
4458     switch (Kind) {
4459     default:  // Default behavior: ignore.
4460       break;
4461 
4462     case SUBMODULE_DEFINITION: {
4463       if (Record.size() < 8) {
4464         Error("malformed module definition");
4465         return Failure;
4466       }
4467 
4468       StringRef Name = Blob;
4469       unsigned Idx = 0;
4470       SubmoduleID GlobalID = getGlobalSubmoduleID(F, Record[Idx++]);
4471       SubmoduleID Parent = getGlobalSubmoduleID(F, Record[Idx++]);
4472       bool IsFramework = Record[Idx++];
4473       bool IsExplicit = Record[Idx++];
4474       bool IsSystem = Record[Idx++];
4475       bool IsExternC = Record[Idx++];
4476       bool InferSubmodules = Record[Idx++];
4477       bool InferExplicitSubmodules = Record[Idx++];
4478       bool InferExportWildcard = Record[Idx++];
4479       bool ConfigMacrosExhaustive = Record[Idx++];
4480 
4481       Module *ParentModule = nullptr;
4482       if (Parent)
4483         ParentModule = getSubmodule(Parent);
4484 
4485       // Retrieve this (sub)module from the module map, creating it if
4486       // necessary.
4487       CurrentModule = ModMap.findOrCreateModule(Name, ParentModule, IsFramework,
4488                                                 IsExplicit).first;
4489 
4490       // FIXME: set the definition loc for CurrentModule, or call
4491       // ModMap.setInferredModuleAllowedBy()
4492 
4493       SubmoduleID GlobalIndex = GlobalID - NUM_PREDEF_SUBMODULE_IDS;
4494       if (GlobalIndex >= SubmodulesLoaded.size() ||
4495           SubmodulesLoaded[GlobalIndex]) {
4496         Error("too many submodules");
4497         return Failure;
4498       }
4499 
4500       if (!ParentModule) {
4501         if (const FileEntry *CurFile = CurrentModule->getASTFile()) {
4502           if (CurFile != F.File) {
4503             if (!Diags.isDiagnosticInFlight()) {
4504               Diag(diag::err_module_file_conflict)
4505                 << CurrentModule->getTopLevelModuleName()
4506                 << CurFile->getName()
4507                 << F.File->getName();
4508             }
4509             return Failure;
4510           }
4511         }
4512 
4513         CurrentModule->setASTFile(F.File);
4514       }
4515 
4516       CurrentModule->Signature = F.Signature;
4517       CurrentModule->IsFromModuleFile = true;
4518       CurrentModule->IsSystem = IsSystem || CurrentModule->IsSystem;
4519       CurrentModule->IsExternC = IsExternC;
4520       CurrentModule->InferSubmodules = InferSubmodules;
4521       CurrentModule->InferExplicitSubmodules = InferExplicitSubmodules;
4522       CurrentModule->InferExportWildcard = InferExportWildcard;
4523       CurrentModule->ConfigMacrosExhaustive = ConfigMacrosExhaustive;
4524       if (DeserializationListener)
4525         DeserializationListener->ModuleRead(GlobalID, CurrentModule);
4526 
4527       SubmodulesLoaded[GlobalIndex] = CurrentModule;
4528 
4529       // Clear out data that will be replaced by what is in the module file.
4530       CurrentModule->LinkLibraries.clear();
4531       CurrentModule->ConfigMacros.clear();
4532       CurrentModule->UnresolvedConflicts.clear();
4533       CurrentModule->Conflicts.clear();
4534 
4535       // The module is available unless it's missing a requirement; relevant
4536       // requirements will be (re-)added by SUBMODULE_REQUIRES records.
4537       // Missing headers that were present when the module was built do not
4538       // make it unavailable -- if we got this far, this must be an explicitly
4539       // imported module file.
4540       CurrentModule->Requirements.clear();
4541       CurrentModule->MissingHeaders.clear();
4542       CurrentModule->IsMissingRequirement =
4543           ParentModule && ParentModule->IsMissingRequirement;
4544       CurrentModule->IsAvailable = !CurrentModule->IsMissingRequirement;
4545       break;
4546     }
4547 
4548     case SUBMODULE_UMBRELLA_HEADER: {
4549       std::string Filename = Blob;
4550       ResolveImportedPath(F, Filename);
4551       if (auto *Umbrella = PP.getFileManager().getFile(Filename)) {
4552         if (!CurrentModule->getUmbrellaHeader())
4553           ModMap.setUmbrellaHeader(CurrentModule, Umbrella, Blob);
4554         else if (CurrentModule->getUmbrellaHeader().Entry != Umbrella) {
4555           // This can be a spurious difference caused by changing the VFS to
4556           // point to a different copy of the file, and it is too late to
4557           // to rebuild safely.
4558           // FIXME: If we wrote the virtual paths instead of the 'real' paths,
4559           // after input file validation only real problems would remain and we
4560           // could just error. For now, assume it's okay.
4561           break;
4562         }
4563       }
4564       break;
4565     }
4566 
4567     case SUBMODULE_HEADER:
4568     case SUBMODULE_EXCLUDED_HEADER:
4569     case SUBMODULE_PRIVATE_HEADER:
4570       // We lazily associate headers with their modules via the HeaderInfo table.
4571       // FIXME: Re-evaluate this section; maybe only store InputFile IDs instead
4572       // of complete filenames or remove it entirely.
4573       break;
4574 
4575     case SUBMODULE_TEXTUAL_HEADER:
4576     case SUBMODULE_PRIVATE_TEXTUAL_HEADER:
4577       // FIXME: Textual headers are not marked in the HeaderInfo table. Load
4578       // them here.
4579       break;
4580 
4581     case SUBMODULE_TOPHEADER: {
4582       CurrentModule->addTopHeaderFilename(Blob);
4583       break;
4584     }
4585 
4586     case SUBMODULE_UMBRELLA_DIR: {
4587       std::string Dirname = Blob;
4588       ResolveImportedPath(F, Dirname);
4589       if (auto *Umbrella = PP.getFileManager().getDirectory(Dirname)) {
4590         if (!CurrentModule->getUmbrellaDir())
4591           ModMap.setUmbrellaDir(CurrentModule, Umbrella, Blob);
4592         else if (CurrentModule->getUmbrellaDir().Entry != Umbrella) {
4593           if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
4594             Error("mismatched umbrella directories in submodule");
4595           return OutOfDate;
4596         }
4597       }
4598       break;
4599     }
4600 
4601     case SUBMODULE_METADATA: {
4602       F.BaseSubmoduleID = getTotalNumSubmodules();
4603       F.LocalNumSubmodules = Record[0];
4604       unsigned LocalBaseSubmoduleID = Record[1];
4605       if (F.LocalNumSubmodules > 0) {
4606         // Introduce the global -> local mapping for submodules within this
4607         // module.
4608         GlobalSubmoduleMap.insert(std::make_pair(getTotalNumSubmodules()+1,&F));
4609 
4610         // Introduce the local -> global mapping for submodules within this
4611         // module.
4612         F.SubmoduleRemap.insertOrReplace(
4613           std::make_pair(LocalBaseSubmoduleID,
4614                          F.BaseSubmoduleID - LocalBaseSubmoduleID));
4615 
4616         SubmodulesLoaded.resize(SubmodulesLoaded.size() + F.LocalNumSubmodules);
4617       }
4618       break;
4619     }
4620 
4621     case SUBMODULE_IMPORTS: {
4622       for (unsigned Idx = 0; Idx != Record.size(); ++Idx) {
4623         UnresolvedModuleRef Unresolved;
4624         Unresolved.File = &F;
4625         Unresolved.Mod = CurrentModule;
4626         Unresolved.ID = Record[Idx];
4627         Unresolved.Kind = UnresolvedModuleRef::Import;
4628         Unresolved.IsWildcard = false;
4629         UnresolvedModuleRefs.push_back(Unresolved);
4630       }
4631       break;
4632     }
4633 
4634     case SUBMODULE_EXPORTS: {
4635       for (unsigned Idx = 0; Idx + 1 < Record.size(); Idx += 2) {
4636         UnresolvedModuleRef Unresolved;
4637         Unresolved.File = &F;
4638         Unresolved.Mod = CurrentModule;
4639         Unresolved.ID = Record[Idx];
4640         Unresolved.Kind = UnresolvedModuleRef::Export;
4641         Unresolved.IsWildcard = Record[Idx + 1];
4642         UnresolvedModuleRefs.push_back(Unresolved);
4643       }
4644 
4645       // Once we've loaded the set of exports, there's no reason to keep
4646       // the parsed, unresolved exports around.
4647       CurrentModule->UnresolvedExports.clear();
4648       break;
4649     }
4650     case SUBMODULE_REQUIRES: {
4651       CurrentModule->addRequirement(Blob, Record[0], Context.getLangOpts(),
4652                                     Context.getTargetInfo());
4653       break;
4654     }
4655 
4656     case SUBMODULE_LINK_LIBRARY:
4657       CurrentModule->LinkLibraries.push_back(
4658                                          Module::LinkLibrary(Blob, Record[0]));
4659       break;
4660 
4661     case SUBMODULE_CONFIG_MACRO:
4662       CurrentModule->ConfigMacros.push_back(Blob.str());
4663       break;
4664 
4665     case SUBMODULE_CONFLICT: {
4666       UnresolvedModuleRef Unresolved;
4667       Unresolved.File = &F;
4668       Unresolved.Mod = CurrentModule;
4669       Unresolved.ID = Record[0];
4670       Unresolved.Kind = UnresolvedModuleRef::Conflict;
4671       Unresolved.IsWildcard = false;
4672       Unresolved.String = Blob;
4673       UnresolvedModuleRefs.push_back(Unresolved);
4674       break;
4675     }
4676     }
4677   }
4678 }
4679 
4680 /// \brief Parse the record that corresponds to a LangOptions data
4681 /// structure.
4682 ///
4683 /// This routine parses the language options from the AST file and then gives
4684 /// them to the AST listener if one is set.
4685 ///
4686 /// \returns true if the listener deems the file unacceptable, false otherwise.
ParseLanguageOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener,bool AllowCompatibleDifferences)4687 bool ASTReader::ParseLanguageOptions(const RecordData &Record,
4688                                      bool Complain,
4689                                      ASTReaderListener &Listener,
4690                                      bool AllowCompatibleDifferences) {
4691   LangOptions LangOpts;
4692   unsigned Idx = 0;
4693 #define LANGOPT(Name, Bits, Default, Description) \
4694   LangOpts.Name = Record[Idx++];
4695 #define ENUM_LANGOPT(Name, Type, Bits, Default, Description) \
4696   LangOpts.set##Name(static_cast<LangOptions::Type>(Record[Idx++]));
4697 #include "clang/Basic/LangOptions.def"
4698 #define SANITIZER(NAME, ID)                                                    \
4699   LangOpts.Sanitize.set(SanitizerKind::ID, Record[Idx++]);
4700 #include "clang/Basic/Sanitizers.def"
4701 
4702   for (unsigned N = Record[Idx++]; N; --N)
4703     LangOpts.ModuleFeatures.push_back(ReadString(Record, Idx));
4704 
4705   ObjCRuntime::Kind runtimeKind = (ObjCRuntime::Kind) Record[Idx++];
4706   VersionTuple runtimeVersion = ReadVersionTuple(Record, Idx);
4707   LangOpts.ObjCRuntime = ObjCRuntime(runtimeKind, runtimeVersion);
4708 
4709   LangOpts.CurrentModule = ReadString(Record, Idx);
4710 
4711   // Comment options.
4712   for (unsigned N = Record[Idx++]; N; --N) {
4713     LangOpts.CommentOpts.BlockCommandNames.push_back(
4714       ReadString(Record, Idx));
4715   }
4716   LangOpts.CommentOpts.ParseAllComments = Record[Idx++];
4717 
4718   // OpenMP offloading options.
4719   for (unsigned N = Record[Idx++]; N; --N) {
4720     LangOpts.OMPTargetTriples.push_back(llvm::Triple(ReadString(Record, Idx)));
4721   }
4722 
4723   LangOpts.OMPHostIRFile = ReadString(Record, Idx);
4724 
4725   return Listener.ReadLanguageOptions(LangOpts, Complain,
4726                                       AllowCompatibleDifferences);
4727 }
4728 
ParseTargetOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener,bool AllowCompatibleDifferences)4729 bool ASTReader::ParseTargetOptions(const RecordData &Record, bool Complain,
4730                                    ASTReaderListener &Listener,
4731                                    bool AllowCompatibleDifferences) {
4732   unsigned Idx = 0;
4733   TargetOptions TargetOpts;
4734   TargetOpts.Triple = ReadString(Record, Idx);
4735   TargetOpts.CPU = ReadString(Record, Idx);
4736   TargetOpts.ABI = ReadString(Record, Idx);
4737   for (unsigned N = Record[Idx++]; N; --N) {
4738     TargetOpts.FeaturesAsWritten.push_back(ReadString(Record, Idx));
4739   }
4740   for (unsigned N = Record[Idx++]; N; --N) {
4741     TargetOpts.Features.push_back(ReadString(Record, Idx));
4742   }
4743 
4744   return Listener.ReadTargetOptions(TargetOpts, Complain,
4745                                     AllowCompatibleDifferences);
4746 }
4747 
ParseDiagnosticOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener)4748 bool ASTReader::ParseDiagnosticOptions(const RecordData &Record, bool Complain,
4749                                        ASTReaderListener &Listener) {
4750   IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts(new DiagnosticOptions);
4751   unsigned Idx = 0;
4752 #define DIAGOPT(Name, Bits, Default) DiagOpts->Name = Record[Idx++];
4753 #define ENUM_DIAGOPT(Name, Type, Bits, Default) \
4754   DiagOpts->set##Name(static_cast<Type>(Record[Idx++]));
4755 #include "clang/Basic/DiagnosticOptions.def"
4756 
4757   for (unsigned N = Record[Idx++]; N; --N)
4758     DiagOpts->Warnings.push_back(ReadString(Record, Idx));
4759   for (unsigned N = Record[Idx++]; N; --N)
4760     DiagOpts->Remarks.push_back(ReadString(Record, Idx));
4761 
4762   return Listener.ReadDiagnosticOptions(DiagOpts, Complain);
4763 }
4764 
ParseFileSystemOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener)4765 bool ASTReader::ParseFileSystemOptions(const RecordData &Record, bool Complain,
4766                                        ASTReaderListener &Listener) {
4767   FileSystemOptions FSOpts;
4768   unsigned Idx = 0;
4769   FSOpts.WorkingDir = ReadString(Record, Idx);
4770   return Listener.ReadFileSystemOptions(FSOpts, Complain);
4771 }
4772 
ParseHeaderSearchOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener)4773 bool ASTReader::ParseHeaderSearchOptions(const RecordData &Record,
4774                                          bool Complain,
4775                                          ASTReaderListener &Listener) {
4776   HeaderSearchOptions HSOpts;
4777   unsigned Idx = 0;
4778   HSOpts.Sysroot = ReadString(Record, Idx);
4779 
4780   // Include entries.
4781   for (unsigned N = Record[Idx++]; N; --N) {
4782     std::string Path = ReadString(Record, Idx);
4783     frontend::IncludeDirGroup Group
4784       = static_cast<frontend::IncludeDirGroup>(Record[Idx++]);
4785     bool IsFramework = Record[Idx++];
4786     bool IgnoreSysRoot = Record[Idx++];
4787     HSOpts.UserEntries.emplace_back(std::move(Path), Group, IsFramework,
4788                                     IgnoreSysRoot);
4789   }
4790 
4791   // System header prefixes.
4792   for (unsigned N = Record[Idx++]; N; --N) {
4793     std::string Prefix = ReadString(Record, Idx);
4794     bool IsSystemHeader = Record[Idx++];
4795     HSOpts.SystemHeaderPrefixes.emplace_back(std::move(Prefix), IsSystemHeader);
4796   }
4797 
4798   HSOpts.ResourceDir = ReadString(Record, Idx);
4799   HSOpts.ModuleCachePath = ReadString(Record, Idx);
4800   HSOpts.ModuleUserBuildPath = ReadString(Record, Idx);
4801   HSOpts.DisableModuleHash = Record[Idx++];
4802   HSOpts.UseBuiltinIncludes = Record[Idx++];
4803   HSOpts.UseStandardSystemIncludes = Record[Idx++];
4804   HSOpts.UseStandardCXXIncludes = Record[Idx++];
4805   HSOpts.UseLibcxx = Record[Idx++];
4806   std::string SpecificModuleCachePath = ReadString(Record, Idx);
4807 
4808   return Listener.ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
4809                                           Complain);
4810 }
4811 
ParsePreprocessorOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener,std::string & SuggestedPredefines)4812 bool ASTReader::ParsePreprocessorOptions(const RecordData &Record,
4813                                          bool Complain,
4814                                          ASTReaderListener &Listener,
4815                                          std::string &SuggestedPredefines) {
4816   PreprocessorOptions PPOpts;
4817   unsigned Idx = 0;
4818 
4819   // Macro definitions/undefs
4820   for (unsigned N = Record[Idx++]; N; --N) {
4821     std::string Macro = ReadString(Record, Idx);
4822     bool IsUndef = Record[Idx++];
4823     PPOpts.Macros.push_back(std::make_pair(Macro, IsUndef));
4824   }
4825 
4826   // Includes
4827   for (unsigned N = Record[Idx++]; N; --N) {
4828     PPOpts.Includes.push_back(ReadString(Record, Idx));
4829   }
4830 
4831   // Macro Includes
4832   for (unsigned N = Record[Idx++]; N; --N) {
4833     PPOpts.MacroIncludes.push_back(ReadString(Record, Idx));
4834   }
4835 
4836   PPOpts.UsePredefines = Record[Idx++];
4837   PPOpts.DetailedRecord = Record[Idx++];
4838   PPOpts.ImplicitPCHInclude = ReadString(Record, Idx);
4839   PPOpts.ImplicitPTHInclude = ReadString(Record, Idx);
4840   PPOpts.ObjCXXARCStandardLibrary =
4841     static_cast<ObjCXXARCStandardLibraryKind>(Record[Idx++]);
4842   SuggestedPredefines.clear();
4843   return Listener.ReadPreprocessorOptions(PPOpts, Complain,
4844                                           SuggestedPredefines);
4845 }
4846 
4847 std::pair<ModuleFile *, unsigned>
getModulePreprocessedEntity(unsigned GlobalIndex)4848 ASTReader::getModulePreprocessedEntity(unsigned GlobalIndex) {
4849   GlobalPreprocessedEntityMapType::iterator
4850   I = GlobalPreprocessedEntityMap.find(GlobalIndex);
4851   assert(I != GlobalPreprocessedEntityMap.end() &&
4852          "Corrupted global preprocessed entity map");
4853   ModuleFile *M = I->second;
4854   unsigned LocalIndex = GlobalIndex - M->BasePreprocessedEntityID;
4855   return std::make_pair(M, LocalIndex);
4856 }
4857 
4858 llvm::iterator_range<PreprocessingRecord::iterator>
getModulePreprocessedEntities(ModuleFile & Mod) const4859 ASTReader::getModulePreprocessedEntities(ModuleFile &Mod) const {
4860   if (PreprocessingRecord *PPRec = PP.getPreprocessingRecord())
4861     return PPRec->getIteratorsForLoadedRange(Mod.BasePreprocessedEntityID,
4862                                              Mod.NumPreprocessedEntities);
4863 
4864   return llvm::make_range(PreprocessingRecord::iterator(),
4865                           PreprocessingRecord::iterator());
4866 }
4867 
4868 llvm::iterator_range<ASTReader::ModuleDeclIterator>
getModuleFileLevelDecls(ModuleFile & Mod)4869 ASTReader::getModuleFileLevelDecls(ModuleFile &Mod) {
4870   return llvm::make_range(
4871       ModuleDeclIterator(this, &Mod, Mod.FileSortedDecls),
4872       ModuleDeclIterator(this, &Mod,
4873                          Mod.FileSortedDecls + Mod.NumFileSortedDecls));
4874 }
4875 
ReadPreprocessedEntity(unsigned Index)4876 PreprocessedEntity *ASTReader::ReadPreprocessedEntity(unsigned Index) {
4877   PreprocessedEntityID PPID = Index+1;
4878   std::pair<ModuleFile *, unsigned> PPInfo = getModulePreprocessedEntity(Index);
4879   ModuleFile &M = *PPInfo.first;
4880   unsigned LocalIndex = PPInfo.second;
4881   const PPEntityOffset &PPOffs = M.PreprocessedEntityOffsets[LocalIndex];
4882 
4883   if (!PP.getPreprocessingRecord()) {
4884     Error("no preprocessing record");
4885     return nullptr;
4886   }
4887 
4888   SavedStreamPosition SavedPosition(M.PreprocessorDetailCursor);
4889   M.PreprocessorDetailCursor.JumpToBit(PPOffs.BitOffset);
4890 
4891   llvm::BitstreamEntry Entry =
4892     M.PreprocessorDetailCursor.advance(BitstreamCursor::AF_DontPopBlockAtEnd);
4893   if (Entry.Kind != llvm::BitstreamEntry::Record)
4894     return nullptr;
4895 
4896   // Read the record.
4897   SourceRange Range(TranslateSourceLocation(M, PPOffs.getBegin()),
4898                     TranslateSourceLocation(M, PPOffs.getEnd()));
4899   PreprocessingRecord &PPRec = *PP.getPreprocessingRecord();
4900   StringRef Blob;
4901   RecordData Record;
4902   PreprocessorDetailRecordTypes RecType =
4903     (PreprocessorDetailRecordTypes)M.PreprocessorDetailCursor.readRecord(
4904                                           Entry.ID, Record, &Blob);
4905   switch (RecType) {
4906   case PPD_MACRO_EXPANSION: {
4907     bool isBuiltin = Record[0];
4908     IdentifierInfo *Name = nullptr;
4909     MacroDefinitionRecord *Def = nullptr;
4910     if (isBuiltin)
4911       Name = getLocalIdentifier(M, Record[1]);
4912     else {
4913       PreprocessedEntityID GlobalID =
4914           getGlobalPreprocessedEntityID(M, Record[1]);
4915       Def = cast<MacroDefinitionRecord>(
4916           PPRec.getLoadedPreprocessedEntity(GlobalID - 1));
4917     }
4918 
4919     MacroExpansion *ME;
4920     if (isBuiltin)
4921       ME = new (PPRec) MacroExpansion(Name, Range);
4922     else
4923       ME = new (PPRec) MacroExpansion(Def, Range);
4924 
4925     return ME;
4926   }
4927 
4928   case PPD_MACRO_DEFINITION: {
4929     // Decode the identifier info and then check again; if the macro is
4930     // still defined and associated with the identifier,
4931     IdentifierInfo *II = getLocalIdentifier(M, Record[0]);
4932     MacroDefinitionRecord *MD = new (PPRec) MacroDefinitionRecord(II, Range);
4933 
4934     if (DeserializationListener)
4935       DeserializationListener->MacroDefinitionRead(PPID, MD);
4936 
4937     return MD;
4938   }
4939 
4940   case PPD_INCLUSION_DIRECTIVE: {
4941     const char *FullFileNameStart = Blob.data() + Record[0];
4942     StringRef FullFileName(FullFileNameStart, Blob.size() - Record[0]);
4943     const FileEntry *File = nullptr;
4944     if (!FullFileName.empty())
4945       File = PP.getFileManager().getFile(FullFileName);
4946 
4947     // FIXME: Stable encoding
4948     InclusionDirective::InclusionKind Kind
4949       = static_cast<InclusionDirective::InclusionKind>(Record[2]);
4950     InclusionDirective *ID
4951       = new (PPRec) InclusionDirective(PPRec, Kind,
4952                                        StringRef(Blob.data(), Record[0]),
4953                                        Record[1], Record[3],
4954                                        File,
4955                                        Range);
4956     return ID;
4957   }
4958   }
4959 
4960   llvm_unreachable("Invalid PreprocessorDetailRecordTypes");
4961 }
4962 
4963 /// \brief \arg SLocMapI points at a chunk of a module that contains no
4964 /// preprocessed entities or the entities it contains are not the ones we are
4965 /// looking for. Find the next module that contains entities and return the ID
4966 /// of the first entry.
findNextPreprocessedEntity(GlobalSLocOffsetMapType::const_iterator SLocMapI) const4967 PreprocessedEntityID ASTReader::findNextPreprocessedEntity(
4968                        GlobalSLocOffsetMapType::const_iterator SLocMapI) const {
4969   ++SLocMapI;
4970   for (GlobalSLocOffsetMapType::const_iterator
4971          EndI = GlobalSLocOffsetMap.end(); SLocMapI != EndI; ++SLocMapI) {
4972     ModuleFile &M = *SLocMapI->second;
4973     if (M.NumPreprocessedEntities)
4974       return M.BasePreprocessedEntityID;
4975   }
4976 
4977   return getTotalNumPreprocessedEntities();
4978 }
4979 
4980 namespace {
4981 
4982 struct PPEntityComp {
4983   const ASTReader &Reader;
4984   ModuleFile &M;
4985 
PPEntityComp__anon6120b52b0711::PPEntityComp4986   PPEntityComp(const ASTReader &Reader, ModuleFile &M) : Reader(Reader), M(M) { }
4987 
operator ()__anon6120b52b0711::PPEntityComp4988   bool operator()(const PPEntityOffset &L, const PPEntityOffset &R) const {
4989     SourceLocation LHS = getLoc(L);
4990     SourceLocation RHS = getLoc(R);
4991     return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
4992   }
4993 
operator ()__anon6120b52b0711::PPEntityComp4994   bool operator()(const PPEntityOffset &L, SourceLocation RHS) const {
4995     SourceLocation LHS = getLoc(L);
4996     return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
4997   }
4998 
operator ()__anon6120b52b0711::PPEntityComp4999   bool operator()(SourceLocation LHS, const PPEntityOffset &R) const {
5000     SourceLocation RHS = getLoc(R);
5001     return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
5002   }
5003 
getLoc__anon6120b52b0711::PPEntityComp5004   SourceLocation getLoc(const PPEntityOffset &PPE) const {
5005     return Reader.TranslateSourceLocation(M, PPE.getBegin());
5006   }
5007 };
5008 
5009 }
5010 
findPreprocessedEntity(SourceLocation Loc,bool EndsAfter) const5011 PreprocessedEntityID ASTReader::findPreprocessedEntity(SourceLocation Loc,
5012                                                        bool EndsAfter) const {
5013   if (SourceMgr.isLocalSourceLocation(Loc))
5014     return getTotalNumPreprocessedEntities();
5015 
5016   GlobalSLocOffsetMapType::const_iterator SLocMapI = GlobalSLocOffsetMap.find(
5017       SourceManager::MaxLoadedOffset - Loc.getOffset() - 1);
5018   assert(SLocMapI != GlobalSLocOffsetMap.end() &&
5019          "Corrupted global sloc offset map");
5020 
5021   if (SLocMapI->second->NumPreprocessedEntities == 0)
5022     return findNextPreprocessedEntity(SLocMapI);
5023 
5024   ModuleFile &M = *SLocMapI->second;
5025   typedef const PPEntityOffset *pp_iterator;
5026   pp_iterator pp_begin = M.PreprocessedEntityOffsets;
5027   pp_iterator pp_end = pp_begin + M.NumPreprocessedEntities;
5028 
5029   size_t Count = M.NumPreprocessedEntities;
5030   size_t Half;
5031   pp_iterator First = pp_begin;
5032   pp_iterator PPI;
5033 
5034   if (EndsAfter) {
5035     PPI = std::upper_bound(pp_begin, pp_end, Loc,
5036                            PPEntityComp(*this, M));
5037   } else {
5038     // Do a binary search manually instead of using std::lower_bound because
5039     // The end locations of entities may be unordered (when a macro expansion
5040     // is inside another macro argument), but for this case it is not important
5041     // whether we get the first macro expansion or its containing macro.
5042     while (Count > 0) {
5043       Half = Count / 2;
5044       PPI = First;
5045       std::advance(PPI, Half);
5046       if (SourceMgr.isBeforeInTranslationUnit(
5047               TranslateSourceLocation(M, PPI->getEnd()), Loc)) {
5048         First = PPI;
5049         ++First;
5050         Count = Count - Half - 1;
5051       } else
5052         Count = Half;
5053     }
5054   }
5055 
5056   if (PPI == pp_end)
5057     return findNextPreprocessedEntity(SLocMapI);
5058 
5059   return M.BasePreprocessedEntityID + (PPI - pp_begin);
5060 }
5061 
5062 /// \brief Returns a pair of [Begin, End) indices of preallocated
5063 /// preprocessed entities that \arg Range encompasses.
5064 std::pair<unsigned, unsigned>
findPreprocessedEntitiesInRange(SourceRange Range)5065     ASTReader::findPreprocessedEntitiesInRange(SourceRange Range) {
5066   if (Range.isInvalid())
5067     return std::make_pair(0,0);
5068   assert(!SourceMgr.isBeforeInTranslationUnit(Range.getEnd(),Range.getBegin()));
5069 
5070   PreprocessedEntityID BeginID =
5071       findPreprocessedEntity(Range.getBegin(), false);
5072   PreprocessedEntityID EndID = findPreprocessedEntity(Range.getEnd(), true);
5073   return std::make_pair(BeginID, EndID);
5074 }
5075 
5076 /// \brief Optionally returns true or false if the preallocated preprocessed
5077 /// entity with index \arg Index came from file \arg FID.
isPreprocessedEntityInFileID(unsigned Index,FileID FID)5078 Optional<bool> ASTReader::isPreprocessedEntityInFileID(unsigned Index,
5079                                                              FileID FID) {
5080   if (FID.isInvalid())
5081     return false;
5082 
5083   std::pair<ModuleFile *, unsigned> PPInfo = getModulePreprocessedEntity(Index);
5084   ModuleFile &M = *PPInfo.first;
5085   unsigned LocalIndex = PPInfo.second;
5086   const PPEntityOffset &PPOffs = M.PreprocessedEntityOffsets[LocalIndex];
5087 
5088   SourceLocation Loc = TranslateSourceLocation(M, PPOffs.getBegin());
5089   if (Loc.isInvalid())
5090     return false;
5091 
5092   if (SourceMgr.isInFileID(SourceMgr.getFileLoc(Loc), FID))
5093     return true;
5094   else
5095     return false;
5096 }
5097 
5098 namespace {
5099   /// \brief Visitor used to search for information about a header file.
5100   class HeaderFileInfoVisitor {
5101     const FileEntry *FE;
5102 
5103     Optional<HeaderFileInfo> HFI;
5104 
5105   public:
HeaderFileInfoVisitor(const FileEntry * FE)5106     explicit HeaderFileInfoVisitor(const FileEntry *FE)
5107       : FE(FE) { }
5108 
operator ()(ModuleFile & M)5109     bool operator()(ModuleFile &M) {
5110       HeaderFileInfoLookupTable *Table
5111         = static_cast<HeaderFileInfoLookupTable *>(M.HeaderFileInfoTable);
5112       if (!Table)
5113         return false;
5114 
5115       // Look in the on-disk hash table for an entry for this file name.
5116       HeaderFileInfoLookupTable::iterator Pos = Table->find(FE);
5117       if (Pos == Table->end())
5118         return false;
5119 
5120       HFI = *Pos;
5121       return true;
5122     }
5123 
getHeaderFileInfo() const5124     Optional<HeaderFileInfo> getHeaderFileInfo() const { return HFI; }
5125   };
5126 }
5127 
GetHeaderFileInfo(const FileEntry * FE)5128 HeaderFileInfo ASTReader::GetHeaderFileInfo(const FileEntry *FE) {
5129   HeaderFileInfoVisitor Visitor(FE);
5130   ModuleMgr.visit(Visitor);
5131   if (Optional<HeaderFileInfo> HFI = Visitor.getHeaderFileInfo())
5132     return *HFI;
5133 
5134   return HeaderFileInfo();
5135 }
5136 
ReadPragmaDiagnosticMappings(DiagnosticsEngine & Diag)5137 void ASTReader::ReadPragmaDiagnosticMappings(DiagnosticsEngine &Diag) {
5138   // FIXME: Make it work properly with modules.
5139   SmallVector<DiagnosticsEngine::DiagState *, 32> DiagStates;
5140   for (ModuleIterator I = ModuleMgr.begin(), E = ModuleMgr.end(); I != E; ++I) {
5141     ModuleFile &F = *(*I);
5142     unsigned Idx = 0;
5143     DiagStates.clear();
5144     assert(!Diag.DiagStates.empty());
5145     DiagStates.push_back(&Diag.DiagStates.front()); // the command-line one.
5146     while (Idx < F.PragmaDiagMappings.size()) {
5147       SourceLocation Loc = ReadSourceLocation(F, F.PragmaDiagMappings[Idx++]);
5148       unsigned DiagStateID = F.PragmaDiagMappings[Idx++];
5149       if (DiagStateID != 0) {
5150         Diag.DiagStatePoints.push_back(
5151                     DiagnosticsEngine::DiagStatePoint(DiagStates[DiagStateID-1],
5152                     FullSourceLoc(Loc, SourceMgr)));
5153         continue;
5154       }
5155 
5156       assert(DiagStateID == 0);
5157       // A new DiagState was created here.
5158       Diag.DiagStates.push_back(*Diag.GetCurDiagState());
5159       DiagnosticsEngine::DiagState *NewState = &Diag.DiagStates.back();
5160       DiagStates.push_back(NewState);
5161       Diag.DiagStatePoints.push_back(
5162           DiagnosticsEngine::DiagStatePoint(NewState,
5163                                             FullSourceLoc(Loc, SourceMgr)));
5164       while (1) {
5165         assert(Idx < F.PragmaDiagMappings.size() &&
5166                "Invalid data, didn't find '-1' marking end of diag/map pairs");
5167         if (Idx >= F.PragmaDiagMappings.size()) {
5168           break; // Something is messed up but at least avoid infinite loop in
5169                  // release build.
5170         }
5171         unsigned DiagID = F.PragmaDiagMappings[Idx++];
5172         if (DiagID == (unsigned)-1) {
5173           break; // no more diag/map pairs for this location.
5174         }
5175         diag::Severity Map = (diag::Severity)F.PragmaDiagMappings[Idx++];
5176         DiagnosticMapping Mapping = Diag.makeUserMapping(Map, Loc);
5177         Diag.GetCurDiagState()->setMapping(DiagID, Mapping);
5178       }
5179     }
5180   }
5181 }
5182 
5183 /// \brief Get the correct cursor and offset for loading a type.
TypeCursorForIndex(unsigned Index)5184 ASTReader::RecordLocation ASTReader::TypeCursorForIndex(unsigned Index) {
5185   GlobalTypeMapType::iterator I = GlobalTypeMap.find(Index);
5186   assert(I != GlobalTypeMap.end() && "Corrupted global type map");
5187   ModuleFile *M = I->second;
5188   return RecordLocation(M, M->TypeOffsets[Index - M->BaseTypeIndex]);
5189 }
5190 
5191 /// \brief Read and return the type with the given index..
5192 ///
5193 /// The index is the type ID, shifted and minus the number of predefs. This
5194 /// routine actually reads the record corresponding to the type at the given
5195 /// location. It is a helper routine for GetType, which deals with reading type
5196 /// IDs.
readTypeRecord(unsigned Index)5197 QualType ASTReader::readTypeRecord(unsigned Index) {
5198   RecordLocation Loc = TypeCursorForIndex(Index);
5199   BitstreamCursor &DeclsCursor = Loc.F->DeclsCursor;
5200 
5201   // Keep track of where we are in the stream, then jump back there
5202   // after reading this type.
5203   SavedStreamPosition SavedPosition(DeclsCursor);
5204 
5205   ReadingKindTracker ReadingKind(Read_Type, *this);
5206 
5207   // Note that we are loading a type record.
5208   Deserializing AType(this);
5209 
5210   unsigned Idx = 0;
5211   DeclsCursor.JumpToBit(Loc.Offset);
5212   RecordData Record;
5213   unsigned Code = DeclsCursor.ReadCode();
5214   switch ((TypeCode)DeclsCursor.readRecord(Code, Record)) {
5215   case TYPE_EXT_QUAL: {
5216     if (Record.size() != 2) {
5217       Error("Incorrect encoding of extended qualifier type");
5218       return QualType();
5219     }
5220     QualType Base = readType(*Loc.F, Record, Idx);
5221     Qualifiers Quals = Qualifiers::fromOpaqueValue(Record[Idx++]);
5222     return Context.getQualifiedType(Base, Quals);
5223   }
5224 
5225   case TYPE_COMPLEX: {
5226     if (Record.size() != 1) {
5227       Error("Incorrect encoding of complex type");
5228       return QualType();
5229     }
5230     QualType ElemType = readType(*Loc.F, Record, Idx);
5231     return Context.getComplexType(ElemType);
5232   }
5233 
5234   case TYPE_POINTER: {
5235     if (Record.size() != 1) {
5236       Error("Incorrect encoding of pointer type");
5237       return QualType();
5238     }
5239     QualType PointeeType = readType(*Loc.F, Record, Idx);
5240     return Context.getPointerType(PointeeType);
5241   }
5242 
5243   case TYPE_DECAYED: {
5244     if (Record.size() != 1) {
5245       Error("Incorrect encoding of decayed type");
5246       return QualType();
5247     }
5248     QualType OriginalType = readType(*Loc.F, Record, Idx);
5249     QualType DT = Context.getAdjustedParameterType(OriginalType);
5250     if (!isa<DecayedType>(DT))
5251       Error("Decayed type does not decay");
5252     return DT;
5253   }
5254 
5255   case TYPE_ADJUSTED: {
5256     if (Record.size() != 2) {
5257       Error("Incorrect encoding of adjusted type");
5258       return QualType();
5259     }
5260     QualType OriginalTy = readType(*Loc.F, Record, Idx);
5261     QualType AdjustedTy = readType(*Loc.F, Record, Idx);
5262     return Context.getAdjustedType(OriginalTy, AdjustedTy);
5263   }
5264 
5265   case TYPE_BLOCK_POINTER: {
5266     if (Record.size() != 1) {
5267       Error("Incorrect encoding of block pointer type");
5268       return QualType();
5269     }
5270     QualType PointeeType = readType(*Loc.F, Record, Idx);
5271     return Context.getBlockPointerType(PointeeType);
5272   }
5273 
5274   case TYPE_LVALUE_REFERENCE: {
5275     if (Record.size() != 2) {
5276       Error("Incorrect encoding of lvalue reference type");
5277       return QualType();
5278     }
5279     QualType PointeeType = readType(*Loc.F, Record, Idx);
5280     return Context.getLValueReferenceType(PointeeType, Record[1]);
5281   }
5282 
5283   case TYPE_RVALUE_REFERENCE: {
5284     if (Record.size() != 1) {
5285       Error("Incorrect encoding of rvalue reference type");
5286       return QualType();
5287     }
5288     QualType PointeeType = readType(*Loc.F, Record, Idx);
5289     return Context.getRValueReferenceType(PointeeType);
5290   }
5291 
5292   case TYPE_MEMBER_POINTER: {
5293     if (Record.size() != 2) {
5294       Error("Incorrect encoding of member pointer type");
5295       return QualType();
5296     }
5297     QualType PointeeType = readType(*Loc.F, Record, Idx);
5298     QualType ClassType = readType(*Loc.F, Record, Idx);
5299     if (PointeeType.isNull() || ClassType.isNull())
5300       return QualType();
5301 
5302     return Context.getMemberPointerType(PointeeType, ClassType.getTypePtr());
5303   }
5304 
5305   case TYPE_CONSTANT_ARRAY: {
5306     QualType ElementType = readType(*Loc.F, Record, Idx);
5307     ArrayType::ArraySizeModifier ASM = (ArrayType::ArraySizeModifier)Record[1];
5308     unsigned IndexTypeQuals = Record[2];
5309     unsigned Idx = 3;
5310     llvm::APInt Size = ReadAPInt(Record, Idx);
5311     return Context.getConstantArrayType(ElementType, Size,
5312                                          ASM, IndexTypeQuals);
5313   }
5314 
5315   case TYPE_INCOMPLETE_ARRAY: {
5316     QualType ElementType = readType(*Loc.F, Record, Idx);
5317     ArrayType::ArraySizeModifier ASM = (ArrayType::ArraySizeModifier)Record[1];
5318     unsigned IndexTypeQuals = Record[2];
5319     return Context.getIncompleteArrayType(ElementType, ASM, IndexTypeQuals);
5320   }
5321 
5322   case TYPE_VARIABLE_ARRAY: {
5323     QualType ElementType = readType(*Loc.F, Record, Idx);
5324     ArrayType::ArraySizeModifier ASM = (ArrayType::ArraySizeModifier)Record[1];
5325     unsigned IndexTypeQuals = Record[2];
5326     SourceLocation LBLoc = ReadSourceLocation(*Loc.F, Record[3]);
5327     SourceLocation RBLoc = ReadSourceLocation(*Loc.F, Record[4]);
5328     return Context.getVariableArrayType(ElementType, ReadExpr(*Loc.F),
5329                                          ASM, IndexTypeQuals,
5330                                          SourceRange(LBLoc, RBLoc));
5331   }
5332 
5333   case TYPE_VECTOR: {
5334     if (Record.size() != 3) {
5335       Error("incorrect encoding of vector type in AST file");
5336       return QualType();
5337     }
5338 
5339     QualType ElementType = readType(*Loc.F, Record, Idx);
5340     unsigned NumElements = Record[1];
5341     unsigned VecKind = Record[2];
5342     return Context.getVectorType(ElementType, NumElements,
5343                                   (VectorType::VectorKind)VecKind);
5344   }
5345 
5346   case TYPE_EXT_VECTOR: {
5347     if (Record.size() != 3) {
5348       Error("incorrect encoding of extended vector type in AST file");
5349       return QualType();
5350     }
5351 
5352     QualType ElementType = readType(*Loc.F, Record, Idx);
5353     unsigned NumElements = Record[1];
5354     return Context.getExtVectorType(ElementType, NumElements);
5355   }
5356 
5357   case TYPE_FUNCTION_NO_PROTO: {
5358     if (Record.size() != 6) {
5359       Error("incorrect encoding of no-proto function type");
5360       return QualType();
5361     }
5362     QualType ResultType = readType(*Loc.F, Record, Idx);
5363     FunctionType::ExtInfo Info(Record[1], Record[2], Record[3],
5364                                (CallingConv)Record[4], Record[5]);
5365     return Context.getFunctionNoProtoType(ResultType, Info);
5366   }
5367 
5368   case TYPE_FUNCTION_PROTO: {
5369     QualType ResultType = readType(*Loc.F, Record, Idx);
5370 
5371     FunctionProtoType::ExtProtoInfo EPI;
5372     EPI.ExtInfo = FunctionType::ExtInfo(/*noreturn*/ Record[1],
5373                                         /*hasregparm*/ Record[2],
5374                                         /*regparm*/ Record[3],
5375                                         static_cast<CallingConv>(Record[4]),
5376                                         /*produces*/ Record[5]);
5377 
5378     unsigned Idx = 6;
5379 
5380     EPI.Variadic = Record[Idx++];
5381     EPI.HasTrailingReturn = Record[Idx++];
5382     EPI.TypeQuals = Record[Idx++];
5383     EPI.RefQualifier = static_cast<RefQualifierKind>(Record[Idx++]);
5384     SmallVector<QualType, 8> ExceptionStorage;
5385     readExceptionSpec(*Loc.F, ExceptionStorage, EPI.ExceptionSpec, Record, Idx);
5386 
5387     unsigned NumParams = Record[Idx++];
5388     SmallVector<QualType, 16> ParamTypes;
5389     for (unsigned I = 0; I != NumParams; ++I)
5390       ParamTypes.push_back(readType(*Loc.F, Record, Idx));
5391 
5392     SmallVector<FunctionProtoType::ExtParameterInfo, 4> ExtParameterInfos;
5393     if (Idx != Record.size()) {
5394       for (unsigned I = 0; I != NumParams; ++I)
5395         ExtParameterInfos.push_back(
5396           FunctionProtoType::ExtParameterInfo
5397                            ::getFromOpaqueValue(Record[Idx++]));
5398       EPI.ExtParameterInfos = ExtParameterInfos.data();
5399     }
5400 
5401     assert(Idx == Record.size());
5402 
5403     return Context.getFunctionType(ResultType, ParamTypes, EPI);
5404   }
5405 
5406   case TYPE_UNRESOLVED_USING: {
5407     unsigned Idx = 0;
5408     return Context.getTypeDeclType(
5409                   ReadDeclAs<UnresolvedUsingTypenameDecl>(*Loc.F, Record, Idx));
5410   }
5411 
5412   case TYPE_TYPEDEF: {
5413     if (Record.size() != 2) {
5414       Error("incorrect encoding of typedef type");
5415       return QualType();
5416     }
5417     unsigned Idx = 0;
5418     TypedefNameDecl *Decl = ReadDeclAs<TypedefNameDecl>(*Loc.F, Record, Idx);
5419     QualType Canonical = readType(*Loc.F, Record, Idx);
5420     if (!Canonical.isNull())
5421       Canonical = Context.getCanonicalType(Canonical);
5422     return Context.getTypedefType(Decl, Canonical);
5423   }
5424 
5425   case TYPE_TYPEOF_EXPR:
5426     return Context.getTypeOfExprType(ReadExpr(*Loc.F));
5427 
5428   case TYPE_TYPEOF: {
5429     if (Record.size() != 1) {
5430       Error("incorrect encoding of typeof(type) in AST file");
5431       return QualType();
5432     }
5433     QualType UnderlyingType = readType(*Loc.F, Record, Idx);
5434     return Context.getTypeOfType(UnderlyingType);
5435   }
5436 
5437   case TYPE_DECLTYPE: {
5438     QualType UnderlyingType = readType(*Loc.F, Record, Idx);
5439     return Context.getDecltypeType(ReadExpr(*Loc.F), UnderlyingType);
5440   }
5441 
5442   case TYPE_UNARY_TRANSFORM: {
5443     QualType BaseType = readType(*Loc.F, Record, Idx);
5444     QualType UnderlyingType = readType(*Loc.F, Record, Idx);
5445     UnaryTransformType::UTTKind UKind = (UnaryTransformType::UTTKind)Record[2];
5446     return Context.getUnaryTransformType(BaseType, UnderlyingType, UKind);
5447   }
5448 
5449   case TYPE_AUTO: {
5450     QualType Deduced = readType(*Loc.F, Record, Idx);
5451     AutoTypeKeyword Keyword = (AutoTypeKeyword)Record[Idx++];
5452     bool IsDependent = Deduced.isNull() ? Record[Idx++] : false;
5453     return Context.getAutoType(Deduced, Keyword, IsDependent);
5454   }
5455 
5456   case TYPE_RECORD: {
5457     if (Record.size() != 2) {
5458       Error("incorrect encoding of record type");
5459       return QualType();
5460     }
5461     unsigned Idx = 0;
5462     bool IsDependent = Record[Idx++];
5463     RecordDecl *RD = ReadDeclAs<RecordDecl>(*Loc.F, Record, Idx);
5464     RD = cast_or_null<RecordDecl>(RD->getCanonicalDecl());
5465     QualType T = Context.getRecordType(RD);
5466     const_cast<Type*>(T.getTypePtr())->setDependent(IsDependent);
5467     return T;
5468   }
5469 
5470   case TYPE_ENUM: {
5471     if (Record.size() != 2) {
5472       Error("incorrect encoding of enum type");
5473       return QualType();
5474     }
5475     unsigned Idx = 0;
5476     bool IsDependent = Record[Idx++];
5477     QualType T
5478       = Context.getEnumType(ReadDeclAs<EnumDecl>(*Loc.F, Record, Idx));
5479     const_cast<Type*>(T.getTypePtr())->setDependent(IsDependent);
5480     return T;
5481   }
5482 
5483   case TYPE_ATTRIBUTED: {
5484     if (Record.size() != 3) {
5485       Error("incorrect encoding of attributed type");
5486       return QualType();
5487     }
5488     QualType modifiedType = readType(*Loc.F, Record, Idx);
5489     QualType equivalentType = readType(*Loc.F, Record, Idx);
5490     AttributedType::Kind kind = static_cast<AttributedType::Kind>(Record[2]);
5491     return Context.getAttributedType(kind, modifiedType, equivalentType);
5492   }
5493 
5494   case TYPE_PAREN: {
5495     if (Record.size() != 1) {
5496       Error("incorrect encoding of paren type");
5497       return QualType();
5498     }
5499     QualType InnerType = readType(*Loc.F, Record, Idx);
5500     return Context.getParenType(InnerType);
5501   }
5502 
5503   case TYPE_PACK_EXPANSION: {
5504     if (Record.size() != 2) {
5505       Error("incorrect encoding of pack expansion type");
5506       return QualType();
5507     }
5508     QualType Pattern = readType(*Loc.F, Record, Idx);
5509     if (Pattern.isNull())
5510       return QualType();
5511     Optional<unsigned> NumExpansions;
5512     if (Record[1])
5513       NumExpansions = Record[1] - 1;
5514     return Context.getPackExpansionType(Pattern, NumExpansions);
5515   }
5516 
5517   case TYPE_ELABORATED: {
5518     unsigned Idx = 0;
5519     ElaboratedTypeKeyword Keyword = (ElaboratedTypeKeyword)Record[Idx++];
5520     NestedNameSpecifier *NNS = ReadNestedNameSpecifier(*Loc.F, Record, Idx);
5521     QualType NamedType = readType(*Loc.F, Record, Idx);
5522     return Context.getElaboratedType(Keyword, NNS, NamedType);
5523   }
5524 
5525   case TYPE_OBJC_INTERFACE: {
5526     unsigned Idx = 0;
5527     ObjCInterfaceDecl *ItfD
5528       = ReadDeclAs<ObjCInterfaceDecl>(*Loc.F, Record, Idx);
5529     return Context.getObjCInterfaceType(ItfD->getCanonicalDecl());
5530   }
5531 
5532   case TYPE_OBJC_OBJECT: {
5533     unsigned Idx = 0;
5534     QualType Base = readType(*Loc.F, Record, Idx);
5535     unsigned NumTypeArgs = Record[Idx++];
5536     SmallVector<QualType, 4> TypeArgs;
5537     for (unsigned I = 0; I != NumTypeArgs; ++I)
5538       TypeArgs.push_back(readType(*Loc.F, Record, Idx));
5539     unsigned NumProtos = Record[Idx++];
5540     SmallVector<ObjCProtocolDecl*, 4> Protos;
5541     for (unsigned I = 0; I != NumProtos; ++I)
5542       Protos.push_back(ReadDeclAs<ObjCProtocolDecl>(*Loc.F, Record, Idx));
5543     bool IsKindOf = Record[Idx++];
5544     return Context.getObjCObjectType(Base, TypeArgs, Protos, IsKindOf);
5545   }
5546 
5547   case TYPE_OBJC_OBJECT_POINTER: {
5548     unsigned Idx = 0;
5549     QualType Pointee = readType(*Loc.F, Record, Idx);
5550     return Context.getObjCObjectPointerType(Pointee);
5551   }
5552 
5553   case TYPE_SUBST_TEMPLATE_TYPE_PARM: {
5554     unsigned Idx = 0;
5555     QualType Parm = readType(*Loc.F, Record, Idx);
5556     QualType Replacement = readType(*Loc.F, Record, Idx);
5557     return Context.getSubstTemplateTypeParmType(
5558         cast<TemplateTypeParmType>(Parm),
5559         Context.getCanonicalType(Replacement));
5560   }
5561 
5562   case TYPE_SUBST_TEMPLATE_TYPE_PARM_PACK: {
5563     unsigned Idx = 0;
5564     QualType Parm = readType(*Loc.F, Record, Idx);
5565     TemplateArgument ArgPack = ReadTemplateArgument(*Loc.F, Record, Idx);
5566     return Context.getSubstTemplateTypeParmPackType(
5567                                                cast<TemplateTypeParmType>(Parm),
5568                                                      ArgPack);
5569   }
5570 
5571   case TYPE_INJECTED_CLASS_NAME: {
5572     CXXRecordDecl *D = ReadDeclAs<CXXRecordDecl>(*Loc.F, Record, Idx);
5573     QualType TST = readType(*Loc.F, Record, Idx); // probably derivable
5574     // FIXME: ASTContext::getInjectedClassNameType is not currently suitable
5575     // for AST reading, too much interdependencies.
5576     const Type *T = nullptr;
5577     for (auto *DI = D; DI; DI = DI->getPreviousDecl()) {
5578       if (const Type *Existing = DI->getTypeForDecl()) {
5579         T = Existing;
5580         break;
5581       }
5582     }
5583     if (!T) {
5584       T = new (Context, TypeAlignment) InjectedClassNameType(D, TST);
5585       for (auto *DI = D; DI; DI = DI->getPreviousDecl())
5586         DI->setTypeForDecl(T);
5587     }
5588     return QualType(T, 0);
5589   }
5590 
5591   case TYPE_TEMPLATE_TYPE_PARM: {
5592     unsigned Idx = 0;
5593     unsigned Depth = Record[Idx++];
5594     unsigned Index = Record[Idx++];
5595     bool Pack = Record[Idx++];
5596     TemplateTypeParmDecl *D
5597       = ReadDeclAs<TemplateTypeParmDecl>(*Loc.F, Record, Idx);
5598     return Context.getTemplateTypeParmType(Depth, Index, Pack, D);
5599   }
5600 
5601   case TYPE_DEPENDENT_NAME: {
5602     unsigned Idx = 0;
5603     ElaboratedTypeKeyword Keyword = (ElaboratedTypeKeyword)Record[Idx++];
5604     NestedNameSpecifier *NNS = ReadNestedNameSpecifier(*Loc.F, Record, Idx);
5605     const IdentifierInfo *Name = GetIdentifierInfo(*Loc.F, Record, Idx);
5606     QualType Canon = readType(*Loc.F, Record, Idx);
5607     if (!Canon.isNull())
5608       Canon = Context.getCanonicalType(Canon);
5609     return Context.getDependentNameType(Keyword, NNS, Name, Canon);
5610   }
5611 
5612   case TYPE_DEPENDENT_TEMPLATE_SPECIALIZATION: {
5613     unsigned Idx = 0;
5614     ElaboratedTypeKeyword Keyword = (ElaboratedTypeKeyword)Record[Idx++];
5615     NestedNameSpecifier *NNS = ReadNestedNameSpecifier(*Loc.F, Record, Idx);
5616     const IdentifierInfo *Name = GetIdentifierInfo(*Loc.F, Record, Idx);
5617     unsigned NumArgs = Record[Idx++];
5618     SmallVector<TemplateArgument, 8> Args;
5619     Args.reserve(NumArgs);
5620     while (NumArgs--)
5621       Args.push_back(ReadTemplateArgument(*Loc.F, Record, Idx));
5622     return Context.getDependentTemplateSpecializationType(Keyword, NNS, Name,
5623                                                           Args);
5624   }
5625 
5626   case TYPE_DEPENDENT_SIZED_ARRAY: {
5627     unsigned Idx = 0;
5628 
5629     // ArrayType
5630     QualType ElementType = readType(*Loc.F, Record, Idx);
5631     ArrayType::ArraySizeModifier ASM
5632       = (ArrayType::ArraySizeModifier)Record[Idx++];
5633     unsigned IndexTypeQuals = Record[Idx++];
5634 
5635     // DependentSizedArrayType
5636     Expr *NumElts = ReadExpr(*Loc.F);
5637     SourceRange Brackets = ReadSourceRange(*Loc.F, Record, Idx);
5638 
5639     return Context.getDependentSizedArrayType(ElementType, NumElts, ASM,
5640                                                IndexTypeQuals, Brackets);
5641   }
5642 
5643   case TYPE_TEMPLATE_SPECIALIZATION: {
5644     unsigned Idx = 0;
5645     bool IsDependent = Record[Idx++];
5646     TemplateName Name = ReadTemplateName(*Loc.F, Record, Idx);
5647     SmallVector<TemplateArgument, 8> Args;
5648     ReadTemplateArgumentList(Args, *Loc.F, Record, Idx);
5649     QualType Underlying = readType(*Loc.F, Record, Idx);
5650     QualType T;
5651     if (Underlying.isNull())
5652       T = Context.getCanonicalTemplateSpecializationType(Name, Args);
5653     else
5654       T = Context.getTemplateSpecializationType(Name, Args, Underlying);
5655     const_cast<Type*>(T.getTypePtr())->setDependent(IsDependent);
5656     return T;
5657   }
5658 
5659   case TYPE_ATOMIC: {
5660     if (Record.size() != 1) {
5661       Error("Incorrect encoding of atomic type");
5662       return QualType();
5663     }
5664     QualType ValueType = readType(*Loc.F, Record, Idx);
5665     return Context.getAtomicType(ValueType);
5666   }
5667 
5668   case TYPE_PIPE: {
5669     if (Record.size() != 1) {
5670       Error("Incorrect encoding of pipe type");
5671       return QualType();
5672     }
5673 
5674     // Reading the pipe element type.
5675     QualType ElementType = readType(*Loc.F, Record, Idx);
5676     return Context.getPipeType(ElementType);
5677   }
5678   }
5679   llvm_unreachable("Invalid TypeCode!");
5680 }
5681 
readExceptionSpec(ModuleFile & ModuleFile,SmallVectorImpl<QualType> & Exceptions,FunctionProtoType::ExceptionSpecInfo & ESI,const RecordData & Record,unsigned & Idx)5682 void ASTReader::readExceptionSpec(ModuleFile &ModuleFile,
5683                                   SmallVectorImpl<QualType> &Exceptions,
5684                                   FunctionProtoType::ExceptionSpecInfo &ESI,
5685                                   const RecordData &Record, unsigned &Idx) {
5686   ExceptionSpecificationType EST =
5687       static_cast<ExceptionSpecificationType>(Record[Idx++]);
5688   ESI.Type = EST;
5689   if (EST == EST_Dynamic) {
5690     for (unsigned I = 0, N = Record[Idx++]; I != N; ++I)
5691       Exceptions.push_back(readType(ModuleFile, Record, Idx));
5692     ESI.Exceptions = Exceptions;
5693   } else if (EST == EST_ComputedNoexcept) {
5694     ESI.NoexceptExpr = ReadExpr(ModuleFile);
5695   } else if (EST == EST_Uninstantiated) {
5696     ESI.SourceDecl = ReadDeclAs<FunctionDecl>(ModuleFile, Record, Idx);
5697     ESI.SourceTemplate = ReadDeclAs<FunctionDecl>(ModuleFile, Record, Idx);
5698   } else if (EST == EST_Unevaluated) {
5699     ESI.SourceDecl = ReadDeclAs<FunctionDecl>(ModuleFile, Record, Idx);
5700   }
5701 }
5702 
5703 class clang::TypeLocReader : public TypeLocVisitor<TypeLocReader> {
5704   ASTReader &Reader;
5705   ModuleFile &F;
5706   const ASTReader::RecordData &Record;
5707   unsigned &Idx;
5708 
ReadSourceLocation(const ASTReader::RecordData & R,unsigned & I)5709   SourceLocation ReadSourceLocation(const ASTReader::RecordData &R,
5710                                     unsigned &I) {
5711     return Reader.ReadSourceLocation(F, R, I);
5712   }
5713 
5714   template<typename T>
ReadDeclAs(const ASTReader::RecordData & Record,unsigned & Idx)5715   T *ReadDeclAs(const ASTReader::RecordData &Record, unsigned &Idx) {
5716     return Reader.ReadDeclAs<T>(F, Record, Idx);
5717   }
5718 
5719 public:
TypeLocReader(ASTReader & Reader,ModuleFile & F,const ASTReader::RecordData & Record,unsigned & Idx)5720   TypeLocReader(ASTReader &Reader, ModuleFile &F,
5721                 const ASTReader::RecordData &Record, unsigned &Idx)
5722     : Reader(Reader), F(F), Record(Record), Idx(Idx)
5723   { }
5724 
5725   // We want compile-time assurance that we've enumerated all of
5726   // these, so unfortunately we have to declare them first, then
5727   // define them out-of-line.
5728 #define ABSTRACT_TYPELOC(CLASS, PARENT)
5729 #define TYPELOC(CLASS, PARENT) \
5730   void Visit##CLASS##TypeLoc(CLASS##TypeLoc TyLoc);
5731 #include "clang/AST/TypeLocNodes.def"
5732 
5733   void VisitFunctionTypeLoc(FunctionTypeLoc);
5734   void VisitArrayTypeLoc(ArrayTypeLoc);
5735 };
5736 
VisitQualifiedTypeLoc(QualifiedTypeLoc TL)5737 void TypeLocReader::VisitQualifiedTypeLoc(QualifiedTypeLoc TL) {
5738   // nothing to do
5739 }
VisitBuiltinTypeLoc(BuiltinTypeLoc TL)5740 void TypeLocReader::VisitBuiltinTypeLoc(BuiltinTypeLoc TL) {
5741   TL.setBuiltinLoc(ReadSourceLocation(Record, Idx));
5742   if (TL.needsExtraLocalData()) {
5743     TL.setWrittenTypeSpec(static_cast<DeclSpec::TST>(Record[Idx++]));
5744     TL.setWrittenSignSpec(static_cast<DeclSpec::TSS>(Record[Idx++]));
5745     TL.setWrittenWidthSpec(static_cast<DeclSpec::TSW>(Record[Idx++]));
5746     TL.setModeAttr(Record[Idx++]);
5747   }
5748 }
VisitComplexTypeLoc(ComplexTypeLoc TL)5749 void TypeLocReader::VisitComplexTypeLoc(ComplexTypeLoc TL) {
5750   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5751 }
VisitPointerTypeLoc(PointerTypeLoc TL)5752 void TypeLocReader::VisitPointerTypeLoc(PointerTypeLoc TL) {
5753   TL.setStarLoc(ReadSourceLocation(Record, Idx));
5754 }
VisitDecayedTypeLoc(DecayedTypeLoc TL)5755 void TypeLocReader::VisitDecayedTypeLoc(DecayedTypeLoc TL) {
5756   // nothing to do
5757 }
VisitAdjustedTypeLoc(AdjustedTypeLoc TL)5758 void TypeLocReader::VisitAdjustedTypeLoc(AdjustedTypeLoc TL) {
5759   // nothing to do
5760 }
VisitBlockPointerTypeLoc(BlockPointerTypeLoc TL)5761 void TypeLocReader::VisitBlockPointerTypeLoc(BlockPointerTypeLoc TL) {
5762   TL.setCaretLoc(ReadSourceLocation(Record, Idx));
5763 }
VisitLValueReferenceTypeLoc(LValueReferenceTypeLoc TL)5764 void TypeLocReader::VisitLValueReferenceTypeLoc(LValueReferenceTypeLoc TL) {
5765   TL.setAmpLoc(ReadSourceLocation(Record, Idx));
5766 }
VisitRValueReferenceTypeLoc(RValueReferenceTypeLoc TL)5767 void TypeLocReader::VisitRValueReferenceTypeLoc(RValueReferenceTypeLoc TL) {
5768   TL.setAmpAmpLoc(ReadSourceLocation(Record, Idx));
5769 }
VisitMemberPointerTypeLoc(MemberPointerTypeLoc TL)5770 void TypeLocReader::VisitMemberPointerTypeLoc(MemberPointerTypeLoc TL) {
5771   TL.setStarLoc(ReadSourceLocation(Record, Idx));
5772   TL.setClassTInfo(Reader.GetTypeSourceInfo(F, Record, Idx));
5773 }
VisitArrayTypeLoc(ArrayTypeLoc TL)5774 void TypeLocReader::VisitArrayTypeLoc(ArrayTypeLoc TL) {
5775   TL.setLBracketLoc(ReadSourceLocation(Record, Idx));
5776   TL.setRBracketLoc(ReadSourceLocation(Record, Idx));
5777   if (Record[Idx++])
5778     TL.setSizeExpr(Reader.ReadExpr(F));
5779   else
5780     TL.setSizeExpr(nullptr);
5781 }
VisitConstantArrayTypeLoc(ConstantArrayTypeLoc TL)5782 void TypeLocReader::VisitConstantArrayTypeLoc(ConstantArrayTypeLoc TL) {
5783   VisitArrayTypeLoc(TL);
5784 }
VisitIncompleteArrayTypeLoc(IncompleteArrayTypeLoc TL)5785 void TypeLocReader::VisitIncompleteArrayTypeLoc(IncompleteArrayTypeLoc TL) {
5786   VisitArrayTypeLoc(TL);
5787 }
VisitVariableArrayTypeLoc(VariableArrayTypeLoc TL)5788 void TypeLocReader::VisitVariableArrayTypeLoc(VariableArrayTypeLoc TL) {
5789   VisitArrayTypeLoc(TL);
5790 }
VisitDependentSizedArrayTypeLoc(DependentSizedArrayTypeLoc TL)5791 void TypeLocReader::VisitDependentSizedArrayTypeLoc(
5792                                             DependentSizedArrayTypeLoc TL) {
5793   VisitArrayTypeLoc(TL);
5794 }
VisitDependentSizedExtVectorTypeLoc(DependentSizedExtVectorTypeLoc TL)5795 void TypeLocReader::VisitDependentSizedExtVectorTypeLoc(
5796                                         DependentSizedExtVectorTypeLoc TL) {
5797   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5798 }
VisitVectorTypeLoc(VectorTypeLoc TL)5799 void TypeLocReader::VisitVectorTypeLoc(VectorTypeLoc TL) {
5800   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5801 }
VisitExtVectorTypeLoc(ExtVectorTypeLoc TL)5802 void TypeLocReader::VisitExtVectorTypeLoc(ExtVectorTypeLoc TL) {
5803   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5804 }
VisitFunctionTypeLoc(FunctionTypeLoc TL)5805 void TypeLocReader::VisitFunctionTypeLoc(FunctionTypeLoc TL) {
5806   TL.setLocalRangeBegin(ReadSourceLocation(Record, Idx));
5807   TL.setLParenLoc(ReadSourceLocation(Record, Idx));
5808   TL.setRParenLoc(ReadSourceLocation(Record, Idx));
5809   TL.setLocalRangeEnd(ReadSourceLocation(Record, Idx));
5810   for (unsigned i = 0, e = TL.getNumParams(); i != e; ++i) {
5811     TL.setParam(i, ReadDeclAs<ParmVarDecl>(Record, Idx));
5812   }
5813 }
VisitFunctionProtoTypeLoc(FunctionProtoTypeLoc TL)5814 void TypeLocReader::VisitFunctionProtoTypeLoc(FunctionProtoTypeLoc TL) {
5815   VisitFunctionTypeLoc(TL);
5816 }
VisitFunctionNoProtoTypeLoc(FunctionNoProtoTypeLoc TL)5817 void TypeLocReader::VisitFunctionNoProtoTypeLoc(FunctionNoProtoTypeLoc TL) {
5818   VisitFunctionTypeLoc(TL);
5819 }
VisitUnresolvedUsingTypeLoc(UnresolvedUsingTypeLoc TL)5820 void TypeLocReader::VisitUnresolvedUsingTypeLoc(UnresolvedUsingTypeLoc TL) {
5821   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5822 }
VisitTypedefTypeLoc(TypedefTypeLoc TL)5823 void TypeLocReader::VisitTypedefTypeLoc(TypedefTypeLoc TL) {
5824   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5825 }
VisitTypeOfExprTypeLoc(TypeOfExprTypeLoc TL)5826 void TypeLocReader::VisitTypeOfExprTypeLoc(TypeOfExprTypeLoc TL) {
5827   TL.setTypeofLoc(ReadSourceLocation(Record, Idx));
5828   TL.setLParenLoc(ReadSourceLocation(Record, Idx));
5829   TL.setRParenLoc(ReadSourceLocation(Record, Idx));
5830 }
VisitTypeOfTypeLoc(TypeOfTypeLoc TL)5831 void TypeLocReader::VisitTypeOfTypeLoc(TypeOfTypeLoc TL) {
5832   TL.setTypeofLoc(ReadSourceLocation(Record, Idx));
5833   TL.setLParenLoc(ReadSourceLocation(Record, Idx));
5834   TL.setRParenLoc(ReadSourceLocation(Record, Idx));
5835   TL.setUnderlyingTInfo(Reader.GetTypeSourceInfo(F, Record, Idx));
5836 }
VisitDecltypeTypeLoc(DecltypeTypeLoc TL)5837 void TypeLocReader::VisitDecltypeTypeLoc(DecltypeTypeLoc TL) {
5838   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5839 }
VisitUnaryTransformTypeLoc(UnaryTransformTypeLoc TL)5840 void TypeLocReader::VisitUnaryTransformTypeLoc(UnaryTransformTypeLoc TL) {
5841   TL.setKWLoc(ReadSourceLocation(Record, Idx));
5842   TL.setLParenLoc(ReadSourceLocation(Record, Idx));
5843   TL.setRParenLoc(ReadSourceLocation(Record, Idx));
5844   TL.setUnderlyingTInfo(Reader.GetTypeSourceInfo(F, Record, Idx));
5845 }
VisitAutoTypeLoc(AutoTypeLoc TL)5846 void TypeLocReader::VisitAutoTypeLoc(AutoTypeLoc TL) {
5847   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5848 }
VisitRecordTypeLoc(RecordTypeLoc TL)5849 void TypeLocReader::VisitRecordTypeLoc(RecordTypeLoc TL) {
5850   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5851 }
VisitEnumTypeLoc(EnumTypeLoc TL)5852 void TypeLocReader::VisitEnumTypeLoc(EnumTypeLoc TL) {
5853   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5854 }
VisitAttributedTypeLoc(AttributedTypeLoc TL)5855 void TypeLocReader::VisitAttributedTypeLoc(AttributedTypeLoc TL) {
5856   TL.setAttrNameLoc(ReadSourceLocation(Record, Idx));
5857   if (TL.hasAttrOperand()) {
5858     SourceRange range;
5859     range.setBegin(ReadSourceLocation(Record, Idx));
5860     range.setEnd(ReadSourceLocation(Record, Idx));
5861     TL.setAttrOperandParensRange(range);
5862   }
5863   if (TL.hasAttrExprOperand()) {
5864     if (Record[Idx++])
5865       TL.setAttrExprOperand(Reader.ReadExpr(F));
5866     else
5867       TL.setAttrExprOperand(nullptr);
5868   } else if (TL.hasAttrEnumOperand())
5869     TL.setAttrEnumOperandLoc(ReadSourceLocation(Record, Idx));
5870 }
VisitTemplateTypeParmTypeLoc(TemplateTypeParmTypeLoc TL)5871 void TypeLocReader::VisitTemplateTypeParmTypeLoc(TemplateTypeParmTypeLoc TL) {
5872   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5873 }
VisitSubstTemplateTypeParmTypeLoc(SubstTemplateTypeParmTypeLoc TL)5874 void TypeLocReader::VisitSubstTemplateTypeParmTypeLoc(
5875                                             SubstTemplateTypeParmTypeLoc TL) {
5876   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5877 }
VisitSubstTemplateTypeParmPackTypeLoc(SubstTemplateTypeParmPackTypeLoc TL)5878 void TypeLocReader::VisitSubstTemplateTypeParmPackTypeLoc(
5879                                           SubstTemplateTypeParmPackTypeLoc TL) {
5880   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5881 }
VisitTemplateSpecializationTypeLoc(TemplateSpecializationTypeLoc TL)5882 void TypeLocReader::VisitTemplateSpecializationTypeLoc(
5883                                            TemplateSpecializationTypeLoc TL) {
5884   TL.setTemplateKeywordLoc(ReadSourceLocation(Record, Idx));
5885   TL.setTemplateNameLoc(ReadSourceLocation(Record, Idx));
5886   TL.setLAngleLoc(ReadSourceLocation(Record, Idx));
5887   TL.setRAngleLoc(ReadSourceLocation(Record, Idx));
5888   for (unsigned i = 0, e = TL.getNumArgs(); i != e; ++i)
5889     TL.setArgLocInfo(i,
5890         Reader.GetTemplateArgumentLocInfo(F,
5891                                           TL.getTypePtr()->getArg(i).getKind(),
5892                                           Record, Idx));
5893 }
VisitParenTypeLoc(ParenTypeLoc TL)5894 void TypeLocReader::VisitParenTypeLoc(ParenTypeLoc TL) {
5895   TL.setLParenLoc(ReadSourceLocation(Record, Idx));
5896   TL.setRParenLoc(ReadSourceLocation(Record, Idx));
5897 }
VisitElaboratedTypeLoc(ElaboratedTypeLoc TL)5898 void TypeLocReader::VisitElaboratedTypeLoc(ElaboratedTypeLoc TL) {
5899   TL.setElaboratedKeywordLoc(ReadSourceLocation(Record, Idx));
5900   TL.setQualifierLoc(Reader.ReadNestedNameSpecifierLoc(F, Record, Idx));
5901 }
VisitInjectedClassNameTypeLoc(InjectedClassNameTypeLoc TL)5902 void TypeLocReader::VisitInjectedClassNameTypeLoc(InjectedClassNameTypeLoc TL) {
5903   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5904 }
VisitDependentNameTypeLoc(DependentNameTypeLoc TL)5905 void TypeLocReader::VisitDependentNameTypeLoc(DependentNameTypeLoc TL) {
5906   TL.setElaboratedKeywordLoc(ReadSourceLocation(Record, Idx));
5907   TL.setQualifierLoc(Reader.ReadNestedNameSpecifierLoc(F, Record, Idx));
5908   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5909 }
VisitDependentTemplateSpecializationTypeLoc(DependentTemplateSpecializationTypeLoc TL)5910 void TypeLocReader::VisitDependentTemplateSpecializationTypeLoc(
5911        DependentTemplateSpecializationTypeLoc TL) {
5912   TL.setElaboratedKeywordLoc(ReadSourceLocation(Record, Idx));
5913   TL.setQualifierLoc(Reader.ReadNestedNameSpecifierLoc(F, Record, Idx));
5914   TL.setTemplateKeywordLoc(ReadSourceLocation(Record, Idx));
5915   TL.setTemplateNameLoc(ReadSourceLocation(Record, Idx));
5916   TL.setLAngleLoc(ReadSourceLocation(Record, Idx));
5917   TL.setRAngleLoc(ReadSourceLocation(Record, Idx));
5918   for (unsigned I = 0, E = TL.getNumArgs(); I != E; ++I)
5919     TL.setArgLocInfo(I,
5920         Reader.GetTemplateArgumentLocInfo(F,
5921                                           TL.getTypePtr()->getArg(I).getKind(),
5922                                           Record, Idx));
5923 }
VisitPackExpansionTypeLoc(PackExpansionTypeLoc TL)5924 void TypeLocReader::VisitPackExpansionTypeLoc(PackExpansionTypeLoc TL) {
5925   TL.setEllipsisLoc(ReadSourceLocation(Record, Idx));
5926 }
VisitObjCInterfaceTypeLoc(ObjCInterfaceTypeLoc TL)5927 void TypeLocReader::VisitObjCInterfaceTypeLoc(ObjCInterfaceTypeLoc TL) {
5928   TL.setNameLoc(ReadSourceLocation(Record, Idx));
5929 }
VisitObjCObjectTypeLoc(ObjCObjectTypeLoc TL)5930 void TypeLocReader::VisitObjCObjectTypeLoc(ObjCObjectTypeLoc TL) {
5931   TL.setHasBaseTypeAsWritten(Record[Idx++]);
5932   TL.setTypeArgsLAngleLoc(ReadSourceLocation(Record, Idx));
5933   TL.setTypeArgsRAngleLoc(ReadSourceLocation(Record, Idx));
5934   for (unsigned i = 0, e = TL.getNumTypeArgs(); i != e; ++i)
5935     TL.setTypeArgTInfo(i, Reader.GetTypeSourceInfo(F, Record, Idx));
5936   TL.setProtocolLAngleLoc(ReadSourceLocation(Record, Idx));
5937   TL.setProtocolRAngleLoc(ReadSourceLocation(Record, Idx));
5938   for (unsigned i = 0, e = TL.getNumProtocols(); i != e; ++i)
5939     TL.setProtocolLoc(i, ReadSourceLocation(Record, Idx));
5940 }
VisitObjCObjectPointerTypeLoc(ObjCObjectPointerTypeLoc TL)5941 void TypeLocReader::VisitObjCObjectPointerTypeLoc(ObjCObjectPointerTypeLoc TL) {
5942   TL.setStarLoc(ReadSourceLocation(Record, Idx));
5943 }
VisitAtomicTypeLoc(AtomicTypeLoc TL)5944 void TypeLocReader::VisitAtomicTypeLoc(AtomicTypeLoc TL) {
5945   TL.setKWLoc(ReadSourceLocation(Record, Idx));
5946   TL.setLParenLoc(ReadSourceLocation(Record, Idx));
5947   TL.setRParenLoc(ReadSourceLocation(Record, Idx));
5948 }
VisitPipeTypeLoc(PipeTypeLoc TL)5949 void TypeLocReader::VisitPipeTypeLoc(PipeTypeLoc TL) {
5950   TL.setKWLoc(ReadSourceLocation(Record, Idx));
5951 }
5952 
GetTypeSourceInfo(ModuleFile & F,const RecordData & Record,unsigned & Idx)5953 TypeSourceInfo *ASTReader::GetTypeSourceInfo(ModuleFile &F,
5954                                              const RecordData &Record,
5955                                              unsigned &Idx) {
5956   QualType InfoTy = readType(F, Record, Idx);
5957   if (InfoTy.isNull())
5958     return nullptr;
5959 
5960   TypeSourceInfo *TInfo = getContext().CreateTypeSourceInfo(InfoTy);
5961   TypeLocReader TLR(*this, F, Record, Idx);
5962   for (TypeLoc TL = TInfo->getTypeLoc(); !TL.isNull(); TL = TL.getNextTypeLoc())
5963     TLR.Visit(TL);
5964   return TInfo;
5965 }
5966 
GetType(TypeID ID)5967 QualType ASTReader::GetType(TypeID ID) {
5968   unsigned FastQuals = ID & Qualifiers::FastMask;
5969   unsigned Index = ID >> Qualifiers::FastWidth;
5970 
5971   if (Index < NUM_PREDEF_TYPE_IDS) {
5972     QualType T;
5973     switch ((PredefinedTypeIDs)Index) {
5974     case PREDEF_TYPE_NULL_ID:
5975       return QualType();
5976     case PREDEF_TYPE_VOID_ID:
5977       T = Context.VoidTy;
5978       break;
5979     case PREDEF_TYPE_BOOL_ID:
5980       T = Context.BoolTy;
5981       break;
5982 
5983     case PREDEF_TYPE_CHAR_U_ID:
5984     case PREDEF_TYPE_CHAR_S_ID:
5985       // FIXME: Check that the signedness of CharTy is correct!
5986       T = Context.CharTy;
5987       break;
5988 
5989     case PREDEF_TYPE_UCHAR_ID:
5990       T = Context.UnsignedCharTy;
5991       break;
5992     case PREDEF_TYPE_USHORT_ID:
5993       T = Context.UnsignedShortTy;
5994       break;
5995     case PREDEF_TYPE_UINT_ID:
5996       T = Context.UnsignedIntTy;
5997       break;
5998     case PREDEF_TYPE_ULONG_ID:
5999       T = Context.UnsignedLongTy;
6000       break;
6001     case PREDEF_TYPE_ULONGLONG_ID:
6002       T = Context.UnsignedLongLongTy;
6003       break;
6004     case PREDEF_TYPE_UINT128_ID:
6005       T = Context.UnsignedInt128Ty;
6006       break;
6007     case PREDEF_TYPE_SCHAR_ID:
6008       T = Context.SignedCharTy;
6009       break;
6010     case PREDEF_TYPE_WCHAR_ID:
6011       T = Context.WCharTy;
6012       break;
6013     case PREDEF_TYPE_SHORT_ID:
6014       T = Context.ShortTy;
6015       break;
6016     case PREDEF_TYPE_INT_ID:
6017       T = Context.IntTy;
6018       break;
6019     case PREDEF_TYPE_LONG_ID:
6020       T = Context.LongTy;
6021       break;
6022     case PREDEF_TYPE_LONGLONG_ID:
6023       T = Context.LongLongTy;
6024       break;
6025     case PREDEF_TYPE_INT128_ID:
6026       T = Context.Int128Ty;
6027       break;
6028     case PREDEF_TYPE_HALF_ID:
6029       T = Context.HalfTy;
6030       break;
6031     case PREDEF_TYPE_FLOAT_ID:
6032       T = Context.FloatTy;
6033       break;
6034     case PREDEF_TYPE_DOUBLE_ID:
6035       T = Context.DoubleTy;
6036       break;
6037     case PREDEF_TYPE_LONGDOUBLE_ID:
6038       T = Context.LongDoubleTy;
6039       break;
6040     case PREDEF_TYPE_FLOAT128_ID:
6041       T = Context.Float128Ty;
6042       break;
6043     case PREDEF_TYPE_OVERLOAD_ID:
6044       T = Context.OverloadTy;
6045       break;
6046     case PREDEF_TYPE_BOUND_MEMBER:
6047       T = Context.BoundMemberTy;
6048       break;
6049     case PREDEF_TYPE_PSEUDO_OBJECT:
6050       T = Context.PseudoObjectTy;
6051       break;
6052     case PREDEF_TYPE_DEPENDENT_ID:
6053       T = Context.DependentTy;
6054       break;
6055     case PREDEF_TYPE_UNKNOWN_ANY:
6056       T = Context.UnknownAnyTy;
6057       break;
6058     case PREDEF_TYPE_NULLPTR_ID:
6059       T = Context.NullPtrTy;
6060       break;
6061     case PREDEF_TYPE_CHAR16_ID:
6062       T = Context.Char16Ty;
6063       break;
6064     case PREDEF_TYPE_CHAR32_ID:
6065       T = Context.Char32Ty;
6066       break;
6067     case PREDEF_TYPE_OBJC_ID:
6068       T = Context.ObjCBuiltinIdTy;
6069       break;
6070     case PREDEF_TYPE_OBJC_CLASS:
6071       T = Context.ObjCBuiltinClassTy;
6072       break;
6073     case PREDEF_TYPE_OBJC_SEL:
6074       T = Context.ObjCBuiltinSelTy;
6075       break;
6076 #define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
6077     case PREDEF_TYPE_##Id##_ID: \
6078       T = Context.SingletonId; \
6079       break;
6080 #include "clang/Basic/OpenCLImageTypes.def"
6081     case PREDEF_TYPE_SAMPLER_ID:
6082       T = Context.OCLSamplerTy;
6083       break;
6084     case PREDEF_TYPE_EVENT_ID:
6085       T = Context.OCLEventTy;
6086       break;
6087     case PREDEF_TYPE_CLK_EVENT_ID:
6088       T = Context.OCLClkEventTy;
6089       break;
6090     case PREDEF_TYPE_QUEUE_ID:
6091       T = Context.OCLQueueTy;
6092       break;
6093     case PREDEF_TYPE_NDRANGE_ID:
6094       T = Context.OCLNDRangeTy;
6095       break;
6096     case PREDEF_TYPE_RESERVE_ID_ID:
6097       T = Context.OCLReserveIDTy;
6098       break;
6099     case PREDEF_TYPE_AUTO_DEDUCT:
6100       T = Context.getAutoDeductType();
6101       break;
6102 
6103     case PREDEF_TYPE_AUTO_RREF_DEDUCT:
6104       T = Context.getAutoRRefDeductType();
6105       break;
6106 
6107     case PREDEF_TYPE_ARC_UNBRIDGED_CAST:
6108       T = Context.ARCUnbridgedCastTy;
6109       break;
6110 
6111     case PREDEF_TYPE_BUILTIN_FN:
6112       T = Context.BuiltinFnTy;
6113       break;
6114 
6115     case PREDEF_TYPE_OMP_ARRAY_SECTION:
6116       T = Context.OMPArraySectionTy;
6117       break;
6118     }
6119 
6120     assert(!T.isNull() && "Unknown predefined type");
6121     return T.withFastQualifiers(FastQuals);
6122   }
6123 
6124   Index -= NUM_PREDEF_TYPE_IDS;
6125   assert(Index < TypesLoaded.size() && "Type index out-of-range");
6126   if (TypesLoaded[Index].isNull()) {
6127     TypesLoaded[Index] = readTypeRecord(Index);
6128     if (TypesLoaded[Index].isNull())
6129       return QualType();
6130 
6131     TypesLoaded[Index]->setFromAST();
6132     if (DeserializationListener)
6133       DeserializationListener->TypeRead(TypeIdx::fromTypeID(ID),
6134                                         TypesLoaded[Index]);
6135   }
6136 
6137   return TypesLoaded[Index].withFastQualifiers(FastQuals);
6138 }
6139 
getLocalType(ModuleFile & F,unsigned LocalID)6140 QualType ASTReader::getLocalType(ModuleFile &F, unsigned LocalID) {
6141   return GetType(getGlobalTypeID(F, LocalID));
6142 }
6143 
6144 serialization::TypeID
getGlobalTypeID(ModuleFile & F,unsigned LocalID) const6145 ASTReader::getGlobalTypeID(ModuleFile &F, unsigned LocalID) const {
6146   unsigned FastQuals = LocalID & Qualifiers::FastMask;
6147   unsigned LocalIndex = LocalID >> Qualifiers::FastWidth;
6148 
6149   if (LocalIndex < NUM_PREDEF_TYPE_IDS)
6150     return LocalID;
6151 
6152   ContinuousRangeMap<uint32_t, int, 2>::iterator I
6153     = F.TypeRemap.find(LocalIndex - NUM_PREDEF_TYPE_IDS);
6154   assert(I != F.TypeRemap.end() && "Invalid index into type index remap");
6155 
6156   unsigned GlobalIndex = LocalIndex + I->second;
6157   return (GlobalIndex << Qualifiers::FastWidth) | FastQuals;
6158 }
6159 
6160 TemplateArgumentLocInfo
GetTemplateArgumentLocInfo(ModuleFile & F,TemplateArgument::ArgKind Kind,const RecordData & Record,unsigned & Index)6161 ASTReader::GetTemplateArgumentLocInfo(ModuleFile &F,
6162                                       TemplateArgument::ArgKind Kind,
6163                                       const RecordData &Record,
6164                                       unsigned &Index) {
6165   switch (Kind) {
6166   case TemplateArgument::Expression:
6167     return ReadExpr(F);
6168   case TemplateArgument::Type:
6169     return GetTypeSourceInfo(F, Record, Index);
6170   case TemplateArgument::Template: {
6171     NestedNameSpecifierLoc QualifierLoc = ReadNestedNameSpecifierLoc(F, Record,
6172                                                                      Index);
6173     SourceLocation TemplateNameLoc = ReadSourceLocation(F, Record, Index);
6174     return TemplateArgumentLocInfo(QualifierLoc, TemplateNameLoc,
6175                                    SourceLocation());
6176   }
6177   case TemplateArgument::TemplateExpansion: {
6178     NestedNameSpecifierLoc QualifierLoc = ReadNestedNameSpecifierLoc(F, Record,
6179                                                                      Index);
6180     SourceLocation TemplateNameLoc = ReadSourceLocation(F, Record, Index);
6181     SourceLocation EllipsisLoc = ReadSourceLocation(F, Record, Index);
6182     return TemplateArgumentLocInfo(QualifierLoc, TemplateNameLoc,
6183                                    EllipsisLoc);
6184   }
6185   case TemplateArgument::Null:
6186   case TemplateArgument::Integral:
6187   case TemplateArgument::Declaration:
6188   case TemplateArgument::NullPtr:
6189   case TemplateArgument::Pack:
6190     // FIXME: Is this right?
6191     return TemplateArgumentLocInfo();
6192   }
6193   llvm_unreachable("unexpected template argument loc");
6194 }
6195 
6196 TemplateArgumentLoc
ReadTemplateArgumentLoc(ModuleFile & F,const RecordData & Record,unsigned & Index)6197 ASTReader::ReadTemplateArgumentLoc(ModuleFile &F,
6198                                    const RecordData &Record, unsigned &Index) {
6199   TemplateArgument Arg = ReadTemplateArgument(F, Record, Index);
6200 
6201   if (Arg.getKind() == TemplateArgument::Expression) {
6202     if (Record[Index++]) // bool InfoHasSameExpr.
6203       return TemplateArgumentLoc(Arg, TemplateArgumentLocInfo(Arg.getAsExpr()));
6204   }
6205   return TemplateArgumentLoc(Arg, GetTemplateArgumentLocInfo(F, Arg.getKind(),
6206                                                              Record, Index));
6207 }
6208 
6209 const ASTTemplateArgumentListInfo*
ReadASTTemplateArgumentListInfo(ModuleFile & F,const RecordData & Record,unsigned & Index)6210 ASTReader::ReadASTTemplateArgumentListInfo(ModuleFile &F,
6211                                            const RecordData &Record,
6212                                            unsigned &Index) {
6213   SourceLocation LAngleLoc = ReadSourceLocation(F, Record, Index);
6214   SourceLocation RAngleLoc = ReadSourceLocation(F, Record, Index);
6215   unsigned NumArgsAsWritten = Record[Index++];
6216   TemplateArgumentListInfo TemplArgsInfo(LAngleLoc, RAngleLoc);
6217   for (unsigned i = 0; i != NumArgsAsWritten; ++i)
6218     TemplArgsInfo.addArgument(ReadTemplateArgumentLoc(F, Record, Index));
6219   return ASTTemplateArgumentListInfo::Create(getContext(), TemplArgsInfo);
6220 }
6221 
GetExternalDecl(uint32_t ID)6222 Decl *ASTReader::GetExternalDecl(uint32_t ID) {
6223   return GetDecl(ID);
6224 }
6225 
6226 template<typename TemplateSpecializationDecl>
completeRedeclChainForTemplateSpecialization(Decl * D)6227 static void completeRedeclChainForTemplateSpecialization(Decl *D) {
6228   if (auto *TSD = dyn_cast<TemplateSpecializationDecl>(D))
6229     TSD->getSpecializedTemplate()->LoadLazySpecializations();
6230 }
6231 
CompleteRedeclChain(const Decl * D)6232 void ASTReader::CompleteRedeclChain(const Decl *D) {
6233   if (NumCurrentElementsDeserializing) {
6234     // We arrange to not care about the complete redeclaration chain while we're
6235     // deserializing. Just remember that the AST has marked this one as complete
6236     // but that it's not actually complete yet, so we know we still need to
6237     // complete it later.
6238     PendingIncompleteDeclChains.push_back(const_cast<Decl*>(D));
6239     return;
6240   }
6241 
6242   const DeclContext *DC = D->getDeclContext()->getRedeclContext();
6243 
6244   // If this is a named declaration, complete it by looking it up
6245   // within its context.
6246   //
6247   // FIXME: Merging a function definition should merge
6248   // all mergeable entities within it.
6249   if (isa<TranslationUnitDecl>(DC) || isa<NamespaceDecl>(DC) ||
6250       isa<CXXRecordDecl>(DC) || isa<EnumDecl>(DC)) {
6251     if (DeclarationName Name = cast<NamedDecl>(D)->getDeclName()) {
6252       if (!getContext().getLangOpts().CPlusPlus &&
6253           isa<TranslationUnitDecl>(DC)) {
6254         // Outside of C++, we don't have a lookup table for the TU, so update
6255         // the identifier instead. (For C++ modules, we don't store decls
6256         // in the serialized identifier table, so we do the lookup in the TU.)
6257         auto *II = Name.getAsIdentifierInfo();
6258         assert(II && "non-identifier name in C?");
6259         if (II->isOutOfDate())
6260           updateOutOfDateIdentifier(*II);
6261       } else
6262         DC->lookup(Name);
6263     } else if (needsAnonymousDeclarationNumber(cast<NamedDecl>(D))) {
6264       // Find all declarations of this kind from the relevant context.
6265       for (auto *DCDecl : cast<Decl>(D->getLexicalDeclContext())->redecls()) {
6266         auto *DC = cast<DeclContext>(DCDecl);
6267         SmallVector<Decl*, 8> Decls;
6268         FindExternalLexicalDecls(
6269             DC, [&](Decl::Kind K) { return K == D->getKind(); }, Decls);
6270       }
6271     }
6272   }
6273 
6274   if (auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(D))
6275     CTSD->getSpecializedTemplate()->LoadLazySpecializations();
6276   if (auto *VTSD = dyn_cast<VarTemplateSpecializationDecl>(D))
6277     VTSD->getSpecializedTemplate()->LoadLazySpecializations();
6278   if (auto *FD = dyn_cast<FunctionDecl>(D)) {
6279     if (auto *Template = FD->getPrimaryTemplate())
6280       Template->LoadLazySpecializations();
6281   }
6282 }
6283 
6284 CXXCtorInitializer **
GetExternalCXXCtorInitializers(uint64_t Offset)6285 ASTReader::GetExternalCXXCtorInitializers(uint64_t Offset) {
6286   RecordLocation Loc = getLocalBitOffset(Offset);
6287   BitstreamCursor &Cursor = Loc.F->DeclsCursor;
6288   SavedStreamPosition SavedPosition(Cursor);
6289   Cursor.JumpToBit(Loc.Offset);
6290   ReadingKindTracker ReadingKind(Read_Decl, *this);
6291 
6292   RecordData Record;
6293   unsigned Code = Cursor.ReadCode();
6294   unsigned RecCode = Cursor.readRecord(Code, Record);
6295   if (RecCode != DECL_CXX_CTOR_INITIALIZERS) {
6296     Error("malformed AST file: missing C++ ctor initializers");
6297     return nullptr;
6298   }
6299 
6300   unsigned Idx = 0;
6301   return ReadCXXCtorInitializers(*Loc.F, Record, Idx);
6302 }
6303 
GetExternalCXXBaseSpecifiers(uint64_t Offset)6304 CXXBaseSpecifier *ASTReader::GetExternalCXXBaseSpecifiers(uint64_t Offset) {
6305   RecordLocation Loc = getLocalBitOffset(Offset);
6306   BitstreamCursor &Cursor = Loc.F->DeclsCursor;
6307   SavedStreamPosition SavedPosition(Cursor);
6308   Cursor.JumpToBit(Loc.Offset);
6309   ReadingKindTracker ReadingKind(Read_Decl, *this);
6310   RecordData Record;
6311   unsigned Code = Cursor.ReadCode();
6312   unsigned RecCode = Cursor.readRecord(Code, Record);
6313   if (RecCode != DECL_CXX_BASE_SPECIFIERS) {
6314     Error("malformed AST file: missing C++ base specifiers");
6315     return nullptr;
6316   }
6317 
6318   unsigned Idx = 0;
6319   unsigned NumBases = Record[Idx++];
6320   void *Mem = Context.Allocate(sizeof(CXXBaseSpecifier) * NumBases);
6321   CXXBaseSpecifier *Bases = new (Mem) CXXBaseSpecifier [NumBases];
6322   for (unsigned I = 0; I != NumBases; ++I)
6323     Bases[I] = ReadCXXBaseSpecifier(*Loc.F, Record, Idx);
6324   return Bases;
6325 }
6326 
6327 serialization::DeclID
getGlobalDeclID(ModuleFile & F,LocalDeclID LocalID) const6328 ASTReader::getGlobalDeclID(ModuleFile &F, LocalDeclID LocalID) const {
6329   if (LocalID < NUM_PREDEF_DECL_IDS)
6330     return LocalID;
6331 
6332   ContinuousRangeMap<uint32_t, int, 2>::iterator I
6333     = F.DeclRemap.find(LocalID - NUM_PREDEF_DECL_IDS);
6334   assert(I != F.DeclRemap.end() && "Invalid index into decl index remap");
6335 
6336   return LocalID + I->second;
6337 }
6338 
isDeclIDFromModule(serialization::GlobalDeclID ID,ModuleFile & M) const6339 bool ASTReader::isDeclIDFromModule(serialization::GlobalDeclID ID,
6340                                    ModuleFile &M) const {
6341   // Predefined decls aren't from any module.
6342   if (ID < NUM_PREDEF_DECL_IDS)
6343     return false;
6344 
6345   return ID - NUM_PREDEF_DECL_IDS >= M.BaseDeclID &&
6346          ID - NUM_PREDEF_DECL_IDS < M.BaseDeclID + M.LocalNumDecls;
6347 }
6348 
getOwningModuleFile(const Decl * D)6349 ModuleFile *ASTReader::getOwningModuleFile(const Decl *D) {
6350   if (!D->isFromASTFile())
6351     return nullptr;
6352   GlobalDeclMapType::const_iterator I = GlobalDeclMap.find(D->getGlobalID());
6353   assert(I != GlobalDeclMap.end() && "Corrupted global declaration map");
6354   return I->second;
6355 }
6356 
getSourceLocationForDeclID(GlobalDeclID ID)6357 SourceLocation ASTReader::getSourceLocationForDeclID(GlobalDeclID ID) {
6358   if (ID < NUM_PREDEF_DECL_IDS)
6359     return SourceLocation();
6360 
6361   unsigned Index = ID - NUM_PREDEF_DECL_IDS;
6362 
6363   if (Index > DeclsLoaded.size()) {
6364     Error("declaration ID out-of-range for AST file");
6365     return SourceLocation();
6366   }
6367 
6368   if (Decl *D = DeclsLoaded[Index])
6369     return D->getLocation();
6370 
6371   SourceLocation Loc;
6372   DeclCursorForID(ID, Loc);
6373   return Loc;
6374 }
6375 
getPredefinedDecl(ASTContext & Context,PredefinedDeclIDs ID)6376 static Decl *getPredefinedDecl(ASTContext &Context, PredefinedDeclIDs ID) {
6377   switch (ID) {
6378   case PREDEF_DECL_NULL_ID:
6379     return nullptr;
6380 
6381   case PREDEF_DECL_TRANSLATION_UNIT_ID:
6382     return Context.getTranslationUnitDecl();
6383 
6384   case PREDEF_DECL_OBJC_ID_ID:
6385     return Context.getObjCIdDecl();
6386 
6387   case PREDEF_DECL_OBJC_SEL_ID:
6388     return Context.getObjCSelDecl();
6389 
6390   case PREDEF_DECL_OBJC_CLASS_ID:
6391     return Context.getObjCClassDecl();
6392 
6393   case PREDEF_DECL_OBJC_PROTOCOL_ID:
6394     return Context.getObjCProtocolDecl();
6395 
6396   case PREDEF_DECL_INT_128_ID:
6397     return Context.getInt128Decl();
6398 
6399   case PREDEF_DECL_UNSIGNED_INT_128_ID:
6400     return Context.getUInt128Decl();
6401 
6402   case PREDEF_DECL_OBJC_INSTANCETYPE_ID:
6403     return Context.getObjCInstanceTypeDecl();
6404 
6405   case PREDEF_DECL_BUILTIN_VA_LIST_ID:
6406     return Context.getBuiltinVaListDecl();
6407 
6408   case PREDEF_DECL_VA_LIST_TAG:
6409     return Context.getVaListTagDecl();
6410 
6411   case PREDEF_DECL_BUILTIN_MS_VA_LIST_ID:
6412     return Context.getBuiltinMSVaListDecl();
6413 
6414   case PREDEF_DECL_EXTERN_C_CONTEXT_ID:
6415     return Context.getExternCContextDecl();
6416 
6417   case PREDEF_DECL_MAKE_INTEGER_SEQ_ID:
6418     return Context.getMakeIntegerSeqDecl();
6419 
6420   case PREDEF_DECL_CF_CONSTANT_STRING_ID:
6421     return Context.getCFConstantStringDecl();
6422 
6423   case PREDEF_DECL_CF_CONSTANT_STRING_TAG_ID:
6424     return Context.getCFConstantStringTagDecl();
6425 
6426   case PREDEF_DECL_TYPE_PACK_ELEMENT_ID:
6427     return Context.getTypePackElementDecl();
6428   }
6429   llvm_unreachable("PredefinedDeclIDs unknown enum value");
6430 }
6431 
GetExistingDecl(DeclID ID)6432 Decl *ASTReader::GetExistingDecl(DeclID ID) {
6433   if (ID < NUM_PREDEF_DECL_IDS) {
6434     Decl *D = getPredefinedDecl(Context, (PredefinedDeclIDs)ID);
6435     if (D) {
6436       // Track that we have merged the declaration with ID \p ID into the
6437       // pre-existing predefined declaration \p D.
6438       auto &Merged = KeyDecls[D->getCanonicalDecl()];
6439       if (Merged.empty())
6440         Merged.push_back(ID);
6441     }
6442     return D;
6443   }
6444 
6445   unsigned Index = ID - NUM_PREDEF_DECL_IDS;
6446 
6447   if (Index >= DeclsLoaded.size()) {
6448     assert(0 && "declaration ID out-of-range for AST file");
6449     Error("declaration ID out-of-range for AST file");
6450     return nullptr;
6451   }
6452 
6453   return DeclsLoaded[Index];
6454 }
6455 
GetDecl(DeclID ID)6456 Decl *ASTReader::GetDecl(DeclID ID) {
6457   if (ID < NUM_PREDEF_DECL_IDS)
6458     return GetExistingDecl(ID);
6459 
6460   unsigned Index = ID - NUM_PREDEF_DECL_IDS;
6461 
6462   if (Index >= DeclsLoaded.size()) {
6463     assert(0 && "declaration ID out-of-range for AST file");
6464     Error("declaration ID out-of-range for AST file");
6465     return nullptr;
6466   }
6467 
6468   if (!DeclsLoaded[Index]) {
6469     ReadDeclRecord(ID);
6470     if (DeserializationListener)
6471       DeserializationListener->DeclRead(ID, DeclsLoaded[Index]);
6472   }
6473 
6474   return DeclsLoaded[Index];
6475 }
6476 
mapGlobalIDToModuleFileGlobalID(ModuleFile & M,DeclID GlobalID)6477 DeclID ASTReader::mapGlobalIDToModuleFileGlobalID(ModuleFile &M,
6478                                                   DeclID GlobalID) {
6479   if (GlobalID < NUM_PREDEF_DECL_IDS)
6480     return GlobalID;
6481 
6482   GlobalDeclMapType::const_iterator I = GlobalDeclMap.find(GlobalID);
6483   assert(I != GlobalDeclMap.end() && "Corrupted global declaration map");
6484   ModuleFile *Owner = I->second;
6485 
6486   llvm::DenseMap<ModuleFile *, serialization::DeclID>::iterator Pos
6487     = M.GlobalToLocalDeclIDs.find(Owner);
6488   if (Pos == M.GlobalToLocalDeclIDs.end())
6489     return 0;
6490 
6491   return GlobalID - Owner->BaseDeclID + Pos->second;
6492 }
6493 
ReadDeclID(ModuleFile & F,const RecordData & Record,unsigned & Idx)6494 serialization::DeclID ASTReader::ReadDeclID(ModuleFile &F,
6495                                             const RecordData &Record,
6496                                             unsigned &Idx) {
6497   if (Idx >= Record.size()) {
6498     Error("Corrupted AST file");
6499     return 0;
6500   }
6501 
6502   return getGlobalDeclID(F, Record[Idx++]);
6503 }
6504 
6505 /// \brief Resolve the offset of a statement into a statement.
6506 ///
6507 /// This operation will read a new statement from the external
6508 /// source each time it is called, and is meant to be used via a
6509 /// LazyOffsetPtr (which is used by Decls for the body of functions, etc).
GetExternalDeclStmt(uint64_t Offset)6510 Stmt *ASTReader::GetExternalDeclStmt(uint64_t Offset) {
6511   // Switch case IDs are per Decl.
6512   ClearSwitchCaseIDs();
6513 
6514   // Offset here is a global offset across the entire chain.
6515   RecordLocation Loc = getLocalBitOffset(Offset);
6516   Loc.F->DeclsCursor.JumpToBit(Loc.Offset);
6517   return ReadStmtFromStream(*Loc.F);
6518 }
6519 
FindExternalLexicalDecls(const DeclContext * DC,llvm::function_ref<bool (Decl::Kind)> IsKindWeWant,SmallVectorImpl<Decl * > & Decls)6520 void ASTReader::FindExternalLexicalDecls(
6521     const DeclContext *DC, llvm::function_ref<bool(Decl::Kind)> IsKindWeWant,
6522     SmallVectorImpl<Decl *> &Decls) {
6523   bool PredefsVisited[NUM_PREDEF_DECL_IDS] = {};
6524 
6525   auto Visit = [&] (ModuleFile *M, LexicalContents LexicalDecls) {
6526     assert(LexicalDecls.size() % 2 == 0 && "expected an even number of entries");
6527     for (int I = 0, N = LexicalDecls.size(); I != N; I += 2) {
6528       auto K = (Decl::Kind)+LexicalDecls[I];
6529       if (!IsKindWeWant(K))
6530         continue;
6531 
6532       auto ID = (serialization::DeclID)+LexicalDecls[I + 1];
6533 
6534       // Don't add predefined declarations to the lexical context more
6535       // than once.
6536       if (ID < NUM_PREDEF_DECL_IDS) {
6537         if (PredefsVisited[ID])
6538           continue;
6539 
6540         PredefsVisited[ID] = true;
6541       }
6542 
6543       if (Decl *D = GetLocalDecl(*M, ID)) {
6544         assert(D->getKind() == K && "wrong kind for lexical decl");
6545         if (!DC->isDeclInLexicalTraversal(D))
6546           Decls.push_back(D);
6547       }
6548     }
6549   };
6550 
6551   if (isa<TranslationUnitDecl>(DC)) {
6552     for (auto Lexical : TULexicalDecls)
6553       Visit(Lexical.first, Lexical.second);
6554   } else {
6555     auto I = LexicalDecls.find(DC);
6556     if (I != LexicalDecls.end())
6557       Visit(I->second.first, I->second.second);
6558   }
6559 
6560   ++NumLexicalDeclContextsRead;
6561 }
6562 
6563 namespace {
6564 
6565 class DeclIDComp {
6566   ASTReader &Reader;
6567   ModuleFile &Mod;
6568 
6569 public:
DeclIDComp(ASTReader & Reader,ModuleFile & M)6570   DeclIDComp(ASTReader &Reader, ModuleFile &M) : Reader(Reader), Mod(M) {}
6571 
operator ()(LocalDeclID L,LocalDeclID R) const6572   bool operator()(LocalDeclID L, LocalDeclID R) const {
6573     SourceLocation LHS = getLocation(L);
6574     SourceLocation RHS = getLocation(R);
6575     return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6576   }
6577 
operator ()(SourceLocation LHS,LocalDeclID R) const6578   bool operator()(SourceLocation LHS, LocalDeclID R) const {
6579     SourceLocation RHS = getLocation(R);
6580     return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6581   }
6582 
operator ()(LocalDeclID L,SourceLocation RHS) const6583   bool operator()(LocalDeclID L, SourceLocation RHS) const {
6584     SourceLocation LHS = getLocation(L);
6585     return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6586   }
6587 
getLocation(LocalDeclID ID) const6588   SourceLocation getLocation(LocalDeclID ID) const {
6589     return Reader.getSourceManager().getFileLoc(
6590             Reader.getSourceLocationForDeclID(Reader.getGlobalDeclID(Mod, ID)));
6591   }
6592 };
6593 
6594 }
6595 
FindFileRegionDecls(FileID File,unsigned Offset,unsigned Length,SmallVectorImpl<Decl * > & Decls)6596 void ASTReader::FindFileRegionDecls(FileID File,
6597                                     unsigned Offset, unsigned Length,
6598                                     SmallVectorImpl<Decl *> &Decls) {
6599   SourceManager &SM = getSourceManager();
6600 
6601   llvm::DenseMap<FileID, FileDeclsInfo>::iterator I = FileDeclIDs.find(File);
6602   if (I == FileDeclIDs.end())
6603     return;
6604 
6605   FileDeclsInfo &DInfo = I->second;
6606   if (DInfo.Decls.empty())
6607     return;
6608 
6609   SourceLocation
6610     BeginLoc = SM.getLocForStartOfFile(File).getLocWithOffset(Offset);
6611   SourceLocation EndLoc = BeginLoc.getLocWithOffset(Length);
6612 
6613   DeclIDComp DIDComp(*this, *DInfo.Mod);
6614   ArrayRef<serialization::LocalDeclID>::iterator
6615     BeginIt = std::lower_bound(DInfo.Decls.begin(), DInfo.Decls.end(),
6616                                BeginLoc, DIDComp);
6617   if (BeginIt != DInfo.Decls.begin())
6618     --BeginIt;
6619 
6620   // If we are pointing at a top-level decl inside an objc container, we need
6621   // to backtrack until we find it otherwise we will fail to report that the
6622   // region overlaps with an objc container.
6623   while (BeginIt != DInfo.Decls.begin() &&
6624          GetDecl(getGlobalDeclID(*DInfo.Mod, *BeginIt))
6625              ->isTopLevelDeclInObjCContainer())
6626     --BeginIt;
6627 
6628   ArrayRef<serialization::LocalDeclID>::iterator
6629     EndIt = std::upper_bound(DInfo.Decls.begin(), DInfo.Decls.end(),
6630                              EndLoc, DIDComp);
6631   if (EndIt != DInfo.Decls.end())
6632     ++EndIt;
6633 
6634   for (ArrayRef<serialization::LocalDeclID>::iterator
6635          DIt = BeginIt; DIt != EndIt; ++DIt)
6636     Decls.push_back(GetDecl(getGlobalDeclID(*DInfo.Mod, *DIt)));
6637 }
6638 
6639 bool
FindExternalVisibleDeclsByName(const DeclContext * DC,DeclarationName Name)6640 ASTReader::FindExternalVisibleDeclsByName(const DeclContext *DC,
6641                                           DeclarationName Name) {
6642   assert(DC->hasExternalVisibleStorage() && DC == DC->getPrimaryContext() &&
6643          "DeclContext has no visible decls in storage");
6644   if (!Name)
6645     return false;
6646 
6647   auto It = Lookups.find(DC);
6648   if (It == Lookups.end())
6649     return false;
6650 
6651   Deserializing LookupResults(this);
6652 
6653   // Load the list of declarations.
6654   SmallVector<NamedDecl *, 64> Decls;
6655   for (DeclID ID : It->second.Table.find(Name)) {
6656     NamedDecl *ND = cast<NamedDecl>(GetDecl(ID));
6657     if (ND->getDeclName() == Name)
6658       Decls.push_back(ND);
6659   }
6660 
6661   ++NumVisibleDeclContextsRead;
6662   SetExternalVisibleDeclsForName(DC, Name, Decls);
6663   return !Decls.empty();
6664 }
6665 
completeVisibleDeclsMap(const DeclContext * DC)6666 void ASTReader::completeVisibleDeclsMap(const DeclContext *DC) {
6667   if (!DC->hasExternalVisibleStorage())
6668     return;
6669 
6670   auto It = Lookups.find(DC);
6671   assert(It != Lookups.end() &&
6672          "have external visible storage but no lookup tables");
6673 
6674   DeclsMap Decls;
6675 
6676   for (DeclID ID : It->second.Table.findAll()) {
6677     NamedDecl *ND = cast<NamedDecl>(GetDecl(ID));
6678     Decls[ND->getDeclName()].push_back(ND);
6679   }
6680 
6681   ++NumVisibleDeclContextsRead;
6682 
6683   for (DeclsMap::iterator I = Decls.begin(), E = Decls.end(); I != E; ++I) {
6684     SetExternalVisibleDeclsForName(DC, I->first, I->second);
6685   }
6686   const_cast<DeclContext *>(DC)->setHasExternalVisibleStorage(false);
6687 }
6688 
6689 const serialization::reader::DeclContextLookupTable *
getLoadedLookupTables(DeclContext * Primary) const6690 ASTReader::getLoadedLookupTables(DeclContext *Primary) const {
6691   auto I = Lookups.find(Primary);
6692   return I == Lookups.end() ? nullptr : &I->second;
6693 }
6694 
6695 /// \brief Under non-PCH compilation the consumer receives the objc methods
6696 /// before receiving the implementation, and codegen depends on this.
6697 /// We simulate this by deserializing and passing to consumer the methods of the
6698 /// implementation before passing the deserialized implementation decl.
PassObjCImplDeclToConsumer(ObjCImplDecl * ImplD,ASTConsumer * Consumer)6699 static void PassObjCImplDeclToConsumer(ObjCImplDecl *ImplD,
6700                                        ASTConsumer *Consumer) {
6701   assert(ImplD && Consumer);
6702 
6703   for (auto *I : ImplD->methods())
6704     Consumer->HandleInterestingDecl(DeclGroupRef(I));
6705 
6706   Consumer->HandleInterestingDecl(DeclGroupRef(ImplD));
6707 }
6708 
PassInterestingDeclsToConsumer()6709 void ASTReader::PassInterestingDeclsToConsumer() {
6710   assert(Consumer);
6711 
6712   if (PassingDeclsToConsumer)
6713     return;
6714 
6715   // Guard variable to avoid recursively redoing the process of passing
6716   // decls to consumer.
6717   SaveAndRestore<bool> GuardPassingDeclsToConsumer(PassingDeclsToConsumer,
6718                                                    true);
6719 
6720   // Ensure that we've loaded all potentially-interesting declarations
6721   // that need to be eagerly loaded.
6722   for (auto ID : EagerlyDeserializedDecls)
6723     GetDecl(ID);
6724   EagerlyDeserializedDecls.clear();
6725 
6726   while (!InterestingDecls.empty()) {
6727     Decl *D = InterestingDecls.front();
6728     InterestingDecls.pop_front();
6729 
6730     PassInterestingDeclToConsumer(D);
6731   }
6732 }
6733 
PassInterestingDeclToConsumer(Decl * D)6734 void ASTReader::PassInterestingDeclToConsumer(Decl *D) {
6735   if (ObjCImplDecl *ImplD = dyn_cast<ObjCImplDecl>(D))
6736     PassObjCImplDeclToConsumer(ImplD, Consumer);
6737   else
6738     Consumer->HandleInterestingDecl(DeclGroupRef(D));
6739 }
6740 
StartTranslationUnit(ASTConsumer * Consumer)6741 void ASTReader::StartTranslationUnit(ASTConsumer *Consumer) {
6742   this->Consumer = Consumer;
6743 
6744   if (Consumer)
6745     PassInterestingDeclsToConsumer();
6746 
6747   if (DeserializationListener)
6748     DeserializationListener->ReaderInitialized(this);
6749 }
6750 
PrintStats()6751 void ASTReader::PrintStats() {
6752   std::fprintf(stderr, "*** AST File Statistics:\n");
6753 
6754   unsigned NumTypesLoaded
6755     = TypesLoaded.size() - std::count(TypesLoaded.begin(), TypesLoaded.end(),
6756                                       QualType());
6757   unsigned NumDeclsLoaded
6758     = DeclsLoaded.size() - std::count(DeclsLoaded.begin(), DeclsLoaded.end(),
6759                                       (Decl *)nullptr);
6760   unsigned NumIdentifiersLoaded
6761     = IdentifiersLoaded.size() - std::count(IdentifiersLoaded.begin(),
6762                                             IdentifiersLoaded.end(),
6763                                             (IdentifierInfo *)nullptr);
6764   unsigned NumMacrosLoaded
6765     = MacrosLoaded.size() - std::count(MacrosLoaded.begin(),
6766                                        MacrosLoaded.end(),
6767                                        (MacroInfo *)nullptr);
6768   unsigned NumSelectorsLoaded
6769     = SelectorsLoaded.size() - std::count(SelectorsLoaded.begin(),
6770                                           SelectorsLoaded.end(),
6771                                           Selector());
6772 
6773   if (unsigned TotalNumSLocEntries = getTotalNumSLocs())
6774     std::fprintf(stderr, "  %u/%u source location entries read (%f%%)\n",
6775                  NumSLocEntriesRead, TotalNumSLocEntries,
6776                  ((float)NumSLocEntriesRead/TotalNumSLocEntries * 100));
6777   if (!TypesLoaded.empty())
6778     std::fprintf(stderr, "  %u/%u types read (%f%%)\n",
6779                  NumTypesLoaded, (unsigned)TypesLoaded.size(),
6780                  ((float)NumTypesLoaded/TypesLoaded.size() * 100));
6781   if (!DeclsLoaded.empty())
6782     std::fprintf(stderr, "  %u/%u declarations read (%f%%)\n",
6783                  NumDeclsLoaded, (unsigned)DeclsLoaded.size(),
6784                  ((float)NumDeclsLoaded/DeclsLoaded.size() * 100));
6785   if (!IdentifiersLoaded.empty())
6786     std::fprintf(stderr, "  %u/%u identifiers read (%f%%)\n",
6787                  NumIdentifiersLoaded, (unsigned)IdentifiersLoaded.size(),
6788                  ((float)NumIdentifiersLoaded/IdentifiersLoaded.size() * 100));
6789   if (!MacrosLoaded.empty())
6790     std::fprintf(stderr, "  %u/%u macros read (%f%%)\n",
6791                  NumMacrosLoaded, (unsigned)MacrosLoaded.size(),
6792                  ((float)NumMacrosLoaded/MacrosLoaded.size() * 100));
6793   if (!SelectorsLoaded.empty())
6794     std::fprintf(stderr, "  %u/%u selectors read (%f%%)\n",
6795                  NumSelectorsLoaded, (unsigned)SelectorsLoaded.size(),
6796                  ((float)NumSelectorsLoaded/SelectorsLoaded.size() * 100));
6797   if (TotalNumStatements)
6798     std::fprintf(stderr, "  %u/%u statements read (%f%%)\n",
6799                  NumStatementsRead, TotalNumStatements,
6800                  ((float)NumStatementsRead/TotalNumStatements * 100));
6801   if (TotalNumMacros)
6802     std::fprintf(stderr, "  %u/%u macros read (%f%%)\n",
6803                  NumMacrosRead, TotalNumMacros,
6804                  ((float)NumMacrosRead/TotalNumMacros * 100));
6805   if (TotalLexicalDeclContexts)
6806     std::fprintf(stderr, "  %u/%u lexical declcontexts read (%f%%)\n",
6807                  NumLexicalDeclContextsRead, TotalLexicalDeclContexts,
6808                  ((float)NumLexicalDeclContextsRead/TotalLexicalDeclContexts
6809                   * 100));
6810   if (TotalVisibleDeclContexts)
6811     std::fprintf(stderr, "  %u/%u visible declcontexts read (%f%%)\n",
6812                  NumVisibleDeclContextsRead, TotalVisibleDeclContexts,
6813                  ((float)NumVisibleDeclContextsRead/TotalVisibleDeclContexts
6814                   * 100));
6815   if (TotalNumMethodPoolEntries) {
6816     std::fprintf(stderr, "  %u/%u method pool entries read (%f%%)\n",
6817                  NumMethodPoolEntriesRead, TotalNumMethodPoolEntries,
6818                  ((float)NumMethodPoolEntriesRead/TotalNumMethodPoolEntries
6819                   * 100));
6820   }
6821   if (NumMethodPoolLookups) {
6822     std::fprintf(stderr, "  %u/%u method pool lookups succeeded (%f%%)\n",
6823                  NumMethodPoolHits, NumMethodPoolLookups,
6824                  ((float)NumMethodPoolHits/NumMethodPoolLookups * 100.0));
6825   }
6826   if (NumMethodPoolTableLookups) {
6827     std::fprintf(stderr, "  %u/%u method pool table lookups succeeded (%f%%)\n",
6828                  NumMethodPoolTableHits, NumMethodPoolTableLookups,
6829                  ((float)NumMethodPoolTableHits/NumMethodPoolTableLookups
6830                   * 100.0));
6831   }
6832 
6833   if (NumIdentifierLookupHits) {
6834     std::fprintf(stderr,
6835                  "  %u / %u identifier table lookups succeeded (%f%%)\n",
6836                  NumIdentifierLookupHits, NumIdentifierLookups,
6837                  (double)NumIdentifierLookupHits*100.0/NumIdentifierLookups);
6838   }
6839 
6840   if (GlobalIndex) {
6841     std::fprintf(stderr, "\n");
6842     GlobalIndex->printStats();
6843   }
6844 
6845   std::fprintf(stderr, "\n");
6846   dump();
6847   std::fprintf(stderr, "\n");
6848 }
6849 
6850 template<typename Key, typename ModuleFile, unsigned InitialCapacity>
6851 static void
dumpModuleIDMap(StringRef Name,const ContinuousRangeMap<Key,ModuleFile *,InitialCapacity> & Map)6852 dumpModuleIDMap(StringRef Name,
6853                 const ContinuousRangeMap<Key, ModuleFile *,
6854                                          InitialCapacity> &Map) {
6855   if (Map.begin() == Map.end())
6856     return;
6857 
6858   typedef ContinuousRangeMap<Key, ModuleFile *, InitialCapacity> MapType;
6859   llvm::errs() << Name << ":\n";
6860   for (typename MapType::const_iterator I = Map.begin(), IEnd = Map.end();
6861        I != IEnd; ++I) {
6862     llvm::errs() << "  " << I->first << " -> " << I->second->FileName
6863       << "\n";
6864   }
6865 }
6866 
dump()6867 LLVM_DUMP_METHOD void ASTReader::dump() {
6868   llvm::errs() << "*** PCH/ModuleFile Remappings:\n";
6869   dumpModuleIDMap("Global bit offset map", GlobalBitOffsetsMap);
6870   dumpModuleIDMap("Global source location entry map", GlobalSLocEntryMap);
6871   dumpModuleIDMap("Global type map", GlobalTypeMap);
6872   dumpModuleIDMap("Global declaration map", GlobalDeclMap);
6873   dumpModuleIDMap("Global identifier map", GlobalIdentifierMap);
6874   dumpModuleIDMap("Global macro map", GlobalMacroMap);
6875   dumpModuleIDMap("Global submodule map", GlobalSubmoduleMap);
6876   dumpModuleIDMap("Global selector map", GlobalSelectorMap);
6877   dumpModuleIDMap("Global preprocessed entity map",
6878                   GlobalPreprocessedEntityMap);
6879 
6880   llvm::errs() << "\n*** PCH/Modules Loaded:";
6881   for (ModuleManager::ModuleConstIterator M = ModuleMgr.begin(),
6882                                        MEnd = ModuleMgr.end();
6883        M != MEnd; ++M)
6884     (*M)->dump();
6885 }
6886 
6887 /// Return the amount of memory used by memory buffers, breaking down
6888 /// by heap-backed versus mmap'ed memory.
getMemoryBufferSizes(MemoryBufferSizes & sizes) const6889 void ASTReader::getMemoryBufferSizes(MemoryBufferSizes &sizes) const {
6890   for (ModuleConstIterator I = ModuleMgr.begin(),
6891       E = ModuleMgr.end(); I != E; ++I) {
6892     if (llvm::MemoryBuffer *buf = (*I)->Buffer.get()) {
6893       size_t bytes = buf->getBufferSize();
6894       switch (buf->getBufferKind()) {
6895         case llvm::MemoryBuffer::MemoryBuffer_Malloc:
6896           sizes.malloc_bytes += bytes;
6897           break;
6898         case llvm::MemoryBuffer::MemoryBuffer_MMap:
6899           sizes.mmap_bytes += bytes;
6900           break;
6901       }
6902     }
6903   }
6904 }
6905 
InitializeSema(Sema & S)6906 void ASTReader::InitializeSema(Sema &S) {
6907   SemaObj = &S;
6908   S.addExternalSource(this);
6909 
6910   // Makes sure any declarations that were deserialized "too early"
6911   // still get added to the identifier's declaration chains.
6912   for (uint64_t ID : PreloadedDeclIDs) {
6913     NamedDecl *D = cast<NamedDecl>(GetDecl(ID));
6914     pushExternalDeclIntoScope(D, D->getDeclName());
6915   }
6916   PreloadedDeclIDs.clear();
6917 
6918   // FIXME: What happens if these are changed by a module import?
6919   if (!FPPragmaOptions.empty()) {
6920     assert(FPPragmaOptions.size() == 1 && "Wrong number of FP_PRAGMA_OPTIONS");
6921     SemaObj->FPFeatures.fp_contract = FPPragmaOptions[0];
6922   }
6923 
6924   // FIXME: What happens if these are changed by a module import?
6925   if (!OpenCLExtensions.empty()) {
6926     unsigned I = 0;
6927 #define OPENCLEXT(nm)  SemaObj->OpenCLFeatures.nm = OpenCLExtensions[I++];
6928 #include "clang/Basic/OpenCLExtensions.def"
6929 
6930     assert(OpenCLExtensions.size() == I && "Wrong number of OPENCL_EXTENSIONS");
6931   }
6932 
6933   UpdateSema();
6934 }
6935 
UpdateSema()6936 void ASTReader::UpdateSema() {
6937   assert(SemaObj && "no Sema to update");
6938 
6939   // Load the offsets of the declarations that Sema references.
6940   // They will be lazily deserialized when needed.
6941   if (!SemaDeclRefs.empty()) {
6942     assert(SemaDeclRefs.size() % 2 == 0);
6943     for (unsigned I = 0; I != SemaDeclRefs.size(); I += 2) {
6944       if (!SemaObj->StdNamespace)
6945         SemaObj->StdNamespace = SemaDeclRefs[I];
6946       if (!SemaObj->StdBadAlloc)
6947         SemaObj->StdBadAlloc = SemaDeclRefs[I+1];
6948     }
6949     SemaDeclRefs.clear();
6950   }
6951 
6952   // Update the state of pragmas. Use the same API as if we had encountered the
6953   // pragma in the source.
6954   if(OptimizeOffPragmaLocation.isValid())
6955     SemaObj->ActOnPragmaOptimize(/* IsOn = */ false, OptimizeOffPragmaLocation);
6956   if (PragmaMSStructState != -1)
6957     SemaObj->ActOnPragmaMSStruct((PragmaMSStructKind)PragmaMSStructState);
6958   if (PointersToMembersPragmaLocation.isValid()) {
6959     SemaObj->ActOnPragmaMSPointersToMembers(
6960         (LangOptions::PragmaMSPointersToMembersKind)
6961             PragmaMSPointersToMembersState,
6962         PointersToMembersPragmaLocation);
6963   }
6964 }
6965 
get(StringRef Name)6966 IdentifierInfo *ASTReader::get(StringRef Name) {
6967   // Note that we are loading an identifier.
6968   Deserializing AnIdentifier(this);
6969 
6970   IdentifierLookupVisitor Visitor(Name, /*PriorGeneration=*/0,
6971                                   NumIdentifierLookups,
6972                                   NumIdentifierLookupHits);
6973 
6974   // We don't need to do identifier table lookups in C++ modules (we preload
6975   // all interesting declarations, and don't need to use the scope for name
6976   // lookups). Perform the lookup in PCH files, though, since we don't build
6977   // a complete initial identifier table if we're carrying on from a PCH.
6978   if (Context.getLangOpts().CPlusPlus) {
6979     for (auto F : ModuleMgr.pch_modules())
6980       if (Visitor(*F))
6981         break;
6982   } else {
6983     // If there is a global index, look there first to determine which modules
6984     // provably do not have any results for this identifier.
6985     GlobalModuleIndex::HitSet Hits;
6986     GlobalModuleIndex::HitSet *HitsPtr = nullptr;
6987     if (!loadGlobalIndex()) {
6988       if (GlobalIndex->lookupIdentifier(Name, Hits)) {
6989         HitsPtr = &Hits;
6990       }
6991     }
6992 
6993     ModuleMgr.visit(Visitor, HitsPtr);
6994   }
6995 
6996   IdentifierInfo *II = Visitor.getIdentifierInfo();
6997   markIdentifierUpToDate(II);
6998   return II;
6999 }
7000 
7001 namespace clang {
7002   /// \brief An identifier-lookup iterator that enumerates all of the
7003   /// identifiers stored within a set of AST files.
7004   class ASTIdentifierIterator : public IdentifierIterator {
7005     /// \brief The AST reader whose identifiers are being enumerated.
7006     const ASTReader &Reader;
7007 
7008     /// \brief The current index into the chain of AST files stored in
7009     /// the AST reader.
7010     unsigned Index;
7011 
7012     /// \brief The current position within the identifier lookup table
7013     /// of the current AST file.
7014     ASTIdentifierLookupTable::key_iterator Current;
7015 
7016     /// \brief The end position within the identifier lookup table of
7017     /// the current AST file.
7018     ASTIdentifierLookupTable::key_iterator End;
7019 
7020     /// \brief Whether to skip any modules in the ASTReader.
7021     bool SkipModules;
7022 
7023   public:
7024     explicit ASTIdentifierIterator(const ASTReader &Reader,
7025                                    bool SkipModules = false);
7026 
7027     StringRef Next() override;
7028   };
7029 }
7030 
ASTIdentifierIterator(const ASTReader & Reader,bool SkipModules)7031 ASTIdentifierIterator::ASTIdentifierIterator(const ASTReader &Reader,
7032                                              bool SkipModules)
7033     : Reader(Reader), Index(Reader.ModuleMgr.size()), SkipModules(SkipModules) {
7034 }
7035 
Next()7036 StringRef ASTIdentifierIterator::Next() {
7037   while (Current == End) {
7038     // If we have exhausted all of our AST files, we're done.
7039     if (Index == 0)
7040       return StringRef();
7041 
7042     --Index;
7043     ModuleFile &F = Reader.ModuleMgr[Index];
7044     if (SkipModules && F.isModule())
7045       continue;
7046 
7047     ASTIdentifierLookupTable *IdTable =
7048         (ASTIdentifierLookupTable *)F.IdentifierLookupTable;
7049     Current = IdTable->key_begin();
7050     End = IdTable->key_end();
7051   }
7052 
7053   // We have any identifiers remaining in the current AST file; return
7054   // the next one.
7055   StringRef Result = *Current;
7056   ++Current;
7057   return Result;
7058 }
7059 
7060 namespace {
7061 /// A utility for appending two IdentifierIterators.
7062 class ChainedIdentifierIterator : public IdentifierIterator {
7063   std::unique_ptr<IdentifierIterator> Current;
7064   std::unique_ptr<IdentifierIterator> Queued;
7065 
7066 public:
ChainedIdentifierIterator(std::unique_ptr<IdentifierIterator> First,std::unique_ptr<IdentifierIterator> Second)7067   ChainedIdentifierIterator(std::unique_ptr<IdentifierIterator> First,
7068                             std::unique_ptr<IdentifierIterator> Second)
7069       : Current(std::move(First)), Queued(std::move(Second)) {}
7070 
Next()7071   StringRef Next() override {
7072     if (!Current)
7073       return StringRef();
7074 
7075     StringRef result = Current->Next();
7076     if (!result.empty())
7077       return result;
7078 
7079     // Try the queued iterator, which may itself be empty.
7080     Current.reset();
7081     std::swap(Current, Queued);
7082     return Next();
7083   }
7084 };
7085 } // end anonymous namespace.
7086 
getIdentifiers()7087 IdentifierIterator *ASTReader::getIdentifiers() {
7088   if (!loadGlobalIndex()) {
7089     std::unique_ptr<IdentifierIterator> ReaderIter(
7090         new ASTIdentifierIterator(*this, /*SkipModules=*/true));
7091     std::unique_ptr<IdentifierIterator> ModulesIter(
7092         GlobalIndex->createIdentifierIterator());
7093     return new ChainedIdentifierIterator(std::move(ReaderIter),
7094                                          std::move(ModulesIter));
7095   }
7096 
7097   return new ASTIdentifierIterator(*this);
7098 }
7099 
7100 namespace clang { namespace serialization {
7101   class ReadMethodPoolVisitor {
7102     ASTReader &Reader;
7103     Selector Sel;
7104     unsigned PriorGeneration;
7105     unsigned InstanceBits;
7106     unsigned FactoryBits;
7107     bool InstanceHasMoreThanOneDecl;
7108     bool FactoryHasMoreThanOneDecl;
7109     SmallVector<ObjCMethodDecl *, 4> InstanceMethods;
7110     SmallVector<ObjCMethodDecl *, 4> FactoryMethods;
7111 
7112   public:
ReadMethodPoolVisitor(ASTReader & Reader,Selector Sel,unsigned PriorGeneration)7113     ReadMethodPoolVisitor(ASTReader &Reader, Selector Sel,
7114                           unsigned PriorGeneration)
7115         : Reader(Reader), Sel(Sel), PriorGeneration(PriorGeneration),
7116           InstanceBits(0), FactoryBits(0), InstanceHasMoreThanOneDecl(false),
7117           FactoryHasMoreThanOneDecl(false) {}
7118 
operator ()(ModuleFile & M)7119     bool operator()(ModuleFile &M) {
7120       if (!M.SelectorLookupTable)
7121         return false;
7122 
7123       // If we've already searched this module file, skip it now.
7124       if (M.Generation <= PriorGeneration)
7125         return true;
7126 
7127       ++Reader.NumMethodPoolTableLookups;
7128       ASTSelectorLookupTable *PoolTable
7129         = (ASTSelectorLookupTable*)M.SelectorLookupTable;
7130       ASTSelectorLookupTable::iterator Pos = PoolTable->find(Sel);
7131       if (Pos == PoolTable->end())
7132         return false;
7133 
7134       ++Reader.NumMethodPoolTableHits;
7135       ++Reader.NumSelectorsRead;
7136       // FIXME: Not quite happy with the statistics here. We probably should
7137       // disable this tracking when called via LoadSelector.
7138       // Also, should entries without methods count as misses?
7139       ++Reader.NumMethodPoolEntriesRead;
7140       ASTSelectorLookupTrait::data_type Data = *Pos;
7141       if (Reader.DeserializationListener)
7142         Reader.DeserializationListener->SelectorRead(Data.ID, Sel);
7143 
7144       InstanceMethods.append(Data.Instance.begin(), Data.Instance.end());
7145       FactoryMethods.append(Data.Factory.begin(), Data.Factory.end());
7146       InstanceBits = Data.InstanceBits;
7147       FactoryBits = Data.FactoryBits;
7148       InstanceHasMoreThanOneDecl = Data.InstanceHasMoreThanOneDecl;
7149       FactoryHasMoreThanOneDecl = Data.FactoryHasMoreThanOneDecl;
7150       return true;
7151     }
7152 
7153     /// \brief Retrieve the instance methods found by this visitor.
getInstanceMethods() const7154     ArrayRef<ObjCMethodDecl *> getInstanceMethods() const {
7155       return InstanceMethods;
7156     }
7157 
7158     /// \brief Retrieve the instance methods found by this visitor.
getFactoryMethods() const7159     ArrayRef<ObjCMethodDecl *> getFactoryMethods() const {
7160       return FactoryMethods;
7161     }
7162 
getInstanceBits() const7163     unsigned getInstanceBits() const { return InstanceBits; }
getFactoryBits() const7164     unsigned getFactoryBits() const { return FactoryBits; }
instanceHasMoreThanOneDecl() const7165     bool instanceHasMoreThanOneDecl() const {
7166       return InstanceHasMoreThanOneDecl;
7167     }
factoryHasMoreThanOneDecl() const7168     bool factoryHasMoreThanOneDecl() const { return FactoryHasMoreThanOneDecl; }
7169   };
7170 } } // end namespace clang::serialization
7171 
7172 /// \brief Add the given set of methods to the method list.
addMethodsToPool(Sema & S,ArrayRef<ObjCMethodDecl * > Methods,ObjCMethodList & List)7173 static void addMethodsToPool(Sema &S, ArrayRef<ObjCMethodDecl *> Methods,
7174                              ObjCMethodList &List) {
7175   for (unsigned I = 0, N = Methods.size(); I != N; ++I) {
7176     S.addMethodToGlobalList(&List, Methods[I]);
7177   }
7178 }
7179 
ReadMethodPool(Selector Sel)7180 void ASTReader::ReadMethodPool(Selector Sel) {
7181   // Get the selector generation and update it to the current generation.
7182   unsigned &Generation = SelectorGeneration[Sel];
7183   unsigned PriorGeneration = Generation;
7184   Generation = getGeneration();
7185   SelectorOutOfDate[Sel] = false;
7186 
7187   // Search for methods defined with this selector.
7188   ++NumMethodPoolLookups;
7189   ReadMethodPoolVisitor Visitor(*this, Sel, PriorGeneration);
7190   ModuleMgr.visit(Visitor);
7191 
7192   if (Visitor.getInstanceMethods().empty() &&
7193       Visitor.getFactoryMethods().empty())
7194     return;
7195 
7196   ++NumMethodPoolHits;
7197 
7198   if (!getSema())
7199     return;
7200 
7201   Sema &S = *getSema();
7202   Sema::GlobalMethodPool::iterator Pos
7203     = S.MethodPool.insert(std::make_pair(Sel, Sema::GlobalMethods())).first;
7204 
7205   Pos->second.first.setBits(Visitor.getInstanceBits());
7206   Pos->second.first.setHasMoreThanOneDecl(Visitor.instanceHasMoreThanOneDecl());
7207   Pos->second.second.setBits(Visitor.getFactoryBits());
7208   Pos->second.second.setHasMoreThanOneDecl(Visitor.factoryHasMoreThanOneDecl());
7209 
7210   // Add methods to the global pool *after* setting hasMoreThanOneDecl, since
7211   // when building a module we keep every method individually and may need to
7212   // update hasMoreThanOneDecl as we add the methods.
7213   addMethodsToPool(S, Visitor.getInstanceMethods(), Pos->second.first);
7214   addMethodsToPool(S, Visitor.getFactoryMethods(), Pos->second.second);
7215 }
7216 
updateOutOfDateSelector(Selector Sel)7217 void ASTReader::updateOutOfDateSelector(Selector Sel) {
7218   if (SelectorOutOfDate[Sel])
7219     ReadMethodPool(Sel);
7220 }
7221 
ReadKnownNamespaces(SmallVectorImpl<NamespaceDecl * > & Namespaces)7222 void ASTReader::ReadKnownNamespaces(
7223                           SmallVectorImpl<NamespaceDecl *> &Namespaces) {
7224   Namespaces.clear();
7225 
7226   for (unsigned I = 0, N = KnownNamespaces.size(); I != N; ++I) {
7227     if (NamespaceDecl *Namespace
7228                 = dyn_cast_or_null<NamespaceDecl>(GetDecl(KnownNamespaces[I])))
7229       Namespaces.push_back(Namespace);
7230   }
7231 }
7232 
ReadUndefinedButUsed(llvm::MapVector<NamedDecl *,SourceLocation> & Undefined)7233 void ASTReader::ReadUndefinedButUsed(
7234     llvm::MapVector<NamedDecl *, SourceLocation> &Undefined) {
7235   for (unsigned Idx = 0, N = UndefinedButUsed.size(); Idx != N;) {
7236     NamedDecl *D = cast<NamedDecl>(GetDecl(UndefinedButUsed[Idx++]));
7237     SourceLocation Loc =
7238         SourceLocation::getFromRawEncoding(UndefinedButUsed[Idx++]);
7239     Undefined.insert(std::make_pair(D, Loc));
7240   }
7241 }
7242 
ReadMismatchingDeleteExpressions(llvm::MapVector<FieldDecl *,llvm::SmallVector<std::pair<SourceLocation,bool>,4>> & Exprs)7243 void ASTReader::ReadMismatchingDeleteExpressions(llvm::MapVector<
7244     FieldDecl *, llvm::SmallVector<std::pair<SourceLocation, bool>, 4>> &
7245                                                      Exprs) {
7246   for (unsigned Idx = 0, N = DelayedDeleteExprs.size(); Idx != N;) {
7247     FieldDecl *FD = cast<FieldDecl>(GetDecl(DelayedDeleteExprs[Idx++]));
7248     uint64_t Count = DelayedDeleteExprs[Idx++];
7249     for (uint64_t C = 0; C < Count; ++C) {
7250       SourceLocation DeleteLoc =
7251           SourceLocation::getFromRawEncoding(DelayedDeleteExprs[Idx++]);
7252       const bool IsArrayForm = DelayedDeleteExprs[Idx++];
7253       Exprs[FD].push_back(std::make_pair(DeleteLoc, IsArrayForm));
7254     }
7255   }
7256 }
7257 
ReadTentativeDefinitions(SmallVectorImpl<VarDecl * > & TentativeDefs)7258 void ASTReader::ReadTentativeDefinitions(
7259                   SmallVectorImpl<VarDecl *> &TentativeDefs) {
7260   for (unsigned I = 0, N = TentativeDefinitions.size(); I != N; ++I) {
7261     VarDecl *Var = dyn_cast_or_null<VarDecl>(GetDecl(TentativeDefinitions[I]));
7262     if (Var)
7263       TentativeDefs.push_back(Var);
7264   }
7265   TentativeDefinitions.clear();
7266 }
7267 
ReadUnusedFileScopedDecls(SmallVectorImpl<const DeclaratorDecl * > & Decls)7268 void ASTReader::ReadUnusedFileScopedDecls(
7269                                SmallVectorImpl<const DeclaratorDecl *> &Decls) {
7270   for (unsigned I = 0, N = UnusedFileScopedDecls.size(); I != N; ++I) {
7271     DeclaratorDecl *D
7272       = dyn_cast_or_null<DeclaratorDecl>(GetDecl(UnusedFileScopedDecls[I]));
7273     if (D)
7274       Decls.push_back(D);
7275   }
7276   UnusedFileScopedDecls.clear();
7277 }
7278 
ReadDelegatingConstructors(SmallVectorImpl<CXXConstructorDecl * > & Decls)7279 void ASTReader::ReadDelegatingConstructors(
7280                                  SmallVectorImpl<CXXConstructorDecl *> &Decls) {
7281   for (unsigned I = 0, N = DelegatingCtorDecls.size(); I != N; ++I) {
7282     CXXConstructorDecl *D
7283       = dyn_cast_or_null<CXXConstructorDecl>(GetDecl(DelegatingCtorDecls[I]));
7284     if (D)
7285       Decls.push_back(D);
7286   }
7287   DelegatingCtorDecls.clear();
7288 }
7289 
ReadExtVectorDecls(SmallVectorImpl<TypedefNameDecl * > & Decls)7290 void ASTReader::ReadExtVectorDecls(SmallVectorImpl<TypedefNameDecl *> &Decls) {
7291   for (unsigned I = 0, N = ExtVectorDecls.size(); I != N; ++I) {
7292     TypedefNameDecl *D
7293       = dyn_cast_or_null<TypedefNameDecl>(GetDecl(ExtVectorDecls[I]));
7294     if (D)
7295       Decls.push_back(D);
7296   }
7297   ExtVectorDecls.clear();
7298 }
7299 
ReadUnusedLocalTypedefNameCandidates(llvm::SmallSetVector<const TypedefNameDecl *,4> & Decls)7300 void ASTReader::ReadUnusedLocalTypedefNameCandidates(
7301     llvm::SmallSetVector<const TypedefNameDecl *, 4> &Decls) {
7302   for (unsigned I = 0, N = UnusedLocalTypedefNameCandidates.size(); I != N;
7303        ++I) {
7304     TypedefNameDecl *D = dyn_cast_or_null<TypedefNameDecl>(
7305         GetDecl(UnusedLocalTypedefNameCandidates[I]));
7306     if (D)
7307       Decls.insert(D);
7308   }
7309   UnusedLocalTypedefNameCandidates.clear();
7310 }
7311 
ReadReferencedSelectors(SmallVectorImpl<std::pair<Selector,SourceLocation>> & Sels)7312 void ASTReader::ReadReferencedSelectors(
7313        SmallVectorImpl<std::pair<Selector, SourceLocation> > &Sels) {
7314   if (ReferencedSelectorsData.empty())
7315     return;
7316 
7317   // If there are @selector references added them to its pool. This is for
7318   // implementation of -Wselector.
7319   unsigned int DataSize = ReferencedSelectorsData.size()-1;
7320   unsigned I = 0;
7321   while (I < DataSize) {
7322     Selector Sel = DecodeSelector(ReferencedSelectorsData[I++]);
7323     SourceLocation SelLoc
7324       = SourceLocation::getFromRawEncoding(ReferencedSelectorsData[I++]);
7325     Sels.push_back(std::make_pair(Sel, SelLoc));
7326   }
7327   ReferencedSelectorsData.clear();
7328 }
7329 
ReadWeakUndeclaredIdentifiers(SmallVectorImpl<std::pair<IdentifierInfo *,WeakInfo>> & WeakIDs)7330 void ASTReader::ReadWeakUndeclaredIdentifiers(
7331        SmallVectorImpl<std::pair<IdentifierInfo *, WeakInfo> > &WeakIDs) {
7332   if (WeakUndeclaredIdentifiers.empty())
7333     return;
7334 
7335   for (unsigned I = 0, N = WeakUndeclaredIdentifiers.size(); I < N; /*none*/) {
7336     IdentifierInfo *WeakId
7337       = DecodeIdentifierInfo(WeakUndeclaredIdentifiers[I++]);
7338     IdentifierInfo *AliasId
7339       = DecodeIdentifierInfo(WeakUndeclaredIdentifiers[I++]);
7340     SourceLocation Loc
7341       = SourceLocation::getFromRawEncoding(WeakUndeclaredIdentifiers[I++]);
7342     bool Used = WeakUndeclaredIdentifiers[I++];
7343     WeakInfo WI(AliasId, Loc);
7344     WI.setUsed(Used);
7345     WeakIDs.push_back(std::make_pair(WeakId, WI));
7346   }
7347   WeakUndeclaredIdentifiers.clear();
7348 }
7349 
ReadUsedVTables(SmallVectorImpl<ExternalVTableUse> & VTables)7350 void ASTReader::ReadUsedVTables(SmallVectorImpl<ExternalVTableUse> &VTables) {
7351   for (unsigned Idx = 0, N = VTableUses.size(); Idx < N; /* In loop */) {
7352     ExternalVTableUse VT;
7353     VT.Record = dyn_cast_or_null<CXXRecordDecl>(GetDecl(VTableUses[Idx++]));
7354     VT.Location = SourceLocation::getFromRawEncoding(VTableUses[Idx++]);
7355     VT.DefinitionRequired = VTableUses[Idx++];
7356     VTables.push_back(VT);
7357   }
7358 
7359   VTableUses.clear();
7360 }
7361 
ReadPendingInstantiations(SmallVectorImpl<std::pair<ValueDecl *,SourceLocation>> & Pending)7362 void ASTReader::ReadPendingInstantiations(
7363        SmallVectorImpl<std::pair<ValueDecl *, SourceLocation> > &Pending) {
7364   for (unsigned Idx = 0, N = PendingInstantiations.size(); Idx < N;) {
7365     ValueDecl *D = cast<ValueDecl>(GetDecl(PendingInstantiations[Idx++]));
7366     SourceLocation Loc
7367       = SourceLocation::getFromRawEncoding(PendingInstantiations[Idx++]);
7368 
7369     Pending.push_back(std::make_pair(D, Loc));
7370   }
7371   PendingInstantiations.clear();
7372 }
7373 
ReadLateParsedTemplates(llvm::MapVector<const FunctionDecl *,LateParsedTemplate * > & LPTMap)7374 void ASTReader::ReadLateParsedTemplates(
7375     llvm::MapVector<const FunctionDecl *, LateParsedTemplate *> &LPTMap) {
7376   for (unsigned Idx = 0, N = LateParsedTemplates.size(); Idx < N;
7377        /* In loop */) {
7378     FunctionDecl *FD = cast<FunctionDecl>(GetDecl(LateParsedTemplates[Idx++]));
7379 
7380     LateParsedTemplate *LT = new LateParsedTemplate;
7381     LT->D = GetDecl(LateParsedTemplates[Idx++]);
7382 
7383     ModuleFile *F = getOwningModuleFile(LT->D);
7384     assert(F && "No module");
7385 
7386     unsigned TokN = LateParsedTemplates[Idx++];
7387     LT->Toks.reserve(TokN);
7388     for (unsigned T = 0; T < TokN; ++T)
7389       LT->Toks.push_back(ReadToken(*F, LateParsedTemplates, Idx));
7390 
7391     LPTMap.insert(std::make_pair(FD, LT));
7392   }
7393 
7394   LateParsedTemplates.clear();
7395 }
7396 
LoadSelector(Selector Sel)7397 void ASTReader::LoadSelector(Selector Sel) {
7398   // It would be complicated to avoid reading the methods anyway. So don't.
7399   ReadMethodPool(Sel);
7400 }
7401 
SetIdentifierInfo(IdentifierID ID,IdentifierInfo * II)7402 void ASTReader::SetIdentifierInfo(IdentifierID ID, IdentifierInfo *II) {
7403   assert(ID && "Non-zero identifier ID required");
7404   assert(ID <= IdentifiersLoaded.size() && "identifier ID out of range");
7405   IdentifiersLoaded[ID - 1] = II;
7406   if (DeserializationListener)
7407     DeserializationListener->IdentifierRead(ID, II);
7408 }
7409 
7410 /// \brief Set the globally-visible declarations associated with the given
7411 /// identifier.
7412 ///
7413 /// If the AST reader is currently in a state where the given declaration IDs
7414 /// cannot safely be resolved, they are queued until it is safe to resolve
7415 /// them.
7416 ///
7417 /// \param II an IdentifierInfo that refers to one or more globally-visible
7418 /// declarations.
7419 ///
7420 /// \param DeclIDs the set of declaration IDs with the name @p II that are
7421 /// visible at global scope.
7422 ///
7423 /// \param Decls if non-null, this vector will be populated with the set of
7424 /// deserialized declarations. These declarations will not be pushed into
7425 /// scope.
7426 void
SetGloballyVisibleDecls(IdentifierInfo * II,const SmallVectorImpl<uint32_t> & DeclIDs,SmallVectorImpl<Decl * > * Decls)7427 ASTReader::SetGloballyVisibleDecls(IdentifierInfo *II,
7428                               const SmallVectorImpl<uint32_t> &DeclIDs,
7429                                    SmallVectorImpl<Decl *> *Decls) {
7430   if (NumCurrentElementsDeserializing && !Decls) {
7431     PendingIdentifierInfos[II].append(DeclIDs.begin(), DeclIDs.end());
7432     return;
7433   }
7434 
7435   for (unsigned I = 0, N = DeclIDs.size(); I != N; ++I) {
7436     if (!SemaObj) {
7437       // Queue this declaration so that it will be added to the
7438       // translation unit scope and identifier's declaration chain
7439       // once a Sema object is known.
7440       PreloadedDeclIDs.push_back(DeclIDs[I]);
7441       continue;
7442     }
7443 
7444     NamedDecl *D = cast<NamedDecl>(GetDecl(DeclIDs[I]));
7445 
7446     // If we're simply supposed to record the declarations, do so now.
7447     if (Decls) {
7448       Decls->push_back(D);
7449       continue;
7450     }
7451 
7452     // Introduce this declaration into the translation-unit scope
7453     // and add it to the declaration chain for this identifier, so
7454     // that (unqualified) name lookup will find it.
7455     pushExternalDeclIntoScope(D, II);
7456   }
7457 }
7458 
DecodeIdentifierInfo(IdentifierID ID)7459 IdentifierInfo *ASTReader::DecodeIdentifierInfo(IdentifierID ID) {
7460   if (ID == 0)
7461     return nullptr;
7462 
7463   if (IdentifiersLoaded.empty()) {
7464     Error("no identifier table in AST file");
7465     return nullptr;
7466   }
7467 
7468   ID -= 1;
7469   if (!IdentifiersLoaded[ID]) {
7470     GlobalIdentifierMapType::iterator I = GlobalIdentifierMap.find(ID + 1);
7471     assert(I != GlobalIdentifierMap.end() && "Corrupted global identifier map");
7472     ModuleFile *M = I->second;
7473     unsigned Index = ID - M->BaseIdentifierID;
7474     const char *Str = M->IdentifierTableData + M->IdentifierOffsets[Index];
7475 
7476     // All of the strings in the AST file are preceded by a 16-bit length.
7477     // Extract that 16-bit length to avoid having to execute strlen().
7478     // NOTE: 'StrLenPtr' is an 'unsigned char*' so that we load bytes as
7479     //  unsigned integers.  This is important to avoid integer overflow when
7480     //  we cast them to 'unsigned'.
7481     const unsigned char *StrLenPtr = (const unsigned char*) Str - 2;
7482     unsigned StrLen = (((unsigned) StrLenPtr[0])
7483                        | (((unsigned) StrLenPtr[1]) << 8)) - 1;
7484     auto &II = PP.getIdentifierTable().get(StringRef(Str, StrLen));
7485     IdentifiersLoaded[ID] = &II;
7486     markIdentifierFromAST(*this,  II);
7487     if (DeserializationListener)
7488       DeserializationListener->IdentifierRead(ID + 1, &II);
7489   }
7490 
7491   return IdentifiersLoaded[ID];
7492 }
7493 
getLocalIdentifier(ModuleFile & M,unsigned LocalID)7494 IdentifierInfo *ASTReader::getLocalIdentifier(ModuleFile &M, unsigned LocalID) {
7495   return DecodeIdentifierInfo(getGlobalIdentifierID(M, LocalID));
7496 }
7497 
getGlobalIdentifierID(ModuleFile & M,unsigned LocalID)7498 IdentifierID ASTReader::getGlobalIdentifierID(ModuleFile &M, unsigned LocalID) {
7499   if (LocalID < NUM_PREDEF_IDENT_IDS)
7500     return LocalID;
7501 
7502   ContinuousRangeMap<uint32_t, int, 2>::iterator I
7503     = M.IdentifierRemap.find(LocalID - NUM_PREDEF_IDENT_IDS);
7504   assert(I != M.IdentifierRemap.end()
7505          && "Invalid index into identifier index remap");
7506 
7507   return LocalID + I->second;
7508 }
7509 
getMacro(MacroID ID)7510 MacroInfo *ASTReader::getMacro(MacroID ID) {
7511   if (ID == 0)
7512     return nullptr;
7513 
7514   if (MacrosLoaded.empty()) {
7515     Error("no macro table in AST file");
7516     return nullptr;
7517   }
7518 
7519   ID -= NUM_PREDEF_MACRO_IDS;
7520   if (!MacrosLoaded[ID]) {
7521     GlobalMacroMapType::iterator I
7522       = GlobalMacroMap.find(ID + NUM_PREDEF_MACRO_IDS);
7523     assert(I != GlobalMacroMap.end() && "Corrupted global macro map");
7524     ModuleFile *M = I->second;
7525     unsigned Index = ID - M->BaseMacroID;
7526     MacrosLoaded[ID] = ReadMacroRecord(*M, M->MacroOffsets[Index]);
7527 
7528     if (DeserializationListener)
7529       DeserializationListener->MacroRead(ID + NUM_PREDEF_MACRO_IDS,
7530                                          MacrosLoaded[ID]);
7531   }
7532 
7533   return MacrosLoaded[ID];
7534 }
7535 
getGlobalMacroID(ModuleFile & M,unsigned LocalID)7536 MacroID ASTReader::getGlobalMacroID(ModuleFile &M, unsigned LocalID) {
7537   if (LocalID < NUM_PREDEF_MACRO_IDS)
7538     return LocalID;
7539 
7540   ContinuousRangeMap<uint32_t, int, 2>::iterator I
7541     = M.MacroRemap.find(LocalID - NUM_PREDEF_MACRO_IDS);
7542   assert(I != M.MacroRemap.end() && "Invalid index into macro index remap");
7543 
7544   return LocalID + I->second;
7545 }
7546 
7547 serialization::SubmoduleID
getGlobalSubmoduleID(ModuleFile & M,unsigned LocalID)7548 ASTReader::getGlobalSubmoduleID(ModuleFile &M, unsigned LocalID) {
7549   if (LocalID < NUM_PREDEF_SUBMODULE_IDS)
7550     return LocalID;
7551 
7552   ContinuousRangeMap<uint32_t, int, 2>::iterator I
7553     = M.SubmoduleRemap.find(LocalID - NUM_PREDEF_SUBMODULE_IDS);
7554   assert(I != M.SubmoduleRemap.end()
7555          && "Invalid index into submodule index remap");
7556 
7557   return LocalID + I->second;
7558 }
7559 
getSubmodule(SubmoduleID GlobalID)7560 Module *ASTReader::getSubmodule(SubmoduleID GlobalID) {
7561   if (GlobalID < NUM_PREDEF_SUBMODULE_IDS) {
7562     assert(GlobalID == 0 && "Unhandled global submodule ID");
7563     return nullptr;
7564   }
7565 
7566   if (GlobalID > SubmodulesLoaded.size()) {
7567     Error("submodule ID out of range in AST file");
7568     return nullptr;
7569   }
7570 
7571   return SubmodulesLoaded[GlobalID - NUM_PREDEF_SUBMODULE_IDS];
7572 }
7573 
getModule(unsigned ID)7574 Module *ASTReader::getModule(unsigned ID) {
7575   return getSubmodule(ID);
7576 }
7577 
getLocalModuleFile(ModuleFile & F,unsigned ID)7578 ModuleFile *ASTReader::getLocalModuleFile(ModuleFile &F, unsigned ID) {
7579   if (ID & 1) {
7580     // It's a module, look it up by submodule ID.
7581     auto I = GlobalSubmoduleMap.find(getGlobalSubmoduleID(F, ID >> 1));
7582     return I == GlobalSubmoduleMap.end() ? nullptr : I->second;
7583   } else {
7584     // It's a prefix (preamble, PCH, ...). Look it up by index.
7585     unsigned IndexFromEnd = ID >> 1;
7586     assert(IndexFromEnd && "got reference to unknown module file");
7587     return getModuleManager().pch_modules().end()[-IndexFromEnd];
7588   }
7589 }
7590 
getModuleFileID(ModuleFile * F)7591 unsigned ASTReader::getModuleFileID(ModuleFile *F) {
7592   if (!F)
7593     return 1;
7594 
7595   // For a file representing a module, use the submodule ID of the top-level
7596   // module as the file ID. For any other kind of file, the number of such
7597   // files loaded beforehand will be the same on reload.
7598   // FIXME: Is this true even if we have an explicit module file and a PCH?
7599   if (F->isModule())
7600     return ((F->BaseSubmoduleID + NUM_PREDEF_SUBMODULE_IDS) << 1) | 1;
7601 
7602   auto PCHModules = getModuleManager().pch_modules();
7603   auto I = std::find(PCHModules.begin(), PCHModules.end(), F);
7604   assert(I != PCHModules.end() && "emitting reference to unknown file");
7605   return (I - PCHModules.end()) << 1;
7606 }
7607 
7608 llvm::Optional<ExternalASTSource::ASTSourceDescriptor>
getSourceDescriptor(unsigned ID)7609 ASTReader::getSourceDescriptor(unsigned ID) {
7610   if (const Module *M = getSubmodule(ID))
7611     return ExternalASTSource::ASTSourceDescriptor(*M);
7612 
7613   // If there is only a single PCH, return it instead.
7614   // Chained PCH are not suported.
7615   if (ModuleMgr.size() == 1) {
7616     ModuleFile &MF = ModuleMgr.getPrimaryModule();
7617     StringRef ModuleName = llvm::sys::path::filename(MF.OriginalSourceFileName);
7618     StringRef FileName = llvm::sys::path::filename(MF.FileName);
7619     return ASTReader::ASTSourceDescriptor(ModuleName, MF.OriginalDir, FileName,
7620                                           MF.Signature);
7621   }
7622   return None;
7623 }
7624 
getLocalSelector(ModuleFile & M,unsigned LocalID)7625 Selector ASTReader::getLocalSelector(ModuleFile &M, unsigned LocalID) {
7626   return DecodeSelector(getGlobalSelectorID(M, LocalID));
7627 }
7628 
DecodeSelector(serialization::SelectorID ID)7629 Selector ASTReader::DecodeSelector(serialization::SelectorID ID) {
7630   if (ID == 0)
7631     return Selector();
7632 
7633   if (ID > SelectorsLoaded.size()) {
7634     Error("selector ID out of range in AST file");
7635     return Selector();
7636   }
7637 
7638   if (SelectorsLoaded[ID - 1].getAsOpaquePtr() == nullptr) {
7639     // Load this selector from the selector table.
7640     GlobalSelectorMapType::iterator I = GlobalSelectorMap.find(ID);
7641     assert(I != GlobalSelectorMap.end() && "Corrupted global selector map");
7642     ModuleFile &M = *I->second;
7643     ASTSelectorLookupTrait Trait(*this, M);
7644     unsigned Idx = ID - M.BaseSelectorID - NUM_PREDEF_SELECTOR_IDS;
7645     SelectorsLoaded[ID - 1] =
7646       Trait.ReadKey(M.SelectorLookupTableData + M.SelectorOffsets[Idx], 0);
7647     if (DeserializationListener)
7648       DeserializationListener->SelectorRead(ID, SelectorsLoaded[ID - 1]);
7649   }
7650 
7651   return SelectorsLoaded[ID - 1];
7652 }
7653 
GetExternalSelector(serialization::SelectorID ID)7654 Selector ASTReader::GetExternalSelector(serialization::SelectorID ID) {
7655   return DecodeSelector(ID);
7656 }
7657 
GetNumExternalSelectors()7658 uint32_t ASTReader::GetNumExternalSelectors() {
7659   // ID 0 (the null selector) is considered an external selector.
7660   return getTotalNumSelectors() + 1;
7661 }
7662 
7663 serialization::SelectorID
getGlobalSelectorID(ModuleFile & M,unsigned LocalID) const7664 ASTReader::getGlobalSelectorID(ModuleFile &M, unsigned LocalID) const {
7665   if (LocalID < NUM_PREDEF_SELECTOR_IDS)
7666     return LocalID;
7667 
7668   ContinuousRangeMap<uint32_t, int, 2>::iterator I
7669     = M.SelectorRemap.find(LocalID - NUM_PREDEF_SELECTOR_IDS);
7670   assert(I != M.SelectorRemap.end()
7671          && "Invalid index into selector index remap");
7672 
7673   return LocalID + I->second;
7674 }
7675 
7676 DeclarationName
ReadDeclarationName(ModuleFile & F,const RecordData & Record,unsigned & Idx)7677 ASTReader::ReadDeclarationName(ModuleFile &F,
7678                                const RecordData &Record, unsigned &Idx) {
7679   DeclarationName::NameKind Kind = (DeclarationName::NameKind)Record[Idx++];
7680   switch (Kind) {
7681   case DeclarationName::Identifier:
7682     return DeclarationName(GetIdentifierInfo(F, Record, Idx));
7683 
7684   case DeclarationName::ObjCZeroArgSelector:
7685   case DeclarationName::ObjCOneArgSelector:
7686   case DeclarationName::ObjCMultiArgSelector:
7687     return DeclarationName(ReadSelector(F, Record, Idx));
7688 
7689   case DeclarationName::CXXConstructorName:
7690     return Context.DeclarationNames.getCXXConstructorName(
7691                           Context.getCanonicalType(readType(F, Record, Idx)));
7692 
7693   case DeclarationName::CXXDestructorName:
7694     return Context.DeclarationNames.getCXXDestructorName(
7695                           Context.getCanonicalType(readType(F, Record, Idx)));
7696 
7697   case DeclarationName::CXXConversionFunctionName:
7698     return Context.DeclarationNames.getCXXConversionFunctionName(
7699                           Context.getCanonicalType(readType(F, Record, Idx)));
7700 
7701   case DeclarationName::CXXOperatorName:
7702     return Context.DeclarationNames.getCXXOperatorName(
7703                                        (OverloadedOperatorKind)Record[Idx++]);
7704 
7705   case DeclarationName::CXXLiteralOperatorName:
7706     return Context.DeclarationNames.getCXXLiteralOperatorName(
7707                                        GetIdentifierInfo(F, Record, Idx));
7708 
7709   case DeclarationName::CXXUsingDirective:
7710     return DeclarationName::getUsingDirectiveName();
7711   }
7712 
7713   llvm_unreachable("Invalid NameKind!");
7714 }
7715 
ReadDeclarationNameLoc(ModuleFile & F,DeclarationNameLoc & DNLoc,DeclarationName Name,const RecordData & Record,unsigned & Idx)7716 void ASTReader::ReadDeclarationNameLoc(ModuleFile &F,
7717                                        DeclarationNameLoc &DNLoc,
7718                                        DeclarationName Name,
7719                                       const RecordData &Record, unsigned &Idx) {
7720   switch (Name.getNameKind()) {
7721   case DeclarationName::CXXConstructorName:
7722   case DeclarationName::CXXDestructorName:
7723   case DeclarationName::CXXConversionFunctionName:
7724     DNLoc.NamedType.TInfo = GetTypeSourceInfo(F, Record, Idx);
7725     break;
7726 
7727   case DeclarationName::CXXOperatorName:
7728     DNLoc.CXXOperatorName.BeginOpNameLoc
7729         = ReadSourceLocation(F, Record, Idx).getRawEncoding();
7730     DNLoc.CXXOperatorName.EndOpNameLoc
7731         = ReadSourceLocation(F, Record, Idx).getRawEncoding();
7732     break;
7733 
7734   case DeclarationName::CXXLiteralOperatorName:
7735     DNLoc.CXXLiteralOperatorName.OpNameLoc
7736         = ReadSourceLocation(F, Record, Idx).getRawEncoding();
7737     break;
7738 
7739   case DeclarationName::Identifier:
7740   case DeclarationName::ObjCZeroArgSelector:
7741   case DeclarationName::ObjCOneArgSelector:
7742   case DeclarationName::ObjCMultiArgSelector:
7743   case DeclarationName::CXXUsingDirective:
7744     break;
7745   }
7746 }
7747 
ReadDeclarationNameInfo(ModuleFile & F,DeclarationNameInfo & NameInfo,const RecordData & Record,unsigned & Idx)7748 void ASTReader::ReadDeclarationNameInfo(ModuleFile &F,
7749                                         DeclarationNameInfo &NameInfo,
7750                                       const RecordData &Record, unsigned &Idx) {
7751   NameInfo.setName(ReadDeclarationName(F, Record, Idx));
7752   NameInfo.setLoc(ReadSourceLocation(F, Record, Idx));
7753   DeclarationNameLoc DNLoc;
7754   ReadDeclarationNameLoc(F, DNLoc, NameInfo.getName(), Record, Idx);
7755   NameInfo.setInfo(DNLoc);
7756 }
7757 
ReadQualifierInfo(ModuleFile & F,QualifierInfo & Info,const RecordData & Record,unsigned & Idx)7758 void ASTReader::ReadQualifierInfo(ModuleFile &F, QualifierInfo &Info,
7759                                   const RecordData &Record, unsigned &Idx) {
7760   Info.QualifierLoc = ReadNestedNameSpecifierLoc(F, Record, Idx);
7761   unsigned NumTPLists = Record[Idx++];
7762   Info.NumTemplParamLists = NumTPLists;
7763   if (NumTPLists) {
7764     Info.TemplParamLists = new (Context) TemplateParameterList*[NumTPLists];
7765     for (unsigned i=0; i != NumTPLists; ++i)
7766       Info.TemplParamLists[i] = ReadTemplateParameterList(F, Record, Idx);
7767   }
7768 }
7769 
7770 TemplateName
ReadTemplateName(ModuleFile & F,const RecordData & Record,unsigned & Idx)7771 ASTReader::ReadTemplateName(ModuleFile &F, const RecordData &Record,
7772                             unsigned &Idx) {
7773   TemplateName::NameKind Kind = (TemplateName::NameKind)Record[Idx++];
7774   switch (Kind) {
7775   case TemplateName::Template:
7776       return TemplateName(ReadDeclAs<TemplateDecl>(F, Record, Idx));
7777 
7778   case TemplateName::OverloadedTemplate: {
7779     unsigned size = Record[Idx++];
7780     UnresolvedSet<8> Decls;
7781     while (size--)
7782       Decls.addDecl(ReadDeclAs<NamedDecl>(F, Record, Idx));
7783 
7784     return Context.getOverloadedTemplateName(Decls.begin(), Decls.end());
7785   }
7786 
7787   case TemplateName::QualifiedTemplate: {
7788     NestedNameSpecifier *NNS = ReadNestedNameSpecifier(F, Record, Idx);
7789     bool hasTemplKeyword = Record[Idx++];
7790     TemplateDecl *Template = ReadDeclAs<TemplateDecl>(F, Record, Idx);
7791     return Context.getQualifiedTemplateName(NNS, hasTemplKeyword, Template);
7792   }
7793 
7794   case TemplateName::DependentTemplate: {
7795     NestedNameSpecifier *NNS = ReadNestedNameSpecifier(F, Record, Idx);
7796     if (Record[Idx++])  // isIdentifier
7797       return Context.getDependentTemplateName(NNS,
7798                                                GetIdentifierInfo(F, Record,
7799                                                                  Idx));
7800     return Context.getDependentTemplateName(NNS,
7801                                          (OverloadedOperatorKind)Record[Idx++]);
7802   }
7803 
7804   case TemplateName::SubstTemplateTemplateParm: {
7805     TemplateTemplateParmDecl *param
7806       = ReadDeclAs<TemplateTemplateParmDecl>(F, Record, Idx);
7807     if (!param) return TemplateName();
7808     TemplateName replacement = ReadTemplateName(F, Record, Idx);
7809     return Context.getSubstTemplateTemplateParm(param, replacement);
7810   }
7811 
7812   case TemplateName::SubstTemplateTemplateParmPack: {
7813     TemplateTemplateParmDecl *Param
7814       = ReadDeclAs<TemplateTemplateParmDecl>(F, Record, Idx);
7815     if (!Param)
7816       return TemplateName();
7817 
7818     TemplateArgument ArgPack = ReadTemplateArgument(F, Record, Idx);
7819     if (ArgPack.getKind() != TemplateArgument::Pack)
7820       return TemplateName();
7821 
7822     return Context.getSubstTemplateTemplateParmPack(Param, ArgPack);
7823   }
7824   }
7825 
7826   llvm_unreachable("Unhandled template name kind!");
7827 }
7828 
ReadTemplateArgument(ModuleFile & F,const RecordData & Record,unsigned & Idx,bool Canonicalize)7829 TemplateArgument ASTReader::ReadTemplateArgument(ModuleFile &F,
7830                                                  const RecordData &Record,
7831                                                  unsigned &Idx,
7832                                                  bool Canonicalize) {
7833   if (Canonicalize) {
7834     // The caller wants a canonical template argument. Sometimes the AST only
7835     // wants template arguments in canonical form (particularly as the template
7836     // argument lists of template specializations) so ensure we preserve that
7837     // canonical form across serialization.
7838     TemplateArgument Arg = ReadTemplateArgument(F, Record, Idx, false);
7839     return Context.getCanonicalTemplateArgument(Arg);
7840   }
7841 
7842   TemplateArgument::ArgKind Kind = (TemplateArgument::ArgKind)Record[Idx++];
7843   switch (Kind) {
7844   case TemplateArgument::Null:
7845     return TemplateArgument();
7846   case TemplateArgument::Type:
7847     return TemplateArgument(readType(F, Record, Idx));
7848   case TemplateArgument::Declaration: {
7849     ValueDecl *D = ReadDeclAs<ValueDecl>(F, Record, Idx);
7850     return TemplateArgument(D, readType(F, Record, Idx));
7851   }
7852   case TemplateArgument::NullPtr:
7853     return TemplateArgument(readType(F, Record, Idx), /*isNullPtr*/true);
7854   case TemplateArgument::Integral: {
7855     llvm::APSInt Value = ReadAPSInt(Record, Idx);
7856     QualType T = readType(F, Record, Idx);
7857     return TemplateArgument(Context, Value, T);
7858   }
7859   case TemplateArgument::Template:
7860     return TemplateArgument(ReadTemplateName(F, Record, Idx));
7861   case TemplateArgument::TemplateExpansion: {
7862     TemplateName Name = ReadTemplateName(F, Record, Idx);
7863     Optional<unsigned> NumTemplateExpansions;
7864     if (unsigned NumExpansions = Record[Idx++])
7865       NumTemplateExpansions = NumExpansions - 1;
7866     return TemplateArgument(Name, NumTemplateExpansions);
7867   }
7868   case TemplateArgument::Expression:
7869     return TemplateArgument(ReadExpr(F));
7870   case TemplateArgument::Pack: {
7871     unsigned NumArgs = Record[Idx++];
7872     TemplateArgument *Args = new (Context) TemplateArgument[NumArgs];
7873     for (unsigned I = 0; I != NumArgs; ++I)
7874       Args[I] = ReadTemplateArgument(F, Record, Idx);
7875     return TemplateArgument(llvm::makeArrayRef(Args, NumArgs));
7876   }
7877   }
7878 
7879   llvm_unreachable("Unhandled template argument kind!");
7880 }
7881 
7882 TemplateParameterList *
ReadTemplateParameterList(ModuleFile & F,const RecordData & Record,unsigned & Idx)7883 ASTReader::ReadTemplateParameterList(ModuleFile &F,
7884                                      const RecordData &Record, unsigned &Idx) {
7885   SourceLocation TemplateLoc = ReadSourceLocation(F, Record, Idx);
7886   SourceLocation LAngleLoc = ReadSourceLocation(F, Record, Idx);
7887   SourceLocation RAngleLoc = ReadSourceLocation(F, Record, Idx);
7888 
7889   unsigned NumParams = Record[Idx++];
7890   SmallVector<NamedDecl *, 16> Params;
7891   Params.reserve(NumParams);
7892   while (NumParams--)
7893     Params.push_back(ReadDeclAs<NamedDecl>(F, Record, Idx));
7894 
7895   TemplateParameterList* TemplateParams =
7896     TemplateParameterList::Create(Context, TemplateLoc, LAngleLoc,
7897                                   Params, RAngleLoc);
7898   return TemplateParams;
7899 }
7900 
7901 void
7902 ASTReader::
ReadTemplateArgumentList(SmallVectorImpl<TemplateArgument> & TemplArgs,ModuleFile & F,const RecordData & Record,unsigned & Idx,bool Canonicalize)7903 ReadTemplateArgumentList(SmallVectorImpl<TemplateArgument> &TemplArgs,
7904                          ModuleFile &F, const RecordData &Record,
7905                          unsigned &Idx, bool Canonicalize) {
7906   unsigned NumTemplateArgs = Record[Idx++];
7907   TemplArgs.reserve(NumTemplateArgs);
7908   while (NumTemplateArgs--)
7909     TemplArgs.push_back(ReadTemplateArgument(F, Record, Idx, Canonicalize));
7910 }
7911 
7912 /// \brief Read a UnresolvedSet structure.
ReadUnresolvedSet(ModuleFile & F,LazyASTUnresolvedSet & Set,const RecordData & Record,unsigned & Idx)7913 void ASTReader::ReadUnresolvedSet(ModuleFile &F, LazyASTUnresolvedSet &Set,
7914                                   const RecordData &Record, unsigned &Idx) {
7915   unsigned NumDecls = Record[Idx++];
7916   Set.reserve(Context, NumDecls);
7917   while (NumDecls--) {
7918     DeclID ID = ReadDeclID(F, Record, Idx);
7919     AccessSpecifier AS = (AccessSpecifier)Record[Idx++];
7920     Set.addLazyDecl(Context, ID, AS);
7921   }
7922 }
7923 
7924 CXXBaseSpecifier
ReadCXXBaseSpecifier(ModuleFile & F,const RecordData & Record,unsigned & Idx)7925 ASTReader::ReadCXXBaseSpecifier(ModuleFile &F,
7926                                 const RecordData &Record, unsigned &Idx) {
7927   bool isVirtual = static_cast<bool>(Record[Idx++]);
7928   bool isBaseOfClass = static_cast<bool>(Record[Idx++]);
7929   AccessSpecifier AS = static_cast<AccessSpecifier>(Record[Idx++]);
7930   bool inheritConstructors = static_cast<bool>(Record[Idx++]);
7931   TypeSourceInfo *TInfo = GetTypeSourceInfo(F, Record, Idx);
7932   SourceRange Range = ReadSourceRange(F, Record, Idx);
7933   SourceLocation EllipsisLoc = ReadSourceLocation(F, Record, Idx);
7934   CXXBaseSpecifier Result(Range, isVirtual, isBaseOfClass, AS, TInfo,
7935                           EllipsisLoc);
7936   Result.setInheritConstructors(inheritConstructors);
7937   return Result;
7938 }
7939 
7940 CXXCtorInitializer **
ReadCXXCtorInitializers(ModuleFile & F,const RecordData & Record,unsigned & Idx)7941 ASTReader::ReadCXXCtorInitializers(ModuleFile &F, const RecordData &Record,
7942                                    unsigned &Idx) {
7943   unsigned NumInitializers = Record[Idx++];
7944   assert(NumInitializers && "wrote ctor initializers but have no inits");
7945   auto **CtorInitializers = new (Context) CXXCtorInitializer*[NumInitializers];
7946   for (unsigned i = 0; i != NumInitializers; ++i) {
7947     TypeSourceInfo *TInfo = nullptr;
7948     bool IsBaseVirtual = false;
7949     FieldDecl *Member = nullptr;
7950     IndirectFieldDecl *IndirectMember = nullptr;
7951 
7952     CtorInitializerType Type = (CtorInitializerType)Record[Idx++];
7953     switch (Type) {
7954     case CTOR_INITIALIZER_BASE:
7955       TInfo = GetTypeSourceInfo(F, Record, Idx);
7956       IsBaseVirtual = Record[Idx++];
7957       break;
7958 
7959     case CTOR_INITIALIZER_DELEGATING:
7960       TInfo = GetTypeSourceInfo(F, Record, Idx);
7961       break;
7962 
7963      case CTOR_INITIALIZER_MEMBER:
7964       Member = ReadDeclAs<FieldDecl>(F, Record, Idx);
7965       break;
7966 
7967      case CTOR_INITIALIZER_INDIRECT_MEMBER:
7968       IndirectMember = ReadDeclAs<IndirectFieldDecl>(F, Record, Idx);
7969       break;
7970     }
7971 
7972     SourceLocation MemberOrEllipsisLoc = ReadSourceLocation(F, Record, Idx);
7973     Expr *Init = ReadExpr(F);
7974     SourceLocation LParenLoc = ReadSourceLocation(F, Record, Idx);
7975     SourceLocation RParenLoc = ReadSourceLocation(F, Record, Idx);
7976     bool IsWritten = Record[Idx++];
7977     unsigned SourceOrderOrNumArrayIndices;
7978     SmallVector<VarDecl *, 8> Indices;
7979     if (IsWritten) {
7980       SourceOrderOrNumArrayIndices = Record[Idx++];
7981     } else {
7982       SourceOrderOrNumArrayIndices = Record[Idx++];
7983       Indices.reserve(SourceOrderOrNumArrayIndices);
7984       for (unsigned i=0; i != SourceOrderOrNumArrayIndices; ++i)
7985         Indices.push_back(ReadDeclAs<VarDecl>(F, Record, Idx));
7986     }
7987 
7988     CXXCtorInitializer *BOMInit;
7989     if (Type == CTOR_INITIALIZER_BASE) {
7990       BOMInit = new (Context)
7991           CXXCtorInitializer(Context, TInfo, IsBaseVirtual, LParenLoc, Init,
7992                              RParenLoc, MemberOrEllipsisLoc);
7993     } else if (Type == CTOR_INITIALIZER_DELEGATING) {
7994       BOMInit = new (Context)
7995           CXXCtorInitializer(Context, TInfo, LParenLoc, Init, RParenLoc);
7996     } else if (IsWritten) {
7997       if (Member)
7998         BOMInit = new (Context) CXXCtorInitializer(
7999             Context, Member, MemberOrEllipsisLoc, LParenLoc, Init, RParenLoc);
8000       else
8001         BOMInit = new (Context)
8002             CXXCtorInitializer(Context, IndirectMember, MemberOrEllipsisLoc,
8003                                LParenLoc, Init, RParenLoc);
8004     } else {
8005       if (IndirectMember) {
8006         assert(Indices.empty() && "Indirect field improperly initialized");
8007         BOMInit = new (Context)
8008             CXXCtorInitializer(Context, IndirectMember, MemberOrEllipsisLoc,
8009                                LParenLoc, Init, RParenLoc);
8010       } else {
8011         BOMInit = CXXCtorInitializer::Create(
8012             Context, Member, MemberOrEllipsisLoc, LParenLoc, Init, RParenLoc,
8013             Indices.data(), Indices.size());
8014       }
8015     }
8016 
8017     if (IsWritten)
8018       BOMInit->setSourceOrder(SourceOrderOrNumArrayIndices);
8019     CtorInitializers[i] = BOMInit;
8020   }
8021 
8022   return CtorInitializers;
8023 }
8024 
8025 NestedNameSpecifier *
ReadNestedNameSpecifier(ModuleFile & F,const RecordData & Record,unsigned & Idx)8026 ASTReader::ReadNestedNameSpecifier(ModuleFile &F,
8027                                    const RecordData &Record, unsigned &Idx) {
8028   unsigned N = Record[Idx++];
8029   NestedNameSpecifier *NNS = nullptr, *Prev = nullptr;
8030   for (unsigned I = 0; I != N; ++I) {
8031     NestedNameSpecifier::SpecifierKind Kind
8032       = (NestedNameSpecifier::SpecifierKind)Record[Idx++];
8033     switch (Kind) {
8034     case NestedNameSpecifier::Identifier: {
8035       IdentifierInfo *II = GetIdentifierInfo(F, Record, Idx);
8036       NNS = NestedNameSpecifier::Create(Context, Prev, II);
8037       break;
8038     }
8039 
8040     case NestedNameSpecifier::Namespace: {
8041       NamespaceDecl *NS = ReadDeclAs<NamespaceDecl>(F, Record, Idx);
8042       NNS = NestedNameSpecifier::Create(Context, Prev, NS);
8043       break;
8044     }
8045 
8046     case NestedNameSpecifier::NamespaceAlias: {
8047       NamespaceAliasDecl *Alias =ReadDeclAs<NamespaceAliasDecl>(F, Record, Idx);
8048       NNS = NestedNameSpecifier::Create(Context, Prev, Alias);
8049       break;
8050     }
8051 
8052     case NestedNameSpecifier::TypeSpec:
8053     case NestedNameSpecifier::TypeSpecWithTemplate: {
8054       const Type *T = readType(F, Record, Idx).getTypePtrOrNull();
8055       if (!T)
8056         return nullptr;
8057 
8058       bool Template = Record[Idx++];
8059       NNS = NestedNameSpecifier::Create(Context, Prev, Template, T);
8060       break;
8061     }
8062 
8063     case NestedNameSpecifier::Global: {
8064       NNS = NestedNameSpecifier::GlobalSpecifier(Context);
8065       // No associated value, and there can't be a prefix.
8066       break;
8067     }
8068 
8069     case NestedNameSpecifier::Super: {
8070       CXXRecordDecl *RD = ReadDeclAs<CXXRecordDecl>(F, Record, Idx);
8071       NNS = NestedNameSpecifier::SuperSpecifier(Context, RD);
8072       break;
8073     }
8074     }
8075     Prev = NNS;
8076   }
8077   return NNS;
8078 }
8079 
8080 NestedNameSpecifierLoc
ReadNestedNameSpecifierLoc(ModuleFile & F,const RecordData & Record,unsigned & Idx)8081 ASTReader::ReadNestedNameSpecifierLoc(ModuleFile &F, const RecordData &Record,
8082                                       unsigned &Idx) {
8083   unsigned N = Record[Idx++];
8084   NestedNameSpecifierLocBuilder Builder;
8085   for (unsigned I = 0; I != N; ++I) {
8086     NestedNameSpecifier::SpecifierKind Kind
8087       = (NestedNameSpecifier::SpecifierKind)Record[Idx++];
8088     switch (Kind) {
8089     case NestedNameSpecifier::Identifier: {
8090       IdentifierInfo *II = GetIdentifierInfo(F, Record, Idx);
8091       SourceRange Range = ReadSourceRange(F, Record, Idx);
8092       Builder.Extend(Context, II, Range.getBegin(), Range.getEnd());
8093       break;
8094     }
8095 
8096     case NestedNameSpecifier::Namespace: {
8097       NamespaceDecl *NS = ReadDeclAs<NamespaceDecl>(F, Record, Idx);
8098       SourceRange Range = ReadSourceRange(F, Record, Idx);
8099       Builder.Extend(Context, NS, Range.getBegin(), Range.getEnd());
8100       break;
8101     }
8102 
8103     case NestedNameSpecifier::NamespaceAlias: {
8104       NamespaceAliasDecl *Alias =ReadDeclAs<NamespaceAliasDecl>(F, Record, Idx);
8105       SourceRange Range = ReadSourceRange(F, Record, Idx);
8106       Builder.Extend(Context, Alias, Range.getBegin(), Range.getEnd());
8107       break;
8108     }
8109 
8110     case NestedNameSpecifier::TypeSpec:
8111     case NestedNameSpecifier::TypeSpecWithTemplate: {
8112       bool Template = Record[Idx++];
8113       TypeSourceInfo *T = GetTypeSourceInfo(F, Record, Idx);
8114       if (!T)
8115         return NestedNameSpecifierLoc();
8116       SourceLocation ColonColonLoc = ReadSourceLocation(F, Record, Idx);
8117 
8118       // FIXME: 'template' keyword location not saved anywhere, so we fake it.
8119       Builder.Extend(Context,
8120                      Template? T->getTypeLoc().getBeginLoc() : SourceLocation(),
8121                      T->getTypeLoc(), ColonColonLoc);
8122       break;
8123     }
8124 
8125     case NestedNameSpecifier::Global: {
8126       SourceLocation ColonColonLoc = ReadSourceLocation(F, Record, Idx);
8127       Builder.MakeGlobal(Context, ColonColonLoc);
8128       break;
8129     }
8130 
8131     case NestedNameSpecifier::Super: {
8132       CXXRecordDecl *RD = ReadDeclAs<CXXRecordDecl>(F, Record, Idx);
8133       SourceRange Range = ReadSourceRange(F, Record, Idx);
8134       Builder.MakeSuper(Context, RD, Range.getBegin(), Range.getEnd());
8135       break;
8136     }
8137     }
8138   }
8139 
8140   return Builder.getWithLocInContext(Context);
8141 }
8142 
8143 SourceRange
ReadSourceRange(ModuleFile & F,const RecordData & Record,unsigned & Idx)8144 ASTReader::ReadSourceRange(ModuleFile &F, const RecordData &Record,
8145                            unsigned &Idx) {
8146   SourceLocation beg = ReadSourceLocation(F, Record, Idx);
8147   SourceLocation end = ReadSourceLocation(F, Record, Idx);
8148   return SourceRange(beg, end);
8149 }
8150 
8151 /// \brief Read an integral value
ReadAPInt(const RecordData & Record,unsigned & Idx)8152 llvm::APInt ASTReader::ReadAPInt(const RecordData &Record, unsigned &Idx) {
8153   unsigned BitWidth = Record[Idx++];
8154   unsigned NumWords = llvm::APInt::getNumWords(BitWidth);
8155   llvm::APInt Result(BitWidth, NumWords, &Record[Idx]);
8156   Idx += NumWords;
8157   return Result;
8158 }
8159 
8160 /// \brief Read a signed integral value
ReadAPSInt(const RecordData & Record,unsigned & Idx)8161 llvm::APSInt ASTReader::ReadAPSInt(const RecordData &Record, unsigned &Idx) {
8162   bool isUnsigned = Record[Idx++];
8163   return llvm::APSInt(ReadAPInt(Record, Idx), isUnsigned);
8164 }
8165 
8166 /// \brief Read a floating-point value
ReadAPFloat(const RecordData & Record,const llvm::fltSemantics & Sem,unsigned & Idx)8167 llvm::APFloat ASTReader::ReadAPFloat(const RecordData &Record,
8168                                      const llvm::fltSemantics &Sem,
8169                                      unsigned &Idx) {
8170   return llvm::APFloat(Sem, ReadAPInt(Record, Idx));
8171 }
8172 
8173 // \brief Read a string
ReadString(const RecordData & Record,unsigned & Idx)8174 std::string ASTReader::ReadString(const RecordData &Record, unsigned &Idx) {
8175   unsigned Len = Record[Idx++];
8176   std::string Result(Record.data() + Idx, Record.data() + Idx + Len);
8177   Idx += Len;
8178   return Result;
8179 }
8180 
ReadPath(ModuleFile & F,const RecordData & Record,unsigned & Idx)8181 std::string ASTReader::ReadPath(ModuleFile &F, const RecordData &Record,
8182                                 unsigned &Idx) {
8183   std::string Filename = ReadString(Record, Idx);
8184   ResolveImportedPath(F, Filename);
8185   return Filename;
8186 }
8187 
ReadVersionTuple(const RecordData & Record,unsigned & Idx)8188 VersionTuple ASTReader::ReadVersionTuple(const RecordData &Record,
8189                                          unsigned &Idx) {
8190   unsigned Major = Record[Idx++];
8191   unsigned Minor = Record[Idx++];
8192   unsigned Subminor = Record[Idx++];
8193   if (Minor == 0)
8194     return VersionTuple(Major);
8195   if (Subminor == 0)
8196     return VersionTuple(Major, Minor - 1);
8197   return VersionTuple(Major, Minor - 1, Subminor - 1);
8198 }
8199 
ReadCXXTemporary(ModuleFile & F,const RecordData & Record,unsigned & Idx)8200 CXXTemporary *ASTReader::ReadCXXTemporary(ModuleFile &F,
8201                                           const RecordData &Record,
8202                                           unsigned &Idx) {
8203   CXXDestructorDecl *Decl = ReadDeclAs<CXXDestructorDecl>(F, Record, Idx);
8204   return CXXTemporary::Create(Context, Decl);
8205 }
8206 
Diag(unsigned DiagID)8207 DiagnosticBuilder ASTReader::Diag(unsigned DiagID) {
8208   return Diag(CurrentImportLoc, DiagID);
8209 }
8210 
Diag(SourceLocation Loc,unsigned DiagID)8211 DiagnosticBuilder ASTReader::Diag(SourceLocation Loc, unsigned DiagID) {
8212   return Diags.Report(Loc, DiagID);
8213 }
8214 
8215 /// \brief Retrieve the identifier table associated with the
8216 /// preprocessor.
getIdentifierTable()8217 IdentifierTable &ASTReader::getIdentifierTable() {
8218   return PP.getIdentifierTable();
8219 }
8220 
8221 /// \brief Record that the given ID maps to the given switch-case
8222 /// statement.
RecordSwitchCaseID(SwitchCase * SC,unsigned ID)8223 void ASTReader::RecordSwitchCaseID(SwitchCase *SC, unsigned ID) {
8224   assert((*CurrSwitchCaseStmts)[ID] == nullptr &&
8225          "Already have a SwitchCase with this ID");
8226   (*CurrSwitchCaseStmts)[ID] = SC;
8227 }
8228 
8229 /// \brief Retrieve the switch-case statement with the given ID.
getSwitchCaseWithID(unsigned ID)8230 SwitchCase *ASTReader::getSwitchCaseWithID(unsigned ID) {
8231   assert((*CurrSwitchCaseStmts)[ID] != nullptr && "No SwitchCase with this ID");
8232   return (*CurrSwitchCaseStmts)[ID];
8233 }
8234 
ClearSwitchCaseIDs()8235 void ASTReader::ClearSwitchCaseIDs() {
8236   CurrSwitchCaseStmts->clear();
8237 }
8238 
ReadComments()8239 void ASTReader::ReadComments() {
8240   std::vector<RawComment *> Comments;
8241   for (SmallVectorImpl<std::pair<BitstreamCursor,
8242                                  serialization::ModuleFile *> >::iterator
8243        I = CommentsCursors.begin(),
8244        E = CommentsCursors.end();
8245        I != E; ++I) {
8246     Comments.clear();
8247     BitstreamCursor &Cursor = I->first;
8248     serialization::ModuleFile &F = *I->second;
8249     SavedStreamPosition SavedPosition(Cursor);
8250 
8251     RecordData Record;
8252     while (true) {
8253       llvm::BitstreamEntry Entry =
8254         Cursor.advanceSkippingSubblocks(BitstreamCursor::AF_DontPopBlockAtEnd);
8255 
8256       switch (Entry.Kind) {
8257       case llvm::BitstreamEntry::SubBlock: // Handled for us already.
8258       case llvm::BitstreamEntry::Error:
8259         Error("malformed block record in AST file");
8260         return;
8261       case llvm::BitstreamEntry::EndBlock:
8262         goto NextCursor;
8263       case llvm::BitstreamEntry::Record:
8264         // The interesting case.
8265         break;
8266       }
8267 
8268       // Read a record.
8269       Record.clear();
8270       switch ((CommentRecordTypes)Cursor.readRecord(Entry.ID, Record)) {
8271       case COMMENTS_RAW_COMMENT: {
8272         unsigned Idx = 0;
8273         SourceRange SR = ReadSourceRange(F, Record, Idx);
8274         RawComment::CommentKind Kind =
8275             (RawComment::CommentKind) Record[Idx++];
8276         bool IsTrailingComment = Record[Idx++];
8277         bool IsAlmostTrailingComment = Record[Idx++];
8278         Comments.push_back(new (Context) RawComment(
8279             SR, Kind, IsTrailingComment, IsAlmostTrailingComment,
8280             Context.getLangOpts().CommentOpts.ParseAllComments));
8281         break;
8282       }
8283       }
8284     }
8285   NextCursor:
8286     Context.Comments.addDeserializedComments(Comments);
8287   }
8288 }
8289 
getOwningModuleNameForDiagnostic(const Decl * D)8290 std::string ASTReader::getOwningModuleNameForDiagnostic(const Decl *D) {
8291   // If we know the owning module, use it.
8292   if (Module *M = D->getImportedOwningModule())
8293     return M->getFullModuleName();
8294 
8295   // Otherwise, use the name of the top-level module the decl is within.
8296   if (ModuleFile *M = getOwningModuleFile(D))
8297     return M->ModuleName;
8298 
8299   // Not from a module.
8300   return "";
8301 }
8302 
finishPendingActions()8303 void ASTReader::finishPendingActions() {
8304   while (!PendingIdentifierInfos.empty() ||
8305          !PendingIncompleteDeclChains.empty() || !PendingDeclChains.empty() ||
8306          !PendingMacroIDs.empty() || !PendingDeclContextInfos.empty() ||
8307          !PendingUpdateRecords.empty()) {
8308     // If any identifiers with corresponding top-level declarations have
8309     // been loaded, load those declarations now.
8310     typedef llvm::DenseMap<IdentifierInfo *, SmallVector<Decl *, 2> >
8311       TopLevelDeclsMap;
8312     TopLevelDeclsMap TopLevelDecls;
8313 
8314     while (!PendingIdentifierInfos.empty()) {
8315       IdentifierInfo *II = PendingIdentifierInfos.back().first;
8316       SmallVector<uint32_t, 4> DeclIDs =
8317           std::move(PendingIdentifierInfos.back().second);
8318       PendingIdentifierInfos.pop_back();
8319 
8320       SetGloballyVisibleDecls(II, DeclIDs, &TopLevelDecls[II]);
8321     }
8322 
8323     // For each decl chain that we wanted to complete while deserializing, mark
8324     // it as "still needs to be completed".
8325     for (unsigned I = 0; I != PendingIncompleteDeclChains.size(); ++I) {
8326       markIncompleteDeclChain(PendingIncompleteDeclChains[I]);
8327     }
8328     PendingIncompleteDeclChains.clear();
8329 
8330     // Load pending declaration chains.
8331     for (unsigned I = 0; I != PendingDeclChains.size(); ++I)
8332       loadPendingDeclChain(PendingDeclChains[I].first, PendingDeclChains[I].second);
8333     PendingDeclChains.clear();
8334 
8335     // Make the most recent of the top-level declarations visible.
8336     for (TopLevelDeclsMap::iterator TLD = TopLevelDecls.begin(),
8337            TLDEnd = TopLevelDecls.end(); TLD != TLDEnd; ++TLD) {
8338       IdentifierInfo *II = TLD->first;
8339       for (unsigned I = 0, N = TLD->second.size(); I != N; ++I) {
8340         pushExternalDeclIntoScope(cast<NamedDecl>(TLD->second[I]), II);
8341       }
8342     }
8343 
8344     // Load any pending macro definitions.
8345     for (unsigned I = 0; I != PendingMacroIDs.size(); ++I) {
8346       IdentifierInfo *II = PendingMacroIDs.begin()[I].first;
8347       SmallVector<PendingMacroInfo, 2> GlobalIDs;
8348       GlobalIDs.swap(PendingMacroIDs.begin()[I].second);
8349       // Initialize the macro history from chained-PCHs ahead of module imports.
8350       for (unsigned IDIdx = 0, NumIDs = GlobalIDs.size(); IDIdx != NumIDs;
8351            ++IDIdx) {
8352         const PendingMacroInfo &Info = GlobalIDs[IDIdx];
8353         if (Info.M->Kind != MK_ImplicitModule &&
8354             Info.M->Kind != MK_ExplicitModule)
8355           resolvePendingMacro(II, Info);
8356       }
8357       // Handle module imports.
8358       for (unsigned IDIdx = 0, NumIDs = GlobalIDs.size(); IDIdx != NumIDs;
8359            ++IDIdx) {
8360         const PendingMacroInfo &Info = GlobalIDs[IDIdx];
8361         if (Info.M->Kind == MK_ImplicitModule ||
8362             Info.M->Kind == MK_ExplicitModule)
8363           resolvePendingMacro(II, Info);
8364       }
8365     }
8366     PendingMacroIDs.clear();
8367 
8368     // Wire up the DeclContexts for Decls that we delayed setting until
8369     // recursive loading is completed.
8370     while (!PendingDeclContextInfos.empty()) {
8371       PendingDeclContextInfo Info = PendingDeclContextInfos.front();
8372       PendingDeclContextInfos.pop_front();
8373       DeclContext *SemaDC = cast<DeclContext>(GetDecl(Info.SemaDC));
8374       DeclContext *LexicalDC = cast<DeclContext>(GetDecl(Info.LexicalDC));
8375       Info.D->setDeclContextsImpl(SemaDC, LexicalDC, getContext());
8376     }
8377 
8378     // Perform any pending declaration updates.
8379     while (!PendingUpdateRecords.empty()) {
8380       auto Update = PendingUpdateRecords.pop_back_val();
8381       ReadingKindTracker ReadingKind(Read_Decl, *this);
8382       loadDeclUpdateRecords(Update.first, Update.second);
8383     }
8384   }
8385 
8386   // At this point, all update records for loaded decls are in place, so any
8387   // fake class definitions should have become real.
8388   assert(PendingFakeDefinitionData.empty() &&
8389          "faked up a class definition but never saw the real one");
8390 
8391   // If we deserialized any C++ or Objective-C class definitions, any
8392   // Objective-C protocol definitions, or any redeclarable templates, make sure
8393   // that all redeclarations point to the definitions. Note that this can only
8394   // happen now, after the redeclaration chains have been fully wired.
8395   for (Decl *D : PendingDefinitions) {
8396     if (TagDecl *TD = dyn_cast<TagDecl>(D)) {
8397       if (const TagType *TagT = dyn_cast<TagType>(TD->getTypeForDecl())) {
8398         // Make sure that the TagType points at the definition.
8399         const_cast<TagType*>(TagT)->decl = TD;
8400       }
8401 
8402       if (auto RD = dyn_cast<CXXRecordDecl>(D)) {
8403         for (auto *R = getMostRecentExistingDecl(RD); R;
8404              R = R->getPreviousDecl()) {
8405           assert((R == D) ==
8406                      cast<CXXRecordDecl>(R)->isThisDeclarationADefinition() &&
8407                  "declaration thinks it's the definition but it isn't");
8408           cast<CXXRecordDecl>(R)->DefinitionData = RD->DefinitionData;
8409         }
8410       }
8411 
8412       continue;
8413     }
8414 
8415     if (auto ID = dyn_cast<ObjCInterfaceDecl>(D)) {
8416       // Make sure that the ObjCInterfaceType points at the definition.
8417       const_cast<ObjCInterfaceType *>(cast<ObjCInterfaceType>(ID->TypeForDecl))
8418         ->Decl = ID;
8419 
8420       for (auto *R = getMostRecentExistingDecl(ID); R; R = R->getPreviousDecl())
8421         cast<ObjCInterfaceDecl>(R)->Data = ID->Data;
8422 
8423       continue;
8424     }
8425 
8426     if (auto PD = dyn_cast<ObjCProtocolDecl>(D)) {
8427       for (auto *R = getMostRecentExistingDecl(PD); R; R = R->getPreviousDecl())
8428         cast<ObjCProtocolDecl>(R)->Data = PD->Data;
8429 
8430       continue;
8431     }
8432 
8433     auto RTD = cast<RedeclarableTemplateDecl>(D)->getCanonicalDecl();
8434     for (auto *R = getMostRecentExistingDecl(RTD); R; R = R->getPreviousDecl())
8435       cast<RedeclarableTemplateDecl>(R)->Common = RTD->Common;
8436   }
8437   PendingDefinitions.clear();
8438 
8439   // Load the bodies of any functions or methods we've encountered. We do
8440   // this now (delayed) so that we can be sure that the declaration chains
8441   // have been fully wired up (hasBody relies on this).
8442   // FIXME: We shouldn't require complete redeclaration chains here.
8443   for (PendingBodiesMap::iterator PB = PendingBodies.begin(),
8444                                PBEnd = PendingBodies.end();
8445        PB != PBEnd; ++PB) {
8446     if (FunctionDecl *FD = dyn_cast<FunctionDecl>(PB->first)) {
8447       // FIXME: Check for =delete/=default?
8448       // FIXME: Complain about ODR violations here?
8449       if (!getContext().getLangOpts().Modules || !FD->hasBody())
8450         FD->setLazyBody(PB->second);
8451       continue;
8452     }
8453 
8454     ObjCMethodDecl *MD = cast<ObjCMethodDecl>(PB->first);
8455     if (!getContext().getLangOpts().Modules || !MD->hasBody())
8456       MD->setLazyBody(PB->second);
8457   }
8458   PendingBodies.clear();
8459 
8460   // Do some cleanup.
8461   for (auto *ND : PendingMergedDefinitionsToDeduplicate)
8462     getContext().deduplicateMergedDefinitonsFor(ND);
8463   PendingMergedDefinitionsToDeduplicate.clear();
8464 }
8465 
diagnoseOdrViolations()8466 void ASTReader::diagnoseOdrViolations() {
8467   if (PendingOdrMergeFailures.empty() && PendingOdrMergeChecks.empty())
8468     return;
8469 
8470   // Trigger the import of the full definition of each class that had any
8471   // odr-merging problems, so we can produce better diagnostics for them.
8472   // These updates may in turn find and diagnose some ODR failures, so take
8473   // ownership of the set first.
8474   auto OdrMergeFailures = std::move(PendingOdrMergeFailures);
8475   PendingOdrMergeFailures.clear();
8476   for (auto &Merge : OdrMergeFailures) {
8477     Merge.first->buildLookup();
8478     Merge.first->decls_begin();
8479     Merge.first->bases_begin();
8480     Merge.first->vbases_begin();
8481     for (auto *RD : Merge.second) {
8482       RD->decls_begin();
8483       RD->bases_begin();
8484       RD->vbases_begin();
8485     }
8486   }
8487 
8488   // For each declaration from a merged context, check that the canonical
8489   // definition of that context also contains a declaration of the same
8490   // entity.
8491   //
8492   // Caution: this loop does things that might invalidate iterators into
8493   // PendingOdrMergeChecks. Don't turn this into a range-based for loop!
8494   while (!PendingOdrMergeChecks.empty()) {
8495     NamedDecl *D = PendingOdrMergeChecks.pop_back_val();
8496 
8497     // FIXME: Skip over implicit declarations for now. This matters for things
8498     // like implicitly-declared special member functions. This isn't entirely
8499     // correct; we can end up with multiple unmerged declarations of the same
8500     // implicit entity.
8501     if (D->isImplicit())
8502       continue;
8503 
8504     DeclContext *CanonDef = D->getDeclContext();
8505 
8506     bool Found = false;
8507     const Decl *DCanon = D->getCanonicalDecl();
8508 
8509     for (auto RI : D->redecls()) {
8510       if (RI->getLexicalDeclContext() == CanonDef) {
8511         Found = true;
8512         break;
8513       }
8514     }
8515     if (Found)
8516       continue;
8517 
8518     // Quick check failed, time to do the slow thing. Note, we can't just
8519     // look up the name of D in CanonDef here, because the member that is
8520     // in CanonDef might not be found by name lookup (it might have been
8521     // replaced by a more recent declaration in the lookup table), and we
8522     // can't necessarily find it in the redeclaration chain because it might
8523     // be merely mergeable, not redeclarable.
8524     llvm::SmallVector<const NamedDecl*, 4> Candidates;
8525     for (auto *CanonMember : CanonDef->decls()) {
8526       if (CanonMember->getCanonicalDecl() == DCanon) {
8527         // This can happen if the declaration is merely mergeable and not
8528         // actually redeclarable (we looked for redeclarations earlier).
8529         //
8530         // FIXME: We should be able to detect this more efficiently, without
8531         // pulling in all of the members of CanonDef.
8532         Found = true;
8533         break;
8534       }
8535       if (auto *ND = dyn_cast<NamedDecl>(CanonMember))
8536         if (ND->getDeclName() == D->getDeclName())
8537           Candidates.push_back(ND);
8538     }
8539 
8540     if (!Found) {
8541       // The AST doesn't like TagDecls becoming invalid after they've been
8542       // completed. We only really need to mark FieldDecls as invalid here.
8543       if (!isa<TagDecl>(D))
8544         D->setInvalidDecl();
8545 
8546       // Ensure we don't accidentally recursively enter deserialization while
8547       // we're producing our diagnostic.
8548       Deserializing RecursionGuard(this);
8549 
8550       std::string CanonDefModule =
8551           getOwningModuleNameForDiagnostic(cast<Decl>(CanonDef));
8552       Diag(D->getLocation(), diag::err_module_odr_violation_missing_decl)
8553         << D << getOwningModuleNameForDiagnostic(D)
8554         << CanonDef << CanonDefModule.empty() << CanonDefModule;
8555 
8556       if (Candidates.empty())
8557         Diag(cast<Decl>(CanonDef)->getLocation(),
8558              diag::note_module_odr_violation_no_possible_decls) << D;
8559       else {
8560         for (unsigned I = 0, N = Candidates.size(); I != N; ++I)
8561           Diag(Candidates[I]->getLocation(),
8562                diag::note_module_odr_violation_possible_decl)
8563             << Candidates[I];
8564       }
8565 
8566       DiagnosedOdrMergeFailures.insert(CanonDef);
8567     }
8568   }
8569 
8570   if (OdrMergeFailures.empty())
8571     return;
8572 
8573   // Ensure we don't accidentally recursively enter deserialization while
8574   // we're producing our diagnostics.
8575   Deserializing RecursionGuard(this);
8576 
8577   // Issue any pending ODR-failure diagnostics.
8578   for (auto &Merge : OdrMergeFailures) {
8579     // If we've already pointed out a specific problem with this class, don't
8580     // bother issuing a general "something's different" diagnostic.
8581     if (!DiagnosedOdrMergeFailures.insert(Merge.first).second)
8582       continue;
8583 
8584     bool Diagnosed = false;
8585     for (auto *RD : Merge.second) {
8586       // Multiple different declarations got merged together; tell the user
8587       // where they came from.
8588       if (Merge.first != RD) {
8589         // FIXME: Walk the definition, figure out what's different,
8590         // and diagnose that.
8591         if (!Diagnosed) {
8592           std::string Module = getOwningModuleNameForDiagnostic(Merge.first);
8593           Diag(Merge.first->getLocation(),
8594                diag::err_module_odr_violation_different_definitions)
8595             << Merge.first << Module.empty() << Module;
8596           Diagnosed = true;
8597         }
8598 
8599         Diag(RD->getLocation(),
8600              diag::note_module_odr_violation_different_definitions)
8601           << getOwningModuleNameForDiagnostic(RD);
8602       }
8603     }
8604 
8605     if (!Diagnosed) {
8606       // All definitions are updates to the same declaration. This happens if a
8607       // module instantiates the declaration of a class template specialization
8608       // and two or more other modules instantiate its definition.
8609       //
8610       // FIXME: Indicate which modules had instantiations of this definition.
8611       // FIXME: How can this even happen?
8612       Diag(Merge.first->getLocation(),
8613            diag::err_module_odr_violation_different_instantiations)
8614         << Merge.first;
8615     }
8616   }
8617 }
8618 
StartedDeserializing()8619 void ASTReader::StartedDeserializing() {
8620   if (++NumCurrentElementsDeserializing == 1 && ReadTimer.get())
8621     ReadTimer->startTimer();
8622 }
8623 
FinishedDeserializing()8624 void ASTReader::FinishedDeserializing() {
8625   assert(NumCurrentElementsDeserializing &&
8626          "FinishedDeserializing not paired with StartedDeserializing");
8627   if (NumCurrentElementsDeserializing == 1) {
8628     // We decrease NumCurrentElementsDeserializing only after pending actions
8629     // are finished, to avoid recursively re-calling finishPendingActions().
8630     finishPendingActions();
8631   }
8632   --NumCurrentElementsDeserializing;
8633 
8634   if (NumCurrentElementsDeserializing == 0) {
8635     // Propagate exception specification updates along redeclaration chains.
8636     while (!PendingExceptionSpecUpdates.empty()) {
8637       auto Updates = std::move(PendingExceptionSpecUpdates);
8638       PendingExceptionSpecUpdates.clear();
8639       for (auto Update : Updates) {
8640         auto *FPT = Update.second->getType()->castAs<FunctionProtoType>();
8641         auto ESI = FPT->getExtProtoInfo().ExceptionSpec;
8642         if (auto *Listener = Context.getASTMutationListener())
8643           Listener->ResolvedExceptionSpec(cast<FunctionDecl>(Update.second));
8644         for (auto *Redecl : Update.second->redecls())
8645           Context.adjustExceptionSpec(cast<FunctionDecl>(Redecl), ESI);
8646       }
8647     }
8648 
8649     if (ReadTimer)
8650       ReadTimer->stopTimer();
8651 
8652     diagnoseOdrViolations();
8653 
8654     // We are not in recursive loading, so it's safe to pass the "interesting"
8655     // decls to the consumer.
8656     if (Consumer)
8657       PassInterestingDeclsToConsumer();
8658   }
8659 }
8660 
pushExternalDeclIntoScope(NamedDecl * D,DeclarationName Name)8661 void ASTReader::pushExternalDeclIntoScope(NamedDecl *D, DeclarationName Name) {
8662   if (IdentifierInfo *II = Name.getAsIdentifierInfo()) {
8663     // Remove any fake results before adding any real ones.
8664     auto It = PendingFakeLookupResults.find(II);
8665     if (It != PendingFakeLookupResults.end()) {
8666       for (auto *ND : It->second)
8667         SemaObj->IdResolver.RemoveDecl(ND);
8668       // FIXME: this works around module+PCH performance issue.
8669       // Rather than erase the result from the map, which is O(n), just clear
8670       // the vector of NamedDecls.
8671       It->second.clear();
8672     }
8673   }
8674 
8675   if (SemaObj->IdResolver.tryAddTopLevelDecl(D, Name) && SemaObj->TUScope) {
8676     SemaObj->TUScope->AddDecl(D);
8677   } else if (SemaObj->TUScope) {
8678     // Adding the decl to IdResolver may have failed because it was already in
8679     // (even though it was not added in scope). If it is already in, make sure
8680     // it gets in the scope as well.
8681     if (std::find(SemaObj->IdResolver.begin(Name),
8682                   SemaObj->IdResolver.end(), D) != SemaObj->IdResolver.end())
8683       SemaObj->TUScope->AddDecl(D);
8684   }
8685 }
8686 
ASTReader(Preprocessor & PP,ASTContext & Context,const PCHContainerReader & PCHContainerRdr,ArrayRef<IntrusiveRefCntPtr<ModuleFileExtension>> Extensions,StringRef isysroot,bool DisableValidation,bool AllowASTWithCompilerErrors,bool AllowConfigurationMismatch,bool ValidateSystemInputs,bool UseGlobalIndex,std::unique_ptr<llvm::Timer> ReadTimer)8687 ASTReader::ASTReader(
8688   Preprocessor &PP, ASTContext &Context,
8689   const PCHContainerReader &PCHContainerRdr,
8690   ArrayRef<IntrusiveRefCntPtr<ModuleFileExtension>> Extensions,
8691   StringRef isysroot, bool DisableValidation,
8692   bool AllowASTWithCompilerErrors,
8693   bool AllowConfigurationMismatch, bool ValidateSystemInputs,
8694   bool UseGlobalIndex,
8695   std::unique_ptr<llvm::Timer> ReadTimer)
8696     : Listener(new PCHValidator(PP, *this)), DeserializationListener(nullptr),
8697       OwnsDeserializationListener(false), SourceMgr(PP.getSourceManager()),
8698       FileMgr(PP.getFileManager()), PCHContainerRdr(PCHContainerRdr),
8699       Diags(PP.getDiagnostics()), SemaObj(nullptr), PP(PP), Context(Context),
8700       Consumer(nullptr), ModuleMgr(PP.getFileManager(), PCHContainerRdr),
8701       DummyIdResolver(PP),
8702       ReadTimer(std::move(ReadTimer)),
8703       PragmaMSStructState(-1),
8704       PragmaMSPointersToMembersState(-1),
8705       isysroot(isysroot), DisableValidation(DisableValidation),
8706       AllowASTWithCompilerErrors(AllowASTWithCompilerErrors),
8707       AllowConfigurationMismatch(AllowConfigurationMismatch),
8708       ValidateSystemInputs(ValidateSystemInputs),
8709       UseGlobalIndex(UseGlobalIndex), TriedLoadingGlobalIndex(false),
8710       CurrSwitchCaseStmts(&SwitchCaseStmts), NumSLocEntriesRead(0),
8711       TotalNumSLocEntries(0), NumStatementsRead(0), TotalNumStatements(0),
8712       NumMacrosRead(0), TotalNumMacros(0), NumIdentifierLookups(0),
8713       NumIdentifierLookupHits(0), NumSelectorsRead(0),
8714       NumMethodPoolEntriesRead(0), NumMethodPoolLookups(0),
8715       NumMethodPoolHits(0), NumMethodPoolTableLookups(0),
8716       NumMethodPoolTableHits(0), TotalNumMethodPoolEntries(0),
8717       NumLexicalDeclContextsRead(0), TotalLexicalDeclContexts(0),
8718       NumVisibleDeclContextsRead(0), TotalVisibleDeclContexts(0),
8719       TotalModulesSizeInBits(0), NumCurrentElementsDeserializing(0),
8720       PassingDeclsToConsumer(false), ReadingKind(Read_None) {
8721   SourceMgr.setExternalSLocEntrySource(this);
8722 
8723   for (const auto &Ext : Extensions) {
8724     auto BlockName = Ext->getExtensionMetadata().BlockName;
8725     auto Known = ModuleFileExtensions.find(BlockName);
8726     if (Known != ModuleFileExtensions.end()) {
8727       Diags.Report(diag::warn_duplicate_module_file_extension)
8728         << BlockName;
8729       continue;
8730     }
8731 
8732     ModuleFileExtensions.insert({BlockName, Ext});
8733   }
8734 }
8735 
~ASTReader()8736 ASTReader::~ASTReader() {
8737   if (OwnsDeserializationListener)
8738     delete DeserializationListener;
8739 }
8740 
getIdResolver()8741 IdentifierResolver &ASTReader::getIdResolver() {
8742   return SemaObj ? SemaObj->IdResolver : DummyIdResolver;
8743 }
8744