1 //===- ASTReader.cpp - AST File Reader ------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This file defines the ASTReader class, which reads AST files.
10 //
11 //===----------------------------------------------------------------------===//
12
13 #include "clang/Basic/OpenMPKinds.h"
14 #include "clang/Serialization/ASTRecordReader.h"
15 #include "ASTCommon.h"
16 #include "ASTReaderInternals.h"
17 #include "clang/AST/AbstractTypeReader.h"
18 #include "clang/AST/ASTConsumer.h"
19 #include "clang/AST/ASTContext.h"
20 #include "clang/AST/ASTMutationListener.h"
21 #include "clang/AST/ASTUnresolvedSet.h"
22 #include "clang/AST/Decl.h"
23 #include "clang/AST/DeclBase.h"
24 #include "clang/AST/DeclCXX.h"
25 #include "clang/AST/DeclFriend.h"
26 #include "clang/AST/DeclGroup.h"
27 #include "clang/AST/DeclObjC.h"
28 #include "clang/AST/DeclTemplate.h"
29 #include "clang/AST/DeclarationName.h"
30 #include "clang/AST/Expr.h"
31 #include "clang/AST/ExprCXX.h"
32 #include "clang/AST/ExternalASTSource.h"
33 #include "clang/AST/NestedNameSpecifier.h"
34 #include "clang/AST/OpenMPClause.h"
35 #include "clang/AST/ODRHash.h"
36 #include "clang/AST/RawCommentList.h"
37 #include "clang/AST/TemplateBase.h"
38 #include "clang/AST/TemplateName.h"
39 #include "clang/AST/Type.h"
40 #include "clang/AST/TypeLoc.h"
41 #include "clang/AST/TypeLocVisitor.h"
42 #include "clang/AST/UnresolvedSet.h"
43 #include "clang/Basic/CommentOptions.h"
44 #include "clang/Basic/Diagnostic.h"
45 #include "clang/Basic/DiagnosticOptions.h"
46 #include "clang/Basic/ExceptionSpecificationType.h"
47 #include "clang/Basic/FileManager.h"
48 #include "clang/Basic/FileSystemOptions.h"
49 #include "clang/Basic/IdentifierTable.h"
50 #include "clang/Basic/LLVM.h"
51 #include "clang/Basic/LangOptions.h"
52 #include "clang/Basic/Module.h"
53 #include "clang/Basic/ObjCRuntime.h"
54 #include "clang/Basic/OperatorKinds.h"
55 #include "clang/Basic/PragmaKinds.h"
56 #include "clang/Basic/Sanitizers.h"
57 #include "clang/Basic/SourceLocation.h"
58 #include "clang/Basic/SourceManager.h"
59 #include "clang/Basic/SourceManagerInternals.h"
60 #include "clang/Basic/Specifiers.h"
61 #include "clang/Basic/TargetInfo.h"
62 #include "clang/Basic/TargetOptions.h"
63 #include "clang/Basic/TokenKinds.h"
64 #include "clang/Basic/Version.h"
65 #include "clang/Lex/HeaderSearch.h"
66 #include "clang/Lex/HeaderSearchOptions.h"
67 #include "clang/Lex/MacroInfo.h"
68 #include "clang/Lex/ModuleMap.h"
69 #include "clang/Lex/PreprocessingRecord.h"
70 #include "clang/Lex/Preprocessor.h"
71 #include "clang/Lex/PreprocessorOptions.h"
72 #include "clang/Lex/Token.h"
73 #include "clang/Sema/ObjCMethodList.h"
74 #include "clang/Sema/Scope.h"
75 #include "clang/Sema/Sema.h"
76 #include "clang/Sema/Weak.h"
77 #include "clang/Serialization/ASTBitCodes.h"
78 #include "clang/Serialization/ASTDeserializationListener.h"
79 #include "clang/Serialization/ContinuousRangeMap.h"
80 #include "clang/Serialization/GlobalModuleIndex.h"
81 #include "clang/Serialization/InMemoryModuleCache.h"
82 #include "clang/Serialization/ModuleFile.h"
83 #include "clang/Serialization/ModuleFileExtension.h"
84 #include "clang/Serialization/ModuleManager.h"
85 #include "clang/Serialization/PCHContainerOperations.h"
86 #include "clang/Serialization/SerializationDiagnostic.h"
87 #include "llvm/ADT/APFloat.h"
88 #include "llvm/ADT/APInt.h"
89 #include "llvm/ADT/APSInt.h"
90 #include "llvm/ADT/ArrayRef.h"
91 #include "llvm/ADT/DenseMap.h"
92 #include "llvm/ADT/FoldingSet.h"
93 #include "llvm/ADT/Hashing.h"
94 #include "llvm/ADT/IntrusiveRefCntPtr.h"
95 #include "llvm/ADT/None.h"
96 #include "llvm/ADT/Optional.h"
97 #include "llvm/ADT/STLExtras.h"
98 #include "llvm/ADT/ScopeExit.h"
99 #include "llvm/ADT/SmallPtrSet.h"
100 #include "llvm/ADT/SmallString.h"
101 #include "llvm/ADT/SmallVector.h"
102 #include "llvm/ADT/StringExtras.h"
103 #include "llvm/ADT/StringMap.h"
104 #include "llvm/ADT/StringRef.h"
105 #include "llvm/ADT/Triple.h"
106 #include "llvm/ADT/iterator_range.h"
107 #include "llvm/Bitstream/BitstreamReader.h"
108 #include "llvm/Support/Casting.h"
109 #include "llvm/Support/Compiler.h"
110 #include "llvm/Support/Compression.h"
111 #include "llvm/Support/DJB.h"
112 #include "llvm/Support/Endian.h"
113 #include "llvm/Support/Error.h"
114 #include "llvm/Support/ErrorHandling.h"
115 #include "llvm/Support/FileSystem.h"
116 #include "llvm/Support/MemoryBuffer.h"
117 #include "llvm/Support/Path.h"
118 #include "llvm/Support/SaveAndRestore.h"
119 #include "llvm/Support/Timer.h"
120 #include "llvm/Support/VersionTuple.h"
121 #include "llvm/Support/raw_ostream.h"
122 #include <algorithm>
123 #include <cassert>
124 #include <cstddef>
125 #include <cstdint>
126 #include <cstdio>
127 #include <ctime>
128 #include <iterator>
129 #include <limits>
130 #include <map>
131 #include <memory>
132 #include <string>
133 #include <system_error>
134 #include <tuple>
135 #include <utility>
136 #include <vector>
137
138 using namespace clang;
139 using namespace clang::serialization;
140 using namespace clang::serialization::reader;
141 using llvm::BitstreamCursor;
142
143 //===----------------------------------------------------------------------===//
144 // ChainedASTReaderListener implementation
145 //===----------------------------------------------------------------------===//
146
147 bool
ReadFullVersionInformation(StringRef FullVersion)148 ChainedASTReaderListener::ReadFullVersionInformation(StringRef FullVersion) {
149 return First->ReadFullVersionInformation(FullVersion) ||
150 Second->ReadFullVersionInformation(FullVersion);
151 }
152
ReadModuleName(StringRef ModuleName)153 void ChainedASTReaderListener::ReadModuleName(StringRef ModuleName) {
154 First->ReadModuleName(ModuleName);
155 Second->ReadModuleName(ModuleName);
156 }
157
ReadModuleMapFile(StringRef ModuleMapPath)158 void ChainedASTReaderListener::ReadModuleMapFile(StringRef ModuleMapPath) {
159 First->ReadModuleMapFile(ModuleMapPath);
160 Second->ReadModuleMapFile(ModuleMapPath);
161 }
162
163 bool
ReadLanguageOptions(const LangOptions & LangOpts,bool Complain,bool AllowCompatibleDifferences)164 ChainedASTReaderListener::ReadLanguageOptions(const LangOptions &LangOpts,
165 bool Complain,
166 bool AllowCompatibleDifferences) {
167 return First->ReadLanguageOptions(LangOpts, Complain,
168 AllowCompatibleDifferences) ||
169 Second->ReadLanguageOptions(LangOpts, Complain,
170 AllowCompatibleDifferences);
171 }
172
ReadTargetOptions(const TargetOptions & TargetOpts,bool Complain,bool AllowCompatibleDifferences)173 bool ChainedASTReaderListener::ReadTargetOptions(
174 const TargetOptions &TargetOpts, bool Complain,
175 bool AllowCompatibleDifferences) {
176 return First->ReadTargetOptions(TargetOpts, Complain,
177 AllowCompatibleDifferences) ||
178 Second->ReadTargetOptions(TargetOpts, Complain,
179 AllowCompatibleDifferences);
180 }
181
ReadDiagnosticOptions(IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts,bool Complain)182 bool ChainedASTReaderListener::ReadDiagnosticOptions(
183 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts, bool Complain) {
184 return First->ReadDiagnosticOptions(DiagOpts, Complain) ||
185 Second->ReadDiagnosticOptions(DiagOpts, Complain);
186 }
187
188 bool
ReadFileSystemOptions(const FileSystemOptions & FSOpts,bool Complain)189 ChainedASTReaderListener::ReadFileSystemOptions(const FileSystemOptions &FSOpts,
190 bool Complain) {
191 return First->ReadFileSystemOptions(FSOpts, Complain) ||
192 Second->ReadFileSystemOptions(FSOpts, Complain);
193 }
194
ReadHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,bool Complain)195 bool ChainedASTReaderListener::ReadHeaderSearchOptions(
196 const HeaderSearchOptions &HSOpts, StringRef SpecificModuleCachePath,
197 bool Complain) {
198 return First->ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
199 Complain) ||
200 Second->ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
201 Complain);
202 }
203
ReadPreprocessorOptions(const PreprocessorOptions & PPOpts,bool Complain,std::string & SuggestedPredefines)204 bool ChainedASTReaderListener::ReadPreprocessorOptions(
205 const PreprocessorOptions &PPOpts, bool Complain,
206 std::string &SuggestedPredefines) {
207 return First->ReadPreprocessorOptions(PPOpts, Complain,
208 SuggestedPredefines) ||
209 Second->ReadPreprocessorOptions(PPOpts, Complain, SuggestedPredefines);
210 }
211
ReadCounter(const serialization::ModuleFile & M,unsigned Value)212 void ChainedASTReaderListener::ReadCounter(const serialization::ModuleFile &M,
213 unsigned Value) {
214 First->ReadCounter(M, Value);
215 Second->ReadCounter(M, Value);
216 }
217
needsInputFileVisitation()218 bool ChainedASTReaderListener::needsInputFileVisitation() {
219 return First->needsInputFileVisitation() ||
220 Second->needsInputFileVisitation();
221 }
222
needsSystemInputFileVisitation()223 bool ChainedASTReaderListener::needsSystemInputFileVisitation() {
224 return First->needsSystemInputFileVisitation() ||
225 Second->needsSystemInputFileVisitation();
226 }
227
visitModuleFile(StringRef Filename,ModuleKind Kind)228 void ChainedASTReaderListener::visitModuleFile(StringRef Filename,
229 ModuleKind Kind) {
230 First->visitModuleFile(Filename, Kind);
231 Second->visitModuleFile(Filename, Kind);
232 }
233
visitInputFile(StringRef Filename,bool isSystem,bool isOverridden,bool isExplicitModule)234 bool ChainedASTReaderListener::visitInputFile(StringRef Filename,
235 bool isSystem,
236 bool isOverridden,
237 bool isExplicitModule) {
238 bool Continue = false;
239 if (First->needsInputFileVisitation() &&
240 (!isSystem || First->needsSystemInputFileVisitation()))
241 Continue |= First->visitInputFile(Filename, isSystem, isOverridden,
242 isExplicitModule);
243 if (Second->needsInputFileVisitation() &&
244 (!isSystem || Second->needsSystemInputFileVisitation()))
245 Continue |= Second->visitInputFile(Filename, isSystem, isOverridden,
246 isExplicitModule);
247 return Continue;
248 }
249
readModuleFileExtension(const ModuleFileExtensionMetadata & Metadata)250 void ChainedASTReaderListener::readModuleFileExtension(
251 const ModuleFileExtensionMetadata &Metadata) {
252 First->readModuleFileExtension(Metadata);
253 Second->readModuleFileExtension(Metadata);
254 }
255
256 //===----------------------------------------------------------------------===//
257 // PCH validator implementation
258 //===----------------------------------------------------------------------===//
259
260 ASTReaderListener::~ASTReaderListener() = default;
261
262 /// Compare the given set of language options against an existing set of
263 /// language options.
264 ///
265 /// \param Diags If non-NULL, diagnostics will be emitted via this engine.
266 /// \param AllowCompatibleDifferences If true, differences between compatible
267 /// language options will be permitted.
268 ///
269 /// \returns true if the languagae options mis-match, false otherwise.
checkLanguageOptions(const LangOptions & LangOpts,const LangOptions & ExistingLangOpts,DiagnosticsEngine * Diags,bool AllowCompatibleDifferences=true)270 static bool checkLanguageOptions(const LangOptions &LangOpts,
271 const LangOptions &ExistingLangOpts,
272 DiagnosticsEngine *Diags,
273 bool AllowCompatibleDifferences = true) {
274 #define LANGOPT(Name, Bits, Default, Description) \
275 if (ExistingLangOpts.Name != LangOpts.Name) { \
276 if (Diags) \
277 Diags->Report(diag::err_pch_langopt_mismatch) \
278 << Description << LangOpts.Name << ExistingLangOpts.Name; \
279 return true; \
280 }
281
282 #define VALUE_LANGOPT(Name, Bits, Default, Description) \
283 if (ExistingLangOpts.Name != LangOpts.Name) { \
284 if (Diags) \
285 Diags->Report(diag::err_pch_langopt_value_mismatch) \
286 << Description; \
287 return true; \
288 }
289
290 #define ENUM_LANGOPT(Name, Type, Bits, Default, Description) \
291 if (ExistingLangOpts.get##Name() != LangOpts.get##Name()) { \
292 if (Diags) \
293 Diags->Report(diag::err_pch_langopt_value_mismatch) \
294 << Description; \
295 return true; \
296 }
297
298 #define COMPATIBLE_LANGOPT(Name, Bits, Default, Description) \
299 if (!AllowCompatibleDifferences) \
300 LANGOPT(Name, Bits, Default, Description)
301
302 #define COMPATIBLE_ENUM_LANGOPT(Name, Bits, Default, Description) \
303 if (!AllowCompatibleDifferences) \
304 ENUM_LANGOPT(Name, Bits, Default, Description)
305
306 #define COMPATIBLE_VALUE_LANGOPT(Name, Bits, Default, Description) \
307 if (!AllowCompatibleDifferences) \
308 VALUE_LANGOPT(Name, Bits, Default, Description)
309
310 #define BENIGN_LANGOPT(Name, Bits, Default, Description)
311 #define BENIGN_ENUM_LANGOPT(Name, Type, Bits, Default, Description)
312 #define BENIGN_VALUE_LANGOPT(Name, Type, Bits, Default, Description)
313 #include "clang/Basic/LangOptions.def"
314
315 if (ExistingLangOpts.ModuleFeatures != LangOpts.ModuleFeatures) {
316 if (Diags)
317 Diags->Report(diag::err_pch_langopt_value_mismatch) << "module features";
318 return true;
319 }
320
321 if (ExistingLangOpts.ObjCRuntime != LangOpts.ObjCRuntime) {
322 if (Diags)
323 Diags->Report(diag::err_pch_langopt_value_mismatch)
324 << "target Objective-C runtime";
325 return true;
326 }
327
328 if (ExistingLangOpts.CommentOpts.BlockCommandNames !=
329 LangOpts.CommentOpts.BlockCommandNames) {
330 if (Diags)
331 Diags->Report(diag::err_pch_langopt_value_mismatch)
332 << "block command names";
333 return true;
334 }
335
336 // Sanitizer feature mismatches are treated as compatible differences. If
337 // compatible differences aren't allowed, we still only want to check for
338 // mismatches of non-modular sanitizers (the only ones which can affect AST
339 // generation).
340 if (!AllowCompatibleDifferences) {
341 SanitizerMask ModularSanitizers = getPPTransparentSanitizers();
342 SanitizerSet ExistingSanitizers = ExistingLangOpts.Sanitize;
343 SanitizerSet ImportedSanitizers = LangOpts.Sanitize;
344 ExistingSanitizers.clear(ModularSanitizers);
345 ImportedSanitizers.clear(ModularSanitizers);
346 if (ExistingSanitizers.Mask != ImportedSanitizers.Mask) {
347 const std::string Flag = "-fsanitize=";
348 if (Diags) {
349 #define SANITIZER(NAME, ID) \
350 { \
351 bool InExistingModule = ExistingSanitizers.has(SanitizerKind::ID); \
352 bool InImportedModule = ImportedSanitizers.has(SanitizerKind::ID); \
353 if (InExistingModule != InImportedModule) \
354 Diags->Report(diag::err_pch_targetopt_feature_mismatch) \
355 << InExistingModule << (Flag + NAME); \
356 }
357 #include "clang/Basic/Sanitizers.def"
358 }
359 return true;
360 }
361 }
362
363 return false;
364 }
365
366 /// Compare the given set of target options against an existing set of
367 /// target options.
368 ///
369 /// \param Diags If non-NULL, diagnostics will be emitted via this engine.
370 ///
371 /// \returns true if the target options mis-match, false otherwise.
checkTargetOptions(const TargetOptions & TargetOpts,const TargetOptions & ExistingTargetOpts,DiagnosticsEngine * Diags,bool AllowCompatibleDifferences=true)372 static bool checkTargetOptions(const TargetOptions &TargetOpts,
373 const TargetOptions &ExistingTargetOpts,
374 DiagnosticsEngine *Diags,
375 bool AllowCompatibleDifferences = true) {
376 #define CHECK_TARGET_OPT(Field, Name) \
377 if (TargetOpts.Field != ExistingTargetOpts.Field) { \
378 if (Diags) \
379 Diags->Report(diag::err_pch_targetopt_mismatch) \
380 << Name << TargetOpts.Field << ExistingTargetOpts.Field; \
381 return true; \
382 }
383
384 // The triple and ABI must match exactly.
385 CHECK_TARGET_OPT(Triple, "target");
386 CHECK_TARGET_OPT(ABI, "target ABI");
387
388 // We can tolerate different CPUs in many cases, notably when one CPU
389 // supports a strict superset of another. When allowing compatible
390 // differences skip this check.
391 if (!AllowCompatibleDifferences)
392 CHECK_TARGET_OPT(CPU, "target CPU");
393
394 #undef CHECK_TARGET_OPT
395
396 // Compare feature sets.
397 SmallVector<StringRef, 4> ExistingFeatures(
398 ExistingTargetOpts.FeaturesAsWritten.begin(),
399 ExistingTargetOpts.FeaturesAsWritten.end());
400 SmallVector<StringRef, 4> ReadFeatures(TargetOpts.FeaturesAsWritten.begin(),
401 TargetOpts.FeaturesAsWritten.end());
402 llvm::sort(ExistingFeatures);
403 llvm::sort(ReadFeatures);
404
405 // We compute the set difference in both directions explicitly so that we can
406 // diagnose the differences differently.
407 SmallVector<StringRef, 4> UnmatchedExistingFeatures, UnmatchedReadFeatures;
408 std::set_difference(
409 ExistingFeatures.begin(), ExistingFeatures.end(), ReadFeatures.begin(),
410 ReadFeatures.end(), std::back_inserter(UnmatchedExistingFeatures));
411 std::set_difference(ReadFeatures.begin(), ReadFeatures.end(),
412 ExistingFeatures.begin(), ExistingFeatures.end(),
413 std::back_inserter(UnmatchedReadFeatures));
414
415 // If we are allowing compatible differences and the read feature set is
416 // a strict subset of the existing feature set, there is nothing to diagnose.
417 if (AllowCompatibleDifferences && UnmatchedReadFeatures.empty())
418 return false;
419
420 if (Diags) {
421 for (StringRef Feature : UnmatchedReadFeatures)
422 Diags->Report(diag::err_pch_targetopt_feature_mismatch)
423 << /* is-existing-feature */ false << Feature;
424 for (StringRef Feature : UnmatchedExistingFeatures)
425 Diags->Report(diag::err_pch_targetopt_feature_mismatch)
426 << /* is-existing-feature */ true << Feature;
427 }
428
429 return !UnmatchedReadFeatures.empty() || !UnmatchedExistingFeatures.empty();
430 }
431
432 bool
ReadLanguageOptions(const LangOptions & LangOpts,bool Complain,bool AllowCompatibleDifferences)433 PCHValidator::ReadLanguageOptions(const LangOptions &LangOpts,
434 bool Complain,
435 bool AllowCompatibleDifferences) {
436 const LangOptions &ExistingLangOpts = PP.getLangOpts();
437 return checkLanguageOptions(LangOpts, ExistingLangOpts,
438 Complain ? &Reader.Diags : nullptr,
439 AllowCompatibleDifferences);
440 }
441
ReadTargetOptions(const TargetOptions & TargetOpts,bool Complain,bool AllowCompatibleDifferences)442 bool PCHValidator::ReadTargetOptions(const TargetOptions &TargetOpts,
443 bool Complain,
444 bool AllowCompatibleDifferences) {
445 const TargetOptions &ExistingTargetOpts = PP.getTargetInfo().getTargetOpts();
446 return checkTargetOptions(TargetOpts, ExistingTargetOpts,
447 Complain ? &Reader.Diags : nullptr,
448 AllowCompatibleDifferences);
449 }
450
451 namespace {
452
453 using MacroDefinitionsMap =
454 llvm::StringMap<std::pair<StringRef, bool /*IsUndef*/>>;
455 using DeclsMap = llvm::DenseMap<DeclarationName, SmallVector<NamedDecl *, 8>>;
456
457 } // namespace
458
checkDiagnosticGroupMappings(DiagnosticsEngine & StoredDiags,DiagnosticsEngine & Diags,bool Complain)459 static bool checkDiagnosticGroupMappings(DiagnosticsEngine &StoredDiags,
460 DiagnosticsEngine &Diags,
461 bool Complain) {
462 using Level = DiagnosticsEngine::Level;
463
464 // Check current mappings for new -Werror mappings, and the stored mappings
465 // for cases that were explicitly mapped to *not* be errors that are now
466 // errors because of options like -Werror.
467 DiagnosticsEngine *MappingSources[] = { &Diags, &StoredDiags };
468
469 for (DiagnosticsEngine *MappingSource : MappingSources) {
470 for (auto DiagIDMappingPair : MappingSource->getDiagnosticMappings()) {
471 diag::kind DiagID = DiagIDMappingPair.first;
472 Level CurLevel = Diags.getDiagnosticLevel(DiagID, SourceLocation());
473 if (CurLevel < DiagnosticsEngine::Error)
474 continue; // not significant
475 Level StoredLevel =
476 StoredDiags.getDiagnosticLevel(DiagID, SourceLocation());
477 if (StoredLevel < DiagnosticsEngine::Error) {
478 if (Complain)
479 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Werror=" +
480 Diags.getDiagnosticIDs()->getWarningOptionForDiag(DiagID).str();
481 return true;
482 }
483 }
484 }
485
486 return false;
487 }
488
isExtHandlingFromDiagsError(DiagnosticsEngine & Diags)489 static bool isExtHandlingFromDiagsError(DiagnosticsEngine &Diags) {
490 diag::Severity Ext = Diags.getExtensionHandlingBehavior();
491 if (Ext == diag::Severity::Warning && Diags.getWarningsAsErrors())
492 return true;
493 return Ext >= diag::Severity::Error;
494 }
495
checkDiagnosticMappings(DiagnosticsEngine & StoredDiags,DiagnosticsEngine & Diags,bool IsSystem,bool Complain)496 static bool checkDiagnosticMappings(DiagnosticsEngine &StoredDiags,
497 DiagnosticsEngine &Diags,
498 bool IsSystem, bool Complain) {
499 // Top-level options
500 if (IsSystem) {
501 if (Diags.getSuppressSystemWarnings())
502 return false;
503 // If -Wsystem-headers was not enabled before, be conservative
504 if (StoredDiags.getSuppressSystemWarnings()) {
505 if (Complain)
506 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Wsystem-headers";
507 return true;
508 }
509 }
510
511 if (Diags.getWarningsAsErrors() && !StoredDiags.getWarningsAsErrors()) {
512 if (Complain)
513 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Werror";
514 return true;
515 }
516
517 if (Diags.getWarningsAsErrors() && Diags.getEnableAllWarnings() &&
518 !StoredDiags.getEnableAllWarnings()) {
519 if (Complain)
520 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Weverything -Werror";
521 return true;
522 }
523
524 if (isExtHandlingFromDiagsError(Diags) &&
525 !isExtHandlingFromDiagsError(StoredDiags)) {
526 if (Complain)
527 Diags.Report(diag::err_pch_diagopt_mismatch) << "-pedantic-errors";
528 return true;
529 }
530
531 return checkDiagnosticGroupMappings(StoredDiags, Diags, Complain);
532 }
533
534 /// Return the top import module if it is implicit, nullptr otherwise.
getTopImportImplicitModule(ModuleManager & ModuleMgr,Preprocessor & PP)535 static Module *getTopImportImplicitModule(ModuleManager &ModuleMgr,
536 Preprocessor &PP) {
537 // If the original import came from a file explicitly generated by the user,
538 // don't check the diagnostic mappings.
539 // FIXME: currently this is approximated by checking whether this is not a
540 // module import of an implicitly-loaded module file.
541 // Note: ModuleMgr.rbegin() may not be the current module, but it must be in
542 // the transitive closure of its imports, since unrelated modules cannot be
543 // imported until after this module finishes validation.
544 ModuleFile *TopImport = &*ModuleMgr.rbegin();
545 while (!TopImport->ImportedBy.empty())
546 TopImport = TopImport->ImportedBy[0];
547 if (TopImport->Kind != MK_ImplicitModule)
548 return nullptr;
549
550 StringRef ModuleName = TopImport->ModuleName;
551 assert(!ModuleName.empty() && "diagnostic options read before module name");
552
553 Module *M = PP.getHeaderSearchInfo().lookupModule(ModuleName);
554 assert(M && "missing module");
555 return M;
556 }
557
ReadDiagnosticOptions(IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts,bool Complain)558 bool PCHValidator::ReadDiagnosticOptions(
559 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts, bool Complain) {
560 DiagnosticsEngine &ExistingDiags = PP.getDiagnostics();
561 IntrusiveRefCntPtr<DiagnosticIDs> DiagIDs(ExistingDiags.getDiagnosticIDs());
562 IntrusiveRefCntPtr<DiagnosticsEngine> Diags(
563 new DiagnosticsEngine(DiagIDs, DiagOpts.get()));
564 // This should never fail, because we would have processed these options
565 // before writing them to an ASTFile.
566 ProcessWarningOptions(*Diags, *DiagOpts, /*Report*/false);
567
568 ModuleManager &ModuleMgr = Reader.getModuleManager();
569 assert(ModuleMgr.size() >= 1 && "what ASTFile is this then");
570
571 Module *TopM = getTopImportImplicitModule(ModuleMgr, PP);
572 if (!TopM)
573 return false;
574
575 // FIXME: if the diagnostics are incompatible, save a DiagnosticOptions that
576 // contains the union of their flags.
577 return checkDiagnosticMappings(*Diags, ExistingDiags, TopM->IsSystem,
578 Complain);
579 }
580
581 /// Collect the macro definitions provided by the given preprocessor
582 /// options.
583 static void
collectMacroDefinitions(const PreprocessorOptions & PPOpts,MacroDefinitionsMap & Macros,SmallVectorImpl<StringRef> * MacroNames=nullptr)584 collectMacroDefinitions(const PreprocessorOptions &PPOpts,
585 MacroDefinitionsMap &Macros,
586 SmallVectorImpl<StringRef> *MacroNames = nullptr) {
587 for (unsigned I = 0, N = PPOpts.Macros.size(); I != N; ++I) {
588 StringRef Macro = PPOpts.Macros[I].first;
589 bool IsUndef = PPOpts.Macros[I].second;
590
591 std::pair<StringRef, StringRef> MacroPair = Macro.split('=');
592 StringRef MacroName = MacroPair.first;
593 StringRef MacroBody = MacroPair.second;
594
595 // For an #undef'd macro, we only care about the name.
596 if (IsUndef) {
597 if (MacroNames && !Macros.count(MacroName))
598 MacroNames->push_back(MacroName);
599
600 Macros[MacroName] = std::make_pair("", true);
601 continue;
602 }
603
604 // For a #define'd macro, figure out the actual definition.
605 if (MacroName.size() == Macro.size())
606 MacroBody = "1";
607 else {
608 // Note: GCC drops anything following an end-of-line character.
609 StringRef::size_type End = MacroBody.find_first_of("\n\r");
610 MacroBody = MacroBody.substr(0, End);
611 }
612
613 if (MacroNames && !Macros.count(MacroName))
614 MacroNames->push_back(MacroName);
615 Macros[MacroName] = std::make_pair(MacroBody, false);
616 }
617 }
618
619 /// Check the preprocessor options deserialized from the control block
620 /// against the preprocessor options in an existing preprocessor.
621 ///
622 /// \param Diags If non-null, produce diagnostics for any mismatches incurred.
623 /// \param Validate If true, validate preprocessor options. If false, allow
624 /// macros defined by \p ExistingPPOpts to override those defined by
625 /// \p PPOpts in SuggestedPredefines.
checkPreprocessorOptions(const PreprocessorOptions & PPOpts,const PreprocessorOptions & ExistingPPOpts,DiagnosticsEngine * Diags,FileManager & FileMgr,std::string & SuggestedPredefines,const LangOptions & LangOpts,bool Validate=true)626 static bool checkPreprocessorOptions(const PreprocessorOptions &PPOpts,
627 const PreprocessorOptions &ExistingPPOpts,
628 DiagnosticsEngine *Diags,
629 FileManager &FileMgr,
630 std::string &SuggestedPredefines,
631 const LangOptions &LangOpts,
632 bool Validate = true) {
633 // Check macro definitions.
634 MacroDefinitionsMap ASTFileMacros;
635 collectMacroDefinitions(PPOpts, ASTFileMacros);
636 MacroDefinitionsMap ExistingMacros;
637 SmallVector<StringRef, 4> ExistingMacroNames;
638 collectMacroDefinitions(ExistingPPOpts, ExistingMacros, &ExistingMacroNames);
639
640 for (unsigned I = 0, N = ExistingMacroNames.size(); I != N; ++I) {
641 // Dig out the macro definition in the existing preprocessor options.
642 StringRef MacroName = ExistingMacroNames[I];
643 std::pair<StringRef, bool> Existing = ExistingMacros[MacroName];
644
645 // Check whether we know anything about this macro name or not.
646 llvm::StringMap<std::pair<StringRef, bool /*IsUndef*/>>::iterator Known =
647 ASTFileMacros.find(MacroName);
648 if (!Validate || Known == ASTFileMacros.end()) {
649 // FIXME: Check whether this identifier was referenced anywhere in the
650 // AST file. If so, we should reject the AST file. Unfortunately, this
651 // information isn't in the control block. What shall we do about it?
652
653 if (Existing.second) {
654 SuggestedPredefines += "#undef ";
655 SuggestedPredefines += MacroName.str();
656 SuggestedPredefines += '\n';
657 } else {
658 SuggestedPredefines += "#define ";
659 SuggestedPredefines += MacroName.str();
660 SuggestedPredefines += ' ';
661 SuggestedPredefines += Existing.first.str();
662 SuggestedPredefines += '\n';
663 }
664 continue;
665 }
666
667 // If the macro was defined in one but undef'd in the other, we have a
668 // conflict.
669 if (Existing.second != Known->second.second) {
670 if (Diags) {
671 Diags->Report(diag::err_pch_macro_def_undef)
672 << MacroName << Known->second.second;
673 }
674 return true;
675 }
676
677 // If the macro was #undef'd in both, or if the macro bodies are identical,
678 // it's fine.
679 if (Existing.second || Existing.first == Known->second.first)
680 continue;
681
682 // The macro bodies differ; complain.
683 if (Diags) {
684 Diags->Report(diag::err_pch_macro_def_conflict)
685 << MacroName << Known->second.first << Existing.first;
686 }
687 return true;
688 }
689
690 // Check whether we're using predefines.
691 if (PPOpts.UsePredefines != ExistingPPOpts.UsePredefines && Validate) {
692 if (Diags) {
693 Diags->Report(diag::err_pch_undef) << ExistingPPOpts.UsePredefines;
694 }
695 return true;
696 }
697
698 // Detailed record is important since it is used for the module cache hash.
699 if (LangOpts.Modules &&
700 PPOpts.DetailedRecord != ExistingPPOpts.DetailedRecord && Validate) {
701 if (Diags) {
702 Diags->Report(diag::err_pch_pp_detailed_record) << PPOpts.DetailedRecord;
703 }
704 return true;
705 }
706
707 // Compute the #include and #include_macros lines we need.
708 for (unsigned I = 0, N = ExistingPPOpts.Includes.size(); I != N; ++I) {
709 StringRef File = ExistingPPOpts.Includes[I];
710
711 if (!ExistingPPOpts.ImplicitPCHInclude.empty() &&
712 !ExistingPPOpts.PCHThroughHeader.empty()) {
713 // In case the through header is an include, we must add all the includes
714 // to the predefines so the start point can be determined.
715 SuggestedPredefines += "#include \"";
716 SuggestedPredefines += File;
717 SuggestedPredefines += "\"\n";
718 continue;
719 }
720
721 if (File == ExistingPPOpts.ImplicitPCHInclude)
722 continue;
723
724 if (std::find(PPOpts.Includes.begin(), PPOpts.Includes.end(), File)
725 != PPOpts.Includes.end())
726 continue;
727
728 SuggestedPredefines += "#include \"";
729 SuggestedPredefines += File;
730 SuggestedPredefines += "\"\n";
731 }
732
733 for (unsigned I = 0, N = ExistingPPOpts.MacroIncludes.size(); I != N; ++I) {
734 StringRef File = ExistingPPOpts.MacroIncludes[I];
735 if (std::find(PPOpts.MacroIncludes.begin(), PPOpts.MacroIncludes.end(),
736 File)
737 != PPOpts.MacroIncludes.end())
738 continue;
739
740 SuggestedPredefines += "#__include_macros \"";
741 SuggestedPredefines += File;
742 SuggestedPredefines += "\"\n##\n";
743 }
744
745 return false;
746 }
747
ReadPreprocessorOptions(const PreprocessorOptions & PPOpts,bool Complain,std::string & SuggestedPredefines)748 bool PCHValidator::ReadPreprocessorOptions(const PreprocessorOptions &PPOpts,
749 bool Complain,
750 std::string &SuggestedPredefines) {
751 const PreprocessorOptions &ExistingPPOpts = PP.getPreprocessorOpts();
752
753 return checkPreprocessorOptions(PPOpts, ExistingPPOpts,
754 Complain? &Reader.Diags : nullptr,
755 PP.getFileManager(),
756 SuggestedPredefines,
757 PP.getLangOpts());
758 }
759
ReadPreprocessorOptions(const PreprocessorOptions & PPOpts,bool Complain,std::string & SuggestedPredefines)760 bool SimpleASTReaderListener::ReadPreprocessorOptions(
761 const PreprocessorOptions &PPOpts,
762 bool Complain,
763 std::string &SuggestedPredefines) {
764 return checkPreprocessorOptions(PPOpts,
765 PP.getPreprocessorOpts(),
766 nullptr,
767 PP.getFileManager(),
768 SuggestedPredefines,
769 PP.getLangOpts(),
770 false);
771 }
772
773 /// Check the header search options deserialized from the control block
774 /// against the header search options in an existing preprocessor.
775 ///
776 /// \param Diags If non-null, produce diagnostics for any mismatches incurred.
checkHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,StringRef ExistingModuleCachePath,DiagnosticsEngine * Diags,const LangOptions & LangOpts)777 static bool checkHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
778 StringRef SpecificModuleCachePath,
779 StringRef ExistingModuleCachePath,
780 DiagnosticsEngine *Diags,
781 const LangOptions &LangOpts) {
782 if (LangOpts.Modules) {
783 if (SpecificModuleCachePath != ExistingModuleCachePath) {
784 if (Diags)
785 Diags->Report(diag::err_pch_modulecache_mismatch)
786 << SpecificModuleCachePath << ExistingModuleCachePath;
787 return true;
788 }
789 }
790
791 return false;
792 }
793
ReadHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,bool Complain)794 bool PCHValidator::ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
795 StringRef SpecificModuleCachePath,
796 bool Complain) {
797 return checkHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
798 PP.getHeaderSearchInfo().getModuleCachePath(),
799 Complain ? &Reader.Diags : nullptr,
800 PP.getLangOpts());
801 }
802
ReadCounter(const ModuleFile & M,unsigned Value)803 void PCHValidator::ReadCounter(const ModuleFile &M, unsigned Value) {
804 PP.setCounterValue(Value);
805 }
806
807 //===----------------------------------------------------------------------===//
808 // AST reader implementation
809 //===----------------------------------------------------------------------===//
810
setDeserializationListener(ASTDeserializationListener * Listener,bool TakeOwnership)811 void ASTReader::setDeserializationListener(ASTDeserializationListener *Listener,
812 bool TakeOwnership) {
813 DeserializationListener = Listener;
814 OwnsDeserializationListener = TakeOwnership;
815 }
816
ComputeHash(Selector Sel)817 unsigned ASTSelectorLookupTrait::ComputeHash(Selector Sel) {
818 return serialization::ComputeHash(Sel);
819 }
820
821 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)822 ASTSelectorLookupTrait::ReadKeyDataLength(const unsigned char*& d) {
823 using namespace llvm::support;
824
825 unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
826 unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
827 return std::make_pair(KeyLen, DataLen);
828 }
829
830 ASTSelectorLookupTrait::internal_key_type
ReadKey(const unsigned char * d,unsigned)831 ASTSelectorLookupTrait::ReadKey(const unsigned char* d, unsigned) {
832 using namespace llvm::support;
833
834 SelectorTable &SelTable = Reader.getContext().Selectors;
835 unsigned N = endian::readNext<uint16_t, little, unaligned>(d);
836 IdentifierInfo *FirstII = Reader.getLocalIdentifier(
837 F, endian::readNext<uint32_t, little, unaligned>(d));
838 if (N == 0)
839 return SelTable.getNullarySelector(FirstII);
840 else if (N == 1)
841 return SelTable.getUnarySelector(FirstII);
842
843 SmallVector<IdentifierInfo *, 16> Args;
844 Args.push_back(FirstII);
845 for (unsigned I = 1; I != N; ++I)
846 Args.push_back(Reader.getLocalIdentifier(
847 F, endian::readNext<uint32_t, little, unaligned>(d)));
848
849 return SelTable.getSelector(N, Args.data());
850 }
851
852 ASTSelectorLookupTrait::data_type
ReadData(Selector,const unsigned char * d,unsigned DataLen)853 ASTSelectorLookupTrait::ReadData(Selector, const unsigned char* d,
854 unsigned DataLen) {
855 using namespace llvm::support;
856
857 data_type Result;
858
859 Result.ID = Reader.getGlobalSelectorID(
860 F, endian::readNext<uint32_t, little, unaligned>(d));
861 unsigned FullInstanceBits = endian::readNext<uint16_t, little, unaligned>(d);
862 unsigned FullFactoryBits = endian::readNext<uint16_t, little, unaligned>(d);
863 Result.InstanceBits = FullInstanceBits & 0x3;
864 Result.InstanceHasMoreThanOneDecl = (FullInstanceBits >> 2) & 0x1;
865 Result.FactoryBits = FullFactoryBits & 0x3;
866 Result.FactoryHasMoreThanOneDecl = (FullFactoryBits >> 2) & 0x1;
867 unsigned NumInstanceMethods = FullInstanceBits >> 3;
868 unsigned NumFactoryMethods = FullFactoryBits >> 3;
869
870 // Load instance methods
871 for (unsigned I = 0; I != NumInstanceMethods; ++I) {
872 if (ObjCMethodDecl *Method = Reader.GetLocalDeclAs<ObjCMethodDecl>(
873 F, endian::readNext<uint32_t, little, unaligned>(d)))
874 Result.Instance.push_back(Method);
875 }
876
877 // Load factory methods
878 for (unsigned I = 0; I != NumFactoryMethods; ++I) {
879 if (ObjCMethodDecl *Method = Reader.GetLocalDeclAs<ObjCMethodDecl>(
880 F, endian::readNext<uint32_t, little, unaligned>(d)))
881 Result.Factory.push_back(Method);
882 }
883
884 return Result;
885 }
886
ComputeHash(const internal_key_type & a)887 unsigned ASTIdentifierLookupTraitBase::ComputeHash(const internal_key_type& a) {
888 return llvm::djbHash(a);
889 }
890
891 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)892 ASTIdentifierLookupTraitBase::ReadKeyDataLength(const unsigned char*& d) {
893 using namespace llvm::support;
894
895 unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
896 unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
897 return std::make_pair(KeyLen, DataLen);
898 }
899
900 ASTIdentifierLookupTraitBase::internal_key_type
ReadKey(const unsigned char * d,unsigned n)901 ASTIdentifierLookupTraitBase::ReadKey(const unsigned char* d, unsigned n) {
902 assert(n >= 2 && d[n-1] == '\0');
903 return StringRef((const char*) d, n-1);
904 }
905
906 /// Whether the given identifier is "interesting".
isInterestingIdentifier(ASTReader & Reader,IdentifierInfo & II,bool IsModule)907 static bool isInterestingIdentifier(ASTReader &Reader, IdentifierInfo &II,
908 bool IsModule) {
909 return II.hadMacroDefinition() ||
910 II.isPoisoned() ||
911 (IsModule ? II.hasRevertedBuiltin() : II.getObjCOrBuiltinID()) ||
912 II.hasRevertedTokenIDToIdentifier() ||
913 (!(IsModule && Reader.getPreprocessor().getLangOpts().CPlusPlus) &&
914 II.getFETokenInfo());
915 }
916
readBit(unsigned & Bits)917 static bool readBit(unsigned &Bits) {
918 bool Value = Bits & 0x1;
919 Bits >>= 1;
920 return Value;
921 }
922
ReadIdentifierID(const unsigned char * d)923 IdentID ASTIdentifierLookupTrait::ReadIdentifierID(const unsigned char *d) {
924 using namespace llvm::support;
925
926 unsigned RawID = endian::readNext<uint32_t, little, unaligned>(d);
927 return Reader.getGlobalIdentifierID(F, RawID >> 1);
928 }
929
markIdentifierFromAST(ASTReader & Reader,IdentifierInfo & II)930 static void markIdentifierFromAST(ASTReader &Reader, IdentifierInfo &II) {
931 if (!II.isFromAST()) {
932 II.setIsFromAST();
933 bool IsModule = Reader.getPreprocessor().getCurrentModule() != nullptr;
934 if (isInterestingIdentifier(Reader, II, IsModule))
935 II.setChangedSinceDeserialization();
936 }
937 }
938
ReadData(const internal_key_type & k,const unsigned char * d,unsigned DataLen)939 IdentifierInfo *ASTIdentifierLookupTrait::ReadData(const internal_key_type& k,
940 const unsigned char* d,
941 unsigned DataLen) {
942 using namespace llvm::support;
943
944 unsigned RawID = endian::readNext<uint32_t, little, unaligned>(d);
945 bool IsInteresting = RawID & 0x01;
946
947 // Wipe out the "is interesting" bit.
948 RawID = RawID >> 1;
949
950 // Build the IdentifierInfo and link the identifier ID with it.
951 IdentifierInfo *II = KnownII;
952 if (!II) {
953 II = &Reader.getIdentifierTable().getOwn(k);
954 KnownII = II;
955 }
956 markIdentifierFromAST(Reader, *II);
957 Reader.markIdentifierUpToDate(II);
958
959 IdentID ID = Reader.getGlobalIdentifierID(F, RawID);
960 if (!IsInteresting) {
961 // For uninteresting identifiers, there's nothing else to do. Just notify
962 // the reader that we've finished loading this identifier.
963 Reader.SetIdentifierInfo(ID, II);
964 return II;
965 }
966
967 unsigned ObjCOrBuiltinID = endian::readNext<uint16_t, little, unaligned>(d);
968 unsigned Bits = endian::readNext<uint16_t, little, unaligned>(d);
969 bool CPlusPlusOperatorKeyword = readBit(Bits);
970 bool HasRevertedTokenIDToIdentifier = readBit(Bits);
971 bool HasRevertedBuiltin = readBit(Bits);
972 bool Poisoned = readBit(Bits);
973 bool ExtensionToken = readBit(Bits);
974 bool HadMacroDefinition = readBit(Bits);
975
976 assert(Bits == 0 && "Extra bits in the identifier?");
977 DataLen -= 8;
978
979 // Set or check the various bits in the IdentifierInfo structure.
980 // Token IDs are read-only.
981 if (HasRevertedTokenIDToIdentifier && II->getTokenID() != tok::identifier)
982 II->revertTokenIDToIdentifier();
983 if (!F.isModule())
984 II->setObjCOrBuiltinID(ObjCOrBuiltinID);
985 else if (HasRevertedBuiltin && II->getBuiltinID()) {
986 II->revertBuiltin();
987 assert((II->hasRevertedBuiltin() ||
988 II->getObjCOrBuiltinID() == ObjCOrBuiltinID) &&
989 "Incorrect ObjC keyword or builtin ID");
990 }
991 assert(II->isExtensionToken() == ExtensionToken &&
992 "Incorrect extension token flag");
993 (void)ExtensionToken;
994 if (Poisoned)
995 II->setIsPoisoned(true);
996 assert(II->isCPlusPlusOperatorKeyword() == CPlusPlusOperatorKeyword &&
997 "Incorrect C++ operator keyword flag");
998 (void)CPlusPlusOperatorKeyword;
999
1000 // If this identifier is a macro, deserialize the macro
1001 // definition.
1002 if (HadMacroDefinition) {
1003 uint32_t MacroDirectivesOffset =
1004 endian::readNext<uint32_t, little, unaligned>(d);
1005 DataLen -= 4;
1006
1007 Reader.addPendingMacro(II, &F, MacroDirectivesOffset);
1008 }
1009
1010 Reader.SetIdentifierInfo(ID, II);
1011
1012 // Read all of the declarations visible at global scope with this
1013 // name.
1014 if (DataLen > 0) {
1015 SmallVector<uint32_t, 4> DeclIDs;
1016 for (; DataLen > 0; DataLen -= 4)
1017 DeclIDs.push_back(Reader.getGlobalDeclID(
1018 F, endian::readNext<uint32_t, little, unaligned>(d)));
1019 Reader.SetGloballyVisibleDecls(II, DeclIDs);
1020 }
1021
1022 return II;
1023 }
1024
DeclarationNameKey(DeclarationName Name)1025 DeclarationNameKey::DeclarationNameKey(DeclarationName Name)
1026 : Kind(Name.getNameKind()) {
1027 switch (Kind) {
1028 case DeclarationName::Identifier:
1029 Data = (uint64_t)Name.getAsIdentifierInfo();
1030 break;
1031 case DeclarationName::ObjCZeroArgSelector:
1032 case DeclarationName::ObjCOneArgSelector:
1033 case DeclarationName::ObjCMultiArgSelector:
1034 Data = (uint64_t)Name.getObjCSelector().getAsOpaquePtr();
1035 break;
1036 case DeclarationName::CXXOperatorName:
1037 Data = Name.getCXXOverloadedOperator();
1038 break;
1039 case DeclarationName::CXXLiteralOperatorName:
1040 Data = (uint64_t)Name.getCXXLiteralIdentifier();
1041 break;
1042 case DeclarationName::CXXDeductionGuideName:
1043 Data = (uint64_t)Name.getCXXDeductionGuideTemplate()
1044 ->getDeclName().getAsIdentifierInfo();
1045 break;
1046 case DeclarationName::CXXConstructorName:
1047 case DeclarationName::CXXDestructorName:
1048 case DeclarationName::CXXConversionFunctionName:
1049 case DeclarationName::CXXUsingDirective:
1050 Data = 0;
1051 break;
1052 }
1053 }
1054
getHash() const1055 unsigned DeclarationNameKey::getHash() const {
1056 llvm::FoldingSetNodeID ID;
1057 ID.AddInteger(Kind);
1058
1059 switch (Kind) {
1060 case DeclarationName::Identifier:
1061 case DeclarationName::CXXLiteralOperatorName:
1062 case DeclarationName::CXXDeductionGuideName:
1063 ID.AddString(((IdentifierInfo*)Data)->getName());
1064 break;
1065 case DeclarationName::ObjCZeroArgSelector:
1066 case DeclarationName::ObjCOneArgSelector:
1067 case DeclarationName::ObjCMultiArgSelector:
1068 ID.AddInteger(serialization::ComputeHash(Selector(Data)));
1069 break;
1070 case DeclarationName::CXXOperatorName:
1071 ID.AddInteger((OverloadedOperatorKind)Data);
1072 break;
1073 case DeclarationName::CXXConstructorName:
1074 case DeclarationName::CXXDestructorName:
1075 case DeclarationName::CXXConversionFunctionName:
1076 case DeclarationName::CXXUsingDirective:
1077 break;
1078 }
1079
1080 return ID.ComputeHash();
1081 }
1082
1083 ModuleFile *
ReadFileRef(const unsigned char * & d)1084 ASTDeclContextNameLookupTrait::ReadFileRef(const unsigned char *&d) {
1085 using namespace llvm::support;
1086
1087 uint32_t ModuleFileID = endian::readNext<uint32_t, little, unaligned>(d);
1088 return Reader.getLocalModuleFile(F, ModuleFileID);
1089 }
1090
1091 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)1092 ASTDeclContextNameLookupTrait::ReadKeyDataLength(const unsigned char *&d) {
1093 using namespace llvm::support;
1094
1095 unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
1096 unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
1097 return std::make_pair(KeyLen, DataLen);
1098 }
1099
1100 ASTDeclContextNameLookupTrait::internal_key_type
ReadKey(const unsigned char * d,unsigned)1101 ASTDeclContextNameLookupTrait::ReadKey(const unsigned char *d, unsigned) {
1102 using namespace llvm::support;
1103
1104 auto Kind = (DeclarationName::NameKind)*d++;
1105 uint64_t Data;
1106 switch (Kind) {
1107 case DeclarationName::Identifier:
1108 case DeclarationName::CXXLiteralOperatorName:
1109 case DeclarationName::CXXDeductionGuideName:
1110 Data = (uint64_t)Reader.getLocalIdentifier(
1111 F, endian::readNext<uint32_t, little, unaligned>(d));
1112 break;
1113 case DeclarationName::ObjCZeroArgSelector:
1114 case DeclarationName::ObjCOneArgSelector:
1115 case DeclarationName::ObjCMultiArgSelector:
1116 Data =
1117 (uint64_t)Reader.getLocalSelector(
1118 F, endian::readNext<uint32_t, little, unaligned>(
1119 d)).getAsOpaquePtr();
1120 break;
1121 case DeclarationName::CXXOperatorName:
1122 Data = *d++; // OverloadedOperatorKind
1123 break;
1124 case DeclarationName::CXXConstructorName:
1125 case DeclarationName::CXXDestructorName:
1126 case DeclarationName::CXXConversionFunctionName:
1127 case DeclarationName::CXXUsingDirective:
1128 Data = 0;
1129 break;
1130 }
1131
1132 return DeclarationNameKey(Kind, Data);
1133 }
1134
ReadDataInto(internal_key_type,const unsigned char * d,unsigned DataLen,data_type_builder & Val)1135 void ASTDeclContextNameLookupTrait::ReadDataInto(internal_key_type,
1136 const unsigned char *d,
1137 unsigned DataLen,
1138 data_type_builder &Val) {
1139 using namespace llvm::support;
1140
1141 for (unsigned NumDecls = DataLen / 4; NumDecls; --NumDecls) {
1142 uint32_t LocalID = endian::readNext<uint32_t, little, unaligned>(d);
1143 Val.insert(Reader.getGlobalDeclID(F, LocalID));
1144 }
1145 }
1146
ReadLexicalDeclContextStorage(ModuleFile & M,BitstreamCursor & Cursor,uint64_t Offset,DeclContext * DC)1147 bool ASTReader::ReadLexicalDeclContextStorage(ModuleFile &M,
1148 BitstreamCursor &Cursor,
1149 uint64_t Offset,
1150 DeclContext *DC) {
1151 assert(Offset != 0);
1152
1153 SavedStreamPosition SavedPosition(Cursor);
1154 if (llvm::Error Err = Cursor.JumpToBit(Offset)) {
1155 Error(std::move(Err));
1156 return true;
1157 }
1158
1159 RecordData Record;
1160 StringRef Blob;
1161 Expected<unsigned> MaybeCode = Cursor.ReadCode();
1162 if (!MaybeCode) {
1163 Error(MaybeCode.takeError());
1164 return true;
1165 }
1166 unsigned Code = MaybeCode.get();
1167
1168 Expected<unsigned> MaybeRecCode = Cursor.readRecord(Code, Record, &Blob);
1169 if (!MaybeRecCode) {
1170 Error(MaybeRecCode.takeError());
1171 return true;
1172 }
1173 unsigned RecCode = MaybeRecCode.get();
1174 if (RecCode != DECL_CONTEXT_LEXICAL) {
1175 Error("Expected lexical block");
1176 return true;
1177 }
1178
1179 assert(!isa<TranslationUnitDecl>(DC) &&
1180 "expected a TU_UPDATE_LEXICAL record for TU");
1181 // If we are handling a C++ class template instantiation, we can see multiple
1182 // lexical updates for the same record. It's important that we select only one
1183 // of them, so that field numbering works properly. Just pick the first one we
1184 // see.
1185 auto &Lex = LexicalDecls[DC];
1186 if (!Lex.first) {
1187 Lex = std::make_pair(
1188 &M, llvm::makeArrayRef(
1189 reinterpret_cast<const llvm::support::unaligned_uint32_t *>(
1190 Blob.data()),
1191 Blob.size() / 4));
1192 }
1193 DC->setHasExternalLexicalStorage(true);
1194 return false;
1195 }
1196
ReadVisibleDeclContextStorage(ModuleFile & M,BitstreamCursor & Cursor,uint64_t Offset,DeclID ID)1197 bool ASTReader::ReadVisibleDeclContextStorage(ModuleFile &M,
1198 BitstreamCursor &Cursor,
1199 uint64_t Offset,
1200 DeclID ID) {
1201 assert(Offset != 0);
1202
1203 SavedStreamPosition SavedPosition(Cursor);
1204 if (llvm::Error Err = Cursor.JumpToBit(Offset)) {
1205 Error(std::move(Err));
1206 return true;
1207 }
1208
1209 RecordData Record;
1210 StringRef Blob;
1211 Expected<unsigned> MaybeCode = Cursor.ReadCode();
1212 if (!MaybeCode) {
1213 Error(MaybeCode.takeError());
1214 return true;
1215 }
1216 unsigned Code = MaybeCode.get();
1217
1218 Expected<unsigned> MaybeRecCode = Cursor.readRecord(Code, Record, &Blob);
1219 if (!MaybeRecCode) {
1220 Error(MaybeRecCode.takeError());
1221 return true;
1222 }
1223 unsigned RecCode = MaybeRecCode.get();
1224 if (RecCode != DECL_CONTEXT_VISIBLE) {
1225 Error("Expected visible lookup table block");
1226 return true;
1227 }
1228
1229 // We can't safely determine the primary context yet, so delay attaching the
1230 // lookup table until we're done with recursive deserialization.
1231 auto *Data = (const unsigned char*)Blob.data();
1232 PendingVisibleUpdates[ID].push_back(PendingVisibleUpdate{&M, Data});
1233 return false;
1234 }
1235
Error(StringRef Msg) const1236 void ASTReader::Error(StringRef Msg) const {
1237 Error(diag::err_fe_pch_malformed, Msg);
1238 if (PP.getLangOpts().Modules && !Diags.isDiagnosticInFlight() &&
1239 !PP.getHeaderSearchInfo().getModuleCachePath().empty()) {
1240 Diag(diag::note_module_cache_path)
1241 << PP.getHeaderSearchInfo().getModuleCachePath();
1242 }
1243 }
1244
Error(unsigned DiagID,StringRef Arg1,StringRef Arg2,StringRef Arg3) const1245 void ASTReader::Error(unsigned DiagID, StringRef Arg1, StringRef Arg2,
1246 StringRef Arg3) const {
1247 if (Diags.isDiagnosticInFlight())
1248 Diags.SetDelayedDiagnostic(DiagID, Arg1, Arg2, Arg3);
1249 else
1250 Diag(DiagID) << Arg1 << Arg2 << Arg3;
1251 }
1252
Error(unsigned DiagID,StringRef Arg1,StringRef Arg2,unsigned Select) const1253 void ASTReader::Error(unsigned DiagID, StringRef Arg1, StringRef Arg2,
1254 unsigned Select) const {
1255 if (!Diags.isDiagnosticInFlight())
1256 Diag(DiagID) << Arg1 << Arg2 << Select;
1257 }
1258
Error(llvm::Error && Err) const1259 void ASTReader::Error(llvm::Error &&Err) const {
1260 Error(toString(std::move(Err)));
1261 }
1262
1263 //===----------------------------------------------------------------------===//
1264 // Source Manager Deserialization
1265 //===----------------------------------------------------------------------===//
1266
1267 /// Read the line table in the source manager block.
1268 /// \returns true if there was an error.
ParseLineTable(ModuleFile & F,const RecordData & Record)1269 bool ASTReader::ParseLineTable(ModuleFile &F,
1270 const RecordData &Record) {
1271 unsigned Idx = 0;
1272 LineTableInfo &LineTable = SourceMgr.getLineTable();
1273
1274 // Parse the file names
1275 std::map<int, int> FileIDs;
1276 FileIDs[-1] = -1; // For unspecified filenames.
1277 for (unsigned I = 0; Record[Idx]; ++I) {
1278 // Extract the file name
1279 auto Filename = ReadPath(F, Record, Idx);
1280 FileIDs[I] = LineTable.getLineTableFilenameID(Filename);
1281 }
1282 ++Idx;
1283
1284 // Parse the line entries
1285 std::vector<LineEntry> Entries;
1286 while (Idx < Record.size()) {
1287 int FID = Record[Idx++];
1288 assert(FID >= 0 && "Serialized line entries for non-local file.");
1289 // Remap FileID from 1-based old view.
1290 FID += F.SLocEntryBaseID - 1;
1291
1292 // Extract the line entries
1293 unsigned NumEntries = Record[Idx++];
1294 assert(NumEntries && "no line entries for file ID");
1295 Entries.clear();
1296 Entries.reserve(NumEntries);
1297 for (unsigned I = 0; I != NumEntries; ++I) {
1298 unsigned FileOffset = Record[Idx++];
1299 unsigned LineNo = Record[Idx++];
1300 int FilenameID = FileIDs[Record[Idx++]];
1301 SrcMgr::CharacteristicKind FileKind
1302 = (SrcMgr::CharacteristicKind)Record[Idx++];
1303 unsigned IncludeOffset = Record[Idx++];
1304 Entries.push_back(LineEntry::get(FileOffset, LineNo, FilenameID,
1305 FileKind, IncludeOffset));
1306 }
1307 LineTable.AddEntry(FileID::get(FID), Entries);
1308 }
1309
1310 return false;
1311 }
1312
1313 /// Read a source manager block
ReadSourceManagerBlock(ModuleFile & F)1314 bool ASTReader::ReadSourceManagerBlock(ModuleFile &F) {
1315 using namespace SrcMgr;
1316
1317 BitstreamCursor &SLocEntryCursor = F.SLocEntryCursor;
1318
1319 // Set the source-location entry cursor to the current position in
1320 // the stream. This cursor will be used to read the contents of the
1321 // source manager block initially, and then lazily read
1322 // source-location entries as needed.
1323 SLocEntryCursor = F.Stream;
1324
1325 // The stream itself is going to skip over the source manager block.
1326 if (llvm::Error Err = F.Stream.SkipBlock()) {
1327 Error(std::move(Err));
1328 return true;
1329 }
1330
1331 // Enter the source manager block.
1332 if (llvm::Error Err =
1333 SLocEntryCursor.EnterSubBlock(SOURCE_MANAGER_BLOCK_ID)) {
1334 Error(std::move(Err));
1335 return true;
1336 }
1337
1338 RecordData Record;
1339 while (true) {
1340 Expected<llvm::BitstreamEntry> MaybeE =
1341 SLocEntryCursor.advanceSkippingSubblocks();
1342 if (!MaybeE) {
1343 Error(MaybeE.takeError());
1344 return true;
1345 }
1346 llvm::BitstreamEntry E = MaybeE.get();
1347
1348 switch (E.Kind) {
1349 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1350 case llvm::BitstreamEntry::Error:
1351 Error("malformed block record in AST file");
1352 return true;
1353 case llvm::BitstreamEntry::EndBlock:
1354 return false;
1355 case llvm::BitstreamEntry::Record:
1356 // The interesting case.
1357 break;
1358 }
1359
1360 // Read a record.
1361 Record.clear();
1362 StringRef Blob;
1363 Expected<unsigned> MaybeRecord =
1364 SLocEntryCursor.readRecord(E.ID, Record, &Blob);
1365 if (!MaybeRecord) {
1366 Error(MaybeRecord.takeError());
1367 return true;
1368 }
1369 switch (MaybeRecord.get()) {
1370 default: // Default behavior: ignore.
1371 break;
1372
1373 case SM_SLOC_FILE_ENTRY:
1374 case SM_SLOC_BUFFER_ENTRY:
1375 case SM_SLOC_EXPANSION_ENTRY:
1376 // Once we hit one of the source location entries, we're done.
1377 return false;
1378 }
1379 }
1380 }
1381
1382 /// If a header file is not found at the path that we expect it to be
1383 /// and the PCH file was moved from its original location, try to resolve the
1384 /// file by assuming that header+PCH were moved together and the header is in
1385 /// the same place relative to the PCH.
1386 static std::string
resolveFileRelativeToOriginalDir(const std::string & Filename,const std::string & OriginalDir,const std::string & CurrDir)1387 resolveFileRelativeToOriginalDir(const std::string &Filename,
1388 const std::string &OriginalDir,
1389 const std::string &CurrDir) {
1390 assert(OriginalDir != CurrDir &&
1391 "No point trying to resolve the file if the PCH dir didn't change");
1392
1393 using namespace llvm::sys;
1394
1395 SmallString<128> filePath(Filename);
1396 fs::make_absolute(filePath);
1397 assert(path::is_absolute(OriginalDir));
1398 SmallString<128> currPCHPath(CurrDir);
1399
1400 path::const_iterator fileDirI = path::begin(path::parent_path(filePath)),
1401 fileDirE = path::end(path::parent_path(filePath));
1402 path::const_iterator origDirI = path::begin(OriginalDir),
1403 origDirE = path::end(OriginalDir);
1404 // Skip the common path components from filePath and OriginalDir.
1405 while (fileDirI != fileDirE && origDirI != origDirE &&
1406 *fileDirI == *origDirI) {
1407 ++fileDirI;
1408 ++origDirI;
1409 }
1410 for (; origDirI != origDirE; ++origDirI)
1411 path::append(currPCHPath, "..");
1412 path::append(currPCHPath, fileDirI, fileDirE);
1413 path::append(currPCHPath, path::filename(Filename));
1414 return currPCHPath.str();
1415 }
1416
ReadSLocEntry(int ID)1417 bool ASTReader::ReadSLocEntry(int ID) {
1418 if (ID == 0)
1419 return false;
1420
1421 if (unsigned(-ID) - 2 >= getTotalNumSLocs() || ID > 0) {
1422 Error("source location entry ID out-of-range for AST file");
1423 return true;
1424 }
1425
1426 // Local helper to read the (possibly-compressed) buffer data following the
1427 // entry record.
1428 auto ReadBuffer = [this](
1429 BitstreamCursor &SLocEntryCursor,
1430 StringRef Name) -> std::unique_ptr<llvm::MemoryBuffer> {
1431 RecordData Record;
1432 StringRef Blob;
1433 Expected<unsigned> MaybeCode = SLocEntryCursor.ReadCode();
1434 if (!MaybeCode) {
1435 Error(MaybeCode.takeError());
1436 return nullptr;
1437 }
1438 unsigned Code = MaybeCode.get();
1439
1440 Expected<unsigned> MaybeRecCode =
1441 SLocEntryCursor.readRecord(Code, Record, &Blob);
1442 if (!MaybeRecCode) {
1443 Error(MaybeRecCode.takeError());
1444 return nullptr;
1445 }
1446 unsigned RecCode = MaybeRecCode.get();
1447
1448 if (RecCode == SM_SLOC_BUFFER_BLOB_COMPRESSED) {
1449 if (!llvm::zlib::isAvailable()) {
1450 Error("zlib is not available");
1451 return nullptr;
1452 }
1453 SmallString<0> Uncompressed;
1454 if (llvm::Error E =
1455 llvm::zlib::uncompress(Blob, Uncompressed, Record[0])) {
1456 Error("could not decompress embedded file contents: " +
1457 llvm::toString(std::move(E)));
1458 return nullptr;
1459 }
1460 return llvm::MemoryBuffer::getMemBufferCopy(Uncompressed, Name);
1461 } else if (RecCode == SM_SLOC_BUFFER_BLOB) {
1462 return llvm::MemoryBuffer::getMemBuffer(Blob.drop_back(1), Name, true);
1463 } else {
1464 Error("AST record has invalid code");
1465 return nullptr;
1466 }
1467 };
1468
1469 ModuleFile *F = GlobalSLocEntryMap.find(-ID)->second;
1470 if (llvm::Error Err = F->SLocEntryCursor.JumpToBit(
1471 F->SLocEntryOffsets[ID - F->SLocEntryBaseID])) {
1472 Error(std::move(Err));
1473 return true;
1474 }
1475
1476 BitstreamCursor &SLocEntryCursor = F->SLocEntryCursor;
1477 unsigned BaseOffset = F->SLocEntryBaseOffset;
1478
1479 ++NumSLocEntriesRead;
1480 Expected<llvm::BitstreamEntry> MaybeEntry = SLocEntryCursor.advance();
1481 if (!MaybeEntry) {
1482 Error(MaybeEntry.takeError());
1483 return true;
1484 }
1485 llvm::BitstreamEntry Entry = MaybeEntry.get();
1486
1487 if (Entry.Kind != llvm::BitstreamEntry::Record) {
1488 Error("incorrectly-formatted source location entry in AST file");
1489 return true;
1490 }
1491
1492 RecordData Record;
1493 StringRef Blob;
1494 Expected<unsigned> MaybeSLOC =
1495 SLocEntryCursor.readRecord(Entry.ID, Record, &Blob);
1496 if (!MaybeSLOC) {
1497 Error(MaybeSLOC.takeError());
1498 return true;
1499 }
1500 switch (MaybeSLOC.get()) {
1501 default:
1502 Error("incorrectly-formatted source location entry in AST file");
1503 return true;
1504
1505 case SM_SLOC_FILE_ENTRY: {
1506 // We will detect whether a file changed and return 'Failure' for it, but
1507 // we will also try to fail gracefully by setting up the SLocEntry.
1508 unsigned InputID = Record[4];
1509 InputFile IF = getInputFile(*F, InputID);
1510 const FileEntry *File = IF.getFile();
1511 bool OverriddenBuffer = IF.isOverridden();
1512
1513 // Note that we only check if a File was returned. If it was out-of-date
1514 // we have complained but we will continue creating a FileID to recover
1515 // gracefully.
1516 if (!File)
1517 return true;
1518
1519 SourceLocation IncludeLoc = ReadSourceLocation(*F, Record[1]);
1520 if (IncludeLoc.isInvalid() && F->Kind != MK_MainFile) {
1521 // This is the module's main file.
1522 IncludeLoc = getImportLocation(F);
1523 }
1524 SrcMgr::CharacteristicKind
1525 FileCharacter = (SrcMgr::CharacteristicKind)Record[2];
1526 // FIXME: The FileID should be created from the FileEntryRef.
1527 FileID FID = SourceMgr.createFileID(File, IncludeLoc, FileCharacter,
1528 ID, BaseOffset + Record[0]);
1529 SrcMgr::FileInfo &FileInfo =
1530 const_cast<SrcMgr::FileInfo&>(SourceMgr.getSLocEntry(FID).getFile());
1531 FileInfo.NumCreatedFIDs = Record[5];
1532 if (Record[3])
1533 FileInfo.setHasLineDirectives();
1534
1535 unsigned NumFileDecls = Record[7];
1536 if (NumFileDecls && ContextObj) {
1537 const DeclID *FirstDecl = F->FileSortedDecls + Record[6];
1538 assert(F->FileSortedDecls && "FILE_SORTED_DECLS not encountered yet ?");
1539 FileDeclIDs[FID] = FileDeclsInfo(F, llvm::makeArrayRef(FirstDecl,
1540 NumFileDecls));
1541 }
1542
1543 const SrcMgr::ContentCache *ContentCache
1544 = SourceMgr.getOrCreateContentCache(File, isSystem(FileCharacter));
1545 if (OverriddenBuffer && !ContentCache->BufferOverridden &&
1546 ContentCache->ContentsEntry == ContentCache->OrigEntry &&
1547 !ContentCache->getRawBuffer()) {
1548 auto Buffer = ReadBuffer(SLocEntryCursor, File->getName());
1549 if (!Buffer)
1550 return true;
1551 SourceMgr.overrideFileContents(File, std::move(Buffer));
1552 }
1553
1554 break;
1555 }
1556
1557 case SM_SLOC_BUFFER_ENTRY: {
1558 const char *Name = Blob.data();
1559 unsigned Offset = Record[0];
1560 SrcMgr::CharacteristicKind
1561 FileCharacter = (SrcMgr::CharacteristicKind)Record[2];
1562 SourceLocation IncludeLoc = ReadSourceLocation(*F, Record[1]);
1563 if (IncludeLoc.isInvalid() && F->isModule()) {
1564 IncludeLoc = getImportLocation(F);
1565 }
1566
1567 auto Buffer = ReadBuffer(SLocEntryCursor, Name);
1568 if (!Buffer)
1569 return true;
1570 SourceMgr.createFileID(std::move(Buffer), FileCharacter, ID,
1571 BaseOffset + Offset, IncludeLoc);
1572 break;
1573 }
1574
1575 case SM_SLOC_EXPANSION_ENTRY: {
1576 SourceLocation SpellingLoc = ReadSourceLocation(*F, Record[1]);
1577 SourceMgr.createExpansionLoc(SpellingLoc,
1578 ReadSourceLocation(*F, Record[2]),
1579 ReadSourceLocation(*F, Record[3]),
1580 Record[5],
1581 Record[4],
1582 ID,
1583 BaseOffset + Record[0]);
1584 break;
1585 }
1586 }
1587
1588 return false;
1589 }
1590
getModuleImportLoc(int ID)1591 std::pair<SourceLocation, StringRef> ASTReader::getModuleImportLoc(int ID) {
1592 if (ID == 0)
1593 return std::make_pair(SourceLocation(), "");
1594
1595 if (unsigned(-ID) - 2 >= getTotalNumSLocs() || ID > 0) {
1596 Error("source location entry ID out-of-range for AST file");
1597 return std::make_pair(SourceLocation(), "");
1598 }
1599
1600 // Find which module file this entry lands in.
1601 ModuleFile *M = GlobalSLocEntryMap.find(-ID)->second;
1602 if (!M->isModule())
1603 return std::make_pair(SourceLocation(), "");
1604
1605 // FIXME: Can we map this down to a particular submodule? That would be
1606 // ideal.
1607 return std::make_pair(M->ImportLoc, StringRef(M->ModuleName));
1608 }
1609
1610 /// Find the location where the module F is imported.
getImportLocation(ModuleFile * F)1611 SourceLocation ASTReader::getImportLocation(ModuleFile *F) {
1612 if (F->ImportLoc.isValid())
1613 return F->ImportLoc;
1614
1615 // Otherwise we have a PCH. It's considered to be "imported" at the first
1616 // location of its includer.
1617 if (F->ImportedBy.empty() || !F->ImportedBy[0]) {
1618 // Main file is the importer.
1619 assert(SourceMgr.getMainFileID().isValid() && "missing main file");
1620 return SourceMgr.getLocForStartOfFile(SourceMgr.getMainFileID());
1621 }
1622 return F->ImportedBy[0]->FirstLoc;
1623 }
1624
1625 /// Enter a subblock of the specified BlockID with the specified cursor. Read
1626 /// the abbreviations that are at the top of the block and then leave the cursor
1627 /// pointing into the block.
ReadBlockAbbrevs(BitstreamCursor & Cursor,unsigned BlockID)1628 bool ASTReader::ReadBlockAbbrevs(BitstreamCursor &Cursor, unsigned BlockID) {
1629 if (llvm::Error Err = Cursor.EnterSubBlock(BlockID)) {
1630 // FIXME this drops errors on the floor.
1631 consumeError(std::move(Err));
1632 return true;
1633 }
1634
1635 while (true) {
1636 uint64_t Offset = Cursor.GetCurrentBitNo();
1637 Expected<unsigned> MaybeCode = Cursor.ReadCode();
1638 if (!MaybeCode) {
1639 // FIXME this drops errors on the floor.
1640 consumeError(MaybeCode.takeError());
1641 return true;
1642 }
1643 unsigned Code = MaybeCode.get();
1644
1645 // We expect all abbrevs to be at the start of the block.
1646 if (Code != llvm::bitc::DEFINE_ABBREV) {
1647 if (llvm::Error Err = Cursor.JumpToBit(Offset)) {
1648 // FIXME this drops errors on the floor.
1649 consumeError(std::move(Err));
1650 return true;
1651 }
1652 return false;
1653 }
1654 if (llvm::Error Err = Cursor.ReadAbbrevRecord()) {
1655 // FIXME this drops errors on the floor.
1656 consumeError(std::move(Err));
1657 return true;
1658 }
1659 }
1660 }
1661
ReadToken(ModuleFile & F,const RecordDataImpl & Record,unsigned & Idx)1662 Token ASTReader::ReadToken(ModuleFile &F, const RecordDataImpl &Record,
1663 unsigned &Idx) {
1664 Token Tok;
1665 Tok.startToken();
1666 Tok.setLocation(ReadSourceLocation(F, Record, Idx));
1667 Tok.setLength(Record[Idx++]);
1668 if (IdentifierInfo *II = getLocalIdentifier(F, Record[Idx++]))
1669 Tok.setIdentifierInfo(II);
1670 Tok.setKind((tok::TokenKind)Record[Idx++]);
1671 Tok.setFlag((Token::TokenFlags)Record[Idx++]);
1672 return Tok;
1673 }
1674
ReadMacroRecord(ModuleFile & F,uint64_t Offset)1675 MacroInfo *ASTReader::ReadMacroRecord(ModuleFile &F, uint64_t Offset) {
1676 BitstreamCursor &Stream = F.MacroCursor;
1677
1678 // Keep track of where we are in the stream, then jump back there
1679 // after reading this macro.
1680 SavedStreamPosition SavedPosition(Stream);
1681
1682 if (llvm::Error Err = Stream.JumpToBit(Offset)) {
1683 // FIXME this drops errors on the floor.
1684 consumeError(std::move(Err));
1685 return nullptr;
1686 }
1687 RecordData Record;
1688 SmallVector<IdentifierInfo*, 16> MacroParams;
1689 MacroInfo *Macro = nullptr;
1690
1691 while (true) {
1692 // Advance to the next record, but if we get to the end of the block, don't
1693 // pop it (removing all the abbreviations from the cursor) since we want to
1694 // be able to reseek within the block and read entries.
1695 unsigned Flags = BitstreamCursor::AF_DontPopBlockAtEnd;
1696 Expected<llvm::BitstreamEntry> MaybeEntry =
1697 Stream.advanceSkippingSubblocks(Flags);
1698 if (!MaybeEntry) {
1699 Error(MaybeEntry.takeError());
1700 return Macro;
1701 }
1702 llvm::BitstreamEntry Entry = MaybeEntry.get();
1703
1704 switch (Entry.Kind) {
1705 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1706 case llvm::BitstreamEntry::Error:
1707 Error("malformed block record in AST file");
1708 return Macro;
1709 case llvm::BitstreamEntry::EndBlock:
1710 return Macro;
1711 case llvm::BitstreamEntry::Record:
1712 // The interesting case.
1713 break;
1714 }
1715
1716 // Read a record.
1717 Record.clear();
1718 PreprocessorRecordTypes RecType;
1719 if (Expected<unsigned> MaybeRecType = Stream.readRecord(Entry.ID, Record))
1720 RecType = (PreprocessorRecordTypes)MaybeRecType.get();
1721 else {
1722 Error(MaybeRecType.takeError());
1723 return Macro;
1724 }
1725 switch (RecType) {
1726 case PP_MODULE_MACRO:
1727 case PP_MACRO_DIRECTIVE_HISTORY:
1728 return Macro;
1729
1730 case PP_MACRO_OBJECT_LIKE:
1731 case PP_MACRO_FUNCTION_LIKE: {
1732 // If we already have a macro, that means that we've hit the end
1733 // of the definition of the macro we were looking for. We're
1734 // done.
1735 if (Macro)
1736 return Macro;
1737
1738 unsigned NextIndex = 1; // Skip identifier ID.
1739 SourceLocation Loc = ReadSourceLocation(F, Record, NextIndex);
1740 MacroInfo *MI = PP.AllocateMacroInfo(Loc);
1741 MI->setDefinitionEndLoc(ReadSourceLocation(F, Record, NextIndex));
1742 MI->setIsUsed(Record[NextIndex++]);
1743 MI->setUsedForHeaderGuard(Record[NextIndex++]);
1744
1745 if (RecType == PP_MACRO_FUNCTION_LIKE) {
1746 // Decode function-like macro info.
1747 bool isC99VarArgs = Record[NextIndex++];
1748 bool isGNUVarArgs = Record[NextIndex++];
1749 bool hasCommaPasting = Record[NextIndex++];
1750 MacroParams.clear();
1751 unsigned NumArgs = Record[NextIndex++];
1752 for (unsigned i = 0; i != NumArgs; ++i)
1753 MacroParams.push_back(getLocalIdentifier(F, Record[NextIndex++]));
1754
1755 // Install function-like macro info.
1756 MI->setIsFunctionLike();
1757 if (isC99VarArgs) MI->setIsC99Varargs();
1758 if (isGNUVarArgs) MI->setIsGNUVarargs();
1759 if (hasCommaPasting) MI->setHasCommaPasting();
1760 MI->setParameterList(MacroParams, PP.getPreprocessorAllocator());
1761 }
1762
1763 // Remember that we saw this macro last so that we add the tokens that
1764 // form its body to it.
1765 Macro = MI;
1766
1767 if (NextIndex + 1 == Record.size() && PP.getPreprocessingRecord() &&
1768 Record[NextIndex]) {
1769 // We have a macro definition. Register the association
1770 PreprocessedEntityID
1771 GlobalID = getGlobalPreprocessedEntityID(F, Record[NextIndex]);
1772 PreprocessingRecord &PPRec = *PP.getPreprocessingRecord();
1773 PreprocessingRecord::PPEntityID PPID =
1774 PPRec.getPPEntityID(GlobalID - 1, /*isLoaded=*/true);
1775 MacroDefinitionRecord *PPDef = cast_or_null<MacroDefinitionRecord>(
1776 PPRec.getPreprocessedEntity(PPID));
1777 if (PPDef)
1778 PPRec.RegisterMacroDefinition(Macro, PPDef);
1779 }
1780
1781 ++NumMacrosRead;
1782 break;
1783 }
1784
1785 case PP_TOKEN: {
1786 // If we see a TOKEN before a PP_MACRO_*, then the file is
1787 // erroneous, just pretend we didn't see this.
1788 if (!Macro) break;
1789
1790 unsigned Idx = 0;
1791 Token Tok = ReadToken(F, Record, Idx);
1792 Macro->AddTokenToBody(Tok);
1793 break;
1794 }
1795 }
1796 }
1797 }
1798
1799 PreprocessedEntityID
getGlobalPreprocessedEntityID(ModuleFile & M,unsigned LocalID) const1800 ASTReader::getGlobalPreprocessedEntityID(ModuleFile &M,
1801 unsigned LocalID) const {
1802 if (!M.ModuleOffsetMap.empty())
1803 ReadModuleOffsetMap(M);
1804
1805 ContinuousRangeMap<uint32_t, int, 2>::const_iterator
1806 I = M.PreprocessedEntityRemap.find(LocalID - NUM_PREDEF_PP_ENTITY_IDS);
1807 assert(I != M.PreprocessedEntityRemap.end()
1808 && "Invalid index into preprocessed entity index remap");
1809
1810 return LocalID + I->second;
1811 }
1812
ComputeHash(internal_key_ref ikey)1813 unsigned HeaderFileInfoTrait::ComputeHash(internal_key_ref ikey) {
1814 return llvm::hash_combine(ikey.Size, ikey.ModTime);
1815 }
1816
1817 HeaderFileInfoTrait::internal_key_type
GetInternalKey(const FileEntry * FE)1818 HeaderFileInfoTrait::GetInternalKey(const FileEntry *FE) {
1819 internal_key_type ikey = {FE->getSize(),
1820 M.HasTimestamps ? FE->getModificationTime() : 0,
1821 FE->getName(), /*Imported*/ false};
1822 return ikey;
1823 }
1824
EqualKey(internal_key_ref a,internal_key_ref b)1825 bool HeaderFileInfoTrait::EqualKey(internal_key_ref a, internal_key_ref b) {
1826 if (a.Size != b.Size || (a.ModTime && b.ModTime && a.ModTime != b.ModTime))
1827 return false;
1828
1829 if (llvm::sys::path::is_absolute(a.Filename) && a.Filename == b.Filename)
1830 return true;
1831
1832 // Determine whether the actual files are equivalent.
1833 FileManager &FileMgr = Reader.getFileManager();
1834 auto GetFile = [&](const internal_key_type &Key) -> const FileEntry* {
1835 if (!Key.Imported) {
1836 if (auto File = FileMgr.getFile(Key.Filename))
1837 return *File;
1838 return nullptr;
1839 }
1840
1841 std::string Resolved = Key.Filename;
1842 Reader.ResolveImportedPath(M, Resolved);
1843 if (auto File = FileMgr.getFile(Resolved))
1844 return *File;
1845 return nullptr;
1846 };
1847
1848 const FileEntry *FEA = GetFile(a);
1849 const FileEntry *FEB = GetFile(b);
1850 return FEA && FEA == FEB;
1851 }
1852
1853 std::pair<unsigned, unsigned>
ReadKeyDataLength(const unsigned char * & d)1854 HeaderFileInfoTrait::ReadKeyDataLength(const unsigned char*& d) {
1855 using namespace llvm::support;
1856
1857 unsigned KeyLen = (unsigned) endian::readNext<uint16_t, little, unaligned>(d);
1858 unsigned DataLen = (unsigned) *d++;
1859 return std::make_pair(KeyLen, DataLen);
1860 }
1861
1862 HeaderFileInfoTrait::internal_key_type
ReadKey(const unsigned char * d,unsigned)1863 HeaderFileInfoTrait::ReadKey(const unsigned char *d, unsigned) {
1864 using namespace llvm::support;
1865
1866 internal_key_type ikey;
1867 ikey.Size = off_t(endian::readNext<uint64_t, little, unaligned>(d));
1868 ikey.ModTime = time_t(endian::readNext<uint64_t, little, unaligned>(d));
1869 ikey.Filename = (const char *)d;
1870 ikey.Imported = true;
1871 return ikey;
1872 }
1873
1874 HeaderFileInfoTrait::data_type
ReadData(internal_key_ref key,const unsigned char * d,unsigned DataLen)1875 HeaderFileInfoTrait::ReadData(internal_key_ref key, const unsigned char *d,
1876 unsigned DataLen) {
1877 using namespace llvm::support;
1878
1879 const unsigned char *End = d + DataLen;
1880 HeaderFileInfo HFI;
1881 unsigned Flags = *d++;
1882 // FIXME: Refactor with mergeHeaderFileInfo in HeaderSearch.cpp.
1883 HFI.isImport |= (Flags >> 5) & 0x01;
1884 HFI.isPragmaOnce |= (Flags >> 4) & 0x01;
1885 HFI.DirInfo = (Flags >> 1) & 0x07;
1886 HFI.IndexHeaderMapHeader = Flags & 0x01;
1887 // FIXME: Find a better way to handle this. Maybe just store a
1888 // "has been included" flag?
1889 HFI.NumIncludes = std::max(endian::readNext<uint16_t, little, unaligned>(d),
1890 HFI.NumIncludes);
1891 HFI.ControllingMacroID = Reader.getGlobalIdentifierID(
1892 M, endian::readNext<uint32_t, little, unaligned>(d));
1893 if (unsigned FrameworkOffset =
1894 endian::readNext<uint32_t, little, unaligned>(d)) {
1895 // The framework offset is 1 greater than the actual offset,
1896 // since 0 is used as an indicator for "no framework name".
1897 StringRef FrameworkName(FrameworkStrings + FrameworkOffset - 1);
1898 HFI.Framework = HS->getUniqueFrameworkName(FrameworkName);
1899 }
1900
1901 assert((End - d) % 4 == 0 &&
1902 "Wrong data length in HeaderFileInfo deserialization");
1903 while (d != End) {
1904 uint32_t LocalSMID = endian::readNext<uint32_t, little, unaligned>(d);
1905 auto HeaderRole = static_cast<ModuleMap::ModuleHeaderRole>(LocalSMID & 3);
1906 LocalSMID >>= 2;
1907
1908 // This header is part of a module. Associate it with the module to enable
1909 // implicit module import.
1910 SubmoduleID GlobalSMID = Reader.getGlobalSubmoduleID(M, LocalSMID);
1911 Module *Mod = Reader.getSubmodule(GlobalSMID);
1912 FileManager &FileMgr = Reader.getFileManager();
1913 ModuleMap &ModMap =
1914 Reader.getPreprocessor().getHeaderSearchInfo().getModuleMap();
1915
1916 std::string Filename = key.Filename;
1917 if (key.Imported)
1918 Reader.ResolveImportedPath(M, Filename);
1919 // FIXME: This is not always the right filename-as-written, but we're not
1920 // going to use this information to rebuild the module, so it doesn't make
1921 // a lot of difference.
1922 Module::Header H = { key.Filename, *FileMgr.getFile(Filename) };
1923 ModMap.addHeader(Mod, H, HeaderRole, /*Imported*/true);
1924 HFI.isModuleHeader |= !(HeaderRole & ModuleMap::TextualHeader);
1925 }
1926
1927 // This HeaderFileInfo was externally loaded.
1928 HFI.External = true;
1929 HFI.IsValid = true;
1930 return HFI;
1931 }
1932
addPendingMacro(IdentifierInfo * II,ModuleFile * M,uint64_t MacroDirectivesOffset)1933 void ASTReader::addPendingMacro(IdentifierInfo *II,
1934 ModuleFile *M,
1935 uint64_t MacroDirectivesOffset) {
1936 assert(NumCurrentElementsDeserializing > 0 &&"Missing deserialization guard");
1937 PendingMacroIDs[II].push_back(PendingMacroInfo(M, MacroDirectivesOffset));
1938 }
1939
ReadDefinedMacros()1940 void ASTReader::ReadDefinedMacros() {
1941 // Note that we are loading defined macros.
1942 Deserializing Macros(this);
1943
1944 for (ModuleFile &I : llvm::reverse(ModuleMgr)) {
1945 BitstreamCursor &MacroCursor = I.MacroCursor;
1946
1947 // If there was no preprocessor block, skip this file.
1948 if (MacroCursor.getBitcodeBytes().empty())
1949 continue;
1950
1951 BitstreamCursor Cursor = MacroCursor;
1952 if (llvm::Error Err = Cursor.JumpToBit(I.MacroStartOffset)) {
1953 Error(std::move(Err));
1954 return;
1955 }
1956
1957 RecordData Record;
1958 while (true) {
1959 Expected<llvm::BitstreamEntry> MaybeE = Cursor.advanceSkippingSubblocks();
1960 if (!MaybeE) {
1961 Error(MaybeE.takeError());
1962 return;
1963 }
1964 llvm::BitstreamEntry E = MaybeE.get();
1965
1966 switch (E.Kind) {
1967 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1968 case llvm::BitstreamEntry::Error:
1969 Error("malformed block record in AST file");
1970 return;
1971 case llvm::BitstreamEntry::EndBlock:
1972 goto NextCursor;
1973
1974 case llvm::BitstreamEntry::Record: {
1975 Record.clear();
1976 Expected<unsigned> MaybeRecord = Cursor.readRecord(E.ID, Record);
1977 if (!MaybeRecord) {
1978 Error(MaybeRecord.takeError());
1979 return;
1980 }
1981 switch (MaybeRecord.get()) {
1982 default: // Default behavior: ignore.
1983 break;
1984
1985 case PP_MACRO_OBJECT_LIKE:
1986 case PP_MACRO_FUNCTION_LIKE: {
1987 IdentifierInfo *II = getLocalIdentifier(I, Record[0]);
1988 if (II->isOutOfDate())
1989 updateOutOfDateIdentifier(*II);
1990 break;
1991 }
1992
1993 case PP_TOKEN:
1994 // Ignore tokens.
1995 break;
1996 }
1997 break;
1998 }
1999 }
2000 }
2001 NextCursor: ;
2002 }
2003 }
2004
2005 namespace {
2006
2007 /// Visitor class used to look up identifirs in an AST file.
2008 class IdentifierLookupVisitor {
2009 StringRef Name;
2010 unsigned NameHash;
2011 unsigned PriorGeneration;
2012 unsigned &NumIdentifierLookups;
2013 unsigned &NumIdentifierLookupHits;
2014 IdentifierInfo *Found = nullptr;
2015
2016 public:
IdentifierLookupVisitor(StringRef Name,unsigned PriorGeneration,unsigned & NumIdentifierLookups,unsigned & NumIdentifierLookupHits)2017 IdentifierLookupVisitor(StringRef Name, unsigned PriorGeneration,
2018 unsigned &NumIdentifierLookups,
2019 unsigned &NumIdentifierLookupHits)
2020 : Name(Name), NameHash(ASTIdentifierLookupTrait::ComputeHash(Name)),
2021 PriorGeneration(PriorGeneration),
2022 NumIdentifierLookups(NumIdentifierLookups),
2023 NumIdentifierLookupHits(NumIdentifierLookupHits) {}
2024
operator ()(ModuleFile & M)2025 bool operator()(ModuleFile &M) {
2026 // If we've already searched this module file, skip it now.
2027 if (M.Generation <= PriorGeneration)
2028 return true;
2029
2030 ASTIdentifierLookupTable *IdTable
2031 = (ASTIdentifierLookupTable *)M.IdentifierLookupTable;
2032 if (!IdTable)
2033 return false;
2034
2035 ASTIdentifierLookupTrait Trait(IdTable->getInfoObj().getReader(), M,
2036 Found);
2037 ++NumIdentifierLookups;
2038 ASTIdentifierLookupTable::iterator Pos =
2039 IdTable->find_hashed(Name, NameHash, &Trait);
2040 if (Pos == IdTable->end())
2041 return false;
2042
2043 // Dereferencing the iterator has the effect of building the
2044 // IdentifierInfo node and populating it with the various
2045 // declarations it needs.
2046 ++NumIdentifierLookupHits;
2047 Found = *Pos;
2048 return true;
2049 }
2050
2051 // Retrieve the identifier info found within the module
2052 // files.
getIdentifierInfo() const2053 IdentifierInfo *getIdentifierInfo() const { return Found; }
2054 };
2055
2056 } // namespace
2057
updateOutOfDateIdentifier(IdentifierInfo & II)2058 void ASTReader::updateOutOfDateIdentifier(IdentifierInfo &II) {
2059 // Note that we are loading an identifier.
2060 Deserializing AnIdentifier(this);
2061
2062 unsigned PriorGeneration = 0;
2063 if (getContext().getLangOpts().Modules)
2064 PriorGeneration = IdentifierGeneration[&II];
2065
2066 // If there is a global index, look there first to determine which modules
2067 // provably do not have any results for this identifier.
2068 GlobalModuleIndex::HitSet Hits;
2069 GlobalModuleIndex::HitSet *HitsPtr = nullptr;
2070 if (!loadGlobalIndex()) {
2071 if (GlobalIndex->lookupIdentifier(II.getName(), Hits)) {
2072 HitsPtr = &Hits;
2073 }
2074 }
2075
2076 IdentifierLookupVisitor Visitor(II.getName(), PriorGeneration,
2077 NumIdentifierLookups,
2078 NumIdentifierLookupHits);
2079 ModuleMgr.visit(Visitor, HitsPtr);
2080 markIdentifierUpToDate(&II);
2081 }
2082
markIdentifierUpToDate(IdentifierInfo * II)2083 void ASTReader::markIdentifierUpToDate(IdentifierInfo *II) {
2084 if (!II)
2085 return;
2086
2087 II->setOutOfDate(false);
2088
2089 // Update the generation for this identifier.
2090 if (getContext().getLangOpts().Modules)
2091 IdentifierGeneration[II] = getGeneration();
2092 }
2093
resolvePendingMacro(IdentifierInfo * II,const PendingMacroInfo & PMInfo)2094 void ASTReader::resolvePendingMacro(IdentifierInfo *II,
2095 const PendingMacroInfo &PMInfo) {
2096 ModuleFile &M = *PMInfo.M;
2097
2098 BitstreamCursor &Cursor = M.MacroCursor;
2099 SavedStreamPosition SavedPosition(Cursor);
2100 if (llvm::Error Err = Cursor.JumpToBit(PMInfo.MacroDirectivesOffset)) {
2101 Error(std::move(Err));
2102 return;
2103 }
2104
2105 struct ModuleMacroRecord {
2106 SubmoduleID SubModID;
2107 MacroInfo *MI;
2108 SmallVector<SubmoduleID, 8> Overrides;
2109 };
2110 llvm::SmallVector<ModuleMacroRecord, 8> ModuleMacros;
2111
2112 // We expect to see a sequence of PP_MODULE_MACRO records listing exported
2113 // macros, followed by a PP_MACRO_DIRECTIVE_HISTORY record with the complete
2114 // macro histroy.
2115 RecordData Record;
2116 while (true) {
2117 Expected<llvm::BitstreamEntry> MaybeEntry =
2118 Cursor.advance(BitstreamCursor::AF_DontPopBlockAtEnd);
2119 if (!MaybeEntry) {
2120 Error(MaybeEntry.takeError());
2121 return;
2122 }
2123 llvm::BitstreamEntry Entry = MaybeEntry.get();
2124
2125 if (Entry.Kind != llvm::BitstreamEntry::Record) {
2126 Error("malformed block record in AST file");
2127 return;
2128 }
2129
2130 Record.clear();
2131 Expected<unsigned> MaybePP = Cursor.readRecord(Entry.ID, Record);
2132 if (!MaybePP) {
2133 Error(MaybePP.takeError());
2134 return;
2135 }
2136 switch ((PreprocessorRecordTypes)MaybePP.get()) {
2137 case PP_MACRO_DIRECTIVE_HISTORY:
2138 break;
2139
2140 case PP_MODULE_MACRO: {
2141 ModuleMacros.push_back(ModuleMacroRecord());
2142 auto &Info = ModuleMacros.back();
2143 Info.SubModID = getGlobalSubmoduleID(M, Record[0]);
2144 Info.MI = getMacro(getGlobalMacroID(M, Record[1]));
2145 for (int I = 2, N = Record.size(); I != N; ++I)
2146 Info.Overrides.push_back(getGlobalSubmoduleID(M, Record[I]));
2147 continue;
2148 }
2149
2150 default:
2151 Error("malformed block record in AST file");
2152 return;
2153 }
2154
2155 // We found the macro directive history; that's the last record
2156 // for this macro.
2157 break;
2158 }
2159
2160 // Module macros are listed in reverse dependency order.
2161 {
2162 std::reverse(ModuleMacros.begin(), ModuleMacros.end());
2163 llvm::SmallVector<ModuleMacro*, 8> Overrides;
2164 for (auto &MMR : ModuleMacros) {
2165 Overrides.clear();
2166 for (unsigned ModID : MMR.Overrides) {
2167 Module *Mod = getSubmodule(ModID);
2168 auto *Macro = PP.getModuleMacro(Mod, II);
2169 assert(Macro && "missing definition for overridden macro");
2170 Overrides.push_back(Macro);
2171 }
2172
2173 bool Inserted = false;
2174 Module *Owner = getSubmodule(MMR.SubModID);
2175 PP.addModuleMacro(Owner, II, MMR.MI, Overrides, Inserted);
2176 }
2177 }
2178
2179 // Don't read the directive history for a module; we don't have anywhere
2180 // to put it.
2181 if (M.isModule())
2182 return;
2183
2184 // Deserialize the macro directives history in reverse source-order.
2185 MacroDirective *Latest = nullptr, *Earliest = nullptr;
2186 unsigned Idx = 0, N = Record.size();
2187 while (Idx < N) {
2188 MacroDirective *MD = nullptr;
2189 SourceLocation Loc = ReadSourceLocation(M, Record, Idx);
2190 MacroDirective::Kind K = (MacroDirective::Kind)Record[Idx++];
2191 switch (K) {
2192 case MacroDirective::MD_Define: {
2193 MacroInfo *MI = getMacro(getGlobalMacroID(M, Record[Idx++]));
2194 MD = PP.AllocateDefMacroDirective(MI, Loc);
2195 break;
2196 }
2197 case MacroDirective::MD_Undefine:
2198 MD = PP.AllocateUndefMacroDirective(Loc);
2199 break;
2200 case MacroDirective::MD_Visibility:
2201 bool isPublic = Record[Idx++];
2202 MD = PP.AllocateVisibilityMacroDirective(Loc, isPublic);
2203 break;
2204 }
2205
2206 if (!Latest)
2207 Latest = MD;
2208 if (Earliest)
2209 Earliest->setPrevious(MD);
2210 Earliest = MD;
2211 }
2212
2213 if (Latest)
2214 PP.setLoadedMacroDirective(II, Earliest, Latest);
2215 }
2216
2217 ASTReader::InputFileInfo
readInputFileInfo(ModuleFile & F,unsigned ID)2218 ASTReader::readInputFileInfo(ModuleFile &F, unsigned ID) {
2219 // Go find this input file.
2220 BitstreamCursor &Cursor = F.InputFilesCursor;
2221 SavedStreamPosition SavedPosition(Cursor);
2222 if (llvm::Error Err = Cursor.JumpToBit(F.InputFileOffsets[ID - 1])) {
2223 // FIXME this drops errors on the floor.
2224 consumeError(std::move(Err));
2225 }
2226
2227 Expected<unsigned> MaybeCode = Cursor.ReadCode();
2228 if (!MaybeCode) {
2229 // FIXME this drops errors on the floor.
2230 consumeError(MaybeCode.takeError());
2231 }
2232 unsigned Code = MaybeCode.get();
2233 RecordData Record;
2234 StringRef Blob;
2235
2236 if (Expected<unsigned> Maybe = Cursor.readRecord(Code, Record, &Blob))
2237 assert(static_cast<InputFileRecordTypes>(Maybe.get()) == INPUT_FILE &&
2238 "invalid record type for input file");
2239 else {
2240 // FIXME this drops errors on the floor.
2241 consumeError(Maybe.takeError());
2242 }
2243
2244 assert(Record[0] == ID && "Bogus stored ID or offset");
2245 InputFileInfo R;
2246 R.StoredSize = static_cast<off_t>(Record[1]);
2247 R.StoredTime = static_cast<time_t>(Record[2]);
2248 R.Overridden = static_cast<bool>(Record[3]);
2249 R.Transient = static_cast<bool>(Record[4]);
2250 R.TopLevelModuleMap = static_cast<bool>(Record[5]);
2251 R.Filename = Blob;
2252 ResolveImportedPath(F, R.Filename);
2253
2254 Expected<llvm::BitstreamEntry> MaybeEntry = Cursor.advance();
2255 if (!MaybeEntry) // FIXME this drops errors on the floor.
2256 consumeError(MaybeEntry.takeError());
2257 llvm::BitstreamEntry Entry = MaybeEntry.get();
2258 assert(Entry.Kind == llvm::BitstreamEntry::Record &&
2259 "expected record type for input file hash");
2260
2261 Record.clear();
2262 if (Expected<unsigned> Maybe = Cursor.readRecord(Entry.ID, Record))
2263 assert(static_cast<InputFileRecordTypes>(Maybe.get()) == INPUT_FILE_HASH &&
2264 "invalid record type for input file hash");
2265 else {
2266 // FIXME this drops errors on the floor.
2267 consumeError(Maybe.takeError());
2268 }
2269 R.ContentHash = (static_cast<uint64_t>(Record[1]) << 32) |
2270 static_cast<uint64_t>(Record[0]);
2271 return R;
2272 }
2273
2274 static unsigned moduleKindForDiagnostic(ModuleKind Kind);
getInputFile(ModuleFile & F,unsigned ID,bool Complain)2275 InputFile ASTReader::getInputFile(ModuleFile &F, unsigned ID, bool Complain) {
2276 // If this ID is bogus, just return an empty input file.
2277 if (ID == 0 || ID > F.InputFilesLoaded.size())
2278 return InputFile();
2279
2280 // If we've already loaded this input file, return it.
2281 if (F.InputFilesLoaded[ID-1].getFile())
2282 return F.InputFilesLoaded[ID-1];
2283
2284 if (F.InputFilesLoaded[ID-1].isNotFound())
2285 return InputFile();
2286
2287 // Go find this input file.
2288 BitstreamCursor &Cursor = F.InputFilesCursor;
2289 SavedStreamPosition SavedPosition(Cursor);
2290 if (llvm::Error Err = Cursor.JumpToBit(F.InputFileOffsets[ID - 1])) {
2291 // FIXME this drops errors on the floor.
2292 consumeError(std::move(Err));
2293 }
2294
2295 InputFileInfo FI = readInputFileInfo(F, ID);
2296 off_t StoredSize = FI.StoredSize;
2297 time_t StoredTime = FI.StoredTime;
2298 bool Overridden = FI.Overridden;
2299 bool Transient = FI.Transient;
2300 StringRef Filename = FI.Filename;
2301 uint64_t StoredContentHash = FI.ContentHash;
2302
2303 const FileEntry *File = nullptr;
2304 if (auto FE = FileMgr.getFile(Filename, /*OpenFile=*/false))
2305 File = *FE;
2306
2307 // If we didn't find the file, resolve it relative to the
2308 // original directory from which this AST file was created.
2309 if (File == nullptr && !F.OriginalDir.empty() && !F.BaseDirectory.empty() &&
2310 F.OriginalDir != F.BaseDirectory) {
2311 std::string Resolved = resolveFileRelativeToOriginalDir(
2312 Filename, F.OriginalDir, F.BaseDirectory);
2313 if (!Resolved.empty())
2314 if (auto FE = FileMgr.getFile(Resolved))
2315 File = *FE;
2316 }
2317
2318 // For an overridden file, create a virtual file with the stored
2319 // size/timestamp.
2320 if ((Overridden || Transient) && File == nullptr)
2321 File = FileMgr.getVirtualFile(Filename, StoredSize, StoredTime);
2322
2323 if (File == nullptr) {
2324 if (Complain) {
2325 std::string ErrorStr = "could not find file '";
2326 ErrorStr += Filename;
2327 ErrorStr += "' referenced by AST file '";
2328 ErrorStr += F.FileName;
2329 ErrorStr += "'";
2330 Error(ErrorStr);
2331 }
2332 // Record that we didn't find the file.
2333 F.InputFilesLoaded[ID-1] = InputFile::getNotFound();
2334 return InputFile();
2335 }
2336
2337 // Check if there was a request to override the contents of the file
2338 // that was part of the precompiled header. Overriding such a file
2339 // can lead to problems when lexing using the source locations from the
2340 // PCH.
2341 SourceManager &SM = getSourceManager();
2342 // FIXME: Reject if the overrides are different.
2343 if ((!Overridden && !Transient) && SM.isFileOverridden(File)) {
2344 if (Complain)
2345 Error(diag::err_fe_pch_file_overridden, Filename);
2346
2347 // After emitting the diagnostic, bypass the overriding file to recover
2348 // (this creates a separate FileEntry).
2349 File = SM.bypassFileContentsOverride(*File);
2350 if (!File) {
2351 F.InputFilesLoaded[ID - 1] = InputFile::getNotFound();
2352 return InputFile();
2353 }
2354 }
2355
2356 enum ModificationType {
2357 Size,
2358 ModTime,
2359 Content,
2360 None,
2361 };
2362 auto HasInputFileChanged = [&]() {
2363 if (StoredSize != File->getSize())
2364 return ModificationType::Size;
2365 if (!DisableValidation && StoredTime &&
2366 StoredTime != File->getModificationTime()) {
2367 // In case the modification time changes but not the content,
2368 // accept the cached file as legit.
2369 if (ValidateASTInputFilesContent &&
2370 StoredContentHash != static_cast<uint64_t>(llvm::hash_code(-1))) {
2371 auto MemBuffOrError = FileMgr.getBufferForFile(File);
2372 if (!MemBuffOrError) {
2373 if (!Complain)
2374 return ModificationType::ModTime;
2375 std::string ErrorStr = "could not get buffer for file '";
2376 ErrorStr += File->getName();
2377 ErrorStr += "'";
2378 Error(ErrorStr);
2379 return ModificationType::ModTime;
2380 }
2381
2382 auto ContentHash = hash_value(MemBuffOrError.get()->getBuffer());
2383 if (StoredContentHash == static_cast<uint64_t>(ContentHash))
2384 return ModificationType::None;
2385 return ModificationType::Content;
2386 }
2387 return ModificationType::ModTime;
2388 }
2389 return ModificationType::None;
2390 };
2391
2392 bool IsOutOfDate = false;
2393 auto FileChange = HasInputFileChanged();
2394 // For an overridden file, there is nothing to validate.
2395 if (!Overridden && FileChange != ModificationType::None) {
2396 if (Complain) {
2397 // Build a list of the PCH imports that got us here (in reverse).
2398 SmallVector<ModuleFile *, 4> ImportStack(1, &F);
2399 while (!ImportStack.back()->ImportedBy.empty())
2400 ImportStack.push_back(ImportStack.back()->ImportedBy[0]);
2401
2402 // The top-level PCH is stale.
2403 StringRef TopLevelPCHName(ImportStack.back()->FileName);
2404 unsigned DiagnosticKind =
2405 moduleKindForDiagnostic(ImportStack.back()->Kind);
2406 if (DiagnosticKind == 0)
2407 Error(diag::err_fe_pch_file_modified, Filename, TopLevelPCHName,
2408 (unsigned)FileChange);
2409 else if (DiagnosticKind == 1)
2410 Error(diag::err_fe_module_file_modified, Filename, TopLevelPCHName,
2411 (unsigned)FileChange);
2412 else
2413 Error(diag::err_fe_ast_file_modified, Filename, TopLevelPCHName,
2414 (unsigned)FileChange);
2415
2416 // Print the import stack.
2417 if (ImportStack.size() > 1 && !Diags.isDiagnosticInFlight()) {
2418 Diag(diag::note_pch_required_by)
2419 << Filename << ImportStack[0]->FileName;
2420 for (unsigned I = 1; I < ImportStack.size(); ++I)
2421 Diag(diag::note_pch_required_by)
2422 << ImportStack[I-1]->FileName << ImportStack[I]->FileName;
2423 }
2424
2425 if (!Diags.isDiagnosticInFlight())
2426 Diag(diag::note_pch_rebuild_required) << TopLevelPCHName;
2427 }
2428
2429 IsOutOfDate = true;
2430 }
2431 // FIXME: If the file is overridden and we've already opened it,
2432 // issue an error (or split it into a separate FileEntry).
2433
2434 InputFile IF = InputFile(File, Overridden || Transient, IsOutOfDate);
2435
2436 // Note that we've loaded this input file.
2437 F.InputFilesLoaded[ID-1] = IF;
2438 return IF;
2439 }
2440
2441 /// If we are loading a relocatable PCH or module file, and the filename
2442 /// is not an absolute path, add the system or module root to the beginning of
2443 /// the file name.
ResolveImportedPath(ModuleFile & M,std::string & Filename)2444 void ASTReader::ResolveImportedPath(ModuleFile &M, std::string &Filename) {
2445 // Resolve relative to the base directory, if we have one.
2446 if (!M.BaseDirectory.empty())
2447 return ResolveImportedPath(Filename, M.BaseDirectory);
2448 }
2449
ResolveImportedPath(std::string & Filename,StringRef Prefix)2450 void ASTReader::ResolveImportedPath(std::string &Filename, StringRef Prefix) {
2451 if (Filename.empty() || llvm::sys::path::is_absolute(Filename))
2452 return;
2453
2454 SmallString<128> Buffer;
2455 llvm::sys::path::append(Buffer, Prefix, Filename);
2456 Filename.assign(Buffer.begin(), Buffer.end());
2457 }
2458
isDiagnosedResult(ASTReader::ASTReadResult ARR,unsigned Caps)2459 static bool isDiagnosedResult(ASTReader::ASTReadResult ARR, unsigned Caps) {
2460 switch (ARR) {
2461 case ASTReader::Failure: return true;
2462 case ASTReader::Missing: return !(Caps & ASTReader::ARR_Missing);
2463 case ASTReader::OutOfDate: return !(Caps & ASTReader::ARR_OutOfDate);
2464 case ASTReader::VersionMismatch: return !(Caps & ASTReader::ARR_VersionMismatch);
2465 case ASTReader::ConfigurationMismatch:
2466 return !(Caps & ASTReader::ARR_ConfigurationMismatch);
2467 case ASTReader::HadErrors: return true;
2468 case ASTReader::Success: return false;
2469 }
2470
2471 llvm_unreachable("unknown ASTReadResult");
2472 }
2473
ReadOptionsBlock(BitstreamCursor & Stream,unsigned ClientLoadCapabilities,bool AllowCompatibleConfigurationMismatch,ASTReaderListener & Listener,std::string & SuggestedPredefines)2474 ASTReader::ASTReadResult ASTReader::ReadOptionsBlock(
2475 BitstreamCursor &Stream, unsigned ClientLoadCapabilities,
2476 bool AllowCompatibleConfigurationMismatch, ASTReaderListener &Listener,
2477 std::string &SuggestedPredefines) {
2478 if (llvm::Error Err = Stream.EnterSubBlock(OPTIONS_BLOCK_ID)) {
2479 // FIXME this drops errors on the floor.
2480 consumeError(std::move(Err));
2481 return Failure;
2482 }
2483
2484 // Read all of the records in the options block.
2485 RecordData Record;
2486 ASTReadResult Result = Success;
2487 while (true) {
2488 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
2489 if (!MaybeEntry) {
2490 // FIXME this drops errors on the floor.
2491 consumeError(MaybeEntry.takeError());
2492 return Failure;
2493 }
2494 llvm::BitstreamEntry Entry = MaybeEntry.get();
2495
2496 switch (Entry.Kind) {
2497 case llvm::BitstreamEntry::Error:
2498 case llvm::BitstreamEntry::SubBlock:
2499 return Failure;
2500
2501 case llvm::BitstreamEntry::EndBlock:
2502 return Result;
2503
2504 case llvm::BitstreamEntry::Record:
2505 // The interesting case.
2506 break;
2507 }
2508
2509 // Read and process a record.
2510 Record.clear();
2511 Expected<unsigned> MaybeRecordType = Stream.readRecord(Entry.ID, Record);
2512 if (!MaybeRecordType) {
2513 // FIXME this drops errors on the floor.
2514 consumeError(MaybeRecordType.takeError());
2515 return Failure;
2516 }
2517 switch ((OptionsRecordTypes)MaybeRecordType.get()) {
2518 case LANGUAGE_OPTIONS: {
2519 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2520 if (ParseLanguageOptions(Record, Complain, Listener,
2521 AllowCompatibleConfigurationMismatch))
2522 Result = ConfigurationMismatch;
2523 break;
2524 }
2525
2526 case TARGET_OPTIONS: {
2527 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2528 if (ParseTargetOptions(Record, Complain, Listener,
2529 AllowCompatibleConfigurationMismatch))
2530 Result = ConfigurationMismatch;
2531 break;
2532 }
2533
2534 case FILE_SYSTEM_OPTIONS: {
2535 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2536 if (!AllowCompatibleConfigurationMismatch &&
2537 ParseFileSystemOptions(Record, Complain, Listener))
2538 Result = ConfigurationMismatch;
2539 break;
2540 }
2541
2542 case HEADER_SEARCH_OPTIONS: {
2543 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2544 if (!AllowCompatibleConfigurationMismatch &&
2545 ParseHeaderSearchOptions(Record, Complain, Listener))
2546 Result = ConfigurationMismatch;
2547 break;
2548 }
2549
2550 case PREPROCESSOR_OPTIONS:
2551 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2552 if (!AllowCompatibleConfigurationMismatch &&
2553 ParsePreprocessorOptions(Record, Complain, Listener,
2554 SuggestedPredefines))
2555 Result = ConfigurationMismatch;
2556 break;
2557 }
2558 }
2559 }
2560
2561 ASTReader::ASTReadResult
ReadControlBlock(ModuleFile & F,SmallVectorImpl<ImportedModule> & Loaded,const ModuleFile * ImportedBy,unsigned ClientLoadCapabilities)2562 ASTReader::ReadControlBlock(ModuleFile &F,
2563 SmallVectorImpl<ImportedModule> &Loaded,
2564 const ModuleFile *ImportedBy,
2565 unsigned ClientLoadCapabilities) {
2566 BitstreamCursor &Stream = F.Stream;
2567
2568 if (llvm::Error Err = Stream.EnterSubBlock(CONTROL_BLOCK_ID)) {
2569 Error(std::move(Err));
2570 return Failure;
2571 }
2572
2573 // Lambda to read the unhashed control block the first time it's called.
2574 //
2575 // For PCM files, the unhashed control block cannot be read until after the
2576 // MODULE_NAME record. However, PCH files have no MODULE_NAME, and yet still
2577 // need to look ahead before reading the IMPORTS record. For consistency,
2578 // this block is always read somehow (see BitstreamEntry::EndBlock).
2579 bool HasReadUnhashedControlBlock = false;
2580 auto readUnhashedControlBlockOnce = [&]() {
2581 if (!HasReadUnhashedControlBlock) {
2582 HasReadUnhashedControlBlock = true;
2583 if (ASTReadResult Result =
2584 readUnhashedControlBlock(F, ImportedBy, ClientLoadCapabilities))
2585 return Result;
2586 }
2587 return Success;
2588 };
2589
2590 // Read all of the records and blocks in the control block.
2591 RecordData Record;
2592 unsigned NumInputs = 0;
2593 unsigned NumUserInputs = 0;
2594 StringRef BaseDirectoryAsWritten;
2595 while (true) {
2596 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
2597 if (!MaybeEntry) {
2598 Error(MaybeEntry.takeError());
2599 return Failure;
2600 }
2601 llvm::BitstreamEntry Entry = MaybeEntry.get();
2602
2603 switch (Entry.Kind) {
2604 case llvm::BitstreamEntry::Error:
2605 Error("malformed block record in AST file");
2606 return Failure;
2607 case llvm::BitstreamEntry::EndBlock: {
2608 // Validate the module before returning. This call catches an AST with
2609 // no module name and no imports.
2610 if (ASTReadResult Result = readUnhashedControlBlockOnce())
2611 return Result;
2612
2613 // Validate input files.
2614 const HeaderSearchOptions &HSOpts =
2615 PP.getHeaderSearchInfo().getHeaderSearchOpts();
2616
2617 // All user input files reside at the index range [0, NumUserInputs), and
2618 // system input files reside at [NumUserInputs, NumInputs). For explicitly
2619 // loaded module files, ignore missing inputs.
2620 if (!DisableValidation && F.Kind != MK_ExplicitModule &&
2621 F.Kind != MK_PrebuiltModule) {
2622 bool Complain = (ClientLoadCapabilities & ARR_OutOfDate) == 0;
2623
2624 // If we are reading a module, we will create a verification timestamp,
2625 // so we verify all input files. Otherwise, verify only user input
2626 // files.
2627
2628 unsigned N = NumUserInputs;
2629 if (ValidateSystemInputs ||
2630 (HSOpts.ModulesValidateOncePerBuildSession &&
2631 F.InputFilesValidationTimestamp <= HSOpts.BuildSessionTimestamp &&
2632 F.Kind == MK_ImplicitModule))
2633 N = NumInputs;
2634
2635 for (unsigned I = 0; I < N; ++I) {
2636 InputFile IF = getInputFile(F, I+1, Complain);
2637 if (!IF.getFile() || IF.isOutOfDate())
2638 return OutOfDate;
2639 }
2640 }
2641
2642 if (Listener)
2643 Listener->visitModuleFile(F.FileName, F.Kind);
2644
2645 if (Listener && Listener->needsInputFileVisitation()) {
2646 unsigned N = Listener->needsSystemInputFileVisitation() ? NumInputs
2647 : NumUserInputs;
2648 for (unsigned I = 0; I < N; ++I) {
2649 bool IsSystem = I >= NumUserInputs;
2650 InputFileInfo FI = readInputFileInfo(F, I+1);
2651 Listener->visitInputFile(FI.Filename, IsSystem, FI.Overridden,
2652 F.Kind == MK_ExplicitModule ||
2653 F.Kind == MK_PrebuiltModule);
2654 }
2655 }
2656
2657 return Success;
2658 }
2659
2660 case llvm::BitstreamEntry::SubBlock:
2661 switch (Entry.ID) {
2662 case INPUT_FILES_BLOCK_ID:
2663 F.InputFilesCursor = Stream;
2664 if (llvm::Error Err = Stream.SkipBlock()) {
2665 Error(std::move(Err));
2666 return Failure;
2667 }
2668 if (ReadBlockAbbrevs(F.InputFilesCursor, INPUT_FILES_BLOCK_ID)) {
2669 Error("malformed block record in AST file");
2670 return Failure;
2671 }
2672 continue;
2673
2674 case OPTIONS_BLOCK_ID:
2675 // If we're reading the first module for this group, check its options
2676 // are compatible with ours. For modules it imports, no further checking
2677 // is required, because we checked them when we built it.
2678 if (Listener && !ImportedBy) {
2679 // Should we allow the configuration of the module file to differ from
2680 // the configuration of the current translation unit in a compatible
2681 // way?
2682 //
2683 // FIXME: Allow this for files explicitly specified with -include-pch.
2684 bool AllowCompatibleConfigurationMismatch =
2685 F.Kind == MK_ExplicitModule || F.Kind == MK_PrebuiltModule;
2686
2687 ASTReadResult Result =
2688 ReadOptionsBlock(Stream, ClientLoadCapabilities,
2689 AllowCompatibleConfigurationMismatch, *Listener,
2690 SuggestedPredefines);
2691 if (Result == Failure) {
2692 Error("malformed block record in AST file");
2693 return Result;
2694 }
2695
2696 if (DisableValidation ||
2697 (AllowConfigurationMismatch && Result == ConfigurationMismatch))
2698 Result = Success;
2699
2700 // If we can't load the module, exit early since we likely
2701 // will rebuild the module anyway. The stream may be in the
2702 // middle of a block.
2703 if (Result != Success)
2704 return Result;
2705 } else if (llvm::Error Err = Stream.SkipBlock()) {
2706 Error(std::move(Err));
2707 return Failure;
2708 }
2709 continue;
2710
2711 default:
2712 if (llvm::Error Err = Stream.SkipBlock()) {
2713 Error(std::move(Err));
2714 return Failure;
2715 }
2716 continue;
2717 }
2718
2719 case llvm::BitstreamEntry::Record:
2720 // The interesting case.
2721 break;
2722 }
2723
2724 // Read and process a record.
2725 Record.clear();
2726 StringRef Blob;
2727 Expected<unsigned> MaybeRecordType =
2728 Stream.readRecord(Entry.ID, Record, &Blob);
2729 if (!MaybeRecordType) {
2730 Error(MaybeRecordType.takeError());
2731 return Failure;
2732 }
2733 switch ((ControlRecordTypes)MaybeRecordType.get()) {
2734 case METADATA: {
2735 if (Record[0] != VERSION_MAJOR && !DisableValidation) {
2736 if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
2737 Diag(Record[0] < VERSION_MAJOR? diag::err_pch_version_too_old
2738 : diag::err_pch_version_too_new);
2739 return VersionMismatch;
2740 }
2741
2742 bool hasErrors = Record[7];
2743 if (hasErrors && !DisableValidation && !AllowASTWithCompilerErrors) {
2744 Diag(diag::err_pch_with_compiler_errors);
2745 return HadErrors;
2746 }
2747 if (hasErrors) {
2748 Diags.ErrorOccurred = true;
2749 Diags.UncompilableErrorOccurred = true;
2750 Diags.UnrecoverableErrorOccurred = true;
2751 }
2752
2753 F.RelocatablePCH = Record[4];
2754 // Relative paths in a relocatable PCH are relative to our sysroot.
2755 if (F.RelocatablePCH)
2756 F.BaseDirectory = isysroot.empty() ? "/" : isysroot;
2757
2758 F.HasTimestamps = Record[5];
2759
2760 F.PCHHasObjectFile = Record[6];
2761
2762 const std::string &CurBranch = getClangFullRepositoryVersion();
2763 StringRef ASTBranch = Blob;
2764 if (StringRef(CurBranch) != ASTBranch && !DisableValidation) {
2765 if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
2766 Diag(diag::err_pch_different_branch) << ASTBranch << CurBranch;
2767 return VersionMismatch;
2768 }
2769 break;
2770 }
2771
2772 case IMPORTS: {
2773 // Validate the AST before processing any imports (otherwise, untangling
2774 // them can be error-prone and expensive). A module will have a name and
2775 // will already have been validated, but this catches the PCH case.
2776 if (ASTReadResult Result = readUnhashedControlBlockOnce())
2777 return Result;
2778
2779 // Load each of the imported PCH files.
2780 unsigned Idx = 0, N = Record.size();
2781 while (Idx < N) {
2782 // Read information about the AST file.
2783 ModuleKind ImportedKind = (ModuleKind)Record[Idx++];
2784 // The import location will be the local one for now; we will adjust
2785 // all import locations of module imports after the global source
2786 // location info are setup, in ReadAST.
2787 SourceLocation ImportLoc =
2788 ReadUntranslatedSourceLocation(Record[Idx++]);
2789 off_t StoredSize = (off_t)Record[Idx++];
2790 time_t StoredModTime = (time_t)Record[Idx++];
2791 ASTFileSignature StoredSignature = {
2792 {{(uint32_t)Record[Idx++], (uint32_t)Record[Idx++],
2793 (uint32_t)Record[Idx++], (uint32_t)Record[Idx++],
2794 (uint32_t)Record[Idx++]}}};
2795
2796 std::string ImportedName = ReadString(Record, Idx);
2797 std::string ImportedFile;
2798
2799 // For prebuilt and explicit modules first consult the file map for
2800 // an override. Note that here we don't search prebuilt module
2801 // directories, only the explicit name to file mappings. Also, we will
2802 // still verify the size/signature making sure it is essentially the
2803 // same file but perhaps in a different location.
2804 if (ImportedKind == MK_PrebuiltModule || ImportedKind == MK_ExplicitModule)
2805 ImportedFile = PP.getHeaderSearchInfo().getPrebuiltModuleFileName(
2806 ImportedName, /*FileMapOnly*/ true);
2807
2808 if (ImportedFile.empty())
2809 // Use BaseDirectoryAsWritten to ensure we use the same path in the
2810 // ModuleCache as when writing.
2811 ImportedFile = ReadPath(BaseDirectoryAsWritten, Record, Idx);
2812 else
2813 SkipPath(Record, Idx);
2814
2815 // If our client can't cope with us being out of date, we can't cope with
2816 // our dependency being missing.
2817 unsigned Capabilities = ClientLoadCapabilities;
2818 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
2819 Capabilities &= ~ARR_Missing;
2820
2821 // Load the AST file.
2822 auto Result = ReadASTCore(ImportedFile, ImportedKind, ImportLoc, &F,
2823 Loaded, StoredSize, StoredModTime,
2824 StoredSignature, Capabilities);
2825
2826 // If we diagnosed a problem, produce a backtrace.
2827 if (isDiagnosedResult(Result, Capabilities))
2828 Diag(diag::note_module_file_imported_by)
2829 << F.FileName << !F.ModuleName.empty() << F.ModuleName;
2830
2831 switch (Result) {
2832 case Failure: return Failure;
2833 // If we have to ignore the dependency, we'll have to ignore this too.
2834 case Missing:
2835 case OutOfDate: return OutOfDate;
2836 case VersionMismatch: return VersionMismatch;
2837 case ConfigurationMismatch: return ConfigurationMismatch;
2838 case HadErrors: return HadErrors;
2839 case Success: break;
2840 }
2841 }
2842 break;
2843 }
2844
2845 case ORIGINAL_FILE:
2846 F.OriginalSourceFileID = FileID::get(Record[0]);
2847 F.ActualOriginalSourceFileName = Blob;
2848 F.OriginalSourceFileName = F.ActualOriginalSourceFileName;
2849 ResolveImportedPath(F, F.OriginalSourceFileName);
2850 break;
2851
2852 case ORIGINAL_FILE_ID:
2853 F.OriginalSourceFileID = FileID::get(Record[0]);
2854 break;
2855
2856 case ORIGINAL_PCH_DIR:
2857 F.OriginalDir = Blob;
2858 break;
2859
2860 case MODULE_NAME:
2861 F.ModuleName = Blob;
2862 Diag(diag::remark_module_import)
2863 << F.ModuleName << F.FileName << (ImportedBy ? true : false)
2864 << (ImportedBy ? StringRef(ImportedBy->ModuleName) : StringRef());
2865 if (Listener)
2866 Listener->ReadModuleName(F.ModuleName);
2867
2868 // Validate the AST as soon as we have a name so we can exit early on
2869 // failure.
2870 if (ASTReadResult Result = readUnhashedControlBlockOnce())
2871 return Result;
2872
2873 break;
2874
2875 case MODULE_DIRECTORY: {
2876 // Save the BaseDirectory as written in the PCM for computing the module
2877 // filename for the ModuleCache.
2878 BaseDirectoryAsWritten = Blob;
2879 assert(!F.ModuleName.empty() &&
2880 "MODULE_DIRECTORY found before MODULE_NAME");
2881 // If we've already loaded a module map file covering this module, we may
2882 // have a better path for it (relative to the current build).
2883 Module *M = PP.getHeaderSearchInfo().lookupModule(
2884 F.ModuleName, /*AllowSearch*/ true,
2885 /*AllowExtraModuleMapSearch*/ true);
2886 if (M && M->Directory) {
2887 // If we're implicitly loading a module, the base directory can't
2888 // change between the build and use.
2889 // Don't emit module relocation error if we have -fno-validate-pch
2890 if (!PP.getPreprocessorOpts().DisablePCHValidation &&
2891 F.Kind != MK_ExplicitModule && F.Kind != MK_PrebuiltModule) {
2892 auto BuildDir = PP.getFileManager().getDirectory(Blob);
2893 if (!BuildDir || *BuildDir != M->Directory) {
2894 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
2895 Diag(diag::err_imported_module_relocated)
2896 << F.ModuleName << Blob << M->Directory->getName();
2897 return OutOfDate;
2898 }
2899 }
2900 F.BaseDirectory = M->Directory->getName();
2901 } else {
2902 F.BaseDirectory = Blob;
2903 }
2904 break;
2905 }
2906
2907 case MODULE_MAP_FILE:
2908 if (ASTReadResult Result =
2909 ReadModuleMapFileBlock(Record, F, ImportedBy, ClientLoadCapabilities))
2910 return Result;
2911 break;
2912
2913 case INPUT_FILE_OFFSETS:
2914 NumInputs = Record[0];
2915 NumUserInputs = Record[1];
2916 F.InputFileOffsets =
2917 (const llvm::support::unaligned_uint64_t *)Blob.data();
2918 F.InputFilesLoaded.resize(NumInputs);
2919 F.NumUserInputFiles = NumUserInputs;
2920 break;
2921 }
2922 }
2923 }
2924
2925 ASTReader::ASTReadResult
ReadASTBlock(ModuleFile & F,unsigned ClientLoadCapabilities)2926 ASTReader::ReadASTBlock(ModuleFile &F, unsigned ClientLoadCapabilities) {
2927 BitstreamCursor &Stream = F.Stream;
2928
2929 if (llvm::Error Err = Stream.EnterSubBlock(AST_BLOCK_ID)) {
2930 Error(std::move(Err));
2931 return Failure;
2932 }
2933
2934 // Read all of the records and blocks for the AST file.
2935 RecordData Record;
2936 while (true) {
2937 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
2938 if (!MaybeEntry) {
2939 Error(MaybeEntry.takeError());
2940 return Failure;
2941 }
2942 llvm::BitstreamEntry Entry = MaybeEntry.get();
2943
2944 switch (Entry.Kind) {
2945 case llvm::BitstreamEntry::Error:
2946 Error("error at end of module block in AST file");
2947 return Failure;
2948 case llvm::BitstreamEntry::EndBlock:
2949 // Outside of C++, we do not store a lookup map for the translation unit.
2950 // Instead, mark it as needing a lookup map to be built if this module
2951 // contains any declarations lexically within it (which it always does!).
2952 // This usually has no cost, since we very rarely need the lookup map for
2953 // the translation unit outside C++.
2954 if (ASTContext *Ctx = ContextObj) {
2955 DeclContext *DC = Ctx->getTranslationUnitDecl();
2956 if (DC->hasExternalLexicalStorage() && !Ctx->getLangOpts().CPlusPlus)
2957 DC->setMustBuildLookupTable();
2958 }
2959
2960 return Success;
2961 case llvm::BitstreamEntry::SubBlock:
2962 switch (Entry.ID) {
2963 case DECLTYPES_BLOCK_ID:
2964 // We lazily load the decls block, but we want to set up the
2965 // DeclsCursor cursor to point into it. Clone our current bitcode
2966 // cursor to it, enter the block and read the abbrevs in that block.
2967 // With the main cursor, we just skip over it.
2968 F.DeclsCursor = Stream;
2969 if (llvm::Error Err = Stream.SkipBlock()) {
2970 Error(std::move(Err));
2971 return Failure;
2972 }
2973 if (ReadBlockAbbrevs(F.DeclsCursor, DECLTYPES_BLOCK_ID)) {
2974 Error("malformed block record in AST file");
2975 return Failure;
2976 }
2977 break;
2978
2979 case PREPROCESSOR_BLOCK_ID:
2980 F.MacroCursor = Stream;
2981 if (!PP.getExternalSource())
2982 PP.setExternalSource(this);
2983
2984 if (llvm::Error Err = Stream.SkipBlock()) {
2985 Error(std::move(Err));
2986 return Failure;
2987 }
2988 if (ReadBlockAbbrevs(F.MacroCursor, PREPROCESSOR_BLOCK_ID)) {
2989 Error("malformed block record in AST file");
2990 return Failure;
2991 }
2992 F.MacroStartOffset = F.MacroCursor.GetCurrentBitNo();
2993 break;
2994
2995 case PREPROCESSOR_DETAIL_BLOCK_ID:
2996 F.PreprocessorDetailCursor = Stream;
2997
2998 if (llvm::Error Err = Stream.SkipBlock()) {
2999 Error(std::move(Err));
3000 return Failure;
3001 }
3002 if (ReadBlockAbbrevs(F.PreprocessorDetailCursor,
3003 PREPROCESSOR_DETAIL_BLOCK_ID)) {
3004 Error("malformed preprocessor detail record in AST file");
3005 return Failure;
3006 }
3007 F.PreprocessorDetailStartOffset
3008 = F.PreprocessorDetailCursor.GetCurrentBitNo();
3009
3010 if (!PP.getPreprocessingRecord())
3011 PP.createPreprocessingRecord();
3012 if (!PP.getPreprocessingRecord()->getExternalSource())
3013 PP.getPreprocessingRecord()->SetExternalSource(*this);
3014 break;
3015
3016 case SOURCE_MANAGER_BLOCK_ID:
3017 if (ReadSourceManagerBlock(F))
3018 return Failure;
3019 break;
3020
3021 case SUBMODULE_BLOCK_ID:
3022 if (ASTReadResult Result =
3023 ReadSubmoduleBlock(F, ClientLoadCapabilities))
3024 return Result;
3025 break;
3026
3027 case COMMENTS_BLOCK_ID: {
3028 BitstreamCursor C = Stream;
3029
3030 if (llvm::Error Err = Stream.SkipBlock()) {
3031 Error(std::move(Err));
3032 return Failure;
3033 }
3034 if (ReadBlockAbbrevs(C, COMMENTS_BLOCK_ID)) {
3035 Error("malformed comments block in AST file");
3036 return Failure;
3037 }
3038 CommentsCursors.push_back(std::make_pair(C, &F));
3039 break;
3040 }
3041
3042 default:
3043 if (llvm::Error Err = Stream.SkipBlock()) {
3044 Error(std::move(Err));
3045 return Failure;
3046 }
3047 break;
3048 }
3049 continue;
3050
3051 case llvm::BitstreamEntry::Record:
3052 // The interesting case.
3053 break;
3054 }
3055
3056 // Read and process a record.
3057 Record.clear();
3058 StringRef Blob;
3059 Expected<unsigned> MaybeRecordType =
3060 Stream.readRecord(Entry.ID, Record, &Blob);
3061 if (!MaybeRecordType) {
3062 Error(MaybeRecordType.takeError());
3063 return Failure;
3064 }
3065 ASTRecordTypes RecordType = (ASTRecordTypes)MaybeRecordType.get();
3066
3067 // If we're not loading an AST context, we don't care about most records.
3068 if (!ContextObj) {
3069 switch (RecordType) {
3070 case IDENTIFIER_TABLE:
3071 case IDENTIFIER_OFFSET:
3072 case INTERESTING_IDENTIFIERS:
3073 case STATISTICS:
3074 case PP_CONDITIONAL_STACK:
3075 case PP_COUNTER_VALUE:
3076 case SOURCE_LOCATION_OFFSETS:
3077 case MODULE_OFFSET_MAP:
3078 case SOURCE_MANAGER_LINE_TABLE:
3079 case SOURCE_LOCATION_PRELOADS:
3080 case PPD_ENTITIES_OFFSETS:
3081 case HEADER_SEARCH_TABLE:
3082 case IMPORTED_MODULES:
3083 case MACRO_OFFSET:
3084 break;
3085 default:
3086 continue;
3087 }
3088 }
3089
3090 switch (RecordType) {
3091 default: // Default behavior: ignore.
3092 break;
3093
3094 case TYPE_OFFSET: {
3095 if (F.LocalNumTypes != 0) {
3096 Error("duplicate TYPE_OFFSET record in AST file");
3097 return Failure;
3098 }
3099 F.TypeOffsets = (const uint32_t *)Blob.data();
3100 F.LocalNumTypes = Record[0];
3101 unsigned LocalBaseTypeIndex = Record[1];
3102 F.BaseTypeIndex = getTotalNumTypes();
3103
3104 if (F.LocalNumTypes > 0) {
3105 // Introduce the global -> local mapping for types within this module.
3106 GlobalTypeMap.insert(std::make_pair(getTotalNumTypes(), &F));
3107
3108 // Introduce the local -> global mapping for types within this module.
3109 F.TypeRemap.insertOrReplace(
3110 std::make_pair(LocalBaseTypeIndex,
3111 F.BaseTypeIndex - LocalBaseTypeIndex));
3112
3113 TypesLoaded.resize(TypesLoaded.size() + F.LocalNumTypes);
3114 }
3115 break;
3116 }
3117
3118 case DECL_OFFSET: {
3119 if (F.LocalNumDecls != 0) {
3120 Error("duplicate DECL_OFFSET record in AST file");
3121 return Failure;
3122 }
3123 F.DeclOffsets = (const DeclOffset *)Blob.data();
3124 F.LocalNumDecls = Record[0];
3125 unsigned LocalBaseDeclID = Record[1];
3126 F.BaseDeclID = getTotalNumDecls();
3127
3128 if (F.LocalNumDecls > 0) {
3129 // Introduce the global -> local mapping for declarations within this
3130 // module.
3131 GlobalDeclMap.insert(
3132 std::make_pair(getTotalNumDecls() + NUM_PREDEF_DECL_IDS, &F));
3133
3134 // Introduce the local -> global mapping for declarations within this
3135 // module.
3136 F.DeclRemap.insertOrReplace(
3137 std::make_pair(LocalBaseDeclID, F.BaseDeclID - LocalBaseDeclID));
3138
3139 // Introduce the global -> local mapping for declarations within this
3140 // module.
3141 F.GlobalToLocalDeclIDs[&F] = LocalBaseDeclID;
3142
3143 DeclsLoaded.resize(DeclsLoaded.size() + F.LocalNumDecls);
3144 }
3145 break;
3146 }
3147
3148 case TU_UPDATE_LEXICAL: {
3149 DeclContext *TU = ContextObj->getTranslationUnitDecl();
3150 LexicalContents Contents(
3151 reinterpret_cast<const llvm::support::unaligned_uint32_t *>(
3152 Blob.data()),
3153 static_cast<unsigned int>(Blob.size() / 4));
3154 TULexicalDecls.push_back(std::make_pair(&F, Contents));
3155 TU->setHasExternalLexicalStorage(true);
3156 break;
3157 }
3158
3159 case UPDATE_VISIBLE: {
3160 unsigned Idx = 0;
3161 serialization::DeclID ID = ReadDeclID(F, Record, Idx);
3162 auto *Data = (const unsigned char*)Blob.data();
3163 PendingVisibleUpdates[ID].push_back(PendingVisibleUpdate{&F, Data});
3164 // If we've already loaded the decl, perform the updates when we finish
3165 // loading this block.
3166 if (Decl *D = GetExistingDecl(ID))
3167 PendingUpdateRecords.push_back(
3168 PendingUpdateRecord(ID, D, /*JustLoaded=*/false));
3169 break;
3170 }
3171
3172 case IDENTIFIER_TABLE:
3173 F.IdentifierTableData = Blob.data();
3174 if (Record[0]) {
3175 F.IdentifierLookupTable = ASTIdentifierLookupTable::Create(
3176 (const unsigned char *)F.IdentifierTableData + Record[0],
3177 (const unsigned char *)F.IdentifierTableData + sizeof(uint32_t),
3178 (const unsigned char *)F.IdentifierTableData,
3179 ASTIdentifierLookupTrait(*this, F));
3180
3181 PP.getIdentifierTable().setExternalIdentifierLookup(this);
3182 }
3183 break;
3184
3185 case IDENTIFIER_OFFSET: {
3186 if (F.LocalNumIdentifiers != 0) {
3187 Error("duplicate IDENTIFIER_OFFSET record in AST file");
3188 return Failure;
3189 }
3190 F.IdentifierOffsets = (const uint32_t *)Blob.data();
3191 F.LocalNumIdentifiers = Record[0];
3192 unsigned LocalBaseIdentifierID = Record[1];
3193 F.BaseIdentifierID = getTotalNumIdentifiers();
3194
3195 if (F.LocalNumIdentifiers > 0) {
3196 // Introduce the global -> local mapping for identifiers within this
3197 // module.
3198 GlobalIdentifierMap.insert(std::make_pair(getTotalNumIdentifiers() + 1,
3199 &F));
3200
3201 // Introduce the local -> global mapping for identifiers within this
3202 // module.
3203 F.IdentifierRemap.insertOrReplace(
3204 std::make_pair(LocalBaseIdentifierID,
3205 F.BaseIdentifierID - LocalBaseIdentifierID));
3206
3207 IdentifiersLoaded.resize(IdentifiersLoaded.size()
3208 + F.LocalNumIdentifiers);
3209 }
3210 break;
3211 }
3212
3213 case INTERESTING_IDENTIFIERS:
3214 F.PreloadIdentifierOffsets.assign(Record.begin(), Record.end());
3215 break;
3216
3217 case EAGERLY_DESERIALIZED_DECLS:
3218 // FIXME: Skip reading this record if our ASTConsumer doesn't care
3219 // about "interesting" decls (for instance, if we're building a module).
3220 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3221 EagerlyDeserializedDecls.push_back(getGlobalDeclID(F, Record[I]));
3222 break;
3223
3224 case MODULAR_CODEGEN_DECLS:
3225 // FIXME: Skip reading this record if our ASTConsumer doesn't care about
3226 // them (ie: if we're not codegenerating this module).
3227 if (F.Kind == MK_MainFile)
3228 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3229 EagerlyDeserializedDecls.push_back(getGlobalDeclID(F, Record[I]));
3230 break;
3231
3232 case SPECIAL_TYPES:
3233 if (SpecialTypes.empty()) {
3234 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3235 SpecialTypes.push_back(getGlobalTypeID(F, Record[I]));
3236 break;
3237 }
3238
3239 if (SpecialTypes.size() != Record.size()) {
3240 Error("invalid special-types record");
3241 return Failure;
3242 }
3243
3244 for (unsigned I = 0, N = Record.size(); I != N; ++I) {
3245 serialization::TypeID ID = getGlobalTypeID(F, Record[I]);
3246 if (!SpecialTypes[I])
3247 SpecialTypes[I] = ID;
3248 // FIXME: If ID && SpecialTypes[I] != ID, do we need a separate
3249 // merge step?
3250 }
3251 break;
3252
3253 case STATISTICS:
3254 TotalNumStatements += Record[0];
3255 TotalNumMacros += Record[1];
3256 TotalLexicalDeclContexts += Record[2];
3257 TotalVisibleDeclContexts += Record[3];
3258 break;
3259
3260 case UNUSED_FILESCOPED_DECLS:
3261 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3262 UnusedFileScopedDecls.push_back(getGlobalDeclID(F, Record[I]));
3263 break;
3264
3265 case DELEGATING_CTORS:
3266 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3267 DelegatingCtorDecls.push_back(getGlobalDeclID(F, Record[I]));
3268 break;
3269
3270 case WEAK_UNDECLARED_IDENTIFIERS:
3271 if (Record.size() % 4 != 0) {
3272 Error("invalid weak identifiers record");
3273 return Failure;
3274 }
3275
3276 // FIXME: Ignore weak undeclared identifiers from non-original PCH
3277 // files. This isn't the way to do it :)
3278 WeakUndeclaredIdentifiers.clear();
3279
3280 // Translate the weak, undeclared identifiers into global IDs.
3281 for (unsigned I = 0, N = Record.size(); I < N; /* in loop */) {
3282 WeakUndeclaredIdentifiers.push_back(
3283 getGlobalIdentifierID(F, Record[I++]));
3284 WeakUndeclaredIdentifiers.push_back(
3285 getGlobalIdentifierID(F, Record[I++]));
3286 WeakUndeclaredIdentifiers.push_back(
3287 ReadSourceLocation(F, Record, I).getRawEncoding());
3288 WeakUndeclaredIdentifiers.push_back(Record[I++]);
3289 }
3290 break;
3291
3292 case SELECTOR_OFFSETS: {
3293 F.SelectorOffsets = (const uint32_t *)Blob.data();
3294 F.LocalNumSelectors = Record[0];
3295 unsigned LocalBaseSelectorID = Record[1];
3296 F.BaseSelectorID = getTotalNumSelectors();
3297
3298 if (F.LocalNumSelectors > 0) {
3299 // Introduce the global -> local mapping for selectors within this
3300 // module.
3301 GlobalSelectorMap.insert(std::make_pair(getTotalNumSelectors()+1, &F));
3302
3303 // Introduce the local -> global mapping for selectors within this
3304 // module.
3305 F.SelectorRemap.insertOrReplace(
3306 std::make_pair(LocalBaseSelectorID,
3307 F.BaseSelectorID - LocalBaseSelectorID));
3308
3309 SelectorsLoaded.resize(SelectorsLoaded.size() + F.LocalNumSelectors);
3310 }
3311 break;
3312 }
3313
3314 case METHOD_POOL:
3315 F.SelectorLookupTableData = (const unsigned char *)Blob.data();
3316 if (Record[0])
3317 F.SelectorLookupTable
3318 = ASTSelectorLookupTable::Create(
3319 F.SelectorLookupTableData + Record[0],
3320 F.SelectorLookupTableData,
3321 ASTSelectorLookupTrait(*this, F));
3322 TotalNumMethodPoolEntries += Record[1];
3323 break;
3324
3325 case REFERENCED_SELECTOR_POOL:
3326 if (!Record.empty()) {
3327 for (unsigned Idx = 0, N = Record.size() - 1; Idx < N; /* in loop */) {
3328 ReferencedSelectorsData.push_back(getGlobalSelectorID(F,
3329 Record[Idx++]));
3330 ReferencedSelectorsData.push_back(ReadSourceLocation(F, Record, Idx).
3331 getRawEncoding());
3332 }
3333 }
3334 break;
3335
3336 case PP_CONDITIONAL_STACK:
3337 if (!Record.empty()) {
3338 unsigned Idx = 0, End = Record.size() - 1;
3339 bool ReachedEOFWhileSkipping = Record[Idx++];
3340 llvm::Optional<Preprocessor::PreambleSkipInfo> SkipInfo;
3341 if (ReachedEOFWhileSkipping) {
3342 SourceLocation HashToken = ReadSourceLocation(F, Record, Idx);
3343 SourceLocation IfTokenLoc = ReadSourceLocation(F, Record, Idx);
3344 bool FoundNonSkipPortion = Record[Idx++];
3345 bool FoundElse = Record[Idx++];
3346 SourceLocation ElseLoc = ReadSourceLocation(F, Record, Idx);
3347 SkipInfo.emplace(HashToken, IfTokenLoc, FoundNonSkipPortion,
3348 FoundElse, ElseLoc);
3349 }
3350 SmallVector<PPConditionalInfo, 4> ConditionalStack;
3351 while (Idx < End) {
3352 auto Loc = ReadSourceLocation(F, Record, Idx);
3353 bool WasSkipping = Record[Idx++];
3354 bool FoundNonSkip = Record[Idx++];
3355 bool FoundElse = Record[Idx++];
3356 ConditionalStack.push_back(
3357 {Loc, WasSkipping, FoundNonSkip, FoundElse});
3358 }
3359 PP.setReplayablePreambleConditionalStack(ConditionalStack, SkipInfo);
3360 }
3361 break;
3362
3363 case PP_COUNTER_VALUE:
3364 if (!Record.empty() && Listener)
3365 Listener->ReadCounter(F, Record[0]);
3366 break;
3367
3368 case FILE_SORTED_DECLS:
3369 F.FileSortedDecls = (const DeclID *)Blob.data();
3370 F.NumFileSortedDecls = Record[0];
3371 break;
3372
3373 case SOURCE_LOCATION_OFFSETS: {
3374 F.SLocEntryOffsets = (const uint32_t *)Blob.data();
3375 F.LocalNumSLocEntries = Record[0];
3376 unsigned SLocSpaceSize = Record[1];
3377 std::tie(F.SLocEntryBaseID, F.SLocEntryBaseOffset) =
3378 SourceMgr.AllocateLoadedSLocEntries(F.LocalNumSLocEntries,
3379 SLocSpaceSize);
3380 if (!F.SLocEntryBaseID) {
3381 Error("ran out of source locations");
3382 break;
3383 }
3384 // Make our entry in the range map. BaseID is negative and growing, so
3385 // we invert it. Because we invert it, though, we need the other end of
3386 // the range.
3387 unsigned RangeStart =
3388 unsigned(-F.SLocEntryBaseID) - F.LocalNumSLocEntries + 1;
3389 GlobalSLocEntryMap.insert(std::make_pair(RangeStart, &F));
3390 F.FirstLoc = SourceLocation::getFromRawEncoding(F.SLocEntryBaseOffset);
3391
3392 // SLocEntryBaseOffset is lower than MaxLoadedOffset and decreasing.
3393 assert((F.SLocEntryBaseOffset & (1U << 31U)) == 0);
3394 GlobalSLocOffsetMap.insert(
3395 std::make_pair(SourceManager::MaxLoadedOffset - F.SLocEntryBaseOffset
3396 - SLocSpaceSize,&F));
3397
3398 // Initialize the remapping table.
3399 // Invalid stays invalid.
3400 F.SLocRemap.insertOrReplace(std::make_pair(0U, 0));
3401 // This module. Base was 2 when being compiled.
3402 F.SLocRemap.insertOrReplace(std::make_pair(2U,
3403 static_cast<int>(F.SLocEntryBaseOffset - 2)));
3404
3405 TotalNumSLocEntries += F.LocalNumSLocEntries;
3406 break;
3407 }
3408
3409 case MODULE_OFFSET_MAP:
3410 F.ModuleOffsetMap = Blob;
3411 break;
3412
3413 case SOURCE_MANAGER_LINE_TABLE:
3414 if (ParseLineTable(F, Record)) {
3415 Error("malformed SOURCE_MANAGER_LINE_TABLE in AST file");
3416 return Failure;
3417 }
3418 break;
3419
3420 case SOURCE_LOCATION_PRELOADS: {
3421 // Need to transform from the local view (1-based IDs) to the global view,
3422 // which is based off F.SLocEntryBaseID.
3423 if (!F.PreloadSLocEntries.empty()) {
3424 Error("Multiple SOURCE_LOCATION_PRELOADS records in AST file");
3425 return Failure;
3426 }
3427
3428 F.PreloadSLocEntries.swap(Record);
3429 break;
3430 }
3431
3432 case EXT_VECTOR_DECLS:
3433 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3434 ExtVectorDecls.push_back(getGlobalDeclID(F, Record[I]));
3435 break;
3436
3437 case VTABLE_USES:
3438 if (Record.size() % 3 != 0) {
3439 Error("Invalid VTABLE_USES record");
3440 return Failure;
3441 }
3442
3443 // Later tables overwrite earlier ones.
3444 // FIXME: Modules will have some trouble with this. This is clearly not
3445 // the right way to do this.
3446 VTableUses.clear();
3447
3448 for (unsigned Idx = 0, N = Record.size(); Idx != N; /* In loop */) {
3449 VTableUses.push_back(getGlobalDeclID(F, Record[Idx++]));
3450 VTableUses.push_back(
3451 ReadSourceLocation(F, Record, Idx).getRawEncoding());
3452 VTableUses.push_back(Record[Idx++]);
3453 }
3454 break;
3455
3456 case PENDING_IMPLICIT_INSTANTIATIONS:
3457 if (PendingInstantiations.size() % 2 != 0) {
3458 Error("Invalid existing PendingInstantiations");
3459 return Failure;
3460 }
3461
3462 if (Record.size() % 2 != 0) {
3463 Error("Invalid PENDING_IMPLICIT_INSTANTIATIONS block");
3464 return Failure;
3465 }
3466
3467 for (unsigned I = 0, N = Record.size(); I != N; /* in loop */) {
3468 PendingInstantiations.push_back(getGlobalDeclID(F, Record[I++]));
3469 PendingInstantiations.push_back(
3470 ReadSourceLocation(F, Record, I).getRawEncoding());
3471 }
3472 break;
3473
3474 case SEMA_DECL_REFS:
3475 if (Record.size() != 3) {
3476 Error("Invalid SEMA_DECL_REFS block");
3477 return Failure;
3478 }
3479 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3480 SemaDeclRefs.push_back(getGlobalDeclID(F, Record[I]));
3481 break;
3482
3483 case PPD_ENTITIES_OFFSETS: {
3484 F.PreprocessedEntityOffsets = (const PPEntityOffset *)Blob.data();
3485 assert(Blob.size() % sizeof(PPEntityOffset) == 0);
3486 F.NumPreprocessedEntities = Blob.size() / sizeof(PPEntityOffset);
3487
3488 unsigned LocalBasePreprocessedEntityID = Record[0];
3489
3490 unsigned StartingID;
3491 if (!PP.getPreprocessingRecord())
3492 PP.createPreprocessingRecord();
3493 if (!PP.getPreprocessingRecord()->getExternalSource())
3494 PP.getPreprocessingRecord()->SetExternalSource(*this);
3495 StartingID
3496 = PP.getPreprocessingRecord()
3497 ->allocateLoadedEntities(F.NumPreprocessedEntities);
3498 F.BasePreprocessedEntityID = StartingID;
3499
3500 if (F.NumPreprocessedEntities > 0) {
3501 // Introduce the global -> local mapping for preprocessed entities in
3502 // this module.
3503 GlobalPreprocessedEntityMap.insert(std::make_pair(StartingID, &F));
3504
3505 // Introduce the local -> global mapping for preprocessed entities in
3506 // this module.
3507 F.PreprocessedEntityRemap.insertOrReplace(
3508 std::make_pair(LocalBasePreprocessedEntityID,
3509 F.BasePreprocessedEntityID - LocalBasePreprocessedEntityID));
3510 }
3511
3512 break;
3513 }
3514
3515 case PPD_SKIPPED_RANGES: {
3516 F.PreprocessedSkippedRangeOffsets = (const PPSkippedRange*)Blob.data();
3517 assert(Blob.size() % sizeof(PPSkippedRange) == 0);
3518 F.NumPreprocessedSkippedRanges = Blob.size() / sizeof(PPSkippedRange);
3519
3520 if (!PP.getPreprocessingRecord())
3521 PP.createPreprocessingRecord();
3522 if (!PP.getPreprocessingRecord()->getExternalSource())
3523 PP.getPreprocessingRecord()->SetExternalSource(*this);
3524 F.BasePreprocessedSkippedRangeID = PP.getPreprocessingRecord()
3525 ->allocateSkippedRanges(F.NumPreprocessedSkippedRanges);
3526
3527 if (F.NumPreprocessedSkippedRanges > 0)
3528 GlobalSkippedRangeMap.insert(
3529 std::make_pair(F.BasePreprocessedSkippedRangeID, &F));
3530 break;
3531 }
3532
3533 case DECL_UPDATE_OFFSETS:
3534 if (Record.size() % 2 != 0) {
3535 Error("invalid DECL_UPDATE_OFFSETS block in AST file");
3536 return Failure;
3537 }
3538 for (unsigned I = 0, N = Record.size(); I != N; I += 2) {
3539 GlobalDeclID ID = getGlobalDeclID(F, Record[I]);
3540 DeclUpdateOffsets[ID].push_back(std::make_pair(&F, Record[I + 1]));
3541
3542 // If we've already loaded the decl, perform the updates when we finish
3543 // loading this block.
3544 if (Decl *D = GetExistingDecl(ID))
3545 PendingUpdateRecords.push_back(
3546 PendingUpdateRecord(ID, D, /*JustLoaded=*/false));
3547 }
3548 break;
3549
3550 case OBJC_CATEGORIES_MAP:
3551 if (F.LocalNumObjCCategoriesInMap != 0) {
3552 Error("duplicate OBJC_CATEGORIES_MAP record in AST file");
3553 return Failure;
3554 }
3555
3556 F.LocalNumObjCCategoriesInMap = Record[0];
3557 F.ObjCCategoriesMap = (const ObjCCategoriesInfo *)Blob.data();
3558 break;
3559
3560 case OBJC_CATEGORIES:
3561 F.ObjCCategories.swap(Record);
3562 break;
3563
3564 case CUDA_SPECIAL_DECL_REFS:
3565 // Later tables overwrite earlier ones.
3566 // FIXME: Modules will have trouble with this.
3567 CUDASpecialDeclRefs.clear();
3568 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3569 CUDASpecialDeclRefs.push_back(getGlobalDeclID(F, Record[I]));
3570 break;
3571
3572 case HEADER_SEARCH_TABLE:
3573 F.HeaderFileInfoTableData = Blob.data();
3574 F.LocalNumHeaderFileInfos = Record[1];
3575 if (Record[0]) {
3576 F.HeaderFileInfoTable
3577 = HeaderFileInfoLookupTable::Create(
3578 (const unsigned char *)F.HeaderFileInfoTableData + Record[0],
3579 (const unsigned char *)F.HeaderFileInfoTableData,
3580 HeaderFileInfoTrait(*this, F,
3581 &PP.getHeaderSearchInfo(),
3582 Blob.data() + Record[2]));
3583
3584 PP.getHeaderSearchInfo().SetExternalSource(this);
3585 if (!PP.getHeaderSearchInfo().getExternalLookup())
3586 PP.getHeaderSearchInfo().SetExternalLookup(this);
3587 }
3588 break;
3589
3590 case FP_PRAGMA_OPTIONS:
3591 // Later tables overwrite earlier ones.
3592 FPPragmaOptions.swap(Record);
3593 break;
3594
3595 case OPENCL_EXTENSIONS:
3596 for (unsigned I = 0, E = Record.size(); I != E; ) {
3597 auto Name = ReadString(Record, I);
3598 auto &Opt = OpenCLExtensions.OptMap[Name];
3599 Opt.Supported = Record[I++] != 0;
3600 Opt.Enabled = Record[I++] != 0;
3601 Opt.Avail = Record[I++];
3602 Opt.Core = Record[I++];
3603 }
3604 break;
3605
3606 case OPENCL_EXTENSION_TYPES:
3607 for (unsigned I = 0, E = Record.size(); I != E;) {
3608 auto TypeID = static_cast<::TypeID>(Record[I++]);
3609 auto *Type = GetType(TypeID).getTypePtr();
3610 auto NumExt = static_cast<unsigned>(Record[I++]);
3611 for (unsigned II = 0; II != NumExt; ++II) {
3612 auto Ext = ReadString(Record, I);
3613 OpenCLTypeExtMap[Type].insert(Ext);
3614 }
3615 }
3616 break;
3617
3618 case OPENCL_EXTENSION_DECLS:
3619 for (unsigned I = 0, E = Record.size(); I != E;) {
3620 auto DeclID = static_cast<::DeclID>(Record[I++]);
3621 auto *Decl = GetDecl(DeclID);
3622 auto NumExt = static_cast<unsigned>(Record[I++]);
3623 for (unsigned II = 0; II != NumExt; ++II) {
3624 auto Ext = ReadString(Record, I);
3625 OpenCLDeclExtMap[Decl].insert(Ext);
3626 }
3627 }
3628 break;
3629
3630 case TENTATIVE_DEFINITIONS:
3631 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3632 TentativeDefinitions.push_back(getGlobalDeclID(F, Record[I]));
3633 break;
3634
3635 case KNOWN_NAMESPACES:
3636 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3637 KnownNamespaces.push_back(getGlobalDeclID(F, Record[I]));
3638 break;
3639
3640 case UNDEFINED_BUT_USED:
3641 if (UndefinedButUsed.size() % 2 != 0) {
3642 Error("Invalid existing UndefinedButUsed");
3643 return Failure;
3644 }
3645
3646 if (Record.size() % 2 != 0) {
3647 Error("invalid undefined-but-used record");
3648 return Failure;
3649 }
3650 for (unsigned I = 0, N = Record.size(); I != N; /* in loop */) {
3651 UndefinedButUsed.push_back(getGlobalDeclID(F, Record[I++]));
3652 UndefinedButUsed.push_back(
3653 ReadSourceLocation(F, Record, I).getRawEncoding());
3654 }
3655 break;
3656
3657 case DELETE_EXPRS_TO_ANALYZE:
3658 for (unsigned I = 0, N = Record.size(); I != N;) {
3659 DelayedDeleteExprs.push_back(getGlobalDeclID(F, Record[I++]));
3660 const uint64_t Count = Record[I++];
3661 DelayedDeleteExprs.push_back(Count);
3662 for (uint64_t C = 0; C < Count; ++C) {
3663 DelayedDeleteExprs.push_back(ReadSourceLocation(F, Record, I).getRawEncoding());
3664 bool IsArrayForm = Record[I++] == 1;
3665 DelayedDeleteExprs.push_back(IsArrayForm);
3666 }
3667 }
3668 break;
3669
3670 case IMPORTED_MODULES:
3671 if (!F.isModule()) {
3672 // If we aren't loading a module (which has its own exports), make
3673 // all of the imported modules visible.
3674 // FIXME: Deal with macros-only imports.
3675 for (unsigned I = 0, N = Record.size(); I != N; /**/) {
3676 unsigned GlobalID = getGlobalSubmoduleID(F, Record[I++]);
3677 SourceLocation Loc = ReadSourceLocation(F, Record, I);
3678 if (GlobalID) {
3679 ImportedModules.push_back(ImportedSubmodule(GlobalID, Loc));
3680 if (DeserializationListener)
3681 DeserializationListener->ModuleImportRead(GlobalID, Loc);
3682 }
3683 }
3684 }
3685 break;
3686
3687 case MACRO_OFFSET: {
3688 if (F.LocalNumMacros != 0) {
3689 Error("duplicate MACRO_OFFSET record in AST file");
3690 return Failure;
3691 }
3692 F.MacroOffsets = (const uint32_t *)Blob.data();
3693 F.LocalNumMacros = Record[0];
3694 unsigned LocalBaseMacroID = Record[1];
3695 F.BaseMacroID = getTotalNumMacros();
3696
3697 if (F.LocalNumMacros > 0) {
3698 // Introduce the global -> local mapping for macros within this module.
3699 GlobalMacroMap.insert(std::make_pair(getTotalNumMacros() + 1, &F));
3700
3701 // Introduce the local -> global mapping for macros within this module.
3702 F.MacroRemap.insertOrReplace(
3703 std::make_pair(LocalBaseMacroID,
3704 F.BaseMacroID - LocalBaseMacroID));
3705
3706 MacrosLoaded.resize(MacrosLoaded.size() + F.LocalNumMacros);
3707 }
3708 break;
3709 }
3710
3711 case LATE_PARSED_TEMPLATE:
3712 LateParsedTemplates.append(Record.begin(), Record.end());
3713 break;
3714
3715 case OPTIMIZE_PRAGMA_OPTIONS:
3716 if (Record.size() != 1) {
3717 Error("invalid pragma optimize record");
3718 return Failure;
3719 }
3720 OptimizeOffPragmaLocation = ReadSourceLocation(F, Record[0]);
3721 break;
3722
3723 case MSSTRUCT_PRAGMA_OPTIONS:
3724 if (Record.size() != 1) {
3725 Error("invalid pragma ms_struct record");
3726 return Failure;
3727 }
3728 PragmaMSStructState = Record[0];
3729 break;
3730
3731 case POINTERS_TO_MEMBERS_PRAGMA_OPTIONS:
3732 if (Record.size() != 2) {
3733 Error("invalid pragma ms_struct record");
3734 return Failure;
3735 }
3736 PragmaMSPointersToMembersState = Record[0];
3737 PointersToMembersPragmaLocation = ReadSourceLocation(F, Record[1]);
3738 break;
3739
3740 case UNUSED_LOCAL_TYPEDEF_NAME_CANDIDATES:
3741 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3742 UnusedLocalTypedefNameCandidates.push_back(
3743 getGlobalDeclID(F, Record[I]));
3744 break;
3745
3746 case CUDA_PRAGMA_FORCE_HOST_DEVICE_DEPTH:
3747 if (Record.size() != 1) {
3748 Error("invalid cuda pragma options record");
3749 return Failure;
3750 }
3751 ForceCUDAHostDeviceDepth = Record[0];
3752 break;
3753
3754 case PACK_PRAGMA_OPTIONS: {
3755 if (Record.size() < 3) {
3756 Error("invalid pragma pack record");
3757 return Failure;
3758 }
3759 PragmaPackCurrentValue = Record[0];
3760 PragmaPackCurrentLocation = ReadSourceLocation(F, Record[1]);
3761 unsigned NumStackEntries = Record[2];
3762 unsigned Idx = 3;
3763 // Reset the stack when importing a new module.
3764 PragmaPackStack.clear();
3765 for (unsigned I = 0; I < NumStackEntries; ++I) {
3766 PragmaPackStackEntry Entry;
3767 Entry.Value = Record[Idx++];
3768 Entry.Location = ReadSourceLocation(F, Record[Idx++]);
3769 Entry.PushLocation = ReadSourceLocation(F, Record[Idx++]);
3770 PragmaPackStrings.push_back(ReadString(Record, Idx));
3771 Entry.SlotLabel = PragmaPackStrings.back();
3772 PragmaPackStack.push_back(Entry);
3773 }
3774 break;
3775 }
3776 }
3777 }
3778 }
3779
ReadModuleOffsetMap(ModuleFile & F) const3780 void ASTReader::ReadModuleOffsetMap(ModuleFile &F) const {
3781 assert(!F.ModuleOffsetMap.empty() && "no module offset map to read");
3782
3783 // Additional remapping information.
3784 const unsigned char *Data = (const unsigned char*)F.ModuleOffsetMap.data();
3785 const unsigned char *DataEnd = Data + F.ModuleOffsetMap.size();
3786 F.ModuleOffsetMap = StringRef();
3787
3788 // If we see this entry before SOURCE_LOCATION_OFFSETS, add placeholders.
3789 if (F.SLocRemap.find(0) == F.SLocRemap.end()) {
3790 F.SLocRemap.insert(std::make_pair(0U, 0));
3791 F.SLocRemap.insert(std::make_pair(2U, 1));
3792 }
3793
3794 // Continuous range maps we may be updating in our module.
3795 using RemapBuilder = ContinuousRangeMap<uint32_t, int, 2>::Builder;
3796 RemapBuilder SLocRemap(F.SLocRemap);
3797 RemapBuilder IdentifierRemap(F.IdentifierRemap);
3798 RemapBuilder MacroRemap(F.MacroRemap);
3799 RemapBuilder PreprocessedEntityRemap(F.PreprocessedEntityRemap);
3800 RemapBuilder SubmoduleRemap(F.SubmoduleRemap);
3801 RemapBuilder SelectorRemap(F.SelectorRemap);
3802 RemapBuilder DeclRemap(F.DeclRemap);
3803 RemapBuilder TypeRemap(F.TypeRemap);
3804
3805 while (Data < DataEnd) {
3806 // FIXME: Looking up dependency modules by filename is horrible. Let's
3807 // start fixing this with prebuilt and explicit modules and see how it
3808 // goes...
3809 using namespace llvm::support;
3810 ModuleKind Kind = static_cast<ModuleKind>(
3811 endian::readNext<uint8_t, little, unaligned>(Data));
3812 uint16_t Len = endian::readNext<uint16_t, little, unaligned>(Data);
3813 StringRef Name = StringRef((const char*)Data, Len);
3814 Data += Len;
3815 ModuleFile *OM = (Kind == MK_PrebuiltModule || Kind == MK_ExplicitModule
3816 ? ModuleMgr.lookupByModuleName(Name)
3817 : ModuleMgr.lookupByFileName(Name));
3818 if (!OM) {
3819 std::string Msg =
3820 "SourceLocation remap refers to unknown module, cannot find ";
3821 Msg.append(Name);
3822 Error(Msg);
3823 return;
3824 }
3825
3826 uint32_t SLocOffset =
3827 endian::readNext<uint32_t, little, unaligned>(Data);
3828 uint32_t IdentifierIDOffset =
3829 endian::readNext<uint32_t, little, unaligned>(Data);
3830 uint32_t MacroIDOffset =
3831 endian::readNext<uint32_t, little, unaligned>(Data);
3832 uint32_t PreprocessedEntityIDOffset =
3833 endian::readNext<uint32_t, little, unaligned>(Data);
3834 uint32_t SubmoduleIDOffset =
3835 endian::readNext<uint32_t, little, unaligned>(Data);
3836 uint32_t SelectorIDOffset =
3837 endian::readNext<uint32_t, little, unaligned>(Data);
3838 uint32_t DeclIDOffset =
3839 endian::readNext<uint32_t, little, unaligned>(Data);
3840 uint32_t TypeIndexOffset =
3841 endian::readNext<uint32_t, little, unaligned>(Data);
3842
3843 uint32_t None = std::numeric_limits<uint32_t>::max();
3844
3845 auto mapOffset = [&](uint32_t Offset, uint32_t BaseOffset,
3846 RemapBuilder &Remap) {
3847 if (Offset != None)
3848 Remap.insert(std::make_pair(Offset,
3849 static_cast<int>(BaseOffset - Offset)));
3850 };
3851 mapOffset(SLocOffset, OM->SLocEntryBaseOffset, SLocRemap);
3852 mapOffset(IdentifierIDOffset, OM->BaseIdentifierID, IdentifierRemap);
3853 mapOffset(MacroIDOffset, OM->BaseMacroID, MacroRemap);
3854 mapOffset(PreprocessedEntityIDOffset, OM->BasePreprocessedEntityID,
3855 PreprocessedEntityRemap);
3856 mapOffset(SubmoduleIDOffset, OM->BaseSubmoduleID, SubmoduleRemap);
3857 mapOffset(SelectorIDOffset, OM->BaseSelectorID, SelectorRemap);
3858 mapOffset(DeclIDOffset, OM->BaseDeclID, DeclRemap);
3859 mapOffset(TypeIndexOffset, OM->BaseTypeIndex, TypeRemap);
3860
3861 // Global -> local mappings.
3862 F.GlobalToLocalDeclIDs[OM] = DeclIDOffset;
3863 }
3864 }
3865
3866 ASTReader::ASTReadResult
ReadModuleMapFileBlock(RecordData & Record,ModuleFile & F,const ModuleFile * ImportedBy,unsigned ClientLoadCapabilities)3867 ASTReader::ReadModuleMapFileBlock(RecordData &Record, ModuleFile &F,
3868 const ModuleFile *ImportedBy,
3869 unsigned ClientLoadCapabilities) {
3870 unsigned Idx = 0;
3871 F.ModuleMapPath = ReadPath(F, Record, Idx);
3872
3873 // Try to resolve ModuleName in the current header search context and
3874 // verify that it is found in the same module map file as we saved. If the
3875 // top-level AST file is a main file, skip this check because there is no
3876 // usable header search context.
3877 assert(!F.ModuleName.empty() &&
3878 "MODULE_NAME should come before MODULE_MAP_FILE");
3879 if (F.Kind == MK_ImplicitModule && ModuleMgr.begin()->Kind != MK_MainFile) {
3880 // An implicitly-loaded module file should have its module listed in some
3881 // module map file that we've already loaded.
3882 Module *M = PP.getHeaderSearchInfo().lookupModule(F.ModuleName);
3883 auto &Map = PP.getHeaderSearchInfo().getModuleMap();
3884 const FileEntry *ModMap = M ? Map.getModuleMapFileForUniquing(M) : nullptr;
3885 // Don't emit module relocation error if we have -fno-validate-pch
3886 if (!PP.getPreprocessorOpts().DisablePCHValidation && !ModMap) {
3887 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0) {
3888 if (auto *ASTFE = M ? M->getASTFile() : nullptr) {
3889 // This module was defined by an imported (explicit) module.
3890 Diag(diag::err_module_file_conflict) << F.ModuleName << F.FileName
3891 << ASTFE->getName();
3892 } else {
3893 // This module was built with a different module map.
3894 Diag(diag::err_imported_module_not_found)
3895 << F.ModuleName << F.FileName
3896 << (ImportedBy ? ImportedBy->FileName : "") << F.ModuleMapPath
3897 << !ImportedBy;
3898 // In case it was imported by a PCH, there's a chance the user is
3899 // just missing to include the search path to the directory containing
3900 // the modulemap.
3901 if (ImportedBy && ImportedBy->Kind == MK_PCH)
3902 Diag(diag::note_imported_by_pch_module_not_found)
3903 << llvm::sys::path::parent_path(F.ModuleMapPath);
3904 }
3905 }
3906 return OutOfDate;
3907 }
3908
3909 assert(M->Name == F.ModuleName && "found module with different name");
3910
3911 // Check the primary module map file.
3912 auto StoredModMap = FileMgr.getFile(F.ModuleMapPath);
3913 if (!StoredModMap || *StoredModMap != ModMap) {
3914 assert(ModMap && "found module is missing module map file");
3915 assert((ImportedBy || F.Kind == MK_ImplicitModule) &&
3916 "top-level import should be verified");
3917 bool NotImported = F.Kind == MK_ImplicitModule && !ImportedBy;
3918 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3919 Diag(diag::err_imported_module_modmap_changed)
3920 << F.ModuleName << (NotImported ? F.FileName : ImportedBy->FileName)
3921 << ModMap->getName() << F.ModuleMapPath << NotImported;
3922 return OutOfDate;
3923 }
3924
3925 llvm::SmallPtrSet<const FileEntry *, 1> AdditionalStoredMaps;
3926 for (unsigned I = 0, N = Record[Idx++]; I < N; ++I) {
3927 // FIXME: we should use input files rather than storing names.
3928 std::string Filename = ReadPath(F, Record, Idx);
3929 auto F = FileMgr.getFile(Filename, false, false);
3930 if (!F) {
3931 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3932 Error("could not find file '" + Filename +"' referenced by AST file");
3933 return OutOfDate;
3934 }
3935 AdditionalStoredMaps.insert(*F);
3936 }
3937
3938 // Check any additional module map files (e.g. module.private.modulemap)
3939 // that are not in the pcm.
3940 if (auto *AdditionalModuleMaps = Map.getAdditionalModuleMapFiles(M)) {
3941 for (const FileEntry *ModMap : *AdditionalModuleMaps) {
3942 // Remove files that match
3943 // Note: SmallPtrSet::erase is really remove
3944 if (!AdditionalStoredMaps.erase(ModMap)) {
3945 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3946 Diag(diag::err_module_different_modmap)
3947 << F.ModuleName << /*new*/0 << ModMap->getName();
3948 return OutOfDate;
3949 }
3950 }
3951 }
3952
3953 // Check any additional module map files that are in the pcm, but not
3954 // found in header search. Cases that match are already removed.
3955 for (const FileEntry *ModMap : AdditionalStoredMaps) {
3956 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3957 Diag(diag::err_module_different_modmap)
3958 << F.ModuleName << /*not new*/1 << ModMap->getName();
3959 return OutOfDate;
3960 }
3961 }
3962
3963 if (Listener)
3964 Listener->ReadModuleMapFile(F.ModuleMapPath);
3965 return Success;
3966 }
3967
3968 /// Move the given method to the back of the global list of methods.
moveMethodToBackOfGlobalList(Sema & S,ObjCMethodDecl * Method)3969 static void moveMethodToBackOfGlobalList(Sema &S, ObjCMethodDecl *Method) {
3970 // Find the entry for this selector in the method pool.
3971 Sema::GlobalMethodPool::iterator Known
3972 = S.MethodPool.find(Method->getSelector());
3973 if (Known == S.MethodPool.end())
3974 return;
3975
3976 // Retrieve the appropriate method list.
3977 ObjCMethodList &Start = Method->isInstanceMethod()? Known->second.first
3978 : Known->second.second;
3979 bool Found = false;
3980 for (ObjCMethodList *List = &Start; List; List = List->getNext()) {
3981 if (!Found) {
3982 if (List->getMethod() == Method) {
3983 Found = true;
3984 } else {
3985 // Keep searching.
3986 continue;
3987 }
3988 }
3989
3990 if (List->getNext())
3991 List->setMethod(List->getNext()->getMethod());
3992 else
3993 List->setMethod(Method);
3994 }
3995 }
3996
makeNamesVisible(const HiddenNames & Names,Module * Owner)3997 void ASTReader::makeNamesVisible(const HiddenNames &Names, Module *Owner) {
3998 assert(Owner->NameVisibility != Module::Hidden && "nothing to make visible?");
3999 for (Decl *D : Names) {
4000 bool wasHidden = D->isHidden();
4001 D->setVisibleDespiteOwningModule();
4002
4003 if (wasHidden && SemaObj) {
4004 if (ObjCMethodDecl *Method = dyn_cast<ObjCMethodDecl>(D)) {
4005 moveMethodToBackOfGlobalList(*SemaObj, Method);
4006 }
4007 }
4008 }
4009 }
4010
makeModuleVisible(Module * Mod,Module::NameVisibilityKind NameVisibility,SourceLocation ImportLoc)4011 void ASTReader::makeModuleVisible(Module *Mod,
4012 Module::NameVisibilityKind NameVisibility,
4013 SourceLocation ImportLoc) {
4014 llvm::SmallPtrSet<Module *, 4> Visited;
4015 SmallVector<Module *, 4> Stack;
4016 Stack.push_back(Mod);
4017 while (!Stack.empty()) {
4018 Mod = Stack.pop_back_val();
4019
4020 if (NameVisibility <= Mod->NameVisibility) {
4021 // This module already has this level of visibility (or greater), so
4022 // there is nothing more to do.
4023 continue;
4024 }
4025
4026 if (!Mod->isAvailable()) {
4027 // Modules that aren't available cannot be made visible.
4028 continue;
4029 }
4030
4031 // Update the module's name visibility.
4032 Mod->NameVisibility = NameVisibility;
4033
4034 // If we've already deserialized any names from this module,
4035 // mark them as visible.
4036 HiddenNamesMapType::iterator Hidden = HiddenNamesMap.find(Mod);
4037 if (Hidden != HiddenNamesMap.end()) {
4038 auto HiddenNames = std::move(*Hidden);
4039 HiddenNamesMap.erase(Hidden);
4040 makeNamesVisible(HiddenNames.second, HiddenNames.first);
4041 assert(HiddenNamesMap.find(Mod) == HiddenNamesMap.end() &&
4042 "making names visible added hidden names");
4043 }
4044
4045 // Push any exported modules onto the stack to be marked as visible.
4046 SmallVector<Module *, 16> Exports;
4047 Mod->getExportedModules(Exports);
4048 for (SmallVectorImpl<Module *>::iterator
4049 I = Exports.begin(), E = Exports.end(); I != E; ++I) {
4050 Module *Exported = *I;
4051 if (Visited.insert(Exported).second)
4052 Stack.push_back(Exported);
4053 }
4054 }
4055 }
4056
4057 /// We've merged the definition \p MergedDef into the existing definition
4058 /// \p Def. Ensure that \p Def is made visible whenever \p MergedDef is made
4059 /// visible.
mergeDefinitionVisibility(NamedDecl * Def,NamedDecl * MergedDef)4060 void ASTReader::mergeDefinitionVisibility(NamedDecl *Def,
4061 NamedDecl *MergedDef) {
4062 if (Def->isHidden()) {
4063 // If MergedDef is visible or becomes visible, make the definition visible.
4064 if (!MergedDef->isHidden())
4065 Def->setVisibleDespiteOwningModule();
4066 else {
4067 getContext().mergeDefinitionIntoModule(
4068 Def, MergedDef->getImportedOwningModule(),
4069 /*NotifyListeners*/ false);
4070 PendingMergedDefinitionsToDeduplicate.insert(Def);
4071 }
4072 }
4073 }
4074
loadGlobalIndex()4075 bool ASTReader::loadGlobalIndex() {
4076 if (GlobalIndex)
4077 return false;
4078
4079 if (TriedLoadingGlobalIndex || !UseGlobalIndex ||
4080 !PP.getLangOpts().Modules)
4081 return true;
4082
4083 // Try to load the global index.
4084 TriedLoadingGlobalIndex = true;
4085 StringRef ModuleCachePath
4086 = getPreprocessor().getHeaderSearchInfo().getModuleCachePath();
4087 std::pair<GlobalModuleIndex *, llvm::Error> Result =
4088 GlobalModuleIndex::readIndex(ModuleCachePath);
4089 if (llvm::Error Err = std::move(Result.second)) {
4090 assert(!Result.first);
4091 consumeError(std::move(Err)); // FIXME this drops errors on the floor.
4092 return true;
4093 }
4094
4095 GlobalIndex.reset(Result.first);
4096 ModuleMgr.setGlobalIndex(GlobalIndex.get());
4097 return false;
4098 }
4099
isGlobalIndexUnavailable() const4100 bool ASTReader::isGlobalIndexUnavailable() const {
4101 return PP.getLangOpts().Modules && UseGlobalIndex &&
4102 !hasGlobalIndex() && TriedLoadingGlobalIndex;
4103 }
4104
updateModuleTimestamp(ModuleFile & MF)4105 static void updateModuleTimestamp(ModuleFile &MF) {
4106 // Overwrite the timestamp file contents so that file's mtime changes.
4107 std::string TimestampFilename = MF.getTimestampFilename();
4108 std::error_code EC;
4109 llvm::raw_fd_ostream OS(TimestampFilename, EC, llvm::sys::fs::OF_Text);
4110 if (EC)
4111 return;
4112 OS << "Timestamp file\n";
4113 OS.close();
4114 OS.clear_error(); // Avoid triggering a fatal error.
4115 }
4116
4117 /// Given a cursor at the start of an AST file, scan ahead and drop the
4118 /// cursor into the start of the given block ID, returning false on success and
4119 /// true on failure.
SkipCursorToBlock(BitstreamCursor & Cursor,unsigned BlockID)4120 static bool SkipCursorToBlock(BitstreamCursor &Cursor, unsigned BlockID) {
4121 while (true) {
4122 Expected<llvm::BitstreamEntry> MaybeEntry = Cursor.advance();
4123 if (!MaybeEntry) {
4124 // FIXME this drops errors on the floor.
4125 consumeError(MaybeEntry.takeError());
4126 return true;
4127 }
4128 llvm::BitstreamEntry Entry = MaybeEntry.get();
4129
4130 switch (Entry.Kind) {
4131 case llvm::BitstreamEntry::Error:
4132 case llvm::BitstreamEntry::EndBlock:
4133 return true;
4134
4135 case llvm::BitstreamEntry::Record:
4136 // Ignore top-level records.
4137 if (Expected<unsigned> Skipped = Cursor.skipRecord(Entry.ID))
4138 break;
4139 else {
4140 // FIXME this drops errors on the floor.
4141 consumeError(Skipped.takeError());
4142 return true;
4143 }
4144
4145 case llvm::BitstreamEntry::SubBlock:
4146 if (Entry.ID == BlockID) {
4147 if (llvm::Error Err = Cursor.EnterSubBlock(BlockID)) {
4148 // FIXME this drops the error on the floor.
4149 consumeError(std::move(Err));
4150 return true;
4151 }
4152 // Found it!
4153 return false;
4154 }
4155
4156 if (llvm::Error Err = Cursor.SkipBlock()) {
4157 // FIXME this drops the error on the floor.
4158 consumeError(std::move(Err));
4159 return true;
4160 }
4161 }
4162 }
4163 }
4164
ReadAST(StringRef FileName,ModuleKind Type,SourceLocation ImportLoc,unsigned ClientLoadCapabilities,SmallVectorImpl<ImportedSubmodule> * Imported)4165 ASTReader::ASTReadResult ASTReader::ReadAST(StringRef FileName,
4166 ModuleKind Type,
4167 SourceLocation ImportLoc,
4168 unsigned ClientLoadCapabilities,
4169 SmallVectorImpl<ImportedSubmodule> *Imported) {
4170 llvm::SaveAndRestore<SourceLocation>
4171 SetCurImportLocRAII(CurrentImportLoc, ImportLoc);
4172
4173 // Defer any pending actions until we get to the end of reading the AST file.
4174 Deserializing AnASTFile(this);
4175
4176 // Bump the generation number.
4177 unsigned PreviousGeneration = 0;
4178 if (ContextObj)
4179 PreviousGeneration = incrementGeneration(*ContextObj);
4180
4181 unsigned NumModules = ModuleMgr.size();
4182 auto removeModulesAndReturn = [&](ASTReadResult ReadResult) {
4183 assert(ReadResult && "expected to return error");
4184 ModuleMgr.removeModules(ModuleMgr.begin() + NumModules,
4185 PP.getLangOpts().Modules
4186 ? &PP.getHeaderSearchInfo().getModuleMap()
4187 : nullptr);
4188
4189 // If we find that any modules are unusable, the global index is going
4190 // to be out-of-date. Just remove it.
4191 GlobalIndex.reset();
4192 ModuleMgr.setGlobalIndex(nullptr);
4193 return ReadResult;
4194 };
4195
4196 SmallVector<ImportedModule, 4> Loaded;
4197 switch (ASTReadResult ReadResult =
4198 ReadASTCore(FileName, Type, ImportLoc,
4199 /*ImportedBy=*/nullptr, Loaded, 0, 0,
4200 ASTFileSignature(), ClientLoadCapabilities)) {
4201 case Failure:
4202 case Missing:
4203 case OutOfDate:
4204 case VersionMismatch:
4205 case ConfigurationMismatch:
4206 case HadErrors:
4207 return removeModulesAndReturn(ReadResult);
4208 case Success:
4209 break;
4210 }
4211
4212 // Here comes stuff that we only do once the entire chain is loaded.
4213
4214 // Load the AST blocks of all of the modules that we loaded. We can still
4215 // hit errors parsing the ASTs at this point.
4216 for (ImportedModule &M : Loaded) {
4217 ModuleFile &F = *M.Mod;
4218
4219 // Read the AST block.
4220 if (ASTReadResult Result = ReadASTBlock(F, ClientLoadCapabilities))
4221 return removeModulesAndReturn(Result);
4222
4223 // The AST block should always have a definition for the main module.
4224 if (F.isModule() && !F.DidReadTopLevelSubmodule) {
4225 Error(diag::err_module_file_missing_top_level_submodule, F.FileName);
4226 return removeModulesAndReturn(Failure);
4227 }
4228
4229 // Read the extension blocks.
4230 while (!SkipCursorToBlock(F.Stream, EXTENSION_BLOCK_ID)) {
4231 if (ASTReadResult Result = ReadExtensionBlock(F))
4232 return removeModulesAndReturn(Result);
4233 }
4234
4235 // Once read, set the ModuleFile bit base offset and update the size in
4236 // bits of all files we've seen.
4237 F.GlobalBitOffset = TotalModulesSizeInBits;
4238 TotalModulesSizeInBits += F.SizeInBits;
4239 GlobalBitOffsetsMap.insert(std::make_pair(F.GlobalBitOffset, &F));
4240 }
4241
4242 // Preload source locations and interesting indentifiers.
4243 for (ImportedModule &M : Loaded) {
4244 ModuleFile &F = *M.Mod;
4245
4246 // Preload SLocEntries.
4247 for (unsigned I = 0, N = F.PreloadSLocEntries.size(); I != N; ++I) {
4248 int Index = int(F.PreloadSLocEntries[I] - 1) + F.SLocEntryBaseID;
4249 // Load it through the SourceManager and don't call ReadSLocEntry()
4250 // directly because the entry may have already been loaded in which case
4251 // calling ReadSLocEntry() directly would trigger an assertion in
4252 // SourceManager.
4253 SourceMgr.getLoadedSLocEntryByID(Index);
4254 }
4255
4256 // Map the original source file ID into the ID space of the current
4257 // compilation.
4258 if (F.OriginalSourceFileID.isValid()) {
4259 F.OriginalSourceFileID = FileID::get(
4260 F.SLocEntryBaseID + F.OriginalSourceFileID.getOpaqueValue() - 1);
4261 }
4262
4263 // Preload all the pending interesting identifiers by marking them out of
4264 // date.
4265 for (auto Offset : F.PreloadIdentifierOffsets) {
4266 const unsigned char *Data = reinterpret_cast<const unsigned char *>(
4267 F.IdentifierTableData + Offset);
4268
4269 ASTIdentifierLookupTrait Trait(*this, F);
4270 auto KeyDataLen = Trait.ReadKeyDataLength(Data);
4271 auto Key = Trait.ReadKey(Data, KeyDataLen.first);
4272 auto &II = PP.getIdentifierTable().getOwn(Key);
4273 II.setOutOfDate(true);
4274
4275 // Mark this identifier as being from an AST file so that we can track
4276 // whether we need to serialize it.
4277 markIdentifierFromAST(*this, II);
4278
4279 // Associate the ID with the identifier so that the writer can reuse it.
4280 auto ID = Trait.ReadIdentifierID(Data + KeyDataLen.first);
4281 SetIdentifierInfo(ID, &II);
4282 }
4283 }
4284
4285 // Setup the import locations and notify the module manager that we've
4286 // committed to these module files.
4287 for (ImportedModule &M : Loaded) {
4288 ModuleFile &F = *M.Mod;
4289
4290 ModuleMgr.moduleFileAccepted(&F);
4291
4292 // Set the import location.
4293 F.DirectImportLoc = ImportLoc;
4294 // FIXME: We assume that locations from PCH / preamble do not need
4295 // any translation.
4296 if (!M.ImportedBy)
4297 F.ImportLoc = M.ImportLoc;
4298 else
4299 F.ImportLoc = TranslateSourceLocation(*M.ImportedBy, M.ImportLoc);
4300 }
4301
4302 if (!PP.getLangOpts().CPlusPlus ||
4303 (Type != MK_ImplicitModule && Type != MK_ExplicitModule &&
4304 Type != MK_PrebuiltModule)) {
4305 // Mark all of the identifiers in the identifier table as being out of date,
4306 // so that various accessors know to check the loaded modules when the
4307 // identifier is used.
4308 //
4309 // For C++ modules, we don't need information on many identifiers (just
4310 // those that provide macros or are poisoned), so we mark all of
4311 // the interesting ones via PreloadIdentifierOffsets.
4312 for (IdentifierTable::iterator Id = PP.getIdentifierTable().begin(),
4313 IdEnd = PP.getIdentifierTable().end();
4314 Id != IdEnd; ++Id)
4315 Id->second->setOutOfDate(true);
4316 }
4317 // Mark selectors as out of date.
4318 for (auto Sel : SelectorGeneration)
4319 SelectorOutOfDate[Sel.first] = true;
4320
4321 // Resolve any unresolved module exports.
4322 for (unsigned I = 0, N = UnresolvedModuleRefs.size(); I != N; ++I) {
4323 UnresolvedModuleRef &Unresolved = UnresolvedModuleRefs[I];
4324 SubmoduleID GlobalID = getGlobalSubmoduleID(*Unresolved.File,Unresolved.ID);
4325 Module *ResolvedMod = getSubmodule(GlobalID);
4326
4327 switch (Unresolved.Kind) {
4328 case UnresolvedModuleRef::Conflict:
4329 if (ResolvedMod) {
4330 Module::Conflict Conflict;
4331 Conflict.Other = ResolvedMod;
4332 Conflict.Message = Unresolved.String.str();
4333 Unresolved.Mod->Conflicts.push_back(Conflict);
4334 }
4335 continue;
4336
4337 case UnresolvedModuleRef::Import:
4338 if (ResolvedMod)
4339 Unresolved.Mod->Imports.insert(ResolvedMod);
4340 continue;
4341
4342 case UnresolvedModuleRef::Export:
4343 if (ResolvedMod || Unresolved.IsWildcard)
4344 Unresolved.Mod->Exports.push_back(
4345 Module::ExportDecl(ResolvedMod, Unresolved.IsWildcard));
4346 continue;
4347 }
4348 }
4349 UnresolvedModuleRefs.clear();
4350
4351 if (Imported)
4352 Imported->append(ImportedModules.begin(),
4353 ImportedModules.end());
4354
4355 // FIXME: How do we load the 'use'd modules? They may not be submodules.
4356 // Might be unnecessary as use declarations are only used to build the
4357 // module itself.
4358
4359 if (ContextObj)
4360 InitializeContext();
4361
4362 if (SemaObj)
4363 UpdateSema();
4364
4365 if (DeserializationListener)
4366 DeserializationListener->ReaderInitialized(this);
4367
4368 ModuleFile &PrimaryModule = ModuleMgr.getPrimaryModule();
4369 if (PrimaryModule.OriginalSourceFileID.isValid()) {
4370 // If this AST file is a precompiled preamble, then set the
4371 // preamble file ID of the source manager to the file source file
4372 // from which the preamble was built.
4373 if (Type == MK_Preamble) {
4374 SourceMgr.setPreambleFileID(PrimaryModule.OriginalSourceFileID);
4375 } else if (Type == MK_MainFile) {
4376 SourceMgr.setMainFileID(PrimaryModule.OriginalSourceFileID);
4377 }
4378 }
4379
4380 // For any Objective-C class definitions we have already loaded, make sure
4381 // that we load any additional categories.
4382 if (ContextObj) {
4383 for (unsigned I = 0, N = ObjCClassesLoaded.size(); I != N; ++I) {
4384 loadObjCCategories(ObjCClassesLoaded[I]->getGlobalID(),
4385 ObjCClassesLoaded[I],
4386 PreviousGeneration);
4387 }
4388 }
4389
4390 if (PP.getHeaderSearchInfo()
4391 .getHeaderSearchOpts()
4392 .ModulesValidateOncePerBuildSession) {
4393 // Now we are certain that the module and all modules it depends on are
4394 // up to date. Create or update timestamp files for modules that are
4395 // located in the module cache (not for PCH files that could be anywhere
4396 // in the filesystem).
4397 for (unsigned I = 0, N = Loaded.size(); I != N; ++I) {
4398 ImportedModule &M = Loaded[I];
4399 if (M.Mod->Kind == MK_ImplicitModule) {
4400 updateModuleTimestamp(*M.Mod);
4401 }
4402 }
4403 }
4404
4405 return Success;
4406 }
4407
4408 static ASTFileSignature readASTFileSignature(StringRef PCH);
4409
4410 /// Whether \p Stream doesn't start with the AST/PCH file magic number 'CPCH'.
doesntStartWithASTFileMagic(BitstreamCursor & Stream)4411 static llvm::Error doesntStartWithASTFileMagic(BitstreamCursor &Stream) {
4412 // FIXME checking magic headers is done in other places such as
4413 // SerializedDiagnosticReader and GlobalModuleIndex, but error handling isn't
4414 // always done the same. Unify it all with a helper.
4415 if (!Stream.canSkipToPos(4))
4416 return llvm::createStringError(std::errc::illegal_byte_sequence,
4417 "file too small to contain AST file magic");
4418 for (unsigned C : {'C', 'P', 'C', 'H'})
4419 if (Expected<llvm::SimpleBitstreamCursor::word_t> Res = Stream.Read(8)) {
4420 if (Res.get() != C)
4421 return llvm::createStringError(
4422 std::errc::illegal_byte_sequence,
4423 "file doesn't start with AST file magic");
4424 } else
4425 return Res.takeError();
4426 return llvm::Error::success();
4427 }
4428
moduleKindForDiagnostic(ModuleKind Kind)4429 static unsigned moduleKindForDiagnostic(ModuleKind Kind) {
4430 switch (Kind) {
4431 case MK_PCH:
4432 return 0; // PCH
4433 case MK_ImplicitModule:
4434 case MK_ExplicitModule:
4435 case MK_PrebuiltModule:
4436 return 1; // module
4437 case MK_MainFile:
4438 case MK_Preamble:
4439 return 2; // main source file
4440 }
4441 llvm_unreachable("unknown module kind");
4442 }
4443
4444 ASTReader::ASTReadResult
ReadASTCore(StringRef FileName,ModuleKind Type,SourceLocation ImportLoc,ModuleFile * ImportedBy,SmallVectorImpl<ImportedModule> & Loaded,off_t ExpectedSize,time_t ExpectedModTime,ASTFileSignature ExpectedSignature,unsigned ClientLoadCapabilities)4445 ASTReader::ReadASTCore(StringRef FileName,
4446 ModuleKind Type,
4447 SourceLocation ImportLoc,
4448 ModuleFile *ImportedBy,
4449 SmallVectorImpl<ImportedModule> &Loaded,
4450 off_t ExpectedSize, time_t ExpectedModTime,
4451 ASTFileSignature ExpectedSignature,
4452 unsigned ClientLoadCapabilities) {
4453 ModuleFile *M;
4454 std::string ErrorStr;
4455 ModuleManager::AddModuleResult AddResult
4456 = ModuleMgr.addModule(FileName, Type, ImportLoc, ImportedBy,
4457 getGeneration(), ExpectedSize, ExpectedModTime,
4458 ExpectedSignature, readASTFileSignature,
4459 M, ErrorStr);
4460
4461 switch (AddResult) {
4462 case ModuleManager::AlreadyLoaded:
4463 Diag(diag::remark_module_import)
4464 << M->ModuleName << M->FileName << (ImportedBy ? true : false)
4465 << (ImportedBy ? StringRef(ImportedBy->ModuleName) : StringRef());
4466 return Success;
4467
4468 case ModuleManager::NewlyLoaded:
4469 // Load module file below.
4470 break;
4471
4472 case ModuleManager::Missing:
4473 // The module file was missing; if the client can handle that, return
4474 // it.
4475 if (ClientLoadCapabilities & ARR_Missing)
4476 return Missing;
4477
4478 // Otherwise, return an error.
4479 Diag(diag::err_module_file_not_found) << moduleKindForDiagnostic(Type)
4480 << FileName << !ErrorStr.empty()
4481 << ErrorStr;
4482 return Failure;
4483
4484 case ModuleManager::OutOfDate:
4485 // We couldn't load the module file because it is out-of-date. If the
4486 // client can handle out-of-date, return it.
4487 if (ClientLoadCapabilities & ARR_OutOfDate)
4488 return OutOfDate;
4489
4490 // Otherwise, return an error.
4491 Diag(diag::err_module_file_out_of_date) << moduleKindForDiagnostic(Type)
4492 << FileName << !ErrorStr.empty()
4493 << ErrorStr;
4494 return Failure;
4495 }
4496
4497 assert(M && "Missing module file");
4498
4499 bool ShouldFinalizePCM = false;
4500 auto FinalizeOrDropPCM = llvm::make_scope_exit([&]() {
4501 auto &MC = getModuleManager().getModuleCache();
4502 if (ShouldFinalizePCM)
4503 MC.finalizePCM(FileName);
4504 else
4505 MC.tryToDropPCM(FileName);
4506 });
4507 ModuleFile &F = *M;
4508 BitstreamCursor &Stream = F.Stream;
4509 Stream = BitstreamCursor(PCHContainerRdr.ExtractPCH(*F.Buffer));
4510 F.SizeInBits = F.Buffer->getBufferSize() * 8;
4511
4512 // Sniff for the signature.
4513 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
4514 Diag(diag::err_module_file_invalid)
4515 << moduleKindForDiagnostic(Type) << FileName << std::move(Err);
4516 return Failure;
4517 }
4518
4519 // This is used for compatibility with older PCH formats.
4520 bool HaveReadControlBlock = false;
4521 while (true) {
4522 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
4523 if (!MaybeEntry) {
4524 Error(MaybeEntry.takeError());
4525 return Failure;
4526 }
4527 llvm::BitstreamEntry Entry = MaybeEntry.get();
4528
4529 switch (Entry.Kind) {
4530 case llvm::BitstreamEntry::Error:
4531 case llvm::BitstreamEntry::Record:
4532 case llvm::BitstreamEntry::EndBlock:
4533 Error("invalid record at top-level of AST file");
4534 return Failure;
4535
4536 case llvm::BitstreamEntry::SubBlock:
4537 break;
4538 }
4539
4540 switch (Entry.ID) {
4541 case CONTROL_BLOCK_ID:
4542 HaveReadControlBlock = true;
4543 switch (ReadControlBlock(F, Loaded, ImportedBy, ClientLoadCapabilities)) {
4544 case Success:
4545 // Check that we didn't try to load a non-module AST file as a module.
4546 //
4547 // FIXME: Should we also perform the converse check? Loading a module as
4548 // a PCH file sort of works, but it's a bit wonky.
4549 if ((Type == MK_ImplicitModule || Type == MK_ExplicitModule ||
4550 Type == MK_PrebuiltModule) &&
4551 F.ModuleName.empty()) {
4552 auto Result = (Type == MK_ImplicitModule) ? OutOfDate : Failure;
4553 if (Result != OutOfDate ||
4554 (ClientLoadCapabilities & ARR_OutOfDate) == 0)
4555 Diag(diag::err_module_file_not_module) << FileName;
4556 return Result;
4557 }
4558 break;
4559
4560 case Failure: return Failure;
4561 case Missing: return Missing;
4562 case OutOfDate: return OutOfDate;
4563 case VersionMismatch: return VersionMismatch;
4564 case ConfigurationMismatch: return ConfigurationMismatch;
4565 case HadErrors: return HadErrors;
4566 }
4567 break;
4568
4569 case AST_BLOCK_ID:
4570 if (!HaveReadControlBlock) {
4571 if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
4572 Diag(diag::err_pch_version_too_old);
4573 return VersionMismatch;
4574 }
4575
4576 // Record that we've loaded this module.
4577 Loaded.push_back(ImportedModule(M, ImportedBy, ImportLoc));
4578 ShouldFinalizePCM = true;
4579 return Success;
4580
4581 case UNHASHED_CONTROL_BLOCK_ID:
4582 // This block is handled using look-ahead during ReadControlBlock. We
4583 // shouldn't get here!
4584 Error("malformed block record in AST file");
4585 return Failure;
4586
4587 default:
4588 if (llvm::Error Err = Stream.SkipBlock()) {
4589 Error(std::move(Err));
4590 return Failure;
4591 }
4592 break;
4593 }
4594 }
4595
4596 llvm_unreachable("unexpected break; expected return");
4597 }
4598
4599 ASTReader::ASTReadResult
readUnhashedControlBlock(ModuleFile & F,bool WasImportedBy,unsigned ClientLoadCapabilities)4600 ASTReader::readUnhashedControlBlock(ModuleFile &F, bool WasImportedBy,
4601 unsigned ClientLoadCapabilities) {
4602 const HeaderSearchOptions &HSOpts =
4603 PP.getHeaderSearchInfo().getHeaderSearchOpts();
4604 bool AllowCompatibleConfigurationMismatch =
4605 F.Kind == MK_ExplicitModule || F.Kind == MK_PrebuiltModule;
4606
4607 ASTReadResult Result = readUnhashedControlBlockImpl(
4608 &F, F.Data, ClientLoadCapabilities, AllowCompatibleConfigurationMismatch,
4609 Listener.get(),
4610 WasImportedBy ? false : HSOpts.ModulesValidateDiagnosticOptions);
4611
4612 // If F was directly imported by another module, it's implicitly validated by
4613 // the importing module.
4614 if (DisableValidation || WasImportedBy ||
4615 (AllowConfigurationMismatch && Result == ConfigurationMismatch))
4616 return Success;
4617
4618 if (Result == Failure) {
4619 Error("malformed block record in AST file");
4620 return Failure;
4621 }
4622
4623 if (Result == OutOfDate && F.Kind == MK_ImplicitModule) {
4624 // If this module has already been finalized in the ModuleCache, we're stuck
4625 // with it; we can only load a single version of each module.
4626 //
4627 // This can happen when a module is imported in two contexts: in one, as a
4628 // user module; in another, as a system module (due to an import from
4629 // another module marked with the [system] flag). It usually indicates a
4630 // bug in the module map: this module should also be marked with [system].
4631 //
4632 // If -Wno-system-headers (the default), and the first import is as a
4633 // system module, then validation will fail during the as-user import,
4634 // since -Werror flags won't have been validated. However, it's reasonable
4635 // to treat this consistently as a system module.
4636 //
4637 // If -Wsystem-headers, the PCM on disk was built with
4638 // -Wno-system-headers, and the first import is as a user module, then
4639 // validation will fail during the as-system import since the PCM on disk
4640 // doesn't guarantee that -Werror was respected. However, the -Werror
4641 // flags were checked during the initial as-user import.
4642 if (getModuleManager().getModuleCache().isPCMFinal(F.FileName)) {
4643 Diag(diag::warn_module_system_bit_conflict) << F.FileName;
4644 return Success;
4645 }
4646 }
4647
4648 return Result;
4649 }
4650
readUnhashedControlBlockImpl(ModuleFile * F,llvm::StringRef StreamData,unsigned ClientLoadCapabilities,bool AllowCompatibleConfigurationMismatch,ASTReaderListener * Listener,bool ValidateDiagnosticOptions)4651 ASTReader::ASTReadResult ASTReader::readUnhashedControlBlockImpl(
4652 ModuleFile *F, llvm::StringRef StreamData, unsigned ClientLoadCapabilities,
4653 bool AllowCompatibleConfigurationMismatch, ASTReaderListener *Listener,
4654 bool ValidateDiagnosticOptions) {
4655 // Initialize a stream.
4656 BitstreamCursor Stream(StreamData);
4657
4658 // Sniff for the signature.
4659 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
4660 // FIXME this drops the error on the floor.
4661 consumeError(std::move(Err));
4662 return Failure;
4663 }
4664
4665 // Scan for the UNHASHED_CONTROL_BLOCK_ID block.
4666 if (SkipCursorToBlock(Stream, UNHASHED_CONTROL_BLOCK_ID))
4667 return Failure;
4668
4669 // Read all of the records in the options block.
4670 RecordData Record;
4671 ASTReadResult Result = Success;
4672 while (true) {
4673 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
4674 if (!MaybeEntry) {
4675 // FIXME this drops the error on the floor.
4676 consumeError(MaybeEntry.takeError());
4677 return Failure;
4678 }
4679 llvm::BitstreamEntry Entry = MaybeEntry.get();
4680
4681 switch (Entry.Kind) {
4682 case llvm::BitstreamEntry::Error:
4683 case llvm::BitstreamEntry::SubBlock:
4684 return Failure;
4685
4686 case llvm::BitstreamEntry::EndBlock:
4687 return Result;
4688
4689 case llvm::BitstreamEntry::Record:
4690 // The interesting case.
4691 break;
4692 }
4693
4694 // Read and process a record.
4695 Record.clear();
4696 Expected<unsigned> MaybeRecordType = Stream.readRecord(Entry.ID, Record);
4697 if (!MaybeRecordType) {
4698 // FIXME this drops the error.
4699 return Failure;
4700 }
4701 switch ((UnhashedControlBlockRecordTypes)MaybeRecordType.get()) {
4702 case SIGNATURE:
4703 if (F)
4704 std::copy(Record.begin(), Record.end(), F->Signature.data());
4705 break;
4706 case DIAGNOSTIC_OPTIONS: {
4707 bool Complain = (ClientLoadCapabilities & ARR_OutOfDate) == 0;
4708 if (Listener && ValidateDiagnosticOptions &&
4709 !AllowCompatibleConfigurationMismatch &&
4710 ParseDiagnosticOptions(Record, Complain, *Listener))
4711 Result = OutOfDate; // Don't return early. Read the signature.
4712 break;
4713 }
4714 case DIAG_PRAGMA_MAPPINGS:
4715 if (!F)
4716 break;
4717 if (F->PragmaDiagMappings.empty())
4718 F->PragmaDiagMappings.swap(Record);
4719 else
4720 F->PragmaDiagMappings.insert(F->PragmaDiagMappings.end(),
4721 Record.begin(), Record.end());
4722 break;
4723 }
4724 }
4725 }
4726
4727 /// Parse a record and blob containing module file extension metadata.
parseModuleFileExtensionMetadata(const SmallVectorImpl<uint64_t> & Record,StringRef Blob,ModuleFileExtensionMetadata & Metadata)4728 static bool parseModuleFileExtensionMetadata(
4729 const SmallVectorImpl<uint64_t> &Record,
4730 StringRef Blob,
4731 ModuleFileExtensionMetadata &Metadata) {
4732 if (Record.size() < 4) return true;
4733
4734 Metadata.MajorVersion = Record[0];
4735 Metadata.MinorVersion = Record[1];
4736
4737 unsigned BlockNameLen = Record[2];
4738 unsigned UserInfoLen = Record[3];
4739
4740 if (BlockNameLen + UserInfoLen > Blob.size()) return true;
4741
4742 Metadata.BlockName = std::string(Blob.data(), Blob.data() + BlockNameLen);
4743 Metadata.UserInfo = std::string(Blob.data() + BlockNameLen,
4744 Blob.data() + BlockNameLen + UserInfoLen);
4745 return false;
4746 }
4747
ReadExtensionBlock(ModuleFile & F)4748 ASTReader::ASTReadResult ASTReader::ReadExtensionBlock(ModuleFile &F) {
4749 BitstreamCursor &Stream = F.Stream;
4750
4751 RecordData Record;
4752 while (true) {
4753 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
4754 if (!MaybeEntry) {
4755 Error(MaybeEntry.takeError());
4756 return Failure;
4757 }
4758 llvm::BitstreamEntry Entry = MaybeEntry.get();
4759
4760 switch (Entry.Kind) {
4761 case llvm::BitstreamEntry::SubBlock:
4762 if (llvm::Error Err = Stream.SkipBlock()) {
4763 Error(std::move(Err));
4764 return Failure;
4765 }
4766 continue;
4767
4768 case llvm::BitstreamEntry::EndBlock:
4769 return Success;
4770
4771 case llvm::BitstreamEntry::Error:
4772 return HadErrors;
4773
4774 case llvm::BitstreamEntry::Record:
4775 break;
4776 }
4777
4778 Record.clear();
4779 StringRef Blob;
4780 Expected<unsigned> MaybeRecCode =
4781 Stream.readRecord(Entry.ID, Record, &Blob);
4782 if (!MaybeRecCode) {
4783 Error(MaybeRecCode.takeError());
4784 return Failure;
4785 }
4786 switch (MaybeRecCode.get()) {
4787 case EXTENSION_METADATA: {
4788 ModuleFileExtensionMetadata Metadata;
4789 if (parseModuleFileExtensionMetadata(Record, Blob, Metadata)) {
4790 Error("malformed EXTENSION_METADATA in AST file");
4791 return Failure;
4792 }
4793
4794 // Find a module file extension with this block name.
4795 auto Known = ModuleFileExtensions.find(Metadata.BlockName);
4796 if (Known == ModuleFileExtensions.end()) break;
4797
4798 // Form a reader.
4799 if (auto Reader = Known->second->createExtensionReader(Metadata, *this,
4800 F, Stream)) {
4801 F.ExtensionReaders.push_back(std::move(Reader));
4802 }
4803
4804 break;
4805 }
4806 }
4807 }
4808
4809 return Success;
4810 }
4811
InitializeContext()4812 void ASTReader::InitializeContext() {
4813 assert(ContextObj && "no context to initialize");
4814 ASTContext &Context = *ContextObj;
4815
4816 // If there's a listener, notify them that we "read" the translation unit.
4817 if (DeserializationListener)
4818 DeserializationListener->DeclRead(PREDEF_DECL_TRANSLATION_UNIT_ID,
4819 Context.getTranslationUnitDecl());
4820
4821 // FIXME: Find a better way to deal with collisions between these
4822 // built-in types. Right now, we just ignore the problem.
4823
4824 // Load the special types.
4825 if (SpecialTypes.size() >= NumSpecialTypeIDs) {
4826 if (unsigned String = SpecialTypes[SPECIAL_TYPE_CF_CONSTANT_STRING]) {
4827 if (!Context.CFConstantStringTypeDecl)
4828 Context.setCFConstantStringType(GetType(String));
4829 }
4830
4831 if (unsigned File = SpecialTypes[SPECIAL_TYPE_FILE]) {
4832 QualType FileType = GetType(File);
4833 if (FileType.isNull()) {
4834 Error("FILE type is NULL");
4835 return;
4836 }
4837
4838 if (!Context.FILEDecl) {
4839 if (const TypedefType *Typedef = FileType->getAs<TypedefType>())
4840 Context.setFILEDecl(Typedef->getDecl());
4841 else {
4842 const TagType *Tag = FileType->getAs<TagType>();
4843 if (!Tag) {
4844 Error("Invalid FILE type in AST file");
4845 return;
4846 }
4847 Context.setFILEDecl(Tag->getDecl());
4848 }
4849 }
4850 }
4851
4852 if (unsigned Jmp_buf = SpecialTypes[SPECIAL_TYPE_JMP_BUF]) {
4853 QualType Jmp_bufType = GetType(Jmp_buf);
4854 if (Jmp_bufType.isNull()) {
4855 Error("jmp_buf type is NULL");
4856 return;
4857 }
4858
4859 if (!Context.jmp_bufDecl) {
4860 if (const TypedefType *Typedef = Jmp_bufType->getAs<TypedefType>())
4861 Context.setjmp_bufDecl(Typedef->getDecl());
4862 else {
4863 const TagType *Tag = Jmp_bufType->getAs<TagType>();
4864 if (!Tag) {
4865 Error("Invalid jmp_buf type in AST file");
4866 return;
4867 }
4868 Context.setjmp_bufDecl(Tag->getDecl());
4869 }
4870 }
4871 }
4872
4873 if (unsigned Sigjmp_buf = SpecialTypes[SPECIAL_TYPE_SIGJMP_BUF]) {
4874 QualType Sigjmp_bufType = GetType(Sigjmp_buf);
4875 if (Sigjmp_bufType.isNull()) {
4876 Error("sigjmp_buf type is NULL");
4877 return;
4878 }
4879
4880 if (!Context.sigjmp_bufDecl) {
4881 if (const TypedefType *Typedef = Sigjmp_bufType->getAs<TypedefType>())
4882 Context.setsigjmp_bufDecl(Typedef->getDecl());
4883 else {
4884 const TagType *Tag = Sigjmp_bufType->getAs<TagType>();
4885 assert(Tag && "Invalid sigjmp_buf type in AST file");
4886 Context.setsigjmp_bufDecl(Tag->getDecl());
4887 }
4888 }
4889 }
4890
4891 if (unsigned ObjCIdRedef
4892 = SpecialTypes[SPECIAL_TYPE_OBJC_ID_REDEFINITION]) {
4893 if (Context.ObjCIdRedefinitionType.isNull())
4894 Context.ObjCIdRedefinitionType = GetType(ObjCIdRedef);
4895 }
4896
4897 if (unsigned ObjCClassRedef
4898 = SpecialTypes[SPECIAL_TYPE_OBJC_CLASS_REDEFINITION]) {
4899 if (Context.ObjCClassRedefinitionType.isNull())
4900 Context.ObjCClassRedefinitionType = GetType(ObjCClassRedef);
4901 }
4902
4903 if (unsigned ObjCSelRedef
4904 = SpecialTypes[SPECIAL_TYPE_OBJC_SEL_REDEFINITION]) {
4905 if (Context.ObjCSelRedefinitionType.isNull())
4906 Context.ObjCSelRedefinitionType = GetType(ObjCSelRedef);
4907 }
4908
4909 if (unsigned Ucontext_t = SpecialTypes[SPECIAL_TYPE_UCONTEXT_T]) {
4910 QualType Ucontext_tType = GetType(Ucontext_t);
4911 if (Ucontext_tType.isNull()) {
4912 Error("ucontext_t type is NULL");
4913 return;
4914 }
4915
4916 if (!Context.ucontext_tDecl) {
4917 if (const TypedefType *Typedef = Ucontext_tType->getAs<TypedefType>())
4918 Context.setucontext_tDecl(Typedef->getDecl());
4919 else {
4920 const TagType *Tag = Ucontext_tType->getAs<TagType>();
4921 assert(Tag && "Invalid ucontext_t type in AST file");
4922 Context.setucontext_tDecl(Tag->getDecl());
4923 }
4924 }
4925 }
4926 }
4927
4928 ReadPragmaDiagnosticMappings(Context.getDiagnostics());
4929
4930 // If there were any CUDA special declarations, deserialize them.
4931 if (!CUDASpecialDeclRefs.empty()) {
4932 assert(CUDASpecialDeclRefs.size() == 1 && "More decl refs than expected!");
4933 Context.setcudaConfigureCallDecl(
4934 cast<FunctionDecl>(GetDecl(CUDASpecialDeclRefs[0])));
4935 }
4936
4937 // Re-export any modules that were imported by a non-module AST file.
4938 // FIXME: This does not make macro-only imports visible again.
4939 for (auto &Import : ImportedModules) {
4940 if (Module *Imported = getSubmodule(Import.ID)) {
4941 makeModuleVisible(Imported, Module::AllVisible,
4942 /*ImportLoc=*/Import.ImportLoc);
4943 if (Import.ImportLoc.isValid())
4944 PP.makeModuleVisible(Imported, Import.ImportLoc);
4945 // FIXME: should we tell Sema to make the module visible too?
4946 }
4947 }
4948 ImportedModules.clear();
4949 }
4950
finalizeForWriting()4951 void ASTReader::finalizeForWriting() {
4952 // Nothing to do for now.
4953 }
4954
4955 /// Reads and return the signature record from \p PCH's control block, or
4956 /// else returns 0.
readASTFileSignature(StringRef PCH)4957 static ASTFileSignature readASTFileSignature(StringRef PCH) {
4958 BitstreamCursor Stream(PCH);
4959 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
4960 // FIXME this drops the error on the floor.
4961 consumeError(std::move(Err));
4962 return ASTFileSignature();
4963 }
4964
4965 // Scan for the UNHASHED_CONTROL_BLOCK_ID block.
4966 if (SkipCursorToBlock(Stream, UNHASHED_CONTROL_BLOCK_ID))
4967 return ASTFileSignature();
4968
4969 // Scan for SIGNATURE inside the diagnostic options block.
4970 ASTReader::RecordData Record;
4971 while (true) {
4972 Expected<llvm::BitstreamEntry> MaybeEntry =
4973 Stream.advanceSkippingSubblocks();
4974 if (!MaybeEntry) {
4975 // FIXME this drops the error on the floor.
4976 consumeError(MaybeEntry.takeError());
4977 return ASTFileSignature();
4978 }
4979 llvm::BitstreamEntry Entry = MaybeEntry.get();
4980
4981 if (Entry.Kind != llvm::BitstreamEntry::Record)
4982 return ASTFileSignature();
4983
4984 Record.clear();
4985 StringRef Blob;
4986 Expected<unsigned> MaybeRecord = Stream.readRecord(Entry.ID, Record, &Blob);
4987 if (!MaybeRecord) {
4988 // FIXME this drops the error on the floor.
4989 consumeError(MaybeRecord.takeError());
4990 return ASTFileSignature();
4991 }
4992 if (SIGNATURE == MaybeRecord.get())
4993 return {{{(uint32_t)Record[0], (uint32_t)Record[1], (uint32_t)Record[2],
4994 (uint32_t)Record[3], (uint32_t)Record[4]}}};
4995 }
4996 }
4997
4998 /// Retrieve the name of the original source file name
4999 /// directly from the AST file, without actually loading the AST
5000 /// file.
getOriginalSourceFile(const std::string & ASTFileName,FileManager & FileMgr,const PCHContainerReader & PCHContainerRdr,DiagnosticsEngine & Diags)5001 std::string ASTReader::getOriginalSourceFile(
5002 const std::string &ASTFileName, FileManager &FileMgr,
5003 const PCHContainerReader &PCHContainerRdr, DiagnosticsEngine &Diags) {
5004 // Open the AST file.
5005 auto Buffer = FileMgr.getBufferForFile(ASTFileName);
5006 if (!Buffer) {
5007 Diags.Report(diag::err_fe_unable_to_read_pch_file)
5008 << ASTFileName << Buffer.getError().message();
5009 return std::string();
5010 }
5011
5012 // Initialize the stream
5013 BitstreamCursor Stream(PCHContainerRdr.ExtractPCH(**Buffer));
5014
5015 // Sniff for the signature.
5016 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
5017 Diags.Report(diag::err_fe_not_a_pch_file) << ASTFileName << std::move(Err);
5018 return std::string();
5019 }
5020
5021 // Scan for the CONTROL_BLOCK_ID block.
5022 if (SkipCursorToBlock(Stream, CONTROL_BLOCK_ID)) {
5023 Diags.Report(diag::err_fe_pch_malformed_block) << ASTFileName;
5024 return std::string();
5025 }
5026
5027 // Scan for ORIGINAL_FILE inside the control block.
5028 RecordData Record;
5029 while (true) {
5030 Expected<llvm::BitstreamEntry> MaybeEntry =
5031 Stream.advanceSkippingSubblocks();
5032 if (!MaybeEntry) {
5033 // FIXME this drops errors on the floor.
5034 consumeError(MaybeEntry.takeError());
5035 return std::string();
5036 }
5037 llvm::BitstreamEntry Entry = MaybeEntry.get();
5038
5039 if (Entry.Kind == llvm::BitstreamEntry::EndBlock)
5040 return std::string();
5041
5042 if (Entry.Kind != llvm::BitstreamEntry::Record) {
5043 Diags.Report(diag::err_fe_pch_malformed_block) << ASTFileName;
5044 return std::string();
5045 }
5046
5047 Record.clear();
5048 StringRef Blob;
5049 Expected<unsigned> MaybeRecord = Stream.readRecord(Entry.ID, Record, &Blob);
5050 if (!MaybeRecord) {
5051 // FIXME this drops the errors on the floor.
5052 consumeError(MaybeRecord.takeError());
5053 return std::string();
5054 }
5055 if (ORIGINAL_FILE == MaybeRecord.get())
5056 return Blob.str();
5057 }
5058 }
5059
5060 namespace {
5061
5062 class SimplePCHValidator : public ASTReaderListener {
5063 const LangOptions &ExistingLangOpts;
5064 const TargetOptions &ExistingTargetOpts;
5065 const PreprocessorOptions &ExistingPPOpts;
5066 std::string ExistingModuleCachePath;
5067 FileManager &FileMgr;
5068
5069 public:
SimplePCHValidator(const LangOptions & ExistingLangOpts,const TargetOptions & ExistingTargetOpts,const PreprocessorOptions & ExistingPPOpts,StringRef ExistingModuleCachePath,FileManager & FileMgr)5070 SimplePCHValidator(const LangOptions &ExistingLangOpts,
5071 const TargetOptions &ExistingTargetOpts,
5072 const PreprocessorOptions &ExistingPPOpts,
5073 StringRef ExistingModuleCachePath,
5074 FileManager &FileMgr)
5075 : ExistingLangOpts(ExistingLangOpts),
5076 ExistingTargetOpts(ExistingTargetOpts),
5077 ExistingPPOpts(ExistingPPOpts),
5078 ExistingModuleCachePath(ExistingModuleCachePath),
5079 FileMgr(FileMgr) {}
5080
ReadLanguageOptions(const LangOptions & LangOpts,bool Complain,bool AllowCompatibleDifferences)5081 bool ReadLanguageOptions(const LangOptions &LangOpts, bool Complain,
5082 bool AllowCompatibleDifferences) override {
5083 return checkLanguageOptions(ExistingLangOpts, LangOpts, nullptr,
5084 AllowCompatibleDifferences);
5085 }
5086
ReadTargetOptions(const TargetOptions & TargetOpts,bool Complain,bool AllowCompatibleDifferences)5087 bool ReadTargetOptions(const TargetOptions &TargetOpts, bool Complain,
5088 bool AllowCompatibleDifferences) override {
5089 return checkTargetOptions(ExistingTargetOpts, TargetOpts, nullptr,
5090 AllowCompatibleDifferences);
5091 }
5092
ReadHeaderSearchOptions(const HeaderSearchOptions & HSOpts,StringRef SpecificModuleCachePath,bool Complain)5093 bool ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
5094 StringRef SpecificModuleCachePath,
5095 bool Complain) override {
5096 return checkHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
5097 ExistingModuleCachePath,
5098 nullptr, ExistingLangOpts);
5099 }
5100
ReadPreprocessorOptions(const PreprocessorOptions & PPOpts,bool Complain,std::string & SuggestedPredefines)5101 bool ReadPreprocessorOptions(const PreprocessorOptions &PPOpts,
5102 bool Complain,
5103 std::string &SuggestedPredefines) override {
5104 return checkPreprocessorOptions(ExistingPPOpts, PPOpts, nullptr, FileMgr,
5105 SuggestedPredefines, ExistingLangOpts);
5106 }
5107 };
5108
5109 } // namespace
5110
readASTFileControlBlock(StringRef Filename,FileManager & FileMgr,const PCHContainerReader & PCHContainerRdr,bool FindModuleFileExtensions,ASTReaderListener & Listener,bool ValidateDiagnosticOptions)5111 bool ASTReader::readASTFileControlBlock(
5112 StringRef Filename, FileManager &FileMgr,
5113 const PCHContainerReader &PCHContainerRdr,
5114 bool FindModuleFileExtensions,
5115 ASTReaderListener &Listener, bool ValidateDiagnosticOptions) {
5116 // Open the AST file.
5117 // FIXME: This allows use of the VFS; we do not allow use of the
5118 // VFS when actually loading a module.
5119 auto Buffer = FileMgr.getBufferForFile(Filename);
5120 if (!Buffer) {
5121 return true;
5122 }
5123
5124 // Initialize the stream
5125 StringRef Bytes = PCHContainerRdr.ExtractPCH(**Buffer);
5126 BitstreamCursor Stream(Bytes);
5127
5128 // Sniff for the signature.
5129 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
5130 consumeError(std::move(Err)); // FIXME this drops errors on the floor.
5131 return true;
5132 }
5133
5134 // Scan for the CONTROL_BLOCK_ID block.
5135 if (SkipCursorToBlock(Stream, CONTROL_BLOCK_ID))
5136 return true;
5137
5138 bool NeedsInputFiles = Listener.needsInputFileVisitation();
5139 bool NeedsSystemInputFiles = Listener.needsSystemInputFileVisitation();
5140 bool NeedsImports = Listener.needsImportVisitation();
5141 BitstreamCursor InputFilesCursor;
5142
5143 RecordData Record;
5144 std::string ModuleDir;
5145 bool DoneWithControlBlock = false;
5146 while (!DoneWithControlBlock) {
5147 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
5148 if (!MaybeEntry) {
5149 // FIXME this drops the error on the floor.
5150 consumeError(MaybeEntry.takeError());
5151 return true;
5152 }
5153 llvm::BitstreamEntry Entry = MaybeEntry.get();
5154
5155 switch (Entry.Kind) {
5156 case llvm::BitstreamEntry::SubBlock: {
5157 switch (Entry.ID) {
5158 case OPTIONS_BLOCK_ID: {
5159 std::string IgnoredSuggestedPredefines;
5160 if (ReadOptionsBlock(Stream, ARR_ConfigurationMismatch | ARR_OutOfDate,
5161 /*AllowCompatibleConfigurationMismatch*/ false,
5162 Listener, IgnoredSuggestedPredefines) != Success)
5163 return true;
5164 break;
5165 }
5166
5167 case INPUT_FILES_BLOCK_ID:
5168 InputFilesCursor = Stream;
5169 if (llvm::Error Err = Stream.SkipBlock()) {
5170 // FIXME this drops the error on the floor.
5171 consumeError(std::move(Err));
5172 return true;
5173 }
5174 if (NeedsInputFiles &&
5175 ReadBlockAbbrevs(InputFilesCursor, INPUT_FILES_BLOCK_ID))
5176 return true;
5177 break;
5178
5179 default:
5180 if (llvm::Error Err = Stream.SkipBlock()) {
5181 // FIXME this drops the error on the floor.
5182 consumeError(std::move(Err));
5183 return true;
5184 }
5185 break;
5186 }
5187
5188 continue;
5189 }
5190
5191 case llvm::BitstreamEntry::EndBlock:
5192 DoneWithControlBlock = true;
5193 break;
5194
5195 case llvm::BitstreamEntry::Error:
5196 return true;
5197
5198 case llvm::BitstreamEntry::Record:
5199 break;
5200 }
5201
5202 if (DoneWithControlBlock) break;
5203
5204 Record.clear();
5205 StringRef Blob;
5206 Expected<unsigned> MaybeRecCode =
5207 Stream.readRecord(Entry.ID, Record, &Blob);
5208 if (!MaybeRecCode) {
5209 // FIXME this drops the error.
5210 return Failure;
5211 }
5212 switch ((ControlRecordTypes)MaybeRecCode.get()) {
5213 case METADATA:
5214 if (Record[0] != VERSION_MAJOR)
5215 return true;
5216 if (Listener.ReadFullVersionInformation(Blob))
5217 return true;
5218 break;
5219 case MODULE_NAME:
5220 Listener.ReadModuleName(Blob);
5221 break;
5222 case MODULE_DIRECTORY:
5223 ModuleDir = Blob;
5224 break;
5225 case MODULE_MAP_FILE: {
5226 unsigned Idx = 0;
5227 auto Path = ReadString(Record, Idx);
5228 ResolveImportedPath(Path, ModuleDir);
5229 Listener.ReadModuleMapFile(Path);
5230 break;
5231 }
5232 case INPUT_FILE_OFFSETS: {
5233 if (!NeedsInputFiles)
5234 break;
5235
5236 unsigned NumInputFiles = Record[0];
5237 unsigned NumUserFiles = Record[1];
5238 const llvm::support::unaligned_uint64_t *InputFileOffs =
5239 (const llvm::support::unaligned_uint64_t *)Blob.data();
5240 for (unsigned I = 0; I != NumInputFiles; ++I) {
5241 // Go find this input file.
5242 bool isSystemFile = I >= NumUserFiles;
5243
5244 if (isSystemFile && !NeedsSystemInputFiles)
5245 break; // the rest are system input files
5246
5247 BitstreamCursor &Cursor = InputFilesCursor;
5248 SavedStreamPosition SavedPosition(Cursor);
5249 if (llvm::Error Err = Cursor.JumpToBit(InputFileOffs[I])) {
5250 // FIXME this drops errors on the floor.
5251 consumeError(std::move(Err));
5252 }
5253
5254 Expected<unsigned> MaybeCode = Cursor.ReadCode();
5255 if (!MaybeCode) {
5256 // FIXME this drops errors on the floor.
5257 consumeError(MaybeCode.takeError());
5258 }
5259 unsigned Code = MaybeCode.get();
5260
5261 RecordData Record;
5262 StringRef Blob;
5263 bool shouldContinue = false;
5264 Expected<unsigned> MaybeRecordType =
5265 Cursor.readRecord(Code, Record, &Blob);
5266 if (!MaybeRecordType) {
5267 // FIXME this drops errors on the floor.
5268 consumeError(MaybeRecordType.takeError());
5269 }
5270 switch ((InputFileRecordTypes)MaybeRecordType.get()) {
5271 case INPUT_FILE_HASH:
5272 break;
5273 case INPUT_FILE:
5274 bool Overridden = static_cast<bool>(Record[3]);
5275 std::string Filename = Blob;
5276 ResolveImportedPath(Filename, ModuleDir);
5277 shouldContinue = Listener.visitInputFile(
5278 Filename, isSystemFile, Overridden, /*IsExplicitModule*/false);
5279 break;
5280 }
5281 if (!shouldContinue)
5282 break;
5283 }
5284 break;
5285 }
5286
5287 case IMPORTS: {
5288 if (!NeedsImports)
5289 break;
5290
5291 unsigned Idx = 0, N = Record.size();
5292 while (Idx < N) {
5293 // Read information about the AST file.
5294 Idx += 1+1+1+1+5; // Kind, ImportLoc, Size, ModTime, Signature
5295 std::string ModuleName = ReadString(Record, Idx);
5296 std::string Filename = ReadString(Record, Idx);
5297 ResolveImportedPath(Filename, ModuleDir);
5298 Listener.visitImport(ModuleName, Filename);
5299 }
5300 break;
5301 }
5302
5303 default:
5304 // No other validation to perform.
5305 break;
5306 }
5307 }
5308
5309 // Look for module file extension blocks, if requested.
5310 if (FindModuleFileExtensions) {
5311 BitstreamCursor SavedStream = Stream;
5312 while (!SkipCursorToBlock(Stream, EXTENSION_BLOCK_ID)) {
5313 bool DoneWithExtensionBlock = false;
5314 while (!DoneWithExtensionBlock) {
5315 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
5316 if (!MaybeEntry) {
5317 // FIXME this drops the error.
5318 return true;
5319 }
5320 llvm::BitstreamEntry Entry = MaybeEntry.get();
5321
5322 switch (Entry.Kind) {
5323 case llvm::BitstreamEntry::SubBlock:
5324 if (llvm::Error Err = Stream.SkipBlock()) {
5325 // FIXME this drops the error on the floor.
5326 consumeError(std::move(Err));
5327 return true;
5328 }
5329 continue;
5330
5331 case llvm::BitstreamEntry::EndBlock:
5332 DoneWithExtensionBlock = true;
5333 continue;
5334
5335 case llvm::BitstreamEntry::Error:
5336 return true;
5337
5338 case llvm::BitstreamEntry::Record:
5339 break;
5340 }
5341
5342 Record.clear();
5343 StringRef Blob;
5344 Expected<unsigned> MaybeRecCode =
5345 Stream.readRecord(Entry.ID, Record, &Blob);
5346 if (!MaybeRecCode) {
5347 // FIXME this drops the error.
5348 return true;
5349 }
5350 switch (MaybeRecCode.get()) {
5351 case EXTENSION_METADATA: {
5352 ModuleFileExtensionMetadata Metadata;
5353 if (parseModuleFileExtensionMetadata(Record, Blob, Metadata))
5354 return true;
5355
5356 Listener.readModuleFileExtension(Metadata);
5357 break;
5358 }
5359 }
5360 }
5361 }
5362 Stream = SavedStream;
5363 }
5364
5365 // Scan for the UNHASHED_CONTROL_BLOCK_ID block.
5366 if (readUnhashedControlBlockImpl(
5367 nullptr, Bytes, ARR_ConfigurationMismatch | ARR_OutOfDate,
5368 /*AllowCompatibleConfigurationMismatch*/ false, &Listener,
5369 ValidateDiagnosticOptions) != Success)
5370 return true;
5371
5372 return false;
5373 }
5374
isAcceptableASTFile(StringRef Filename,FileManager & FileMgr,const PCHContainerReader & PCHContainerRdr,const LangOptions & LangOpts,const TargetOptions & TargetOpts,const PreprocessorOptions & PPOpts,StringRef ExistingModuleCachePath)5375 bool ASTReader::isAcceptableASTFile(StringRef Filename, FileManager &FileMgr,
5376 const PCHContainerReader &PCHContainerRdr,
5377 const LangOptions &LangOpts,
5378 const TargetOptions &TargetOpts,
5379 const PreprocessorOptions &PPOpts,
5380 StringRef ExistingModuleCachePath) {
5381 SimplePCHValidator validator(LangOpts, TargetOpts, PPOpts,
5382 ExistingModuleCachePath, FileMgr);
5383 return !readASTFileControlBlock(Filename, FileMgr, PCHContainerRdr,
5384 /*FindModuleFileExtensions=*/false,
5385 validator,
5386 /*ValidateDiagnosticOptions=*/true);
5387 }
5388
5389 ASTReader::ASTReadResult
ReadSubmoduleBlock(ModuleFile & F,unsigned ClientLoadCapabilities)5390 ASTReader::ReadSubmoduleBlock(ModuleFile &F, unsigned ClientLoadCapabilities) {
5391 // Enter the submodule block.
5392 if (llvm::Error Err = F.Stream.EnterSubBlock(SUBMODULE_BLOCK_ID)) {
5393 Error(std::move(Err));
5394 return Failure;
5395 }
5396
5397 ModuleMap &ModMap = PP.getHeaderSearchInfo().getModuleMap();
5398 bool First = true;
5399 Module *CurrentModule = nullptr;
5400 RecordData Record;
5401 while (true) {
5402 Expected<llvm::BitstreamEntry> MaybeEntry =
5403 F.Stream.advanceSkippingSubblocks();
5404 if (!MaybeEntry) {
5405 Error(MaybeEntry.takeError());
5406 return Failure;
5407 }
5408 llvm::BitstreamEntry Entry = MaybeEntry.get();
5409
5410 switch (Entry.Kind) {
5411 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
5412 case llvm::BitstreamEntry::Error:
5413 Error("malformed block record in AST file");
5414 return Failure;
5415 case llvm::BitstreamEntry::EndBlock:
5416 return Success;
5417 case llvm::BitstreamEntry::Record:
5418 // The interesting case.
5419 break;
5420 }
5421
5422 // Read a record.
5423 StringRef Blob;
5424 Record.clear();
5425 Expected<unsigned> MaybeKind = F.Stream.readRecord(Entry.ID, Record, &Blob);
5426 if (!MaybeKind) {
5427 Error(MaybeKind.takeError());
5428 return Failure;
5429 }
5430 unsigned Kind = MaybeKind.get();
5431
5432 if ((Kind == SUBMODULE_METADATA) != First) {
5433 Error("submodule metadata record should be at beginning of block");
5434 return Failure;
5435 }
5436 First = false;
5437
5438 // Submodule information is only valid if we have a current module.
5439 // FIXME: Should we error on these cases?
5440 if (!CurrentModule && Kind != SUBMODULE_METADATA &&
5441 Kind != SUBMODULE_DEFINITION)
5442 continue;
5443
5444 switch (Kind) {
5445 default: // Default behavior: ignore.
5446 break;
5447
5448 case SUBMODULE_DEFINITION: {
5449 if (Record.size() < 12) {
5450 Error("malformed module definition");
5451 return Failure;
5452 }
5453
5454 StringRef Name = Blob;
5455 unsigned Idx = 0;
5456 SubmoduleID GlobalID = getGlobalSubmoduleID(F, Record[Idx++]);
5457 SubmoduleID Parent = getGlobalSubmoduleID(F, Record[Idx++]);
5458 Module::ModuleKind Kind = (Module::ModuleKind)Record[Idx++];
5459 bool IsFramework = Record[Idx++];
5460 bool IsExplicit = Record[Idx++];
5461 bool IsSystem = Record[Idx++];
5462 bool IsExternC = Record[Idx++];
5463 bool InferSubmodules = Record[Idx++];
5464 bool InferExplicitSubmodules = Record[Idx++];
5465 bool InferExportWildcard = Record[Idx++];
5466 bool ConfigMacrosExhaustive = Record[Idx++];
5467 bool ModuleMapIsPrivate = Record[Idx++];
5468
5469 Module *ParentModule = nullptr;
5470 if (Parent)
5471 ParentModule = getSubmodule(Parent);
5472
5473 // Retrieve this (sub)module from the module map, creating it if
5474 // necessary.
5475 CurrentModule =
5476 ModMap.findOrCreateModule(Name, ParentModule, IsFramework, IsExplicit)
5477 .first;
5478
5479 // FIXME: set the definition loc for CurrentModule, or call
5480 // ModMap.setInferredModuleAllowedBy()
5481
5482 SubmoduleID GlobalIndex = GlobalID - NUM_PREDEF_SUBMODULE_IDS;
5483 if (GlobalIndex >= SubmodulesLoaded.size() ||
5484 SubmodulesLoaded[GlobalIndex]) {
5485 Error("too many submodules");
5486 return Failure;
5487 }
5488
5489 if (!ParentModule) {
5490 if (const FileEntry *CurFile = CurrentModule->getASTFile()) {
5491 // Don't emit module relocation error if we have -fno-validate-pch
5492 if (!PP.getPreprocessorOpts().DisablePCHValidation &&
5493 CurFile != F.File) {
5494 Error(diag::err_module_file_conflict,
5495 CurrentModule->getTopLevelModuleName(), CurFile->getName(),
5496 F.File->getName());
5497 return Failure;
5498 }
5499 }
5500
5501 F.DidReadTopLevelSubmodule = true;
5502 CurrentModule->setASTFile(F.File);
5503 CurrentModule->PresumedModuleMapFile = F.ModuleMapPath;
5504 }
5505
5506 CurrentModule->Kind = Kind;
5507 CurrentModule->Signature = F.Signature;
5508 CurrentModule->IsFromModuleFile = true;
5509 CurrentModule->IsSystem = IsSystem || CurrentModule->IsSystem;
5510 CurrentModule->IsExternC = IsExternC;
5511 CurrentModule->InferSubmodules = InferSubmodules;
5512 CurrentModule->InferExplicitSubmodules = InferExplicitSubmodules;
5513 CurrentModule->InferExportWildcard = InferExportWildcard;
5514 CurrentModule->ConfigMacrosExhaustive = ConfigMacrosExhaustive;
5515 CurrentModule->ModuleMapIsPrivate = ModuleMapIsPrivate;
5516 if (DeserializationListener)
5517 DeserializationListener->ModuleRead(GlobalID, CurrentModule);
5518
5519 SubmodulesLoaded[GlobalIndex] = CurrentModule;
5520
5521 // Clear out data that will be replaced by what is in the module file.
5522 CurrentModule->LinkLibraries.clear();
5523 CurrentModule->ConfigMacros.clear();
5524 CurrentModule->UnresolvedConflicts.clear();
5525 CurrentModule->Conflicts.clear();
5526
5527 // The module is available unless it's missing a requirement; relevant
5528 // requirements will be (re-)added by SUBMODULE_REQUIRES records.
5529 // Missing headers that were present when the module was built do not
5530 // make it unavailable -- if we got this far, this must be an explicitly
5531 // imported module file.
5532 CurrentModule->Requirements.clear();
5533 CurrentModule->MissingHeaders.clear();
5534 CurrentModule->IsMissingRequirement =
5535 ParentModule && ParentModule->IsMissingRequirement;
5536 CurrentModule->IsAvailable = !CurrentModule->IsMissingRequirement;
5537 break;
5538 }
5539
5540 case SUBMODULE_UMBRELLA_HEADER: {
5541 std::string Filename = Blob;
5542 ResolveImportedPath(F, Filename);
5543 if (auto Umbrella = PP.getFileManager().getFile(Filename)) {
5544 if (!CurrentModule->getUmbrellaHeader())
5545 ModMap.setUmbrellaHeader(CurrentModule, *Umbrella, Blob);
5546 else if (CurrentModule->getUmbrellaHeader().Entry != *Umbrella) {
5547 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
5548 Error("mismatched umbrella headers in submodule");
5549 return OutOfDate;
5550 }
5551 }
5552 break;
5553 }
5554
5555 case SUBMODULE_HEADER:
5556 case SUBMODULE_EXCLUDED_HEADER:
5557 case SUBMODULE_PRIVATE_HEADER:
5558 // We lazily associate headers with their modules via the HeaderInfo table.
5559 // FIXME: Re-evaluate this section; maybe only store InputFile IDs instead
5560 // of complete filenames or remove it entirely.
5561 break;
5562
5563 case SUBMODULE_TEXTUAL_HEADER:
5564 case SUBMODULE_PRIVATE_TEXTUAL_HEADER:
5565 // FIXME: Textual headers are not marked in the HeaderInfo table. Load
5566 // them here.
5567 break;
5568
5569 case SUBMODULE_TOPHEADER:
5570 CurrentModule->addTopHeaderFilename(Blob);
5571 break;
5572
5573 case SUBMODULE_UMBRELLA_DIR: {
5574 std::string Dirname = Blob;
5575 ResolveImportedPath(F, Dirname);
5576 if (auto Umbrella = PP.getFileManager().getDirectory(Dirname)) {
5577 if (!CurrentModule->getUmbrellaDir())
5578 ModMap.setUmbrellaDir(CurrentModule, *Umbrella, Blob);
5579 else if (CurrentModule->getUmbrellaDir().Entry != *Umbrella) {
5580 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
5581 Error("mismatched umbrella directories in submodule");
5582 return OutOfDate;
5583 }
5584 }
5585 break;
5586 }
5587
5588 case SUBMODULE_METADATA: {
5589 F.BaseSubmoduleID = getTotalNumSubmodules();
5590 F.LocalNumSubmodules = Record[0];
5591 unsigned LocalBaseSubmoduleID = Record[1];
5592 if (F.LocalNumSubmodules > 0) {
5593 // Introduce the global -> local mapping for submodules within this
5594 // module.
5595 GlobalSubmoduleMap.insert(std::make_pair(getTotalNumSubmodules()+1,&F));
5596
5597 // Introduce the local -> global mapping for submodules within this
5598 // module.
5599 F.SubmoduleRemap.insertOrReplace(
5600 std::make_pair(LocalBaseSubmoduleID,
5601 F.BaseSubmoduleID - LocalBaseSubmoduleID));
5602
5603 SubmodulesLoaded.resize(SubmodulesLoaded.size() + F.LocalNumSubmodules);
5604 }
5605 break;
5606 }
5607
5608 case SUBMODULE_IMPORTS:
5609 for (unsigned Idx = 0; Idx != Record.size(); ++Idx) {
5610 UnresolvedModuleRef Unresolved;
5611 Unresolved.File = &F;
5612 Unresolved.Mod = CurrentModule;
5613 Unresolved.ID = Record[Idx];
5614 Unresolved.Kind = UnresolvedModuleRef::Import;
5615 Unresolved.IsWildcard = false;
5616 UnresolvedModuleRefs.push_back(Unresolved);
5617 }
5618 break;
5619
5620 case SUBMODULE_EXPORTS:
5621 for (unsigned Idx = 0; Idx + 1 < Record.size(); Idx += 2) {
5622 UnresolvedModuleRef Unresolved;
5623 Unresolved.File = &F;
5624 Unresolved.Mod = CurrentModule;
5625 Unresolved.ID = Record[Idx];
5626 Unresolved.Kind = UnresolvedModuleRef::Export;
5627 Unresolved.IsWildcard = Record[Idx + 1];
5628 UnresolvedModuleRefs.push_back(Unresolved);
5629 }
5630
5631 // Once we've loaded the set of exports, there's no reason to keep
5632 // the parsed, unresolved exports around.
5633 CurrentModule->UnresolvedExports.clear();
5634 break;
5635
5636 case SUBMODULE_REQUIRES:
5637 CurrentModule->addRequirement(Blob, Record[0], PP.getLangOpts(),
5638 PP.getTargetInfo());
5639 break;
5640
5641 case SUBMODULE_LINK_LIBRARY:
5642 ModMap.resolveLinkAsDependencies(CurrentModule);
5643 CurrentModule->LinkLibraries.push_back(
5644 Module::LinkLibrary(Blob, Record[0]));
5645 break;
5646
5647 case SUBMODULE_CONFIG_MACRO:
5648 CurrentModule->ConfigMacros.push_back(Blob.str());
5649 break;
5650
5651 case SUBMODULE_CONFLICT: {
5652 UnresolvedModuleRef Unresolved;
5653 Unresolved.File = &F;
5654 Unresolved.Mod = CurrentModule;
5655 Unresolved.ID = Record[0];
5656 Unresolved.Kind = UnresolvedModuleRef::Conflict;
5657 Unresolved.IsWildcard = false;
5658 Unresolved.String = Blob;
5659 UnresolvedModuleRefs.push_back(Unresolved);
5660 break;
5661 }
5662
5663 case SUBMODULE_INITIALIZERS: {
5664 if (!ContextObj)
5665 break;
5666 SmallVector<uint32_t, 16> Inits;
5667 for (auto &ID : Record)
5668 Inits.push_back(getGlobalDeclID(F, ID));
5669 ContextObj->addLazyModuleInitializers(CurrentModule, Inits);
5670 break;
5671 }
5672
5673 case SUBMODULE_EXPORT_AS:
5674 CurrentModule->ExportAsModule = Blob.str();
5675 ModMap.addLinkAsDependency(CurrentModule);
5676 break;
5677 }
5678 }
5679 }
5680
5681 /// Parse the record that corresponds to a LangOptions data
5682 /// structure.
5683 ///
5684 /// This routine parses the language options from the AST file and then gives
5685 /// them to the AST listener if one is set.
5686 ///
5687 /// \returns true if the listener deems the file unacceptable, false otherwise.
ParseLanguageOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener,bool AllowCompatibleDifferences)5688 bool ASTReader::ParseLanguageOptions(const RecordData &Record,
5689 bool Complain,
5690 ASTReaderListener &Listener,
5691 bool AllowCompatibleDifferences) {
5692 LangOptions LangOpts;
5693 unsigned Idx = 0;
5694 #define LANGOPT(Name, Bits, Default, Description) \
5695 LangOpts.Name = Record[Idx++];
5696 #define ENUM_LANGOPT(Name, Type, Bits, Default, Description) \
5697 LangOpts.set##Name(static_cast<LangOptions::Type>(Record[Idx++]));
5698 #include "clang/Basic/LangOptions.def"
5699 #define SANITIZER(NAME, ID) \
5700 LangOpts.Sanitize.set(SanitizerKind::ID, Record[Idx++]);
5701 #include "clang/Basic/Sanitizers.def"
5702
5703 for (unsigned N = Record[Idx++]; N; --N)
5704 LangOpts.ModuleFeatures.push_back(ReadString(Record, Idx));
5705
5706 ObjCRuntime::Kind runtimeKind = (ObjCRuntime::Kind) Record[Idx++];
5707 VersionTuple runtimeVersion = ReadVersionTuple(Record, Idx);
5708 LangOpts.ObjCRuntime = ObjCRuntime(runtimeKind, runtimeVersion);
5709
5710 LangOpts.CurrentModule = ReadString(Record, Idx);
5711
5712 // Comment options.
5713 for (unsigned N = Record[Idx++]; N; --N) {
5714 LangOpts.CommentOpts.BlockCommandNames.push_back(
5715 ReadString(Record, Idx));
5716 }
5717 LangOpts.CommentOpts.ParseAllComments = Record[Idx++];
5718
5719 // OpenMP offloading options.
5720 for (unsigned N = Record[Idx++]; N; --N) {
5721 LangOpts.OMPTargetTriples.push_back(llvm::Triple(ReadString(Record, Idx)));
5722 }
5723
5724 LangOpts.OMPHostIRFile = ReadString(Record, Idx);
5725
5726 return Listener.ReadLanguageOptions(LangOpts, Complain,
5727 AllowCompatibleDifferences);
5728 }
5729
ParseTargetOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener,bool AllowCompatibleDifferences)5730 bool ASTReader::ParseTargetOptions(const RecordData &Record, bool Complain,
5731 ASTReaderListener &Listener,
5732 bool AllowCompatibleDifferences) {
5733 unsigned Idx = 0;
5734 TargetOptions TargetOpts;
5735 TargetOpts.Triple = ReadString(Record, Idx);
5736 TargetOpts.CPU = ReadString(Record, Idx);
5737 TargetOpts.ABI = ReadString(Record, Idx);
5738 for (unsigned N = Record[Idx++]; N; --N) {
5739 TargetOpts.FeaturesAsWritten.push_back(ReadString(Record, Idx));
5740 }
5741 for (unsigned N = Record[Idx++]; N; --N) {
5742 TargetOpts.Features.push_back(ReadString(Record, Idx));
5743 }
5744
5745 return Listener.ReadTargetOptions(TargetOpts, Complain,
5746 AllowCompatibleDifferences);
5747 }
5748
ParseDiagnosticOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener)5749 bool ASTReader::ParseDiagnosticOptions(const RecordData &Record, bool Complain,
5750 ASTReaderListener &Listener) {
5751 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts(new DiagnosticOptions);
5752 unsigned Idx = 0;
5753 #define DIAGOPT(Name, Bits, Default) DiagOpts->Name = Record[Idx++];
5754 #define ENUM_DIAGOPT(Name, Type, Bits, Default) \
5755 DiagOpts->set##Name(static_cast<Type>(Record[Idx++]));
5756 #include "clang/Basic/DiagnosticOptions.def"
5757
5758 for (unsigned N = Record[Idx++]; N; --N)
5759 DiagOpts->Warnings.push_back(ReadString(Record, Idx));
5760 for (unsigned N = Record[Idx++]; N; --N)
5761 DiagOpts->Remarks.push_back(ReadString(Record, Idx));
5762
5763 return Listener.ReadDiagnosticOptions(DiagOpts, Complain);
5764 }
5765
ParseFileSystemOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener)5766 bool ASTReader::ParseFileSystemOptions(const RecordData &Record, bool Complain,
5767 ASTReaderListener &Listener) {
5768 FileSystemOptions FSOpts;
5769 unsigned Idx = 0;
5770 FSOpts.WorkingDir = ReadString(Record, Idx);
5771 return Listener.ReadFileSystemOptions(FSOpts, Complain);
5772 }
5773
ParseHeaderSearchOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener)5774 bool ASTReader::ParseHeaderSearchOptions(const RecordData &Record,
5775 bool Complain,
5776 ASTReaderListener &Listener) {
5777 HeaderSearchOptions HSOpts;
5778 unsigned Idx = 0;
5779 HSOpts.Sysroot = ReadString(Record, Idx);
5780
5781 // Include entries.
5782 for (unsigned N = Record[Idx++]; N; --N) {
5783 std::string Path = ReadString(Record, Idx);
5784 frontend::IncludeDirGroup Group
5785 = static_cast<frontend::IncludeDirGroup>(Record[Idx++]);
5786 bool IsFramework = Record[Idx++];
5787 bool IgnoreSysRoot = Record[Idx++];
5788 HSOpts.UserEntries.emplace_back(std::move(Path), Group, IsFramework,
5789 IgnoreSysRoot);
5790 }
5791
5792 // System header prefixes.
5793 for (unsigned N = Record[Idx++]; N; --N) {
5794 std::string Prefix = ReadString(Record, Idx);
5795 bool IsSystemHeader = Record[Idx++];
5796 HSOpts.SystemHeaderPrefixes.emplace_back(std::move(Prefix), IsSystemHeader);
5797 }
5798
5799 HSOpts.ResourceDir = ReadString(Record, Idx);
5800 HSOpts.ModuleCachePath = ReadString(Record, Idx);
5801 HSOpts.ModuleUserBuildPath = ReadString(Record, Idx);
5802 HSOpts.DisableModuleHash = Record[Idx++];
5803 HSOpts.ImplicitModuleMaps = Record[Idx++];
5804 HSOpts.ModuleMapFileHomeIsCwd = Record[Idx++];
5805 HSOpts.UseBuiltinIncludes = Record[Idx++];
5806 HSOpts.UseStandardSystemIncludes = Record[Idx++];
5807 HSOpts.UseStandardCXXIncludes = Record[Idx++];
5808 HSOpts.UseLibcxx = Record[Idx++];
5809 std::string SpecificModuleCachePath = ReadString(Record, Idx);
5810
5811 return Listener.ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
5812 Complain);
5813 }
5814
ParsePreprocessorOptions(const RecordData & Record,bool Complain,ASTReaderListener & Listener,std::string & SuggestedPredefines)5815 bool ASTReader::ParsePreprocessorOptions(const RecordData &Record,
5816 bool Complain,
5817 ASTReaderListener &Listener,
5818 std::string &SuggestedPredefines) {
5819 PreprocessorOptions PPOpts;
5820 unsigned Idx = 0;
5821
5822 // Macro definitions/undefs
5823 for (unsigned N = Record[Idx++]; N; --N) {
5824 std::string Macro = ReadString(Record, Idx);
5825 bool IsUndef = Record[Idx++];
5826 PPOpts.Macros.push_back(std::make_pair(Macro, IsUndef));
5827 }
5828
5829 // Includes
5830 for (unsigned N = Record[Idx++]; N; --N) {
5831 PPOpts.Includes.push_back(ReadString(Record, Idx));
5832 }
5833
5834 // Macro Includes
5835 for (unsigned N = Record[Idx++]; N; --N) {
5836 PPOpts.MacroIncludes.push_back(ReadString(Record, Idx));
5837 }
5838
5839 PPOpts.UsePredefines = Record[Idx++];
5840 PPOpts.DetailedRecord = Record[Idx++];
5841 PPOpts.ImplicitPCHInclude = ReadString(Record, Idx);
5842 PPOpts.ObjCXXARCStandardLibrary =
5843 static_cast<ObjCXXARCStandardLibraryKind>(Record[Idx++]);
5844 SuggestedPredefines.clear();
5845 return Listener.ReadPreprocessorOptions(PPOpts, Complain,
5846 SuggestedPredefines);
5847 }
5848
5849 std::pair<ModuleFile *, unsigned>
getModulePreprocessedEntity(unsigned GlobalIndex)5850 ASTReader::getModulePreprocessedEntity(unsigned GlobalIndex) {
5851 GlobalPreprocessedEntityMapType::iterator
5852 I = GlobalPreprocessedEntityMap.find(GlobalIndex);
5853 assert(I != GlobalPreprocessedEntityMap.end() &&
5854 "Corrupted global preprocessed entity map");
5855 ModuleFile *M = I->second;
5856 unsigned LocalIndex = GlobalIndex - M->BasePreprocessedEntityID;
5857 return std::make_pair(M, LocalIndex);
5858 }
5859
5860 llvm::iterator_range<PreprocessingRecord::iterator>
getModulePreprocessedEntities(ModuleFile & Mod) const5861 ASTReader::getModulePreprocessedEntities(ModuleFile &Mod) const {
5862 if (PreprocessingRecord *PPRec = PP.getPreprocessingRecord())
5863 return PPRec->getIteratorsForLoadedRange(Mod.BasePreprocessedEntityID,
5864 Mod.NumPreprocessedEntities);
5865
5866 return llvm::make_range(PreprocessingRecord::iterator(),
5867 PreprocessingRecord::iterator());
5868 }
5869
5870 llvm::iterator_range<ASTReader::ModuleDeclIterator>
getModuleFileLevelDecls(ModuleFile & Mod)5871 ASTReader::getModuleFileLevelDecls(ModuleFile &Mod) {
5872 return llvm::make_range(
5873 ModuleDeclIterator(this, &Mod, Mod.FileSortedDecls),
5874 ModuleDeclIterator(this, &Mod,
5875 Mod.FileSortedDecls + Mod.NumFileSortedDecls));
5876 }
5877
ReadSkippedRange(unsigned GlobalIndex)5878 SourceRange ASTReader::ReadSkippedRange(unsigned GlobalIndex) {
5879 auto I = GlobalSkippedRangeMap.find(GlobalIndex);
5880 assert(I != GlobalSkippedRangeMap.end() &&
5881 "Corrupted global skipped range map");
5882 ModuleFile *M = I->second;
5883 unsigned LocalIndex = GlobalIndex - M->BasePreprocessedSkippedRangeID;
5884 assert(LocalIndex < M->NumPreprocessedSkippedRanges);
5885 PPSkippedRange RawRange = M->PreprocessedSkippedRangeOffsets[LocalIndex];
5886 SourceRange Range(TranslateSourceLocation(*M, RawRange.getBegin()),
5887 TranslateSourceLocation(*M, RawRange.getEnd()));
5888 assert(Range.isValid());
5889 return Range;
5890 }
5891
ReadPreprocessedEntity(unsigned Index)5892 PreprocessedEntity *ASTReader::ReadPreprocessedEntity(unsigned Index) {
5893 PreprocessedEntityID PPID = Index+1;
5894 std::pair<ModuleFile *, unsigned> PPInfo = getModulePreprocessedEntity(Index);
5895 ModuleFile &M = *PPInfo.first;
5896 unsigned LocalIndex = PPInfo.second;
5897 const PPEntityOffset &PPOffs = M.PreprocessedEntityOffsets[LocalIndex];
5898
5899 if (!PP.getPreprocessingRecord()) {
5900 Error("no preprocessing record");
5901 return nullptr;
5902 }
5903
5904 SavedStreamPosition SavedPosition(M.PreprocessorDetailCursor);
5905 if (llvm::Error Err =
5906 M.PreprocessorDetailCursor.JumpToBit(PPOffs.BitOffset)) {
5907 Error(std::move(Err));
5908 return nullptr;
5909 }
5910
5911 Expected<llvm::BitstreamEntry> MaybeEntry =
5912 M.PreprocessorDetailCursor.advance(BitstreamCursor::AF_DontPopBlockAtEnd);
5913 if (!MaybeEntry) {
5914 Error(MaybeEntry.takeError());
5915 return nullptr;
5916 }
5917 llvm::BitstreamEntry Entry = MaybeEntry.get();
5918
5919 if (Entry.Kind != llvm::BitstreamEntry::Record)
5920 return nullptr;
5921
5922 // Read the record.
5923 SourceRange Range(TranslateSourceLocation(M, PPOffs.getBegin()),
5924 TranslateSourceLocation(M, PPOffs.getEnd()));
5925 PreprocessingRecord &PPRec = *PP.getPreprocessingRecord();
5926 StringRef Blob;
5927 RecordData Record;
5928 Expected<unsigned> MaybeRecType =
5929 M.PreprocessorDetailCursor.readRecord(Entry.ID, Record, &Blob);
5930 if (!MaybeRecType) {
5931 Error(MaybeRecType.takeError());
5932 return nullptr;
5933 }
5934 switch ((PreprocessorDetailRecordTypes)MaybeRecType.get()) {
5935 case PPD_MACRO_EXPANSION: {
5936 bool isBuiltin = Record[0];
5937 IdentifierInfo *Name = nullptr;
5938 MacroDefinitionRecord *Def = nullptr;
5939 if (isBuiltin)
5940 Name = getLocalIdentifier(M, Record[1]);
5941 else {
5942 PreprocessedEntityID GlobalID =
5943 getGlobalPreprocessedEntityID(M, Record[1]);
5944 Def = cast<MacroDefinitionRecord>(
5945 PPRec.getLoadedPreprocessedEntity(GlobalID - 1));
5946 }
5947
5948 MacroExpansion *ME;
5949 if (isBuiltin)
5950 ME = new (PPRec) MacroExpansion(Name, Range);
5951 else
5952 ME = new (PPRec) MacroExpansion(Def, Range);
5953
5954 return ME;
5955 }
5956
5957 case PPD_MACRO_DEFINITION: {
5958 // Decode the identifier info and then check again; if the macro is
5959 // still defined and associated with the identifier,
5960 IdentifierInfo *II = getLocalIdentifier(M, Record[0]);
5961 MacroDefinitionRecord *MD = new (PPRec) MacroDefinitionRecord(II, Range);
5962
5963 if (DeserializationListener)
5964 DeserializationListener->MacroDefinitionRead(PPID, MD);
5965
5966 return MD;
5967 }
5968
5969 case PPD_INCLUSION_DIRECTIVE: {
5970 const char *FullFileNameStart = Blob.data() + Record[0];
5971 StringRef FullFileName(FullFileNameStart, Blob.size() - Record[0]);
5972 const FileEntry *File = nullptr;
5973 if (!FullFileName.empty())
5974 if (auto FE = PP.getFileManager().getFile(FullFileName))
5975 File = *FE;
5976
5977 // FIXME: Stable encoding
5978 InclusionDirective::InclusionKind Kind
5979 = static_cast<InclusionDirective::InclusionKind>(Record[2]);
5980 InclusionDirective *ID
5981 = new (PPRec) InclusionDirective(PPRec, Kind,
5982 StringRef(Blob.data(), Record[0]),
5983 Record[1], Record[3],
5984 File,
5985 Range);
5986 return ID;
5987 }
5988 }
5989
5990 llvm_unreachable("Invalid PreprocessorDetailRecordTypes");
5991 }
5992
5993 /// Find the next module that contains entities and return the ID
5994 /// of the first entry.
5995 ///
5996 /// \param SLocMapI points at a chunk of a module that contains no
5997 /// preprocessed entities or the entities it contains are not the ones we are
5998 /// looking for.
findNextPreprocessedEntity(GlobalSLocOffsetMapType::const_iterator SLocMapI) const5999 PreprocessedEntityID ASTReader::findNextPreprocessedEntity(
6000 GlobalSLocOffsetMapType::const_iterator SLocMapI) const {
6001 ++SLocMapI;
6002 for (GlobalSLocOffsetMapType::const_iterator
6003 EndI = GlobalSLocOffsetMap.end(); SLocMapI != EndI; ++SLocMapI) {
6004 ModuleFile &M = *SLocMapI->second;
6005 if (M.NumPreprocessedEntities)
6006 return M.BasePreprocessedEntityID;
6007 }
6008
6009 return getTotalNumPreprocessedEntities();
6010 }
6011
6012 namespace {
6013
6014 struct PPEntityComp {
6015 const ASTReader &Reader;
6016 ModuleFile &M;
6017
PPEntityComp__anon6f7646f90b11::PPEntityComp6018 PPEntityComp(const ASTReader &Reader, ModuleFile &M) : Reader(Reader), M(M) {}
6019
operator ()__anon6f7646f90b11::PPEntityComp6020 bool operator()(const PPEntityOffset &L, const PPEntityOffset &R) const {
6021 SourceLocation LHS = getLoc(L);
6022 SourceLocation RHS = getLoc(R);
6023 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6024 }
6025
operator ()__anon6f7646f90b11::PPEntityComp6026 bool operator()(const PPEntityOffset &L, SourceLocation RHS) const {
6027 SourceLocation LHS = getLoc(L);
6028 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6029 }
6030
operator ()__anon6f7646f90b11::PPEntityComp6031 bool operator()(SourceLocation LHS, const PPEntityOffset &R) const {
6032 SourceLocation RHS = getLoc(R);
6033 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6034 }
6035
getLoc__anon6f7646f90b11::PPEntityComp6036 SourceLocation getLoc(const PPEntityOffset &PPE) const {
6037 return Reader.TranslateSourceLocation(M, PPE.getBegin());
6038 }
6039 };
6040
6041 } // namespace
6042
findPreprocessedEntity(SourceLocation Loc,bool EndsAfter) const6043 PreprocessedEntityID ASTReader::findPreprocessedEntity(SourceLocation Loc,
6044 bool EndsAfter) const {
6045 if (SourceMgr.isLocalSourceLocation(Loc))
6046 return getTotalNumPreprocessedEntities();
6047
6048 GlobalSLocOffsetMapType::const_iterator SLocMapI = GlobalSLocOffsetMap.find(
6049 SourceManager::MaxLoadedOffset - Loc.getOffset() - 1);
6050 assert(SLocMapI != GlobalSLocOffsetMap.end() &&
6051 "Corrupted global sloc offset map");
6052
6053 if (SLocMapI->second->NumPreprocessedEntities == 0)
6054 return findNextPreprocessedEntity(SLocMapI);
6055
6056 ModuleFile &M = *SLocMapI->second;
6057
6058 using pp_iterator = const PPEntityOffset *;
6059
6060 pp_iterator pp_begin = M.PreprocessedEntityOffsets;
6061 pp_iterator pp_end = pp_begin + M.NumPreprocessedEntities;
6062
6063 size_t Count = M.NumPreprocessedEntities;
6064 size_t Half;
6065 pp_iterator First = pp_begin;
6066 pp_iterator PPI;
6067
6068 if (EndsAfter) {
6069 PPI = std::upper_bound(pp_begin, pp_end, Loc,
6070 PPEntityComp(*this, M));
6071 } else {
6072 // Do a binary search manually instead of using std::lower_bound because
6073 // The end locations of entities may be unordered (when a macro expansion
6074 // is inside another macro argument), but for this case it is not important
6075 // whether we get the first macro expansion or its containing macro.
6076 while (Count > 0) {
6077 Half = Count / 2;
6078 PPI = First;
6079 std::advance(PPI, Half);
6080 if (SourceMgr.isBeforeInTranslationUnit(
6081 TranslateSourceLocation(M, PPI->getEnd()), Loc)) {
6082 First = PPI;
6083 ++First;
6084 Count = Count - Half - 1;
6085 } else
6086 Count = Half;
6087 }
6088 }
6089
6090 if (PPI == pp_end)
6091 return findNextPreprocessedEntity(SLocMapI);
6092
6093 return M.BasePreprocessedEntityID + (PPI - pp_begin);
6094 }
6095
6096 /// Returns a pair of [Begin, End) indices of preallocated
6097 /// preprocessed entities that \arg Range encompasses.
6098 std::pair<unsigned, unsigned>
findPreprocessedEntitiesInRange(SourceRange Range)6099 ASTReader::findPreprocessedEntitiesInRange(SourceRange Range) {
6100 if (Range.isInvalid())
6101 return std::make_pair(0,0);
6102 assert(!SourceMgr.isBeforeInTranslationUnit(Range.getEnd(),Range.getBegin()));
6103
6104 PreprocessedEntityID BeginID =
6105 findPreprocessedEntity(Range.getBegin(), false);
6106 PreprocessedEntityID EndID = findPreprocessedEntity(Range.getEnd(), true);
6107 return std::make_pair(BeginID, EndID);
6108 }
6109
6110 /// Optionally returns true or false if the preallocated preprocessed
6111 /// entity with index \arg Index came from file \arg FID.
isPreprocessedEntityInFileID(unsigned Index,FileID FID)6112 Optional<bool> ASTReader::isPreprocessedEntityInFileID(unsigned Index,
6113 FileID FID) {
6114 if (FID.isInvalid())
6115 return false;
6116
6117 std::pair<ModuleFile *, unsigned> PPInfo = getModulePreprocessedEntity(Index);
6118 ModuleFile &M = *PPInfo.first;
6119 unsigned LocalIndex = PPInfo.second;
6120 const PPEntityOffset &PPOffs = M.PreprocessedEntityOffsets[LocalIndex];
6121
6122 SourceLocation Loc = TranslateSourceLocation(M, PPOffs.getBegin());
6123 if (Loc.isInvalid())
6124 return false;
6125
6126 if (SourceMgr.isInFileID(SourceMgr.getFileLoc(Loc), FID))
6127 return true;
6128 else
6129 return false;
6130 }
6131
6132 namespace {
6133
6134 /// Visitor used to search for information about a header file.
6135 class HeaderFileInfoVisitor {
6136 const FileEntry *FE;
6137 Optional<HeaderFileInfo> HFI;
6138
6139 public:
HeaderFileInfoVisitor(const FileEntry * FE)6140 explicit HeaderFileInfoVisitor(const FileEntry *FE) : FE(FE) {}
6141
operator ()(ModuleFile & M)6142 bool operator()(ModuleFile &M) {
6143 HeaderFileInfoLookupTable *Table
6144 = static_cast<HeaderFileInfoLookupTable *>(M.HeaderFileInfoTable);
6145 if (!Table)
6146 return false;
6147
6148 // Look in the on-disk hash table for an entry for this file name.
6149 HeaderFileInfoLookupTable::iterator Pos = Table->find(FE);
6150 if (Pos == Table->end())
6151 return false;
6152
6153 HFI = *Pos;
6154 return true;
6155 }
6156
getHeaderFileInfo() const6157 Optional<HeaderFileInfo> getHeaderFileInfo() const { return HFI; }
6158 };
6159
6160 } // namespace
6161
GetHeaderFileInfo(const FileEntry * FE)6162 HeaderFileInfo ASTReader::GetHeaderFileInfo(const FileEntry *FE) {
6163 HeaderFileInfoVisitor Visitor(FE);
6164 ModuleMgr.visit(Visitor);
6165 if (Optional<HeaderFileInfo> HFI = Visitor.getHeaderFileInfo())
6166 return *HFI;
6167
6168 return HeaderFileInfo();
6169 }
6170
ReadPragmaDiagnosticMappings(DiagnosticsEngine & Diag)6171 void ASTReader::ReadPragmaDiagnosticMappings(DiagnosticsEngine &Diag) {
6172 using DiagState = DiagnosticsEngine::DiagState;
6173 SmallVector<DiagState *, 32> DiagStates;
6174
6175 for (ModuleFile &F : ModuleMgr) {
6176 unsigned Idx = 0;
6177 auto &Record = F.PragmaDiagMappings;
6178 if (Record.empty())
6179 continue;
6180
6181 DiagStates.clear();
6182
6183 auto ReadDiagState =
6184 [&](const DiagState &BasedOn, SourceLocation Loc,
6185 bool IncludeNonPragmaStates) -> DiagnosticsEngine::DiagState * {
6186 unsigned BackrefID = Record[Idx++];
6187 if (BackrefID != 0)
6188 return DiagStates[BackrefID - 1];
6189
6190 // A new DiagState was created here.
6191 Diag.DiagStates.push_back(BasedOn);
6192 DiagState *NewState = &Diag.DiagStates.back();
6193 DiagStates.push_back(NewState);
6194 unsigned Size = Record[Idx++];
6195 assert(Idx + Size * 2 <= Record.size() &&
6196 "Invalid data, not enough diag/map pairs");
6197 while (Size--) {
6198 unsigned DiagID = Record[Idx++];
6199 DiagnosticMapping NewMapping =
6200 DiagnosticMapping::deserialize(Record[Idx++]);
6201 if (!NewMapping.isPragma() && !IncludeNonPragmaStates)
6202 continue;
6203
6204 DiagnosticMapping &Mapping = NewState->getOrAddMapping(DiagID);
6205
6206 // If this mapping was specified as a warning but the severity was
6207 // upgraded due to diagnostic settings, simulate the current diagnostic
6208 // settings (and use a warning).
6209 if (NewMapping.wasUpgradedFromWarning() && !Mapping.isErrorOrFatal()) {
6210 NewMapping.setSeverity(diag::Severity::Warning);
6211 NewMapping.setUpgradedFromWarning(false);
6212 }
6213
6214 Mapping = NewMapping;
6215 }
6216 return NewState;
6217 };
6218
6219 // Read the first state.
6220 DiagState *FirstState;
6221 if (F.Kind == MK_ImplicitModule) {
6222 // Implicitly-built modules are reused with different diagnostic
6223 // settings. Use the initial diagnostic state from Diag to simulate this
6224 // compilation's diagnostic settings.
6225 FirstState = Diag.DiagStatesByLoc.FirstDiagState;
6226 DiagStates.push_back(FirstState);
6227
6228 // Skip the initial diagnostic state from the serialized module.
6229 assert(Record[1] == 0 &&
6230 "Invalid data, unexpected backref in initial state");
6231 Idx = 3 + Record[2] * 2;
6232 assert(Idx < Record.size() &&
6233 "Invalid data, not enough state change pairs in initial state");
6234 } else if (F.isModule()) {
6235 // For an explicit module, preserve the flags from the module build
6236 // command line (-w, -Weverything, -Werror, ...) along with any explicit
6237 // -Wblah flags.
6238 unsigned Flags = Record[Idx++];
6239 DiagState Initial;
6240 Initial.SuppressSystemWarnings = Flags & 1; Flags >>= 1;
6241 Initial.ErrorsAsFatal = Flags & 1; Flags >>= 1;
6242 Initial.WarningsAsErrors = Flags & 1; Flags >>= 1;
6243 Initial.EnableAllWarnings = Flags & 1; Flags >>= 1;
6244 Initial.IgnoreAllWarnings = Flags & 1; Flags >>= 1;
6245 Initial.ExtBehavior = (diag::Severity)Flags;
6246 FirstState = ReadDiagState(Initial, SourceLocation(), true);
6247
6248 assert(F.OriginalSourceFileID.isValid());
6249
6250 // Set up the root buffer of the module to start with the initial
6251 // diagnostic state of the module itself, to cover files that contain no
6252 // explicit transitions (for which we did not serialize anything).
6253 Diag.DiagStatesByLoc.Files[F.OriginalSourceFileID]
6254 .StateTransitions.push_back({FirstState, 0});
6255 } else {
6256 // For prefix ASTs, start with whatever the user configured on the
6257 // command line.
6258 Idx++; // Skip flags.
6259 FirstState = ReadDiagState(*Diag.DiagStatesByLoc.CurDiagState,
6260 SourceLocation(), false);
6261 }
6262
6263 // Read the state transitions.
6264 unsigned NumLocations = Record[Idx++];
6265 while (NumLocations--) {
6266 assert(Idx < Record.size() &&
6267 "Invalid data, missing pragma diagnostic states");
6268 SourceLocation Loc = ReadSourceLocation(F, Record[Idx++]);
6269 auto IDAndOffset = SourceMgr.getDecomposedLoc(Loc);
6270 assert(IDAndOffset.first.isValid() && "invalid FileID for transition");
6271 assert(IDAndOffset.second == 0 && "not a start location for a FileID");
6272 unsigned Transitions = Record[Idx++];
6273
6274 // Note that we don't need to set up Parent/ParentOffset here, because
6275 // we won't be changing the diagnostic state within imported FileIDs
6276 // (other than perhaps appending to the main source file, which has no
6277 // parent).
6278 auto &F = Diag.DiagStatesByLoc.Files[IDAndOffset.first];
6279 F.StateTransitions.reserve(F.StateTransitions.size() + Transitions);
6280 for (unsigned I = 0; I != Transitions; ++I) {
6281 unsigned Offset = Record[Idx++];
6282 auto *State =
6283 ReadDiagState(*FirstState, Loc.getLocWithOffset(Offset), false);
6284 F.StateTransitions.push_back({State, Offset});
6285 }
6286 }
6287
6288 // Read the final state.
6289 assert(Idx < Record.size() &&
6290 "Invalid data, missing final pragma diagnostic state");
6291 SourceLocation CurStateLoc =
6292 ReadSourceLocation(F, F.PragmaDiagMappings[Idx++]);
6293 auto *CurState = ReadDiagState(*FirstState, CurStateLoc, false);
6294
6295 if (!F.isModule()) {
6296 Diag.DiagStatesByLoc.CurDiagState = CurState;
6297 Diag.DiagStatesByLoc.CurDiagStateLoc = CurStateLoc;
6298
6299 // Preserve the property that the imaginary root file describes the
6300 // current state.
6301 FileID NullFile;
6302 auto &T = Diag.DiagStatesByLoc.Files[NullFile].StateTransitions;
6303 if (T.empty())
6304 T.push_back({CurState, 0});
6305 else
6306 T[0].State = CurState;
6307 }
6308
6309 // Don't try to read these mappings again.
6310 Record.clear();
6311 }
6312 }
6313
6314 /// Get the correct cursor and offset for loading a type.
TypeCursorForIndex(unsigned Index)6315 ASTReader::RecordLocation ASTReader::TypeCursorForIndex(unsigned Index) {
6316 GlobalTypeMapType::iterator I = GlobalTypeMap.find(Index);
6317 assert(I != GlobalTypeMap.end() && "Corrupted global type map");
6318 ModuleFile *M = I->second;
6319 return RecordLocation(M, M->TypeOffsets[Index - M->BaseTypeIndex]);
6320 }
6321
getTypeClassForCode(TypeCode code)6322 static llvm::Optional<Type::TypeClass> getTypeClassForCode(TypeCode code) {
6323 switch (code) {
6324 #define TYPE_BIT_CODE(CLASS_ID, CODE_ID, CODE_VALUE) \
6325 case TYPE_##CODE_ID: return Type::CLASS_ID;
6326 #include "clang/Serialization/TypeBitCodes.def"
6327 default: return llvm::None;
6328 }
6329 }
6330
6331 /// Read and return the type with the given index..
6332 ///
6333 /// The index is the type ID, shifted and minus the number of predefs. This
6334 /// routine actually reads the record corresponding to the type at the given
6335 /// location. It is a helper routine for GetType, which deals with reading type
6336 /// IDs.
readTypeRecord(unsigned Index)6337 QualType ASTReader::readTypeRecord(unsigned Index) {
6338 assert(ContextObj && "reading type with no AST context");
6339 ASTContext &Context = *ContextObj;
6340 RecordLocation Loc = TypeCursorForIndex(Index);
6341 BitstreamCursor &DeclsCursor = Loc.F->DeclsCursor;
6342
6343 // Keep track of where we are in the stream, then jump back there
6344 // after reading this type.
6345 SavedStreamPosition SavedPosition(DeclsCursor);
6346
6347 ReadingKindTracker ReadingKind(Read_Type, *this);
6348
6349 // Note that we are loading a type record.
6350 Deserializing AType(this);
6351
6352 if (llvm::Error Err = DeclsCursor.JumpToBit(Loc.Offset)) {
6353 Error(std::move(Err));
6354 return QualType();
6355 }
6356 Expected<unsigned> RawCode = DeclsCursor.ReadCode();
6357 if (!RawCode) {
6358 Error(RawCode.takeError());
6359 return QualType();
6360 }
6361
6362 ASTRecordReader Record(*this, *Loc.F);
6363 Expected<unsigned> Code = Record.readRecord(DeclsCursor, RawCode.get());
6364 if (!Code) {
6365 Error(Code.takeError());
6366 return QualType();
6367 }
6368 if (Code.get() == TYPE_EXT_QUAL) {
6369 QualType baseType = Record.readQualType();
6370 Qualifiers quals = Record.readQualifiers();
6371 return Context.getQualifiedType(baseType, quals);
6372 }
6373
6374 auto maybeClass = getTypeClassForCode((TypeCode) Code.get());
6375 if (!maybeClass) {
6376 Error("Unexpected code for type");
6377 return QualType();
6378 }
6379
6380 serialization::AbstractTypeReader<ASTRecordReader> TypeReader(Record);
6381 return TypeReader.read(*maybeClass);
6382 }
6383
6384 namespace clang {
6385
6386 class TypeLocReader : public TypeLocVisitor<TypeLocReader> {
6387 ASTRecordReader &Reader;
6388
readSourceLocation()6389 SourceLocation readSourceLocation() {
6390 return Reader.readSourceLocation();
6391 }
6392
GetTypeSourceInfo()6393 TypeSourceInfo *GetTypeSourceInfo() {
6394 return Reader.readTypeSourceInfo();
6395 }
6396
ReadNestedNameSpecifierLoc()6397 NestedNameSpecifierLoc ReadNestedNameSpecifierLoc() {
6398 return Reader.readNestedNameSpecifierLoc();
6399 }
6400
ReadAttr()6401 Attr *ReadAttr() {
6402 return Reader.readAttr();
6403 }
6404
6405 public:
TypeLocReader(ASTRecordReader & Reader)6406 TypeLocReader(ASTRecordReader &Reader) : Reader(Reader) {}
6407
6408 // We want compile-time assurance that we've enumerated all of
6409 // these, so unfortunately we have to declare them first, then
6410 // define them out-of-line.
6411 #define ABSTRACT_TYPELOC(CLASS, PARENT)
6412 #define TYPELOC(CLASS, PARENT) \
6413 void Visit##CLASS##TypeLoc(CLASS##TypeLoc TyLoc);
6414 #include "clang/AST/TypeLocNodes.def"
6415
6416 void VisitFunctionTypeLoc(FunctionTypeLoc);
6417 void VisitArrayTypeLoc(ArrayTypeLoc);
6418 };
6419
6420 } // namespace clang
6421
VisitQualifiedTypeLoc(QualifiedTypeLoc TL)6422 void TypeLocReader::VisitQualifiedTypeLoc(QualifiedTypeLoc TL) {
6423 // nothing to do
6424 }
6425
VisitBuiltinTypeLoc(BuiltinTypeLoc TL)6426 void TypeLocReader::VisitBuiltinTypeLoc(BuiltinTypeLoc TL) {
6427 TL.setBuiltinLoc(readSourceLocation());
6428 if (TL.needsExtraLocalData()) {
6429 TL.setWrittenTypeSpec(static_cast<DeclSpec::TST>(Reader.readInt()));
6430 TL.setWrittenSignSpec(static_cast<DeclSpec::TSS>(Reader.readInt()));
6431 TL.setWrittenWidthSpec(static_cast<DeclSpec::TSW>(Reader.readInt()));
6432 TL.setModeAttr(Reader.readInt());
6433 }
6434 }
6435
VisitComplexTypeLoc(ComplexTypeLoc TL)6436 void TypeLocReader::VisitComplexTypeLoc(ComplexTypeLoc TL) {
6437 TL.setNameLoc(readSourceLocation());
6438 }
6439
VisitPointerTypeLoc(PointerTypeLoc TL)6440 void TypeLocReader::VisitPointerTypeLoc(PointerTypeLoc TL) {
6441 TL.setStarLoc(readSourceLocation());
6442 }
6443
VisitDecayedTypeLoc(DecayedTypeLoc TL)6444 void TypeLocReader::VisitDecayedTypeLoc(DecayedTypeLoc TL) {
6445 // nothing to do
6446 }
6447
VisitAdjustedTypeLoc(AdjustedTypeLoc TL)6448 void TypeLocReader::VisitAdjustedTypeLoc(AdjustedTypeLoc TL) {
6449 // nothing to do
6450 }
6451
VisitMacroQualifiedTypeLoc(MacroQualifiedTypeLoc TL)6452 void TypeLocReader::VisitMacroQualifiedTypeLoc(MacroQualifiedTypeLoc TL) {
6453 TL.setExpansionLoc(readSourceLocation());
6454 }
6455
VisitBlockPointerTypeLoc(BlockPointerTypeLoc TL)6456 void TypeLocReader::VisitBlockPointerTypeLoc(BlockPointerTypeLoc TL) {
6457 TL.setCaretLoc(readSourceLocation());
6458 }
6459
VisitLValueReferenceTypeLoc(LValueReferenceTypeLoc TL)6460 void TypeLocReader::VisitLValueReferenceTypeLoc(LValueReferenceTypeLoc TL) {
6461 TL.setAmpLoc(readSourceLocation());
6462 }
6463
VisitRValueReferenceTypeLoc(RValueReferenceTypeLoc TL)6464 void TypeLocReader::VisitRValueReferenceTypeLoc(RValueReferenceTypeLoc TL) {
6465 TL.setAmpAmpLoc(readSourceLocation());
6466 }
6467
VisitMemberPointerTypeLoc(MemberPointerTypeLoc TL)6468 void TypeLocReader::VisitMemberPointerTypeLoc(MemberPointerTypeLoc TL) {
6469 TL.setStarLoc(readSourceLocation());
6470 TL.setClassTInfo(GetTypeSourceInfo());
6471 }
6472
VisitArrayTypeLoc(ArrayTypeLoc TL)6473 void TypeLocReader::VisitArrayTypeLoc(ArrayTypeLoc TL) {
6474 TL.setLBracketLoc(readSourceLocation());
6475 TL.setRBracketLoc(readSourceLocation());
6476 if (Reader.readBool())
6477 TL.setSizeExpr(Reader.readExpr());
6478 else
6479 TL.setSizeExpr(nullptr);
6480 }
6481
VisitConstantArrayTypeLoc(ConstantArrayTypeLoc TL)6482 void TypeLocReader::VisitConstantArrayTypeLoc(ConstantArrayTypeLoc TL) {
6483 VisitArrayTypeLoc(TL);
6484 }
6485
VisitIncompleteArrayTypeLoc(IncompleteArrayTypeLoc TL)6486 void TypeLocReader::VisitIncompleteArrayTypeLoc(IncompleteArrayTypeLoc TL) {
6487 VisitArrayTypeLoc(TL);
6488 }
6489
VisitVariableArrayTypeLoc(VariableArrayTypeLoc TL)6490 void TypeLocReader::VisitVariableArrayTypeLoc(VariableArrayTypeLoc TL) {
6491 VisitArrayTypeLoc(TL);
6492 }
6493
VisitDependentSizedArrayTypeLoc(DependentSizedArrayTypeLoc TL)6494 void TypeLocReader::VisitDependentSizedArrayTypeLoc(
6495 DependentSizedArrayTypeLoc TL) {
6496 VisitArrayTypeLoc(TL);
6497 }
6498
VisitDependentAddressSpaceTypeLoc(DependentAddressSpaceTypeLoc TL)6499 void TypeLocReader::VisitDependentAddressSpaceTypeLoc(
6500 DependentAddressSpaceTypeLoc TL) {
6501
6502 TL.setAttrNameLoc(readSourceLocation());
6503 TL.setAttrOperandParensRange(Reader.readSourceRange());
6504 TL.setAttrExprOperand(Reader.readExpr());
6505 }
6506
VisitDependentSizedExtVectorTypeLoc(DependentSizedExtVectorTypeLoc TL)6507 void TypeLocReader::VisitDependentSizedExtVectorTypeLoc(
6508 DependentSizedExtVectorTypeLoc TL) {
6509 TL.setNameLoc(readSourceLocation());
6510 }
6511
VisitVectorTypeLoc(VectorTypeLoc TL)6512 void TypeLocReader::VisitVectorTypeLoc(VectorTypeLoc TL) {
6513 TL.setNameLoc(readSourceLocation());
6514 }
6515
VisitDependentVectorTypeLoc(DependentVectorTypeLoc TL)6516 void TypeLocReader::VisitDependentVectorTypeLoc(
6517 DependentVectorTypeLoc TL) {
6518 TL.setNameLoc(readSourceLocation());
6519 }
6520
VisitExtVectorTypeLoc(ExtVectorTypeLoc TL)6521 void TypeLocReader::VisitExtVectorTypeLoc(ExtVectorTypeLoc TL) {
6522 TL.setNameLoc(readSourceLocation());
6523 }
6524
VisitFunctionTypeLoc(FunctionTypeLoc TL)6525 void TypeLocReader::VisitFunctionTypeLoc(FunctionTypeLoc TL) {
6526 TL.setLocalRangeBegin(readSourceLocation());
6527 TL.setLParenLoc(readSourceLocation());
6528 TL.setRParenLoc(readSourceLocation());
6529 TL.setExceptionSpecRange(Reader.readSourceRange());
6530 TL.setLocalRangeEnd(readSourceLocation());
6531 for (unsigned i = 0, e = TL.getNumParams(); i != e; ++i) {
6532 TL.setParam(i, Reader.readDeclAs<ParmVarDecl>());
6533 }
6534 }
6535
VisitFunctionProtoTypeLoc(FunctionProtoTypeLoc TL)6536 void TypeLocReader::VisitFunctionProtoTypeLoc(FunctionProtoTypeLoc TL) {
6537 VisitFunctionTypeLoc(TL);
6538 }
6539
VisitFunctionNoProtoTypeLoc(FunctionNoProtoTypeLoc TL)6540 void TypeLocReader::VisitFunctionNoProtoTypeLoc(FunctionNoProtoTypeLoc TL) {
6541 VisitFunctionTypeLoc(TL);
6542 }
6543
VisitUnresolvedUsingTypeLoc(UnresolvedUsingTypeLoc TL)6544 void TypeLocReader::VisitUnresolvedUsingTypeLoc(UnresolvedUsingTypeLoc TL) {
6545 TL.setNameLoc(readSourceLocation());
6546 }
6547
VisitTypedefTypeLoc(TypedefTypeLoc TL)6548 void TypeLocReader::VisitTypedefTypeLoc(TypedefTypeLoc TL) {
6549 TL.setNameLoc(readSourceLocation());
6550 }
6551
VisitTypeOfExprTypeLoc(TypeOfExprTypeLoc TL)6552 void TypeLocReader::VisitTypeOfExprTypeLoc(TypeOfExprTypeLoc TL) {
6553 TL.setTypeofLoc(readSourceLocation());
6554 TL.setLParenLoc(readSourceLocation());
6555 TL.setRParenLoc(readSourceLocation());
6556 }
6557
VisitTypeOfTypeLoc(TypeOfTypeLoc TL)6558 void TypeLocReader::VisitTypeOfTypeLoc(TypeOfTypeLoc TL) {
6559 TL.setTypeofLoc(readSourceLocation());
6560 TL.setLParenLoc(readSourceLocation());
6561 TL.setRParenLoc(readSourceLocation());
6562 TL.setUnderlyingTInfo(GetTypeSourceInfo());
6563 }
6564
VisitDecltypeTypeLoc(DecltypeTypeLoc TL)6565 void TypeLocReader::VisitDecltypeTypeLoc(DecltypeTypeLoc TL) {
6566 TL.setNameLoc(readSourceLocation());
6567 }
6568
VisitUnaryTransformTypeLoc(UnaryTransformTypeLoc TL)6569 void TypeLocReader::VisitUnaryTransformTypeLoc(UnaryTransformTypeLoc TL) {
6570 TL.setKWLoc(readSourceLocation());
6571 TL.setLParenLoc(readSourceLocation());
6572 TL.setRParenLoc(readSourceLocation());
6573 TL.setUnderlyingTInfo(GetTypeSourceInfo());
6574 }
6575
VisitAutoTypeLoc(AutoTypeLoc TL)6576 void TypeLocReader::VisitAutoTypeLoc(AutoTypeLoc TL) {
6577 TL.setNameLoc(readSourceLocation());
6578 if (Reader.readBool()) {
6579 TL.setNestedNameSpecifierLoc(ReadNestedNameSpecifierLoc());
6580 TL.setTemplateKWLoc(readSourceLocation());
6581 TL.setConceptNameLoc(readSourceLocation());
6582 TL.setFoundDecl(Reader.readDeclAs<NamedDecl>());
6583 TL.setLAngleLoc(readSourceLocation());
6584 TL.setRAngleLoc(readSourceLocation());
6585 for (unsigned i = 0, e = TL.getNumArgs(); i != e; ++i)
6586 TL.setArgLocInfo(i, Reader.readTemplateArgumentLocInfo(
6587 TL.getTypePtr()->getArg(i).getKind()));
6588 }
6589 }
6590
VisitDeducedTemplateSpecializationTypeLoc(DeducedTemplateSpecializationTypeLoc TL)6591 void TypeLocReader::VisitDeducedTemplateSpecializationTypeLoc(
6592 DeducedTemplateSpecializationTypeLoc TL) {
6593 TL.setTemplateNameLoc(readSourceLocation());
6594 }
6595
VisitRecordTypeLoc(RecordTypeLoc TL)6596 void TypeLocReader::VisitRecordTypeLoc(RecordTypeLoc TL) {
6597 TL.setNameLoc(readSourceLocation());
6598 }
6599
VisitEnumTypeLoc(EnumTypeLoc TL)6600 void TypeLocReader::VisitEnumTypeLoc(EnumTypeLoc TL) {
6601 TL.setNameLoc(readSourceLocation());
6602 }
6603
VisitAttributedTypeLoc(AttributedTypeLoc TL)6604 void TypeLocReader::VisitAttributedTypeLoc(AttributedTypeLoc TL) {
6605 TL.setAttr(ReadAttr());
6606 }
6607
VisitTemplateTypeParmTypeLoc(TemplateTypeParmTypeLoc TL)6608 void TypeLocReader::VisitTemplateTypeParmTypeLoc(TemplateTypeParmTypeLoc TL) {
6609 TL.setNameLoc(readSourceLocation());
6610 }
6611
VisitSubstTemplateTypeParmTypeLoc(SubstTemplateTypeParmTypeLoc TL)6612 void TypeLocReader::VisitSubstTemplateTypeParmTypeLoc(
6613 SubstTemplateTypeParmTypeLoc TL) {
6614 TL.setNameLoc(readSourceLocation());
6615 }
6616
VisitSubstTemplateTypeParmPackTypeLoc(SubstTemplateTypeParmPackTypeLoc TL)6617 void TypeLocReader::VisitSubstTemplateTypeParmPackTypeLoc(
6618 SubstTemplateTypeParmPackTypeLoc TL) {
6619 TL.setNameLoc(readSourceLocation());
6620 }
6621
VisitTemplateSpecializationTypeLoc(TemplateSpecializationTypeLoc TL)6622 void TypeLocReader::VisitTemplateSpecializationTypeLoc(
6623 TemplateSpecializationTypeLoc TL) {
6624 TL.setTemplateKeywordLoc(readSourceLocation());
6625 TL.setTemplateNameLoc(readSourceLocation());
6626 TL.setLAngleLoc(readSourceLocation());
6627 TL.setRAngleLoc(readSourceLocation());
6628 for (unsigned i = 0, e = TL.getNumArgs(); i != e; ++i)
6629 TL.setArgLocInfo(
6630 i,
6631 Reader.readTemplateArgumentLocInfo(
6632 TL.getTypePtr()->getArg(i).getKind()));
6633 }
6634
VisitParenTypeLoc(ParenTypeLoc TL)6635 void TypeLocReader::VisitParenTypeLoc(ParenTypeLoc TL) {
6636 TL.setLParenLoc(readSourceLocation());
6637 TL.setRParenLoc(readSourceLocation());
6638 }
6639
VisitElaboratedTypeLoc(ElaboratedTypeLoc TL)6640 void TypeLocReader::VisitElaboratedTypeLoc(ElaboratedTypeLoc TL) {
6641 TL.setElaboratedKeywordLoc(readSourceLocation());
6642 TL.setQualifierLoc(ReadNestedNameSpecifierLoc());
6643 }
6644
VisitInjectedClassNameTypeLoc(InjectedClassNameTypeLoc TL)6645 void TypeLocReader::VisitInjectedClassNameTypeLoc(InjectedClassNameTypeLoc TL) {
6646 TL.setNameLoc(readSourceLocation());
6647 }
6648
VisitDependentNameTypeLoc(DependentNameTypeLoc TL)6649 void TypeLocReader::VisitDependentNameTypeLoc(DependentNameTypeLoc TL) {
6650 TL.setElaboratedKeywordLoc(readSourceLocation());
6651 TL.setQualifierLoc(ReadNestedNameSpecifierLoc());
6652 TL.setNameLoc(readSourceLocation());
6653 }
6654
VisitDependentTemplateSpecializationTypeLoc(DependentTemplateSpecializationTypeLoc TL)6655 void TypeLocReader::VisitDependentTemplateSpecializationTypeLoc(
6656 DependentTemplateSpecializationTypeLoc TL) {
6657 TL.setElaboratedKeywordLoc(readSourceLocation());
6658 TL.setQualifierLoc(ReadNestedNameSpecifierLoc());
6659 TL.setTemplateKeywordLoc(readSourceLocation());
6660 TL.setTemplateNameLoc(readSourceLocation());
6661 TL.setLAngleLoc(readSourceLocation());
6662 TL.setRAngleLoc(readSourceLocation());
6663 for (unsigned I = 0, E = TL.getNumArgs(); I != E; ++I)
6664 TL.setArgLocInfo(
6665 I,
6666 Reader.readTemplateArgumentLocInfo(
6667 TL.getTypePtr()->getArg(I).getKind()));
6668 }
6669
VisitPackExpansionTypeLoc(PackExpansionTypeLoc TL)6670 void TypeLocReader::VisitPackExpansionTypeLoc(PackExpansionTypeLoc TL) {
6671 TL.setEllipsisLoc(readSourceLocation());
6672 }
6673
VisitObjCInterfaceTypeLoc(ObjCInterfaceTypeLoc TL)6674 void TypeLocReader::VisitObjCInterfaceTypeLoc(ObjCInterfaceTypeLoc TL) {
6675 TL.setNameLoc(readSourceLocation());
6676 }
6677
VisitObjCTypeParamTypeLoc(ObjCTypeParamTypeLoc TL)6678 void TypeLocReader::VisitObjCTypeParamTypeLoc(ObjCTypeParamTypeLoc TL) {
6679 if (TL.getNumProtocols()) {
6680 TL.setProtocolLAngleLoc(readSourceLocation());
6681 TL.setProtocolRAngleLoc(readSourceLocation());
6682 }
6683 for (unsigned i = 0, e = TL.getNumProtocols(); i != e; ++i)
6684 TL.setProtocolLoc(i, readSourceLocation());
6685 }
6686
VisitObjCObjectTypeLoc(ObjCObjectTypeLoc TL)6687 void TypeLocReader::VisitObjCObjectTypeLoc(ObjCObjectTypeLoc TL) {
6688 TL.setHasBaseTypeAsWritten(Reader.readBool());
6689 TL.setTypeArgsLAngleLoc(readSourceLocation());
6690 TL.setTypeArgsRAngleLoc(readSourceLocation());
6691 for (unsigned i = 0, e = TL.getNumTypeArgs(); i != e; ++i)
6692 TL.setTypeArgTInfo(i, GetTypeSourceInfo());
6693 TL.setProtocolLAngleLoc(readSourceLocation());
6694 TL.setProtocolRAngleLoc(readSourceLocation());
6695 for (unsigned i = 0, e = TL.getNumProtocols(); i != e; ++i)
6696 TL.setProtocolLoc(i, readSourceLocation());
6697 }
6698
VisitObjCObjectPointerTypeLoc(ObjCObjectPointerTypeLoc TL)6699 void TypeLocReader::VisitObjCObjectPointerTypeLoc(ObjCObjectPointerTypeLoc TL) {
6700 TL.setStarLoc(readSourceLocation());
6701 }
6702
VisitAtomicTypeLoc(AtomicTypeLoc TL)6703 void TypeLocReader::VisitAtomicTypeLoc(AtomicTypeLoc TL) {
6704 TL.setKWLoc(readSourceLocation());
6705 TL.setLParenLoc(readSourceLocation());
6706 TL.setRParenLoc(readSourceLocation());
6707 }
6708
VisitPipeTypeLoc(PipeTypeLoc TL)6709 void TypeLocReader::VisitPipeTypeLoc(PipeTypeLoc TL) {
6710 TL.setKWLoc(readSourceLocation());
6711 }
6712
readTypeLoc(TypeLoc TL)6713 void ASTRecordReader::readTypeLoc(TypeLoc TL) {
6714 TypeLocReader TLR(*this);
6715 for (; !TL.isNull(); TL = TL.getNextTypeLoc())
6716 TLR.Visit(TL);
6717 }
6718
readTypeSourceInfo()6719 TypeSourceInfo *ASTRecordReader::readTypeSourceInfo() {
6720 QualType InfoTy = readType();
6721 if (InfoTy.isNull())
6722 return nullptr;
6723
6724 TypeSourceInfo *TInfo = getContext().CreateTypeSourceInfo(InfoTy);
6725 readTypeLoc(TInfo->getTypeLoc());
6726 return TInfo;
6727 }
6728
GetType(TypeID ID)6729 QualType ASTReader::GetType(TypeID ID) {
6730 assert(ContextObj && "reading type with no AST context");
6731 ASTContext &Context = *ContextObj;
6732
6733 unsigned FastQuals = ID & Qualifiers::FastMask;
6734 unsigned Index = ID >> Qualifiers::FastWidth;
6735
6736 if (Index < NUM_PREDEF_TYPE_IDS) {
6737 QualType T;
6738 switch ((PredefinedTypeIDs)Index) {
6739 case PREDEF_TYPE_NULL_ID:
6740 return QualType();
6741 case PREDEF_TYPE_VOID_ID:
6742 T = Context.VoidTy;
6743 break;
6744 case PREDEF_TYPE_BOOL_ID:
6745 T = Context.BoolTy;
6746 break;
6747 case PREDEF_TYPE_CHAR_U_ID:
6748 case PREDEF_TYPE_CHAR_S_ID:
6749 // FIXME: Check that the signedness of CharTy is correct!
6750 T = Context.CharTy;
6751 break;
6752 case PREDEF_TYPE_UCHAR_ID:
6753 T = Context.UnsignedCharTy;
6754 break;
6755 case PREDEF_TYPE_USHORT_ID:
6756 T = Context.UnsignedShortTy;
6757 break;
6758 case PREDEF_TYPE_UINT_ID:
6759 T = Context.UnsignedIntTy;
6760 break;
6761 case PREDEF_TYPE_ULONG_ID:
6762 T = Context.UnsignedLongTy;
6763 break;
6764 case PREDEF_TYPE_ULONGLONG_ID:
6765 T = Context.UnsignedLongLongTy;
6766 break;
6767 case PREDEF_TYPE_UINT128_ID:
6768 T = Context.UnsignedInt128Ty;
6769 break;
6770 case PREDEF_TYPE_SCHAR_ID:
6771 T = Context.SignedCharTy;
6772 break;
6773 case PREDEF_TYPE_WCHAR_ID:
6774 T = Context.WCharTy;
6775 break;
6776 case PREDEF_TYPE_SHORT_ID:
6777 T = Context.ShortTy;
6778 break;
6779 case PREDEF_TYPE_INT_ID:
6780 T = Context.IntTy;
6781 break;
6782 case PREDEF_TYPE_LONG_ID:
6783 T = Context.LongTy;
6784 break;
6785 case PREDEF_TYPE_LONGLONG_ID:
6786 T = Context.LongLongTy;
6787 break;
6788 case PREDEF_TYPE_INT128_ID:
6789 T = Context.Int128Ty;
6790 break;
6791 case PREDEF_TYPE_HALF_ID:
6792 T = Context.HalfTy;
6793 break;
6794 case PREDEF_TYPE_FLOAT_ID:
6795 T = Context.FloatTy;
6796 break;
6797 case PREDEF_TYPE_DOUBLE_ID:
6798 T = Context.DoubleTy;
6799 break;
6800 case PREDEF_TYPE_LONGDOUBLE_ID:
6801 T = Context.LongDoubleTy;
6802 break;
6803 case PREDEF_TYPE_SHORT_ACCUM_ID:
6804 T = Context.ShortAccumTy;
6805 break;
6806 case PREDEF_TYPE_ACCUM_ID:
6807 T = Context.AccumTy;
6808 break;
6809 case PREDEF_TYPE_LONG_ACCUM_ID:
6810 T = Context.LongAccumTy;
6811 break;
6812 case PREDEF_TYPE_USHORT_ACCUM_ID:
6813 T = Context.UnsignedShortAccumTy;
6814 break;
6815 case PREDEF_TYPE_UACCUM_ID:
6816 T = Context.UnsignedAccumTy;
6817 break;
6818 case PREDEF_TYPE_ULONG_ACCUM_ID:
6819 T = Context.UnsignedLongAccumTy;
6820 break;
6821 case PREDEF_TYPE_SHORT_FRACT_ID:
6822 T = Context.ShortFractTy;
6823 break;
6824 case PREDEF_TYPE_FRACT_ID:
6825 T = Context.FractTy;
6826 break;
6827 case PREDEF_TYPE_LONG_FRACT_ID:
6828 T = Context.LongFractTy;
6829 break;
6830 case PREDEF_TYPE_USHORT_FRACT_ID:
6831 T = Context.UnsignedShortFractTy;
6832 break;
6833 case PREDEF_TYPE_UFRACT_ID:
6834 T = Context.UnsignedFractTy;
6835 break;
6836 case PREDEF_TYPE_ULONG_FRACT_ID:
6837 T = Context.UnsignedLongFractTy;
6838 break;
6839 case PREDEF_TYPE_SAT_SHORT_ACCUM_ID:
6840 T = Context.SatShortAccumTy;
6841 break;
6842 case PREDEF_TYPE_SAT_ACCUM_ID:
6843 T = Context.SatAccumTy;
6844 break;
6845 case PREDEF_TYPE_SAT_LONG_ACCUM_ID:
6846 T = Context.SatLongAccumTy;
6847 break;
6848 case PREDEF_TYPE_SAT_USHORT_ACCUM_ID:
6849 T = Context.SatUnsignedShortAccumTy;
6850 break;
6851 case PREDEF_TYPE_SAT_UACCUM_ID:
6852 T = Context.SatUnsignedAccumTy;
6853 break;
6854 case PREDEF_TYPE_SAT_ULONG_ACCUM_ID:
6855 T = Context.SatUnsignedLongAccumTy;
6856 break;
6857 case PREDEF_TYPE_SAT_SHORT_FRACT_ID:
6858 T = Context.SatShortFractTy;
6859 break;
6860 case PREDEF_TYPE_SAT_FRACT_ID:
6861 T = Context.SatFractTy;
6862 break;
6863 case PREDEF_TYPE_SAT_LONG_FRACT_ID:
6864 T = Context.SatLongFractTy;
6865 break;
6866 case PREDEF_TYPE_SAT_USHORT_FRACT_ID:
6867 T = Context.SatUnsignedShortFractTy;
6868 break;
6869 case PREDEF_TYPE_SAT_UFRACT_ID:
6870 T = Context.SatUnsignedFractTy;
6871 break;
6872 case PREDEF_TYPE_SAT_ULONG_FRACT_ID:
6873 T = Context.SatUnsignedLongFractTy;
6874 break;
6875 case PREDEF_TYPE_FLOAT16_ID:
6876 T = Context.Float16Ty;
6877 break;
6878 case PREDEF_TYPE_FLOAT128_ID:
6879 T = Context.Float128Ty;
6880 break;
6881 case PREDEF_TYPE_OVERLOAD_ID:
6882 T = Context.OverloadTy;
6883 break;
6884 case PREDEF_TYPE_BOUND_MEMBER:
6885 T = Context.BoundMemberTy;
6886 break;
6887 case PREDEF_TYPE_PSEUDO_OBJECT:
6888 T = Context.PseudoObjectTy;
6889 break;
6890 case PREDEF_TYPE_DEPENDENT_ID:
6891 T = Context.DependentTy;
6892 break;
6893 case PREDEF_TYPE_UNKNOWN_ANY:
6894 T = Context.UnknownAnyTy;
6895 break;
6896 case PREDEF_TYPE_NULLPTR_ID:
6897 T = Context.NullPtrTy;
6898 break;
6899 case PREDEF_TYPE_CHAR8_ID:
6900 T = Context.Char8Ty;
6901 break;
6902 case PREDEF_TYPE_CHAR16_ID:
6903 T = Context.Char16Ty;
6904 break;
6905 case PREDEF_TYPE_CHAR32_ID:
6906 T = Context.Char32Ty;
6907 break;
6908 case PREDEF_TYPE_OBJC_ID:
6909 T = Context.ObjCBuiltinIdTy;
6910 break;
6911 case PREDEF_TYPE_OBJC_CLASS:
6912 T = Context.ObjCBuiltinClassTy;
6913 break;
6914 case PREDEF_TYPE_OBJC_SEL:
6915 T = Context.ObjCBuiltinSelTy;
6916 break;
6917 #define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
6918 case PREDEF_TYPE_##Id##_ID: \
6919 T = Context.SingletonId; \
6920 break;
6921 #include "clang/Basic/OpenCLImageTypes.def"
6922 #define EXT_OPAQUE_TYPE(ExtType, Id, Ext) \
6923 case PREDEF_TYPE_##Id##_ID: \
6924 T = Context.Id##Ty; \
6925 break;
6926 #include "clang/Basic/OpenCLExtensionTypes.def"
6927 case PREDEF_TYPE_SAMPLER_ID:
6928 T = Context.OCLSamplerTy;
6929 break;
6930 case PREDEF_TYPE_EVENT_ID:
6931 T = Context.OCLEventTy;
6932 break;
6933 case PREDEF_TYPE_CLK_EVENT_ID:
6934 T = Context.OCLClkEventTy;
6935 break;
6936 case PREDEF_TYPE_QUEUE_ID:
6937 T = Context.OCLQueueTy;
6938 break;
6939 case PREDEF_TYPE_RESERVE_ID_ID:
6940 T = Context.OCLReserveIDTy;
6941 break;
6942 case PREDEF_TYPE_AUTO_DEDUCT:
6943 T = Context.getAutoDeductType();
6944 break;
6945 case PREDEF_TYPE_AUTO_RREF_DEDUCT:
6946 T = Context.getAutoRRefDeductType();
6947 break;
6948 case PREDEF_TYPE_ARC_UNBRIDGED_CAST:
6949 T = Context.ARCUnbridgedCastTy;
6950 break;
6951 case PREDEF_TYPE_BUILTIN_FN:
6952 T = Context.BuiltinFnTy;
6953 break;
6954 case PREDEF_TYPE_OMP_ARRAY_SECTION:
6955 T = Context.OMPArraySectionTy;
6956 break;
6957 #define SVE_TYPE(Name, Id, SingletonId) \
6958 case PREDEF_TYPE_##Id##_ID: \
6959 T = Context.SingletonId; \
6960 break;
6961 #include "clang/Basic/AArch64SVEACLETypes.def"
6962 }
6963
6964 assert(!T.isNull() && "Unknown predefined type");
6965 return T.withFastQualifiers(FastQuals);
6966 }
6967
6968 Index -= NUM_PREDEF_TYPE_IDS;
6969 assert(Index < TypesLoaded.size() && "Type index out-of-range");
6970 if (TypesLoaded[Index].isNull()) {
6971 TypesLoaded[Index] = readTypeRecord(Index);
6972 if (TypesLoaded[Index].isNull())
6973 return QualType();
6974
6975 TypesLoaded[Index]->setFromAST();
6976 if (DeserializationListener)
6977 DeserializationListener->TypeRead(TypeIdx::fromTypeID(ID),
6978 TypesLoaded[Index]);
6979 }
6980
6981 return TypesLoaded[Index].withFastQualifiers(FastQuals);
6982 }
6983
getLocalType(ModuleFile & F,unsigned LocalID)6984 QualType ASTReader::getLocalType(ModuleFile &F, unsigned LocalID) {
6985 return GetType(getGlobalTypeID(F, LocalID));
6986 }
6987
6988 serialization::TypeID
getGlobalTypeID(ModuleFile & F,unsigned LocalID) const6989 ASTReader::getGlobalTypeID(ModuleFile &F, unsigned LocalID) const {
6990 unsigned FastQuals = LocalID & Qualifiers::FastMask;
6991 unsigned LocalIndex = LocalID >> Qualifiers::FastWidth;
6992
6993 if (LocalIndex < NUM_PREDEF_TYPE_IDS)
6994 return LocalID;
6995
6996 if (!F.ModuleOffsetMap.empty())
6997 ReadModuleOffsetMap(F);
6998
6999 ContinuousRangeMap<uint32_t, int, 2>::iterator I
7000 = F.TypeRemap.find(LocalIndex - NUM_PREDEF_TYPE_IDS);
7001 assert(I != F.TypeRemap.end() && "Invalid index into type index remap");
7002
7003 unsigned GlobalIndex = LocalIndex + I->second;
7004 return (GlobalIndex << Qualifiers::FastWidth) | FastQuals;
7005 }
7006
7007 TemplateArgumentLocInfo
readTemplateArgumentLocInfo(TemplateArgument::ArgKind Kind)7008 ASTRecordReader::readTemplateArgumentLocInfo(TemplateArgument::ArgKind Kind) {
7009 switch (Kind) {
7010 case TemplateArgument::Expression:
7011 return readExpr();
7012 case TemplateArgument::Type:
7013 return readTypeSourceInfo();
7014 case TemplateArgument::Template: {
7015 NestedNameSpecifierLoc QualifierLoc =
7016 readNestedNameSpecifierLoc();
7017 SourceLocation TemplateNameLoc = readSourceLocation();
7018 return TemplateArgumentLocInfo(QualifierLoc, TemplateNameLoc,
7019 SourceLocation());
7020 }
7021 case TemplateArgument::TemplateExpansion: {
7022 NestedNameSpecifierLoc QualifierLoc = readNestedNameSpecifierLoc();
7023 SourceLocation TemplateNameLoc = readSourceLocation();
7024 SourceLocation EllipsisLoc = readSourceLocation();
7025 return TemplateArgumentLocInfo(QualifierLoc, TemplateNameLoc,
7026 EllipsisLoc);
7027 }
7028 case TemplateArgument::Null:
7029 case TemplateArgument::Integral:
7030 case TemplateArgument::Declaration:
7031 case TemplateArgument::NullPtr:
7032 case TemplateArgument::Pack:
7033 // FIXME: Is this right?
7034 return TemplateArgumentLocInfo();
7035 }
7036 llvm_unreachable("unexpected template argument loc");
7037 }
7038
readTemplateArgumentLoc()7039 TemplateArgumentLoc ASTRecordReader::readTemplateArgumentLoc() {
7040 TemplateArgument Arg = readTemplateArgument();
7041
7042 if (Arg.getKind() == TemplateArgument::Expression) {
7043 if (readBool()) // bool InfoHasSameExpr.
7044 return TemplateArgumentLoc(Arg, TemplateArgumentLocInfo(Arg.getAsExpr()));
7045 }
7046 return TemplateArgumentLoc(Arg, readTemplateArgumentLocInfo(Arg.getKind()));
7047 }
7048
7049 const ASTTemplateArgumentListInfo *
readASTTemplateArgumentListInfo()7050 ASTRecordReader::readASTTemplateArgumentListInfo() {
7051 SourceLocation LAngleLoc = readSourceLocation();
7052 SourceLocation RAngleLoc = readSourceLocation();
7053 unsigned NumArgsAsWritten = readInt();
7054 TemplateArgumentListInfo TemplArgsInfo(LAngleLoc, RAngleLoc);
7055 for (unsigned i = 0; i != NumArgsAsWritten; ++i)
7056 TemplArgsInfo.addArgument(readTemplateArgumentLoc());
7057 return ASTTemplateArgumentListInfo::Create(getContext(), TemplArgsInfo);
7058 }
7059
GetExternalDecl(uint32_t ID)7060 Decl *ASTReader::GetExternalDecl(uint32_t ID) {
7061 return GetDecl(ID);
7062 }
7063
CompleteRedeclChain(const Decl * D)7064 void ASTReader::CompleteRedeclChain(const Decl *D) {
7065 if (NumCurrentElementsDeserializing) {
7066 // We arrange to not care about the complete redeclaration chain while we're
7067 // deserializing. Just remember that the AST has marked this one as complete
7068 // but that it's not actually complete yet, so we know we still need to
7069 // complete it later.
7070 PendingIncompleteDeclChains.push_back(const_cast<Decl*>(D));
7071 return;
7072 }
7073
7074 const DeclContext *DC = D->getDeclContext()->getRedeclContext();
7075
7076 // If this is a named declaration, complete it by looking it up
7077 // within its context.
7078 //
7079 // FIXME: Merging a function definition should merge
7080 // all mergeable entities within it.
7081 if (isa<TranslationUnitDecl>(DC) || isa<NamespaceDecl>(DC) ||
7082 isa<CXXRecordDecl>(DC) || isa<EnumDecl>(DC)) {
7083 if (DeclarationName Name = cast<NamedDecl>(D)->getDeclName()) {
7084 if (!getContext().getLangOpts().CPlusPlus &&
7085 isa<TranslationUnitDecl>(DC)) {
7086 // Outside of C++, we don't have a lookup table for the TU, so update
7087 // the identifier instead. (For C++ modules, we don't store decls
7088 // in the serialized identifier table, so we do the lookup in the TU.)
7089 auto *II = Name.getAsIdentifierInfo();
7090 assert(II && "non-identifier name in C?");
7091 if (II->isOutOfDate())
7092 updateOutOfDateIdentifier(*II);
7093 } else
7094 DC->lookup(Name);
7095 } else if (needsAnonymousDeclarationNumber(cast<NamedDecl>(D))) {
7096 // Find all declarations of this kind from the relevant context.
7097 for (auto *DCDecl : cast<Decl>(D->getLexicalDeclContext())->redecls()) {
7098 auto *DC = cast<DeclContext>(DCDecl);
7099 SmallVector<Decl*, 8> Decls;
7100 FindExternalLexicalDecls(
7101 DC, [&](Decl::Kind K) { return K == D->getKind(); }, Decls);
7102 }
7103 }
7104 }
7105
7106 if (auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(D))
7107 CTSD->getSpecializedTemplate()->LoadLazySpecializations();
7108 if (auto *VTSD = dyn_cast<VarTemplateSpecializationDecl>(D))
7109 VTSD->getSpecializedTemplate()->LoadLazySpecializations();
7110 if (auto *FD = dyn_cast<FunctionDecl>(D)) {
7111 if (auto *Template = FD->getPrimaryTemplate())
7112 Template->LoadLazySpecializations();
7113 }
7114 }
7115
7116 CXXCtorInitializer **
GetExternalCXXCtorInitializers(uint64_t Offset)7117 ASTReader::GetExternalCXXCtorInitializers(uint64_t Offset) {
7118 RecordLocation Loc = getLocalBitOffset(Offset);
7119 BitstreamCursor &Cursor = Loc.F->DeclsCursor;
7120 SavedStreamPosition SavedPosition(Cursor);
7121 if (llvm::Error Err = Cursor.JumpToBit(Loc.Offset)) {
7122 Error(std::move(Err));
7123 return nullptr;
7124 }
7125 ReadingKindTracker ReadingKind(Read_Decl, *this);
7126
7127 Expected<unsigned> MaybeCode = Cursor.ReadCode();
7128 if (!MaybeCode) {
7129 Error(MaybeCode.takeError());
7130 return nullptr;
7131 }
7132 unsigned Code = MaybeCode.get();
7133
7134 ASTRecordReader Record(*this, *Loc.F);
7135 Expected<unsigned> MaybeRecCode = Record.readRecord(Cursor, Code);
7136 if (!MaybeRecCode) {
7137 Error(MaybeRecCode.takeError());
7138 return nullptr;
7139 }
7140 if (MaybeRecCode.get() != DECL_CXX_CTOR_INITIALIZERS) {
7141 Error("malformed AST file: missing C++ ctor initializers");
7142 return nullptr;
7143 }
7144
7145 return Record.readCXXCtorInitializers();
7146 }
7147
GetExternalCXXBaseSpecifiers(uint64_t Offset)7148 CXXBaseSpecifier *ASTReader::GetExternalCXXBaseSpecifiers(uint64_t Offset) {
7149 assert(ContextObj && "reading base specifiers with no AST context");
7150 ASTContext &Context = *ContextObj;
7151
7152 RecordLocation Loc = getLocalBitOffset(Offset);
7153 BitstreamCursor &Cursor = Loc.F->DeclsCursor;
7154 SavedStreamPosition SavedPosition(Cursor);
7155 if (llvm::Error Err = Cursor.JumpToBit(Loc.Offset)) {
7156 Error(std::move(Err));
7157 return nullptr;
7158 }
7159 ReadingKindTracker ReadingKind(Read_Decl, *this);
7160
7161 Expected<unsigned> MaybeCode = Cursor.ReadCode();
7162 if (!MaybeCode) {
7163 Error(MaybeCode.takeError());
7164 return nullptr;
7165 }
7166 unsigned Code = MaybeCode.get();
7167
7168 ASTRecordReader Record(*this, *Loc.F);
7169 Expected<unsigned> MaybeRecCode = Record.readRecord(Cursor, Code);
7170 if (!MaybeRecCode) {
7171 Error(MaybeCode.takeError());
7172 return nullptr;
7173 }
7174 unsigned RecCode = MaybeRecCode.get();
7175
7176 if (RecCode != DECL_CXX_BASE_SPECIFIERS) {
7177 Error("malformed AST file: missing C++ base specifiers");
7178 return nullptr;
7179 }
7180
7181 unsigned NumBases = Record.readInt();
7182 void *Mem = Context.Allocate(sizeof(CXXBaseSpecifier) * NumBases);
7183 CXXBaseSpecifier *Bases = new (Mem) CXXBaseSpecifier [NumBases];
7184 for (unsigned I = 0; I != NumBases; ++I)
7185 Bases[I] = Record.readCXXBaseSpecifier();
7186 return Bases;
7187 }
7188
7189 serialization::DeclID
getGlobalDeclID(ModuleFile & F,LocalDeclID LocalID) const7190 ASTReader::getGlobalDeclID(ModuleFile &F, LocalDeclID LocalID) const {
7191 if (LocalID < NUM_PREDEF_DECL_IDS)
7192 return LocalID;
7193
7194 if (!F.ModuleOffsetMap.empty())
7195 ReadModuleOffsetMap(F);
7196
7197 ContinuousRangeMap<uint32_t, int, 2>::iterator I
7198 = F.DeclRemap.find(LocalID - NUM_PREDEF_DECL_IDS);
7199 assert(I != F.DeclRemap.end() && "Invalid index into decl index remap");
7200
7201 return LocalID + I->second;
7202 }
7203
isDeclIDFromModule(serialization::GlobalDeclID ID,ModuleFile & M) const7204 bool ASTReader::isDeclIDFromModule(serialization::GlobalDeclID ID,
7205 ModuleFile &M) const {
7206 // Predefined decls aren't from any module.
7207 if (ID < NUM_PREDEF_DECL_IDS)
7208 return false;
7209
7210 return ID - NUM_PREDEF_DECL_IDS >= M.BaseDeclID &&
7211 ID - NUM_PREDEF_DECL_IDS < M.BaseDeclID + M.LocalNumDecls;
7212 }
7213
getOwningModuleFile(const Decl * D)7214 ModuleFile *ASTReader::getOwningModuleFile(const Decl *D) {
7215 if (!D->isFromASTFile())
7216 return nullptr;
7217 GlobalDeclMapType::const_iterator I = GlobalDeclMap.find(D->getGlobalID());
7218 assert(I != GlobalDeclMap.end() && "Corrupted global declaration map");
7219 return I->second;
7220 }
7221
getSourceLocationForDeclID(GlobalDeclID ID)7222 SourceLocation ASTReader::getSourceLocationForDeclID(GlobalDeclID ID) {
7223 if (ID < NUM_PREDEF_DECL_IDS)
7224 return SourceLocation();
7225
7226 unsigned Index = ID - NUM_PREDEF_DECL_IDS;
7227
7228 if (Index > DeclsLoaded.size()) {
7229 Error("declaration ID out-of-range for AST file");
7230 return SourceLocation();
7231 }
7232
7233 if (Decl *D = DeclsLoaded[Index])
7234 return D->getLocation();
7235
7236 SourceLocation Loc;
7237 DeclCursorForID(ID, Loc);
7238 return Loc;
7239 }
7240
getPredefinedDecl(ASTContext & Context,PredefinedDeclIDs ID)7241 static Decl *getPredefinedDecl(ASTContext &Context, PredefinedDeclIDs ID) {
7242 switch (ID) {
7243 case PREDEF_DECL_NULL_ID:
7244 return nullptr;
7245
7246 case PREDEF_DECL_TRANSLATION_UNIT_ID:
7247 return Context.getTranslationUnitDecl();
7248
7249 case PREDEF_DECL_OBJC_ID_ID:
7250 return Context.getObjCIdDecl();
7251
7252 case PREDEF_DECL_OBJC_SEL_ID:
7253 return Context.getObjCSelDecl();
7254
7255 case PREDEF_DECL_OBJC_CLASS_ID:
7256 return Context.getObjCClassDecl();
7257
7258 case PREDEF_DECL_OBJC_PROTOCOL_ID:
7259 return Context.getObjCProtocolDecl();
7260
7261 case PREDEF_DECL_INT_128_ID:
7262 return Context.getInt128Decl();
7263
7264 case PREDEF_DECL_UNSIGNED_INT_128_ID:
7265 return Context.getUInt128Decl();
7266
7267 case PREDEF_DECL_OBJC_INSTANCETYPE_ID:
7268 return Context.getObjCInstanceTypeDecl();
7269
7270 case PREDEF_DECL_BUILTIN_VA_LIST_ID:
7271 return Context.getBuiltinVaListDecl();
7272
7273 case PREDEF_DECL_VA_LIST_TAG:
7274 return Context.getVaListTagDecl();
7275
7276 case PREDEF_DECL_BUILTIN_MS_VA_LIST_ID:
7277 return Context.getBuiltinMSVaListDecl();
7278
7279 case PREDEF_DECL_EXTERN_C_CONTEXT_ID:
7280 return Context.getExternCContextDecl();
7281
7282 case PREDEF_DECL_MAKE_INTEGER_SEQ_ID:
7283 return Context.getMakeIntegerSeqDecl();
7284
7285 case PREDEF_DECL_CF_CONSTANT_STRING_ID:
7286 return Context.getCFConstantStringDecl();
7287
7288 case PREDEF_DECL_CF_CONSTANT_STRING_TAG_ID:
7289 return Context.getCFConstantStringTagDecl();
7290
7291 case PREDEF_DECL_TYPE_PACK_ELEMENT_ID:
7292 return Context.getTypePackElementDecl();
7293 }
7294 llvm_unreachable("PredefinedDeclIDs unknown enum value");
7295 }
7296
GetExistingDecl(DeclID ID)7297 Decl *ASTReader::GetExistingDecl(DeclID ID) {
7298 assert(ContextObj && "reading decl with no AST context");
7299 if (ID < NUM_PREDEF_DECL_IDS) {
7300 Decl *D = getPredefinedDecl(*ContextObj, (PredefinedDeclIDs)ID);
7301 if (D) {
7302 // Track that we have merged the declaration with ID \p ID into the
7303 // pre-existing predefined declaration \p D.
7304 auto &Merged = KeyDecls[D->getCanonicalDecl()];
7305 if (Merged.empty())
7306 Merged.push_back(ID);
7307 }
7308 return D;
7309 }
7310
7311 unsigned Index = ID - NUM_PREDEF_DECL_IDS;
7312
7313 if (Index >= DeclsLoaded.size()) {
7314 assert(0 && "declaration ID out-of-range for AST file");
7315 Error("declaration ID out-of-range for AST file");
7316 return nullptr;
7317 }
7318
7319 return DeclsLoaded[Index];
7320 }
7321
GetDecl(DeclID ID)7322 Decl *ASTReader::GetDecl(DeclID ID) {
7323 if (ID < NUM_PREDEF_DECL_IDS)
7324 return GetExistingDecl(ID);
7325
7326 unsigned Index = ID - NUM_PREDEF_DECL_IDS;
7327
7328 if (Index >= DeclsLoaded.size()) {
7329 assert(0 && "declaration ID out-of-range for AST file");
7330 Error("declaration ID out-of-range for AST file");
7331 return nullptr;
7332 }
7333
7334 if (!DeclsLoaded[Index]) {
7335 ReadDeclRecord(ID);
7336 if (DeserializationListener)
7337 DeserializationListener->DeclRead(ID, DeclsLoaded[Index]);
7338 }
7339
7340 return DeclsLoaded[Index];
7341 }
7342
mapGlobalIDToModuleFileGlobalID(ModuleFile & M,DeclID GlobalID)7343 DeclID ASTReader::mapGlobalIDToModuleFileGlobalID(ModuleFile &M,
7344 DeclID GlobalID) {
7345 if (GlobalID < NUM_PREDEF_DECL_IDS)
7346 return GlobalID;
7347
7348 GlobalDeclMapType::const_iterator I = GlobalDeclMap.find(GlobalID);
7349 assert(I != GlobalDeclMap.end() && "Corrupted global declaration map");
7350 ModuleFile *Owner = I->second;
7351
7352 llvm::DenseMap<ModuleFile *, serialization::DeclID>::iterator Pos
7353 = M.GlobalToLocalDeclIDs.find(Owner);
7354 if (Pos == M.GlobalToLocalDeclIDs.end())
7355 return 0;
7356
7357 return GlobalID - Owner->BaseDeclID + Pos->second;
7358 }
7359
ReadDeclID(ModuleFile & F,const RecordData & Record,unsigned & Idx)7360 serialization::DeclID ASTReader::ReadDeclID(ModuleFile &F,
7361 const RecordData &Record,
7362 unsigned &Idx) {
7363 if (Idx >= Record.size()) {
7364 Error("Corrupted AST file");
7365 return 0;
7366 }
7367
7368 return getGlobalDeclID(F, Record[Idx++]);
7369 }
7370
7371 /// Resolve the offset of a statement into a statement.
7372 ///
7373 /// This operation will read a new statement from the external
7374 /// source each time it is called, and is meant to be used via a
7375 /// LazyOffsetPtr (which is used by Decls for the body of functions, etc).
GetExternalDeclStmt(uint64_t Offset)7376 Stmt *ASTReader::GetExternalDeclStmt(uint64_t Offset) {
7377 // Switch case IDs are per Decl.
7378 ClearSwitchCaseIDs();
7379
7380 // Offset here is a global offset across the entire chain.
7381 RecordLocation Loc = getLocalBitOffset(Offset);
7382 if (llvm::Error Err = Loc.F->DeclsCursor.JumpToBit(Loc.Offset)) {
7383 Error(std::move(Err));
7384 return nullptr;
7385 }
7386 assert(NumCurrentElementsDeserializing == 0 &&
7387 "should not be called while already deserializing");
7388 Deserializing D(this);
7389 return ReadStmtFromStream(*Loc.F);
7390 }
7391
FindExternalLexicalDecls(const DeclContext * DC,llvm::function_ref<bool (Decl::Kind)> IsKindWeWant,SmallVectorImpl<Decl * > & Decls)7392 void ASTReader::FindExternalLexicalDecls(
7393 const DeclContext *DC, llvm::function_ref<bool(Decl::Kind)> IsKindWeWant,
7394 SmallVectorImpl<Decl *> &Decls) {
7395 bool PredefsVisited[NUM_PREDEF_DECL_IDS] = {};
7396
7397 auto Visit = [&] (ModuleFile *M, LexicalContents LexicalDecls) {
7398 assert(LexicalDecls.size() % 2 == 0 && "expected an even number of entries");
7399 for (int I = 0, N = LexicalDecls.size(); I != N; I += 2) {
7400 auto K = (Decl::Kind)+LexicalDecls[I];
7401 if (!IsKindWeWant(K))
7402 continue;
7403
7404 auto ID = (serialization::DeclID)+LexicalDecls[I + 1];
7405
7406 // Don't add predefined declarations to the lexical context more
7407 // than once.
7408 if (ID < NUM_PREDEF_DECL_IDS) {
7409 if (PredefsVisited[ID])
7410 continue;
7411
7412 PredefsVisited[ID] = true;
7413 }
7414
7415 if (Decl *D = GetLocalDecl(*M, ID)) {
7416 assert(D->getKind() == K && "wrong kind for lexical decl");
7417 if (!DC->isDeclInLexicalTraversal(D))
7418 Decls.push_back(D);
7419 }
7420 }
7421 };
7422
7423 if (isa<TranslationUnitDecl>(DC)) {
7424 for (auto Lexical : TULexicalDecls)
7425 Visit(Lexical.first, Lexical.second);
7426 } else {
7427 auto I = LexicalDecls.find(DC);
7428 if (I != LexicalDecls.end())
7429 Visit(I->second.first, I->second.second);
7430 }
7431
7432 ++NumLexicalDeclContextsRead;
7433 }
7434
7435 namespace {
7436
7437 class DeclIDComp {
7438 ASTReader &Reader;
7439 ModuleFile &Mod;
7440
7441 public:
DeclIDComp(ASTReader & Reader,ModuleFile & M)7442 DeclIDComp(ASTReader &Reader, ModuleFile &M) : Reader(Reader), Mod(M) {}
7443
operator ()(LocalDeclID L,LocalDeclID R) const7444 bool operator()(LocalDeclID L, LocalDeclID R) const {
7445 SourceLocation LHS = getLocation(L);
7446 SourceLocation RHS = getLocation(R);
7447 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
7448 }
7449
operator ()(SourceLocation LHS,LocalDeclID R) const7450 bool operator()(SourceLocation LHS, LocalDeclID R) const {
7451 SourceLocation RHS = getLocation(R);
7452 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
7453 }
7454
operator ()(LocalDeclID L,SourceLocation RHS) const7455 bool operator()(LocalDeclID L, SourceLocation RHS) const {
7456 SourceLocation LHS = getLocation(L);
7457 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
7458 }
7459
getLocation(LocalDeclID ID) const7460 SourceLocation getLocation(LocalDeclID ID) const {
7461 return Reader.getSourceManager().getFileLoc(
7462 Reader.getSourceLocationForDeclID(Reader.getGlobalDeclID(Mod, ID)));
7463 }
7464 };
7465
7466 } // namespace
7467
FindFileRegionDecls(FileID File,unsigned Offset,unsigned Length,SmallVectorImpl<Decl * > & Decls)7468 void ASTReader::FindFileRegionDecls(FileID File,
7469 unsigned Offset, unsigned Length,
7470 SmallVectorImpl<Decl *> &Decls) {
7471 SourceManager &SM = getSourceManager();
7472
7473 llvm::DenseMap<FileID, FileDeclsInfo>::iterator I = FileDeclIDs.find(File);
7474 if (I == FileDeclIDs.end())
7475 return;
7476
7477 FileDeclsInfo &DInfo = I->second;
7478 if (DInfo.Decls.empty())
7479 return;
7480
7481 SourceLocation
7482 BeginLoc = SM.getLocForStartOfFile(File).getLocWithOffset(Offset);
7483 SourceLocation EndLoc = BeginLoc.getLocWithOffset(Length);
7484
7485 DeclIDComp DIDComp(*this, *DInfo.Mod);
7486 ArrayRef<serialization::LocalDeclID>::iterator BeginIt =
7487 llvm::lower_bound(DInfo.Decls, BeginLoc, DIDComp);
7488 if (BeginIt != DInfo.Decls.begin())
7489 --BeginIt;
7490
7491 // If we are pointing at a top-level decl inside an objc container, we need
7492 // to backtrack until we find it otherwise we will fail to report that the
7493 // region overlaps with an objc container.
7494 while (BeginIt != DInfo.Decls.begin() &&
7495 GetDecl(getGlobalDeclID(*DInfo.Mod, *BeginIt))
7496 ->isTopLevelDeclInObjCContainer())
7497 --BeginIt;
7498
7499 ArrayRef<serialization::LocalDeclID>::iterator EndIt =
7500 llvm::upper_bound(DInfo.Decls, EndLoc, DIDComp);
7501 if (EndIt != DInfo.Decls.end())
7502 ++EndIt;
7503
7504 for (ArrayRef<serialization::LocalDeclID>::iterator
7505 DIt = BeginIt; DIt != EndIt; ++DIt)
7506 Decls.push_back(GetDecl(getGlobalDeclID(*DInfo.Mod, *DIt)));
7507 }
7508
7509 bool
FindExternalVisibleDeclsByName(const DeclContext * DC,DeclarationName Name)7510 ASTReader::FindExternalVisibleDeclsByName(const DeclContext *DC,
7511 DeclarationName Name) {
7512 assert(DC->hasExternalVisibleStorage() && DC == DC->getPrimaryContext() &&
7513 "DeclContext has no visible decls in storage");
7514 if (!Name)
7515 return false;
7516
7517 auto It = Lookups.find(DC);
7518 if (It == Lookups.end())
7519 return false;
7520
7521 Deserializing LookupResults(this);
7522
7523 // Load the list of declarations.
7524 SmallVector<NamedDecl *, 64> Decls;
7525 for (DeclID ID : It->second.Table.find(Name)) {
7526 NamedDecl *ND = cast<NamedDecl>(GetDecl(ID));
7527 if (ND->getDeclName() == Name)
7528 Decls.push_back(ND);
7529 }
7530
7531 ++NumVisibleDeclContextsRead;
7532 SetExternalVisibleDeclsForName(DC, Name, Decls);
7533 return !Decls.empty();
7534 }
7535
completeVisibleDeclsMap(const DeclContext * DC)7536 void ASTReader::completeVisibleDeclsMap(const DeclContext *DC) {
7537 if (!DC->hasExternalVisibleStorage())
7538 return;
7539
7540 auto It = Lookups.find(DC);
7541 assert(It != Lookups.end() &&
7542 "have external visible storage but no lookup tables");
7543
7544 DeclsMap Decls;
7545
7546 for (DeclID ID : It->second.Table.findAll()) {
7547 NamedDecl *ND = cast<NamedDecl>(GetDecl(ID));
7548 Decls[ND->getDeclName()].push_back(ND);
7549 }
7550
7551 ++NumVisibleDeclContextsRead;
7552
7553 for (DeclsMap::iterator I = Decls.begin(), E = Decls.end(); I != E; ++I) {
7554 SetExternalVisibleDeclsForName(DC, I->first, I->second);
7555 }
7556 const_cast<DeclContext *>(DC)->setHasExternalVisibleStorage(false);
7557 }
7558
7559 const serialization::reader::DeclContextLookupTable *
getLoadedLookupTables(DeclContext * Primary) const7560 ASTReader::getLoadedLookupTables(DeclContext *Primary) const {
7561 auto I = Lookups.find(Primary);
7562 return I == Lookups.end() ? nullptr : &I->second;
7563 }
7564
7565 /// Under non-PCH compilation the consumer receives the objc methods
7566 /// before receiving the implementation, and codegen depends on this.
7567 /// We simulate this by deserializing and passing to consumer the methods of the
7568 /// implementation before passing the deserialized implementation decl.
PassObjCImplDeclToConsumer(ObjCImplDecl * ImplD,ASTConsumer * Consumer)7569 static void PassObjCImplDeclToConsumer(ObjCImplDecl *ImplD,
7570 ASTConsumer *Consumer) {
7571 assert(ImplD && Consumer);
7572
7573 for (auto *I : ImplD->methods())
7574 Consumer->HandleInterestingDecl(DeclGroupRef(I));
7575
7576 Consumer->HandleInterestingDecl(DeclGroupRef(ImplD));
7577 }
7578
PassInterestingDeclToConsumer(Decl * D)7579 void ASTReader::PassInterestingDeclToConsumer(Decl *D) {
7580 if (ObjCImplDecl *ImplD = dyn_cast<ObjCImplDecl>(D))
7581 PassObjCImplDeclToConsumer(ImplD, Consumer);
7582 else
7583 Consumer->HandleInterestingDecl(DeclGroupRef(D));
7584 }
7585
StartTranslationUnit(ASTConsumer * Consumer)7586 void ASTReader::StartTranslationUnit(ASTConsumer *Consumer) {
7587 this->Consumer = Consumer;
7588
7589 if (Consumer)
7590 PassInterestingDeclsToConsumer();
7591
7592 if (DeserializationListener)
7593 DeserializationListener->ReaderInitialized(this);
7594 }
7595
PrintStats()7596 void ASTReader::PrintStats() {
7597 std::fprintf(stderr, "*** AST File Statistics:\n");
7598
7599 unsigned NumTypesLoaded
7600 = TypesLoaded.size() - std::count(TypesLoaded.begin(), TypesLoaded.end(),
7601 QualType());
7602 unsigned NumDeclsLoaded
7603 = DeclsLoaded.size() - std::count(DeclsLoaded.begin(), DeclsLoaded.end(),
7604 (Decl *)nullptr);
7605 unsigned NumIdentifiersLoaded
7606 = IdentifiersLoaded.size() - std::count(IdentifiersLoaded.begin(),
7607 IdentifiersLoaded.end(),
7608 (IdentifierInfo *)nullptr);
7609 unsigned NumMacrosLoaded
7610 = MacrosLoaded.size() - std::count(MacrosLoaded.begin(),
7611 MacrosLoaded.end(),
7612 (MacroInfo *)nullptr);
7613 unsigned NumSelectorsLoaded
7614 = SelectorsLoaded.size() - std::count(SelectorsLoaded.begin(),
7615 SelectorsLoaded.end(),
7616 Selector());
7617
7618 if (unsigned TotalNumSLocEntries = getTotalNumSLocs())
7619 std::fprintf(stderr, " %u/%u source location entries read (%f%%)\n",
7620 NumSLocEntriesRead, TotalNumSLocEntries,
7621 ((float)NumSLocEntriesRead/TotalNumSLocEntries * 100));
7622 if (!TypesLoaded.empty())
7623 std::fprintf(stderr, " %u/%u types read (%f%%)\n",
7624 NumTypesLoaded, (unsigned)TypesLoaded.size(),
7625 ((float)NumTypesLoaded/TypesLoaded.size() * 100));
7626 if (!DeclsLoaded.empty())
7627 std::fprintf(stderr, " %u/%u declarations read (%f%%)\n",
7628 NumDeclsLoaded, (unsigned)DeclsLoaded.size(),
7629 ((float)NumDeclsLoaded/DeclsLoaded.size() * 100));
7630 if (!IdentifiersLoaded.empty())
7631 std::fprintf(stderr, " %u/%u identifiers read (%f%%)\n",
7632 NumIdentifiersLoaded, (unsigned)IdentifiersLoaded.size(),
7633 ((float)NumIdentifiersLoaded/IdentifiersLoaded.size() * 100));
7634 if (!MacrosLoaded.empty())
7635 std::fprintf(stderr, " %u/%u macros read (%f%%)\n",
7636 NumMacrosLoaded, (unsigned)MacrosLoaded.size(),
7637 ((float)NumMacrosLoaded/MacrosLoaded.size() * 100));
7638 if (!SelectorsLoaded.empty())
7639 std::fprintf(stderr, " %u/%u selectors read (%f%%)\n",
7640 NumSelectorsLoaded, (unsigned)SelectorsLoaded.size(),
7641 ((float)NumSelectorsLoaded/SelectorsLoaded.size() * 100));
7642 if (TotalNumStatements)
7643 std::fprintf(stderr, " %u/%u statements read (%f%%)\n",
7644 NumStatementsRead, TotalNumStatements,
7645 ((float)NumStatementsRead/TotalNumStatements * 100));
7646 if (TotalNumMacros)
7647 std::fprintf(stderr, " %u/%u macros read (%f%%)\n",
7648 NumMacrosRead, TotalNumMacros,
7649 ((float)NumMacrosRead/TotalNumMacros * 100));
7650 if (TotalLexicalDeclContexts)
7651 std::fprintf(stderr, " %u/%u lexical declcontexts read (%f%%)\n",
7652 NumLexicalDeclContextsRead, TotalLexicalDeclContexts,
7653 ((float)NumLexicalDeclContextsRead/TotalLexicalDeclContexts
7654 * 100));
7655 if (TotalVisibleDeclContexts)
7656 std::fprintf(stderr, " %u/%u visible declcontexts read (%f%%)\n",
7657 NumVisibleDeclContextsRead, TotalVisibleDeclContexts,
7658 ((float)NumVisibleDeclContextsRead/TotalVisibleDeclContexts
7659 * 100));
7660 if (TotalNumMethodPoolEntries)
7661 std::fprintf(stderr, " %u/%u method pool entries read (%f%%)\n",
7662 NumMethodPoolEntriesRead, TotalNumMethodPoolEntries,
7663 ((float)NumMethodPoolEntriesRead/TotalNumMethodPoolEntries
7664 * 100));
7665 if (NumMethodPoolLookups)
7666 std::fprintf(stderr, " %u/%u method pool lookups succeeded (%f%%)\n",
7667 NumMethodPoolHits, NumMethodPoolLookups,
7668 ((float)NumMethodPoolHits/NumMethodPoolLookups * 100.0));
7669 if (NumMethodPoolTableLookups)
7670 std::fprintf(stderr, " %u/%u method pool table lookups succeeded (%f%%)\n",
7671 NumMethodPoolTableHits, NumMethodPoolTableLookups,
7672 ((float)NumMethodPoolTableHits/NumMethodPoolTableLookups
7673 * 100.0));
7674 if (NumIdentifierLookupHits)
7675 std::fprintf(stderr,
7676 " %u / %u identifier table lookups succeeded (%f%%)\n",
7677 NumIdentifierLookupHits, NumIdentifierLookups,
7678 (double)NumIdentifierLookupHits*100.0/NumIdentifierLookups);
7679
7680 if (GlobalIndex) {
7681 std::fprintf(stderr, "\n");
7682 GlobalIndex->printStats();
7683 }
7684
7685 std::fprintf(stderr, "\n");
7686 dump();
7687 std::fprintf(stderr, "\n");
7688 }
7689
7690 template<typename Key, typename ModuleFile, unsigned InitialCapacity>
7691 LLVM_DUMP_METHOD static void
dumpModuleIDMap(StringRef Name,const ContinuousRangeMap<Key,ModuleFile *,InitialCapacity> & Map)7692 dumpModuleIDMap(StringRef Name,
7693 const ContinuousRangeMap<Key, ModuleFile *,
7694 InitialCapacity> &Map) {
7695 if (Map.begin() == Map.end())
7696 return;
7697
7698 using MapType = ContinuousRangeMap<Key, ModuleFile *, InitialCapacity>;
7699
7700 llvm::errs() << Name << ":\n";
7701 for (typename MapType::const_iterator I = Map.begin(), IEnd = Map.end();
7702 I != IEnd; ++I) {
7703 llvm::errs() << " " << I->first << " -> " << I->second->FileName
7704 << "\n";
7705 }
7706 }
7707
dump()7708 LLVM_DUMP_METHOD void ASTReader::dump() {
7709 llvm::errs() << "*** PCH/ModuleFile Remappings:\n";
7710 dumpModuleIDMap("Global bit offset map", GlobalBitOffsetsMap);
7711 dumpModuleIDMap("Global source location entry map", GlobalSLocEntryMap);
7712 dumpModuleIDMap("Global type map", GlobalTypeMap);
7713 dumpModuleIDMap("Global declaration map", GlobalDeclMap);
7714 dumpModuleIDMap("Global identifier map", GlobalIdentifierMap);
7715 dumpModuleIDMap("Global macro map", GlobalMacroMap);
7716 dumpModuleIDMap("Global submodule map", GlobalSubmoduleMap);
7717 dumpModuleIDMap("Global selector map", GlobalSelectorMap);
7718 dumpModuleIDMap("Global preprocessed entity map",
7719 GlobalPreprocessedEntityMap);
7720
7721 llvm::errs() << "\n*** PCH/Modules Loaded:";
7722 for (ModuleFile &M : ModuleMgr)
7723 M.dump();
7724 }
7725
7726 /// Return the amount of memory used by memory buffers, breaking down
7727 /// by heap-backed versus mmap'ed memory.
getMemoryBufferSizes(MemoryBufferSizes & sizes) const7728 void ASTReader::getMemoryBufferSizes(MemoryBufferSizes &sizes) const {
7729 for (ModuleFile &I : ModuleMgr) {
7730 if (llvm::MemoryBuffer *buf = I.Buffer) {
7731 size_t bytes = buf->getBufferSize();
7732 switch (buf->getBufferKind()) {
7733 case llvm::MemoryBuffer::MemoryBuffer_Malloc:
7734 sizes.malloc_bytes += bytes;
7735 break;
7736 case llvm::MemoryBuffer::MemoryBuffer_MMap:
7737 sizes.mmap_bytes += bytes;
7738 break;
7739 }
7740 }
7741 }
7742 }
7743
InitializeSema(Sema & S)7744 void ASTReader::InitializeSema(Sema &S) {
7745 SemaObj = &S;
7746 S.addExternalSource(this);
7747
7748 // Makes sure any declarations that were deserialized "too early"
7749 // still get added to the identifier's declaration chains.
7750 for (uint64_t ID : PreloadedDeclIDs) {
7751 NamedDecl *D = cast<NamedDecl>(GetDecl(ID));
7752 pushExternalDeclIntoScope(D, D->getDeclName());
7753 }
7754 PreloadedDeclIDs.clear();
7755
7756 // FIXME: What happens if these are changed by a module import?
7757 if (!FPPragmaOptions.empty()) {
7758 assert(FPPragmaOptions.size() == 1 && "Wrong number of FP_PRAGMA_OPTIONS");
7759 SemaObj->FPFeatures = FPOptions(FPPragmaOptions[0]);
7760 }
7761
7762 SemaObj->OpenCLFeatures.copy(OpenCLExtensions);
7763 SemaObj->OpenCLTypeExtMap = OpenCLTypeExtMap;
7764 SemaObj->OpenCLDeclExtMap = OpenCLDeclExtMap;
7765
7766 UpdateSema();
7767 }
7768
UpdateSema()7769 void ASTReader::UpdateSema() {
7770 assert(SemaObj && "no Sema to update");
7771
7772 // Load the offsets of the declarations that Sema references.
7773 // They will be lazily deserialized when needed.
7774 if (!SemaDeclRefs.empty()) {
7775 assert(SemaDeclRefs.size() % 3 == 0);
7776 for (unsigned I = 0; I != SemaDeclRefs.size(); I += 3) {
7777 if (!SemaObj->StdNamespace)
7778 SemaObj->StdNamespace = SemaDeclRefs[I];
7779 if (!SemaObj->StdBadAlloc)
7780 SemaObj->StdBadAlloc = SemaDeclRefs[I+1];
7781 if (!SemaObj->StdAlignValT)
7782 SemaObj->StdAlignValT = SemaDeclRefs[I+2];
7783 }
7784 SemaDeclRefs.clear();
7785 }
7786
7787 // Update the state of pragmas. Use the same API as if we had encountered the
7788 // pragma in the source.
7789 if(OptimizeOffPragmaLocation.isValid())
7790 SemaObj->ActOnPragmaOptimize(/* On = */ false, OptimizeOffPragmaLocation);
7791 if (PragmaMSStructState != -1)
7792 SemaObj->ActOnPragmaMSStruct((PragmaMSStructKind)PragmaMSStructState);
7793 if (PointersToMembersPragmaLocation.isValid()) {
7794 SemaObj->ActOnPragmaMSPointersToMembers(
7795 (LangOptions::PragmaMSPointersToMembersKind)
7796 PragmaMSPointersToMembersState,
7797 PointersToMembersPragmaLocation);
7798 }
7799 SemaObj->ForceCUDAHostDeviceDepth = ForceCUDAHostDeviceDepth;
7800
7801 if (PragmaPackCurrentValue) {
7802 // The bottom of the stack might have a default value. It must be adjusted
7803 // to the current value to ensure that the packing state is preserved after
7804 // popping entries that were included/imported from a PCH/module.
7805 bool DropFirst = false;
7806 if (!PragmaPackStack.empty() &&
7807 PragmaPackStack.front().Location.isInvalid()) {
7808 assert(PragmaPackStack.front().Value == SemaObj->PackStack.DefaultValue &&
7809 "Expected a default alignment value");
7810 SemaObj->PackStack.Stack.emplace_back(
7811 PragmaPackStack.front().SlotLabel, SemaObj->PackStack.CurrentValue,
7812 SemaObj->PackStack.CurrentPragmaLocation,
7813 PragmaPackStack.front().PushLocation);
7814 DropFirst = true;
7815 }
7816 for (const auto &Entry :
7817 llvm::makeArrayRef(PragmaPackStack).drop_front(DropFirst ? 1 : 0))
7818 SemaObj->PackStack.Stack.emplace_back(Entry.SlotLabel, Entry.Value,
7819 Entry.Location, Entry.PushLocation);
7820 if (PragmaPackCurrentLocation.isInvalid()) {
7821 assert(*PragmaPackCurrentValue == SemaObj->PackStack.DefaultValue &&
7822 "Expected a default alignment value");
7823 // Keep the current values.
7824 } else {
7825 SemaObj->PackStack.CurrentValue = *PragmaPackCurrentValue;
7826 SemaObj->PackStack.CurrentPragmaLocation = PragmaPackCurrentLocation;
7827 }
7828 }
7829 }
7830
get(StringRef Name)7831 IdentifierInfo *ASTReader::get(StringRef Name) {
7832 // Note that we are loading an identifier.
7833 Deserializing AnIdentifier(this);
7834
7835 IdentifierLookupVisitor Visitor(Name, /*PriorGeneration=*/0,
7836 NumIdentifierLookups,
7837 NumIdentifierLookupHits);
7838
7839 // We don't need to do identifier table lookups in C++ modules (we preload
7840 // all interesting declarations, and don't need to use the scope for name
7841 // lookups). Perform the lookup in PCH files, though, since we don't build
7842 // a complete initial identifier table if we're carrying on from a PCH.
7843 if (PP.getLangOpts().CPlusPlus) {
7844 for (auto F : ModuleMgr.pch_modules())
7845 if (Visitor(*F))
7846 break;
7847 } else {
7848 // If there is a global index, look there first to determine which modules
7849 // provably do not have any results for this identifier.
7850 GlobalModuleIndex::HitSet Hits;
7851 GlobalModuleIndex::HitSet *HitsPtr = nullptr;
7852 if (!loadGlobalIndex()) {
7853 if (GlobalIndex->lookupIdentifier(Name, Hits)) {
7854 HitsPtr = &Hits;
7855 }
7856 }
7857
7858 ModuleMgr.visit(Visitor, HitsPtr);
7859 }
7860
7861 IdentifierInfo *II = Visitor.getIdentifierInfo();
7862 markIdentifierUpToDate(II);
7863 return II;
7864 }
7865
7866 namespace clang {
7867
7868 /// An identifier-lookup iterator that enumerates all of the
7869 /// identifiers stored within a set of AST files.
7870 class ASTIdentifierIterator : public IdentifierIterator {
7871 /// The AST reader whose identifiers are being enumerated.
7872 const ASTReader &Reader;
7873
7874 /// The current index into the chain of AST files stored in
7875 /// the AST reader.
7876 unsigned Index;
7877
7878 /// The current position within the identifier lookup table
7879 /// of the current AST file.
7880 ASTIdentifierLookupTable::key_iterator Current;
7881
7882 /// The end position within the identifier lookup table of
7883 /// the current AST file.
7884 ASTIdentifierLookupTable::key_iterator End;
7885
7886 /// Whether to skip any modules in the ASTReader.
7887 bool SkipModules;
7888
7889 public:
7890 explicit ASTIdentifierIterator(const ASTReader &Reader,
7891 bool SkipModules = false);
7892
7893 StringRef Next() override;
7894 };
7895
7896 } // namespace clang
7897
ASTIdentifierIterator(const ASTReader & Reader,bool SkipModules)7898 ASTIdentifierIterator::ASTIdentifierIterator(const ASTReader &Reader,
7899 bool SkipModules)
7900 : Reader(Reader), Index(Reader.ModuleMgr.size()), SkipModules(SkipModules) {
7901 }
7902
Next()7903 StringRef ASTIdentifierIterator::Next() {
7904 while (Current == End) {
7905 // If we have exhausted all of our AST files, we're done.
7906 if (Index == 0)
7907 return StringRef();
7908
7909 --Index;
7910 ModuleFile &F = Reader.ModuleMgr[Index];
7911 if (SkipModules && F.isModule())
7912 continue;
7913
7914 ASTIdentifierLookupTable *IdTable =
7915 (ASTIdentifierLookupTable *)F.IdentifierLookupTable;
7916 Current = IdTable->key_begin();
7917 End = IdTable->key_end();
7918 }
7919
7920 // We have any identifiers remaining in the current AST file; return
7921 // the next one.
7922 StringRef Result = *Current;
7923 ++Current;
7924 return Result;
7925 }
7926
7927 namespace {
7928
7929 /// A utility for appending two IdentifierIterators.
7930 class ChainedIdentifierIterator : public IdentifierIterator {
7931 std::unique_ptr<IdentifierIterator> Current;
7932 std::unique_ptr<IdentifierIterator> Queued;
7933
7934 public:
ChainedIdentifierIterator(std::unique_ptr<IdentifierIterator> First,std::unique_ptr<IdentifierIterator> Second)7935 ChainedIdentifierIterator(std::unique_ptr<IdentifierIterator> First,
7936 std::unique_ptr<IdentifierIterator> Second)
7937 : Current(std::move(First)), Queued(std::move(Second)) {}
7938
Next()7939 StringRef Next() override {
7940 if (!Current)
7941 return StringRef();
7942
7943 StringRef result = Current->Next();
7944 if (!result.empty())
7945 return result;
7946
7947 // Try the queued iterator, which may itself be empty.
7948 Current.reset();
7949 std::swap(Current, Queued);
7950 return Next();
7951 }
7952 };
7953
7954 } // namespace
7955
getIdentifiers()7956 IdentifierIterator *ASTReader::getIdentifiers() {
7957 if (!loadGlobalIndex()) {
7958 std::unique_ptr<IdentifierIterator> ReaderIter(
7959 new ASTIdentifierIterator(*this, /*SkipModules=*/true));
7960 std::unique_ptr<IdentifierIterator> ModulesIter(
7961 GlobalIndex->createIdentifierIterator());
7962 return new ChainedIdentifierIterator(std::move(ReaderIter),
7963 std::move(ModulesIter));
7964 }
7965
7966 return new ASTIdentifierIterator(*this);
7967 }
7968
7969 namespace clang {
7970 namespace serialization {
7971
7972 class ReadMethodPoolVisitor {
7973 ASTReader &Reader;
7974 Selector Sel;
7975 unsigned PriorGeneration;
7976 unsigned InstanceBits = 0;
7977 unsigned FactoryBits = 0;
7978 bool InstanceHasMoreThanOneDecl = false;
7979 bool FactoryHasMoreThanOneDecl = false;
7980 SmallVector<ObjCMethodDecl *, 4> InstanceMethods;
7981 SmallVector<ObjCMethodDecl *, 4> FactoryMethods;
7982
7983 public:
ReadMethodPoolVisitor(ASTReader & Reader,Selector Sel,unsigned PriorGeneration)7984 ReadMethodPoolVisitor(ASTReader &Reader, Selector Sel,
7985 unsigned PriorGeneration)
7986 : Reader(Reader), Sel(Sel), PriorGeneration(PriorGeneration) {}
7987
operator ()(ModuleFile & M)7988 bool operator()(ModuleFile &M) {
7989 if (!M.SelectorLookupTable)
7990 return false;
7991
7992 // If we've already searched this module file, skip it now.
7993 if (M.Generation <= PriorGeneration)
7994 return true;
7995
7996 ++Reader.NumMethodPoolTableLookups;
7997 ASTSelectorLookupTable *PoolTable
7998 = (ASTSelectorLookupTable*)M.SelectorLookupTable;
7999 ASTSelectorLookupTable::iterator Pos = PoolTable->find(Sel);
8000 if (Pos == PoolTable->end())
8001 return false;
8002
8003 ++Reader.NumMethodPoolTableHits;
8004 ++Reader.NumSelectorsRead;
8005 // FIXME: Not quite happy with the statistics here. We probably should
8006 // disable this tracking when called via LoadSelector.
8007 // Also, should entries without methods count as misses?
8008 ++Reader.NumMethodPoolEntriesRead;
8009 ASTSelectorLookupTrait::data_type Data = *Pos;
8010 if (Reader.DeserializationListener)
8011 Reader.DeserializationListener->SelectorRead(Data.ID, Sel);
8012
8013 InstanceMethods.append(Data.Instance.begin(), Data.Instance.end());
8014 FactoryMethods.append(Data.Factory.begin(), Data.Factory.end());
8015 InstanceBits = Data.InstanceBits;
8016 FactoryBits = Data.FactoryBits;
8017 InstanceHasMoreThanOneDecl = Data.InstanceHasMoreThanOneDecl;
8018 FactoryHasMoreThanOneDecl = Data.FactoryHasMoreThanOneDecl;
8019 return true;
8020 }
8021
8022 /// Retrieve the instance methods found by this visitor.
getInstanceMethods() const8023 ArrayRef<ObjCMethodDecl *> getInstanceMethods() const {
8024 return InstanceMethods;
8025 }
8026
8027 /// Retrieve the instance methods found by this visitor.
getFactoryMethods() const8028 ArrayRef<ObjCMethodDecl *> getFactoryMethods() const {
8029 return FactoryMethods;
8030 }
8031
getInstanceBits() const8032 unsigned getInstanceBits() const { return InstanceBits; }
getFactoryBits() const8033 unsigned getFactoryBits() const { return FactoryBits; }
8034
instanceHasMoreThanOneDecl() const8035 bool instanceHasMoreThanOneDecl() const {
8036 return InstanceHasMoreThanOneDecl;
8037 }
8038
factoryHasMoreThanOneDecl() const8039 bool factoryHasMoreThanOneDecl() const { return FactoryHasMoreThanOneDecl; }
8040 };
8041
8042 } // namespace serialization
8043 } // namespace clang
8044
8045 /// Add the given set of methods to the method list.
addMethodsToPool(Sema & S,ArrayRef<ObjCMethodDecl * > Methods,ObjCMethodList & List)8046 static void addMethodsToPool(Sema &S, ArrayRef<ObjCMethodDecl *> Methods,
8047 ObjCMethodList &List) {
8048 for (unsigned I = 0, N = Methods.size(); I != N; ++I) {
8049 S.addMethodToGlobalList(&List, Methods[I]);
8050 }
8051 }
8052
ReadMethodPool(Selector Sel)8053 void ASTReader::ReadMethodPool(Selector Sel) {
8054 // Get the selector generation and update it to the current generation.
8055 unsigned &Generation = SelectorGeneration[Sel];
8056 unsigned PriorGeneration = Generation;
8057 Generation = getGeneration();
8058 SelectorOutOfDate[Sel] = false;
8059
8060 // Search for methods defined with this selector.
8061 ++NumMethodPoolLookups;
8062 ReadMethodPoolVisitor Visitor(*this, Sel, PriorGeneration);
8063 ModuleMgr.visit(Visitor);
8064
8065 if (Visitor.getInstanceMethods().empty() &&
8066 Visitor.getFactoryMethods().empty())
8067 return;
8068
8069 ++NumMethodPoolHits;
8070
8071 if (!getSema())
8072 return;
8073
8074 Sema &S = *getSema();
8075 Sema::GlobalMethodPool::iterator Pos
8076 = S.MethodPool.insert(std::make_pair(Sel, Sema::GlobalMethods())).first;
8077
8078 Pos->second.first.setBits(Visitor.getInstanceBits());
8079 Pos->second.first.setHasMoreThanOneDecl(Visitor.instanceHasMoreThanOneDecl());
8080 Pos->second.second.setBits(Visitor.getFactoryBits());
8081 Pos->second.second.setHasMoreThanOneDecl(Visitor.factoryHasMoreThanOneDecl());
8082
8083 // Add methods to the global pool *after* setting hasMoreThanOneDecl, since
8084 // when building a module we keep every method individually and may need to
8085 // update hasMoreThanOneDecl as we add the methods.
8086 addMethodsToPool(S, Visitor.getInstanceMethods(), Pos->second.first);
8087 addMethodsToPool(S, Visitor.getFactoryMethods(), Pos->second.second);
8088 }
8089
updateOutOfDateSelector(Selector Sel)8090 void ASTReader::updateOutOfDateSelector(Selector Sel) {
8091 if (SelectorOutOfDate[Sel])
8092 ReadMethodPool(Sel);
8093 }
8094
ReadKnownNamespaces(SmallVectorImpl<NamespaceDecl * > & Namespaces)8095 void ASTReader::ReadKnownNamespaces(
8096 SmallVectorImpl<NamespaceDecl *> &Namespaces) {
8097 Namespaces.clear();
8098
8099 for (unsigned I = 0, N = KnownNamespaces.size(); I != N; ++I) {
8100 if (NamespaceDecl *Namespace
8101 = dyn_cast_or_null<NamespaceDecl>(GetDecl(KnownNamespaces[I])))
8102 Namespaces.push_back(Namespace);
8103 }
8104 }
8105
ReadUndefinedButUsed(llvm::MapVector<NamedDecl *,SourceLocation> & Undefined)8106 void ASTReader::ReadUndefinedButUsed(
8107 llvm::MapVector<NamedDecl *, SourceLocation> &Undefined) {
8108 for (unsigned Idx = 0, N = UndefinedButUsed.size(); Idx != N;) {
8109 NamedDecl *D = cast<NamedDecl>(GetDecl(UndefinedButUsed[Idx++]));
8110 SourceLocation Loc =
8111 SourceLocation::getFromRawEncoding(UndefinedButUsed[Idx++]);
8112 Undefined.insert(std::make_pair(D, Loc));
8113 }
8114 }
8115
ReadMismatchingDeleteExpressions(llvm::MapVector<FieldDecl *,llvm::SmallVector<std::pair<SourceLocation,bool>,4>> & Exprs)8116 void ASTReader::ReadMismatchingDeleteExpressions(llvm::MapVector<
8117 FieldDecl *, llvm::SmallVector<std::pair<SourceLocation, bool>, 4>> &
8118 Exprs) {
8119 for (unsigned Idx = 0, N = DelayedDeleteExprs.size(); Idx != N;) {
8120 FieldDecl *FD = cast<FieldDecl>(GetDecl(DelayedDeleteExprs[Idx++]));
8121 uint64_t Count = DelayedDeleteExprs[Idx++];
8122 for (uint64_t C = 0; C < Count; ++C) {
8123 SourceLocation DeleteLoc =
8124 SourceLocation::getFromRawEncoding(DelayedDeleteExprs[Idx++]);
8125 const bool IsArrayForm = DelayedDeleteExprs[Idx++];
8126 Exprs[FD].push_back(std::make_pair(DeleteLoc, IsArrayForm));
8127 }
8128 }
8129 }
8130
ReadTentativeDefinitions(SmallVectorImpl<VarDecl * > & TentativeDefs)8131 void ASTReader::ReadTentativeDefinitions(
8132 SmallVectorImpl<VarDecl *> &TentativeDefs) {
8133 for (unsigned I = 0, N = TentativeDefinitions.size(); I != N; ++I) {
8134 VarDecl *Var = dyn_cast_or_null<VarDecl>(GetDecl(TentativeDefinitions[I]));
8135 if (Var)
8136 TentativeDefs.push_back(Var);
8137 }
8138 TentativeDefinitions.clear();
8139 }
8140
ReadUnusedFileScopedDecls(SmallVectorImpl<const DeclaratorDecl * > & Decls)8141 void ASTReader::ReadUnusedFileScopedDecls(
8142 SmallVectorImpl<const DeclaratorDecl *> &Decls) {
8143 for (unsigned I = 0, N = UnusedFileScopedDecls.size(); I != N; ++I) {
8144 DeclaratorDecl *D
8145 = dyn_cast_or_null<DeclaratorDecl>(GetDecl(UnusedFileScopedDecls[I]));
8146 if (D)
8147 Decls.push_back(D);
8148 }
8149 UnusedFileScopedDecls.clear();
8150 }
8151
ReadDelegatingConstructors(SmallVectorImpl<CXXConstructorDecl * > & Decls)8152 void ASTReader::ReadDelegatingConstructors(
8153 SmallVectorImpl<CXXConstructorDecl *> &Decls) {
8154 for (unsigned I = 0, N = DelegatingCtorDecls.size(); I != N; ++I) {
8155 CXXConstructorDecl *D
8156 = dyn_cast_or_null<CXXConstructorDecl>(GetDecl(DelegatingCtorDecls[I]));
8157 if (D)
8158 Decls.push_back(D);
8159 }
8160 DelegatingCtorDecls.clear();
8161 }
8162
ReadExtVectorDecls(SmallVectorImpl<TypedefNameDecl * > & Decls)8163 void ASTReader::ReadExtVectorDecls(SmallVectorImpl<TypedefNameDecl *> &Decls) {
8164 for (unsigned I = 0, N = ExtVectorDecls.size(); I != N; ++I) {
8165 TypedefNameDecl *D
8166 = dyn_cast_or_null<TypedefNameDecl>(GetDecl(ExtVectorDecls[I]));
8167 if (D)
8168 Decls.push_back(D);
8169 }
8170 ExtVectorDecls.clear();
8171 }
8172
ReadUnusedLocalTypedefNameCandidates(llvm::SmallSetVector<const TypedefNameDecl *,4> & Decls)8173 void ASTReader::ReadUnusedLocalTypedefNameCandidates(
8174 llvm::SmallSetVector<const TypedefNameDecl *, 4> &Decls) {
8175 for (unsigned I = 0, N = UnusedLocalTypedefNameCandidates.size(); I != N;
8176 ++I) {
8177 TypedefNameDecl *D = dyn_cast_or_null<TypedefNameDecl>(
8178 GetDecl(UnusedLocalTypedefNameCandidates[I]));
8179 if (D)
8180 Decls.insert(D);
8181 }
8182 UnusedLocalTypedefNameCandidates.clear();
8183 }
8184
ReadReferencedSelectors(SmallVectorImpl<std::pair<Selector,SourceLocation>> & Sels)8185 void ASTReader::ReadReferencedSelectors(
8186 SmallVectorImpl<std::pair<Selector, SourceLocation>> &Sels) {
8187 if (ReferencedSelectorsData.empty())
8188 return;
8189
8190 // If there are @selector references added them to its pool. This is for
8191 // implementation of -Wselector.
8192 unsigned int DataSize = ReferencedSelectorsData.size()-1;
8193 unsigned I = 0;
8194 while (I < DataSize) {
8195 Selector Sel = DecodeSelector(ReferencedSelectorsData[I++]);
8196 SourceLocation SelLoc
8197 = SourceLocation::getFromRawEncoding(ReferencedSelectorsData[I++]);
8198 Sels.push_back(std::make_pair(Sel, SelLoc));
8199 }
8200 ReferencedSelectorsData.clear();
8201 }
8202
ReadWeakUndeclaredIdentifiers(SmallVectorImpl<std::pair<IdentifierInfo *,WeakInfo>> & WeakIDs)8203 void ASTReader::ReadWeakUndeclaredIdentifiers(
8204 SmallVectorImpl<std::pair<IdentifierInfo *, WeakInfo>> &WeakIDs) {
8205 if (WeakUndeclaredIdentifiers.empty())
8206 return;
8207
8208 for (unsigned I = 0, N = WeakUndeclaredIdentifiers.size(); I < N; /*none*/) {
8209 IdentifierInfo *WeakId
8210 = DecodeIdentifierInfo(WeakUndeclaredIdentifiers[I++]);
8211 IdentifierInfo *AliasId
8212 = DecodeIdentifierInfo(WeakUndeclaredIdentifiers[I++]);
8213 SourceLocation Loc
8214 = SourceLocation::getFromRawEncoding(WeakUndeclaredIdentifiers[I++]);
8215 bool Used = WeakUndeclaredIdentifiers[I++];
8216 WeakInfo WI(AliasId, Loc);
8217 WI.setUsed(Used);
8218 WeakIDs.push_back(std::make_pair(WeakId, WI));
8219 }
8220 WeakUndeclaredIdentifiers.clear();
8221 }
8222
ReadUsedVTables(SmallVectorImpl<ExternalVTableUse> & VTables)8223 void ASTReader::ReadUsedVTables(SmallVectorImpl<ExternalVTableUse> &VTables) {
8224 for (unsigned Idx = 0, N = VTableUses.size(); Idx < N; /* In loop */) {
8225 ExternalVTableUse VT;
8226 VT.Record = dyn_cast_or_null<CXXRecordDecl>(GetDecl(VTableUses[Idx++]));
8227 VT.Location = SourceLocation::getFromRawEncoding(VTableUses[Idx++]);
8228 VT.DefinitionRequired = VTableUses[Idx++];
8229 VTables.push_back(VT);
8230 }
8231
8232 VTableUses.clear();
8233 }
8234
ReadPendingInstantiations(SmallVectorImpl<std::pair<ValueDecl *,SourceLocation>> & Pending)8235 void ASTReader::ReadPendingInstantiations(
8236 SmallVectorImpl<std::pair<ValueDecl *, SourceLocation>> &Pending) {
8237 for (unsigned Idx = 0, N = PendingInstantiations.size(); Idx < N;) {
8238 ValueDecl *D = cast<ValueDecl>(GetDecl(PendingInstantiations[Idx++]));
8239 SourceLocation Loc
8240 = SourceLocation::getFromRawEncoding(PendingInstantiations[Idx++]);
8241
8242 Pending.push_back(std::make_pair(D, Loc));
8243 }
8244 PendingInstantiations.clear();
8245 }
8246
ReadLateParsedTemplates(llvm::MapVector<const FunctionDecl *,std::unique_ptr<LateParsedTemplate>> & LPTMap)8247 void ASTReader::ReadLateParsedTemplates(
8248 llvm::MapVector<const FunctionDecl *, std::unique_ptr<LateParsedTemplate>>
8249 &LPTMap) {
8250 for (unsigned Idx = 0, N = LateParsedTemplates.size(); Idx < N;
8251 /* In loop */) {
8252 FunctionDecl *FD = cast<FunctionDecl>(GetDecl(LateParsedTemplates[Idx++]));
8253
8254 auto LT = std::make_unique<LateParsedTemplate>();
8255 LT->D = GetDecl(LateParsedTemplates[Idx++]);
8256
8257 ModuleFile *F = getOwningModuleFile(LT->D);
8258 assert(F && "No module");
8259
8260 unsigned TokN = LateParsedTemplates[Idx++];
8261 LT->Toks.reserve(TokN);
8262 for (unsigned T = 0; T < TokN; ++T)
8263 LT->Toks.push_back(ReadToken(*F, LateParsedTemplates, Idx));
8264
8265 LPTMap.insert(std::make_pair(FD, std::move(LT)));
8266 }
8267
8268 LateParsedTemplates.clear();
8269 }
8270
LoadSelector(Selector Sel)8271 void ASTReader::LoadSelector(Selector Sel) {
8272 // It would be complicated to avoid reading the methods anyway. So don't.
8273 ReadMethodPool(Sel);
8274 }
8275
SetIdentifierInfo(IdentifierID ID,IdentifierInfo * II)8276 void ASTReader::SetIdentifierInfo(IdentifierID ID, IdentifierInfo *II) {
8277 assert(ID && "Non-zero identifier ID required");
8278 assert(ID <= IdentifiersLoaded.size() && "identifier ID out of range");
8279 IdentifiersLoaded[ID - 1] = II;
8280 if (DeserializationListener)
8281 DeserializationListener->IdentifierRead(ID, II);
8282 }
8283
8284 /// Set the globally-visible declarations associated with the given
8285 /// identifier.
8286 ///
8287 /// If the AST reader is currently in a state where the given declaration IDs
8288 /// cannot safely be resolved, they are queued until it is safe to resolve
8289 /// them.
8290 ///
8291 /// \param II an IdentifierInfo that refers to one or more globally-visible
8292 /// declarations.
8293 ///
8294 /// \param DeclIDs the set of declaration IDs with the name @p II that are
8295 /// visible at global scope.
8296 ///
8297 /// \param Decls if non-null, this vector will be populated with the set of
8298 /// deserialized declarations. These declarations will not be pushed into
8299 /// scope.
8300 void
SetGloballyVisibleDecls(IdentifierInfo * II,const SmallVectorImpl<uint32_t> & DeclIDs,SmallVectorImpl<Decl * > * Decls)8301 ASTReader::SetGloballyVisibleDecls(IdentifierInfo *II,
8302 const SmallVectorImpl<uint32_t> &DeclIDs,
8303 SmallVectorImpl<Decl *> *Decls) {
8304 if (NumCurrentElementsDeserializing && !Decls) {
8305 PendingIdentifierInfos[II].append(DeclIDs.begin(), DeclIDs.end());
8306 return;
8307 }
8308
8309 for (unsigned I = 0, N = DeclIDs.size(); I != N; ++I) {
8310 if (!SemaObj) {
8311 // Queue this declaration so that it will be added to the
8312 // translation unit scope and identifier's declaration chain
8313 // once a Sema object is known.
8314 PreloadedDeclIDs.push_back(DeclIDs[I]);
8315 continue;
8316 }
8317
8318 NamedDecl *D = cast<NamedDecl>(GetDecl(DeclIDs[I]));
8319
8320 // If we're simply supposed to record the declarations, do so now.
8321 if (Decls) {
8322 Decls->push_back(D);
8323 continue;
8324 }
8325
8326 // Introduce this declaration into the translation-unit scope
8327 // and add it to the declaration chain for this identifier, so
8328 // that (unqualified) name lookup will find it.
8329 pushExternalDeclIntoScope(D, II);
8330 }
8331 }
8332
DecodeIdentifierInfo(IdentifierID ID)8333 IdentifierInfo *ASTReader::DecodeIdentifierInfo(IdentifierID ID) {
8334 if (ID == 0)
8335 return nullptr;
8336
8337 if (IdentifiersLoaded.empty()) {
8338 Error("no identifier table in AST file");
8339 return nullptr;
8340 }
8341
8342 ID -= 1;
8343 if (!IdentifiersLoaded[ID]) {
8344 GlobalIdentifierMapType::iterator I = GlobalIdentifierMap.find(ID + 1);
8345 assert(I != GlobalIdentifierMap.end() && "Corrupted global identifier map");
8346 ModuleFile *M = I->second;
8347 unsigned Index = ID - M->BaseIdentifierID;
8348 const char *Str = M->IdentifierTableData + M->IdentifierOffsets[Index];
8349
8350 // All of the strings in the AST file are preceded by a 16-bit length.
8351 // Extract that 16-bit length to avoid having to execute strlen().
8352 // NOTE: 'StrLenPtr' is an 'unsigned char*' so that we load bytes as
8353 // unsigned integers. This is important to avoid integer overflow when
8354 // we cast them to 'unsigned'.
8355 const unsigned char *StrLenPtr = (const unsigned char*) Str - 2;
8356 unsigned StrLen = (((unsigned) StrLenPtr[0])
8357 | (((unsigned) StrLenPtr[1]) << 8)) - 1;
8358 auto &II = PP.getIdentifierTable().get(StringRef(Str, StrLen));
8359 IdentifiersLoaded[ID] = &II;
8360 markIdentifierFromAST(*this, II);
8361 if (DeserializationListener)
8362 DeserializationListener->IdentifierRead(ID + 1, &II);
8363 }
8364
8365 return IdentifiersLoaded[ID];
8366 }
8367
getLocalIdentifier(ModuleFile & M,unsigned LocalID)8368 IdentifierInfo *ASTReader::getLocalIdentifier(ModuleFile &M, unsigned LocalID) {
8369 return DecodeIdentifierInfo(getGlobalIdentifierID(M, LocalID));
8370 }
8371
getGlobalIdentifierID(ModuleFile & M,unsigned LocalID)8372 IdentifierID ASTReader::getGlobalIdentifierID(ModuleFile &M, unsigned LocalID) {
8373 if (LocalID < NUM_PREDEF_IDENT_IDS)
8374 return LocalID;
8375
8376 if (!M.ModuleOffsetMap.empty())
8377 ReadModuleOffsetMap(M);
8378
8379 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8380 = M.IdentifierRemap.find(LocalID - NUM_PREDEF_IDENT_IDS);
8381 assert(I != M.IdentifierRemap.end()
8382 && "Invalid index into identifier index remap");
8383
8384 return LocalID + I->second;
8385 }
8386
getMacro(MacroID ID)8387 MacroInfo *ASTReader::getMacro(MacroID ID) {
8388 if (ID == 0)
8389 return nullptr;
8390
8391 if (MacrosLoaded.empty()) {
8392 Error("no macro table in AST file");
8393 return nullptr;
8394 }
8395
8396 ID -= NUM_PREDEF_MACRO_IDS;
8397 if (!MacrosLoaded[ID]) {
8398 GlobalMacroMapType::iterator I
8399 = GlobalMacroMap.find(ID + NUM_PREDEF_MACRO_IDS);
8400 assert(I != GlobalMacroMap.end() && "Corrupted global macro map");
8401 ModuleFile *M = I->second;
8402 unsigned Index = ID - M->BaseMacroID;
8403 MacrosLoaded[ID] = ReadMacroRecord(*M, M->MacroOffsets[Index]);
8404
8405 if (DeserializationListener)
8406 DeserializationListener->MacroRead(ID + NUM_PREDEF_MACRO_IDS,
8407 MacrosLoaded[ID]);
8408 }
8409
8410 return MacrosLoaded[ID];
8411 }
8412
getGlobalMacroID(ModuleFile & M,unsigned LocalID)8413 MacroID ASTReader::getGlobalMacroID(ModuleFile &M, unsigned LocalID) {
8414 if (LocalID < NUM_PREDEF_MACRO_IDS)
8415 return LocalID;
8416
8417 if (!M.ModuleOffsetMap.empty())
8418 ReadModuleOffsetMap(M);
8419
8420 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8421 = M.MacroRemap.find(LocalID - NUM_PREDEF_MACRO_IDS);
8422 assert(I != M.MacroRemap.end() && "Invalid index into macro index remap");
8423
8424 return LocalID + I->second;
8425 }
8426
8427 serialization::SubmoduleID
getGlobalSubmoduleID(ModuleFile & M,unsigned LocalID)8428 ASTReader::getGlobalSubmoduleID(ModuleFile &M, unsigned LocalID) {
8429 if (LocalID < NUM_PREDEF_SUBMODULE_IDS)
8430 return LocalID;
8431
8432 if (!M.ModuleOffsetMap.empty())
8433 ReadModuleOffsetMap(M);
8434
8435 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8436 = M.SubmoduleRemap.find(LocalID - NUM_PREDEF_SUBMODULE_IDS);
8437 assert(I != M.SubmoduleRemap.end()
8438 && "Invalid index into submodule index remap");
8439
8440 return LocalID + I->second;
8441 }
8442
getSubmodule(SubmoduleID GlobalID)8443 Module *ASTReader::getSubmodule(SubmoduleID GlobalID) {
8444 if (GlobalID < NUM_PREDEF_SUBMODULE_IDS) {
8445 assert(GlobalID == 0 && "Unhandled global submodule ID");
8446 return nullptr;
8447 }
8448
8449 if (GlobalID > SubmodulesLoaded.size()) {
8450 Error("submodule ID out of range in AST file");
8451 return nullptr;
8452 }
8453
8454 return SubmodulesLoaded[GlobalID - NUM_PREDEF_SUBMODULE_IDS];
8455 }
8456
getModule(unsigned ID)8457 Module *ASTReader::getModule(unsigned ID) {
8458 return getSubmodule(ID);
8459 }
8460
DeclIsFromPCHWithObjectFile(const Decl * D)8461 bool ASTReader::DeclIsFromPCHWithObjectFile(const Decl *D) {
8462 ModuleFile *MF = getOwningModuleFile(D);
8463 return MF && MF->PCHHasObjectFile;
8464 }
8465
getLocalModuleFile(ModuleFile & F,unsigned ID)8466 ModuleFile *ASTReader::getLocalModuleFile(ModuleFile &F, unsigned ID) {
8467 if (ID & 1) {
8468 // It's a module, look it up by submodule ID.
8469 auto I = GlobalSubmoduleMap.find(getGlobalSubmoduleID(F, ID >> 1));
8470 return I == GlobalSubmoduleMap.end() ? nullptr : I->second;
8471 } else {
8472 // It's a prefix (preamble, PCH, ...). Look it up by index.
8473 unsigned IndexFromEnd = ID >> 1;
8474 assert(IndexFromEnd && "got reference to unknown module file");
8475 return getModuleManager().pch_modules().end()[-IndexFromEnd];
8476 }
8477 }
8478
getModuleFileID(ModuleFile * F)8479 unsigned ASTReader::getModuleFileID(ModuleFile *F) {
8480 if (!F)
8481 return 1;
8482
8483 // For a file representing a module, use the submodule ID of the top-level
8484 // module as the file ID. For any other kind of file, the number of such
8485 // files loaded beforehand will be the same on reload.
8486 // FIXME: Is this true even if we have an explicit module file and a PCH?
8487 if (F->isModule())
8488 return ((F->BaseSubmoduleID + NUM_PREDEF_SUBMODULE_IDS) << 1) | 1;
8489
8490 auto PCHModules = getModuleManager().pch_modules();
8491 auto I = llvm::find(PCHModules, F);
8492 assert(I != PCHModules.end() && "emitting reference to unknown file");
8493 return (I - PCHModules.end()) << 1;
8494 }
8495
8496 llvm::Optional<ExternalASTSource::ASTSourceDescriptor>
getSourceDescriptor(unsigned ID)8497 ASTReader::getSourceDescriptor(unsigned ID) {
8498 if (const Module *M = getSubmodule(ID))
8499 return ExternalASTSource::ASTSourceDescriptor(*M);
8500
8501 // If there is only a single PCH, return it instead.
8502 // Chained PCH are not supported.
8503 const auto &PCHChain = ModuleMgr.pch_modules();
8504 if (std::distance(std::begin(PCHChain), std::end(PCHChain))) {
8505 ModuleFile &MF = ModuleMgr.getPrimaryModule();
8506 StringRef ModuleName = llvm::sys::path::filename(MF.OriginalSourceFileName);
8507 StringRef FileName = llvm::sys::path::filename(MF.FileName);
8508 return ASTReader::ASTSourceDescriptor(ModuleName, MF.OriginalDir, FileName,
8509 MF.Signature);
8510 }
8511 return None;
8512 }
8513
hasExternalDefinitions(const Decl * FD)8514 ExternalASTSource::ExtKind ASTReader::hasExternalDefinitions(const Decl *FD) {
8515 auto I = DefinitionSource.find(FD);
8516 if (I == DefinitionSource.end())
8517 return EK_ReplyHazy;
8518 return I->second ? EK_Never : EK_Always;
8519 }
8520
getLocalSelector(ModuleFile & M,unsigned LocalID)8521 Selector ASTReader::getLocalSelector(ModuleFile &M, unsigned LocalID) {
8522 return DecodeSelector(getGlobalSelectorID(M, LocalID));
8523 }
8524
DecodeSelector(serialization::SelectorID ID)8525 Selector ASTReader::DecodeSelector(serialization::SelectorID ID) {
8526 if (ID == 0)
8527 return Selector();
8528
8529 if (ID > SelectorsLoaded.size()) {
8530 Error("selector ID out of range in AST file");
8531 return Selector();
8532 }
8533
8534 if (SelectorsLoaded[ID - 1].getAsOpaquePtr() == nullptr) {
8535 // Load this selector from the selector table.
8536 GlobalSelectorMapType::iterator I = GlobalSelectorMap.find(ID);
8537 assert(I != GlobalSelectorMap.end() && "Corrupted global selector map");
8538 ModuleFile &M = *I->second;
8539 ASTSelectorLookupTrait Trait(*this, M);
8540 unsigned Idx = ID - M.BaseSelectorID - NUM_PREDEF_SELECTOR_IDS;
8541 SelectorsLoaded[ID - 1] =
8542 Trait.ReadKey(M.SelectorLookupTableData + M.SelectorOffsets[Idx], 0);
8543 if (DeserializationListener)
8544 DeserializationListener->SelectorRead(ID, SelectorsLoaded[ID - 1]);
8545 }
8546
8547 return SelectorsLoaded[ID - 1];
8548 }
8549
GetExternalSelector(serialization::SelectorID ID)8550 Selector ASTReader::GetExternalSelector(serialization::SelectorID ID) {
8551 return DecodeSelector(ID);
8552 }
8553
GetNumExternalSelectors()8554 uint32_t ASTReader::GetNumExternalSelectors() {
8555 // ID 0 (the null selector) is considered an external selector.
8556 return getTotalNumSelectors() + 1;
8557 }
8558
8559 serialization::SelectorID
getGlobalSelectorID(ModuleFile & M,unsigned LocalID) const8560 ASTReader::getGlobalSelectorID(ModuleFile &M, unsigned LocalID) const {
8561 if (LocalID < NUM_PREDEF_SELECTOR_IDS)
8562 return LocalID;
8563
8564 if (!M.ModuleOffsetMap.empty())
8565 ReadModuleOffsetMap(M);
8566
8567 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8568 = M.SelectorRemap.find(LocalID - NUM_PREDEF_SELECTOR_IDS);
8569 assert(I != M.SelectorRemap.end()
8570 && "Invalid index into selector index remap");
8571
8572 return LocalID + I->second;
8573 }
8574
8575 DeclarationNameLoc
readDeclarationNameLoc(DeclarationName Name)8576 ASTRecordReader::readDeclarationNameLoc(DeclarationName Name) {
8577 DeclarationNameLoc DNLoc;
8578 switch (Name.getNameKind()) {
8579 case DeclarationName::CXXConstructorName:
8580 case DeclarationName::CXXDestructorName:
8581 case DeclarationName::CXXConversionFunctionName:
8582 DNLoc.NamedType.TInfo = readTypeSourceInfo();
8583 break;
8584
8585 case DeclarationName::CXXOperatorName:
8586 DNLoc.CXXOperatorName.BeginOpNameLoc
8587 = readSourceLocation().getRawEncoding();
8588 DNLoc.CXXOperatorName.EndOpNameLoc
8589 = readSourceLocation().getRawEncoding();
8590 break;
8591
8592 case DeclarationName::CXXLiteralOperatorName:
8593 DNLoc.CXXLiteralOperatorName.OpNameLoc
8594 = readSourceLocation().getRawEncoding();
8595 break;
8596
8597 case DeclarationName::Identifier:
8598 case DeclarationName::ObjCZeroArgSelector:
8599 case DeclarationName::ObjCOneArgSelector:
8600 case DeclarationName::ObjCMultiArgSelector:
8601 case DeclarationName::CXXUsingDirective:
8602 case DeclarationName::CXXDeductionGuideName:
8603 break;
8604 }
8605 return DNLoc;
8606 }
8607
readDeclarationNameInfo()8608 DeclarationNameInfo ASTRecordReader::readDeclarationNameInfo() {
8609 DeclarationNameInfo NameInfo;
8610 NameInfo.setName(readDeclarationName());
8611 NameInfo.setLoc(readSourceLocation());
8612 NameInfo.setInfo(readDeclarationNameLoc(NameInfo.getName()));
8613 return NameInfo;
8614 }
8615
readQualifierInfo(QualifierInfo & Info)8616 void ASTRecordReader::readQualifierInfo(QualifierInfo &Info) {
8617 Info.QualifierLoc = readNestedNameSpecifierLoc();
8618 unsigned NumTPLists = readInt();
8619 Info.NumTemplParamLists = NumTPLists;
8620 if (NumTPLists) {
8621 Info.TemplParamLists =
8622 new (getContext()) TemplateParameterList *[NumTPLists];
8623 for (unsigned i = 0; i != NumTPLists; ++i)
8624 Info.TemplParamLists[i] = readTemplateParameterList();
8625 }
8626 }
8627
8628 TemplateParameterList *
readTemplateParameterList()8629 ASTRecordReader::readTemplateParameterList() {
8630 SourceLocation TemplateLoc = readSourceLocation();
8631 SourceLocation LAngleLoc = readSourceLocation();
8632 SourceLocation RAngleLoc = readSourceLocation();
8633
8634 unsigned NumParams = readInt();
8635 SmallVector<NamedDecl *, 16> Params;
8636 Params.reserve(NumParams);
8637 while (NumParams--)
8638 Params.push_back(readDeclAs<NamedDecl>());
8639
8640 bool HasRequiresClause = readBool();
8641 Expr *RequiresClause = HasRequiresClause ? readExpr() : nullptr;
8642
8643 TemplateParameterList *TemplateParams = TemplateParameterList::Create(
8644 getContext(), TemplateLoc, LAngleLoc, Params, RAngleLoc, RequiresClause);
8645 return TemplateParams;
8646 }
8647
readTemplateArgumentList(SmallVectorImpl<TemplateArgument> & TemplArgs,bool Canonicalize)8648 void ASTRecordReader::readTemplateArgumentList(
8649 SmallVectorImpl<TemplateArgument> &TemplArgs,
8650 bool Canonicalize) {
8651 unsigned NumTemplateArgs = readInt();
8652 TemplArgs.reserve(NumTemplateArgs);
8653 while (NumTemplateArgs--)
8654 TemplArgs.push_back(readTemplateArgument(Canonicalize));
8655 }
8656
8657 /// Read a UnresolvedSet structure.
readUnresolvedSet(LazyASTUnresolvedSet & Set)8658 void ASTRecordReader::readUnresolvedSet(LazyASTUnresolvedSet &Set) {
8659 unsigned NumDecls = readInt();
8660 Set.reserve(getContext(), NumDecls);
8661 while (NumDecls--) {
8662 DeclID ID = readDeclID();
8663 AccessSpecifier AS = (AccessSpecifier) readInt();
8664 Set.addLazyDecl(getContext(), ID, AS);
8665 }
8666 }
8667
8668 CXXBaseSpecifier
readCXXBaseSpecifier()8669 ASTRecordReader::readCXXBaseSpecifier() {
8670 bool isVirtual = readBool();
8671 bool isBaseOfClass = readBool();
8672 AccessSpecifier AS = static_cast<AccessSpecifier>(readInt());
8673 bool inheritConstructors = readBool();
8674 TypeSourceInfo *TInfo = readTypeSourceInfo();
8675 SourceRange Range = readSourceRange();
8676 SourceLocation EllipsisLoc = readSourceLocation();
8677 CXXBaseSpecifier Result(Range, isVirtual, isBaseOfClass, AS, TInfo,
8678 EllipsisLoc);
8679 Result.setInheritConstructors(inheritConstructors);
8680 return Result;
8681 }
8682
8683 CXXCtorInitializer **
readCXXCtorInitializers()8684 ASTRecordReader::readCXXCtorInitializers() {
8685 ASTContext &Context = getContext();
8686 unsigned NumInitializers = readInt();
8687 assert(NumInitializers && "wrote ctor initializers but have no inits");
8688 auto **CtorInitializers = new (Context) CXXCtorInitializer*[NumInitializers];
8689 for (unsigned i = 0; i != NumInitializers; ++i) {
8690 TypeSourceInfo *TInfo = nullptr;
8691 bool IsBaseVirtual = false;
8692 FieldDecl *Member = nullptr;
8693 IndirectFieldDecl *IndirectMember = nullptr;
8694
8695 CtorInitializerType Type = (CtorInitializerType) readInt();
8696 switch (Type) {
8697 case CTOR_INITIALIZER_BASE:
8698 TInfo = readTypeSourceInfo();
8699 IsBaseVirtual = readBool();
8700 break;
8701
8702 case CTOR_INITIALIZER_DELEGATING:
8703 TInfo = readTypeSourceInfo();
8704 break;
8705
8706 case CTOR_INITIALIZER_MEMBER:
8707 Member = readDeclAs<FieldDecl>();
8708 break;
8709
8710 case CTOR_INITIALIZER_INDIRECT_MEMBER:
8711 IndirectMember = readDeclAs<IndirectFieldDecl>();
8712 break;
8713 }
8714
8715 SourceLocation MemberOrEllipsisLoc = readSourceLocation();
8716 Expr *Init = readExpr();
8717 SourceLocation LParenLoc = readSourceLocation();
8718 SourceLocation RParenLoc = readSourceLocation();
8719
8720 CXXCtorInitializer *BOMInit;
8721 if (Type == CTOR_INITIALIZER_BASE)
8722 BOMInit = new (Context)
8723 CXXCtorInitializer(Context, TInfo, IsBaseVirtual, LParenLoc, Init,
8724 RParenLoc, MemberOrEllipsisLoc);
8725 else if (Type == CTOR_INITIALIZER_DELEGATING)
8726 BOMInit = new (Context)
8727 CXXCtorInitializer(Context, TInfo, LParenLoc, Init, RParenLoc);
8728 else if (Member)
8729 BOMInit = new (Context)
8730 CXXCtorInitializer(Context, Member, MemberOrEllipsisLoc, LParenLoc,
8731 Init, RParenLoc);
8732 else
8733 BOMInit = new (Context)
8734 CXXCtorInitializer(Context, IndirectMember, MemberOrEllipsisLoc,
8735 LParenLoc, Init, RParenLoc);
8736
8737 if (/*IsWritten*/readBool()) {
8738 unsigned SourceOrder = readInt();
8739 BOMInit->setSourceOrder(SourceOrder);
8740 }
8741
8742 CtorInitializers[i] = BOMInit;
8743 }
8744
8745 return CtorInitializers;
8746 }
8747
8748 NestedNameSpecifierLoc
readNestedNameSpecifierLoc()8749 ASTRecordReader::readNestedNameSpecifierLoc() {
8750 ASTContext &Context = getContext();
8751 unsigned N = readInt();
8752 NestedNameSpecifierLocBuilder Builder;
8753 for (unsigned I = 0; I != N; ++I) {
8754 auto Kind = readNestedNameSpecifierKind();
8755 switch (Kind) {
8756 case NestedNameSpecifier::Identifier: {
8757 IdentifierInfo *II = readIdentifier();
8758 SourceRange Range = readSourceRange();
8759 Builder.Extend(Context, II, Range.getBegin(), Range.getEnd());
8760 break;
8761 }
8762
8763 case NestedNameSpecifier::Namespace: {
8764 NamespaceDecl *NS = readDeclAs<NamespaceDecl>();
8765 SourceRange Range = readSourceRange();
8766 Builder.Extend(Context, NS, Range.getBegin(), Range.getEnd());
8767 break;
8768 }
8769
8770 case NestedNameSpecifier::NamespaceAlias: {
8771 NamespaceAliasDecl *Alias = readDeclAs<NamespaceAliasDecl>();
8772 SourceRange Range = readSourceRange();
8773 Builder.Extend(Context, Alias, Range.getBegin(), Range.getEnd());
8774 break;
8775 }
8776
8777 case NestedNameSpecifier::TypeSpec:
8778 case NestedNameSpecifier::TypeSpecWithTemplate: {
8779 bool Template = readBool();
8780 TypeSourceInfo *T = readTypeSourceInfo();
8781 if (!T)
8782 return NestedNameSpecifierLoc();
8783 SourceLocation ColonColonLoc = readSourceLocation();
8784
8785 // FIXME: 'template' keyword location not saved anywhere, so we fake it.
8786 Builder.Extend(Context,
8787 Template? T->getTypeLoc().getBeginLoc() : SourceLocation(),
8788 T->getTypeLoc(), ColonColonLoc);
8789 break;
8790 }
8791
8792 case NestedNameSpecifier::Global: {
8793 SourceLocation ColonColonLoc = readSourceLocation();
8794 Builder.MakeGlobal(Context, ColonColonLoc);
8795 break;
8796 }
8797
8798 case NestedNameSpecifier::Super: {
8799 CXXRecordDecl *RD = readDeclAs<CXXRecordDecl>();
8800 SourceRange Range = readSourceRange();
8801 Builder.MakeSuper(Context, RD, Range.getBegin(), Range.getEnd());
8802 break;
8803 }
8804 }
8805 }
8806
8807 return Builder.getWithLocInContext(Context);
8808 }
8809
8810 SourceRange
ReadSourceRange(ModuleFile & F,const RecordData & Record,unsigned & Idx)8811 ASTReader::ReadSourceRange(ModuleFile &F, const RecordData &Record,
8812 unsigned &Idx) {
8813 SourceLocation beg = ReadSourceLocation(F, Record, Idx);
8814 SourceLocation end = ReadSourceLocation(F, Record, Idx);
8815 return SourceRange(beg, end);
8816 }
8817
8818 static FixedPointSemantics
ReadFixedPointSemantics(const SmallVectorImpl<uint64_t> & Record,unsigned & Idx)8819 ReadFixedPointSemantics(const SmallVectorImpl<uint64_t> &Record,
8820 unsigned &Idx) {
8821 unsigned Width = Record[Idx++];
8822 unsigned Scale = Record[Idx++];
8823 uint64_t Tmp = Record[Idx++];
8824 bool IsSigned = Tmp & 0x1;
8825 bool IsSaturated = Tmp & 0x2;
8826 bool HasUnsignedPadding = Tmp & 0x4;
8827 return FixedPointSemantics(Width, Scale, IsSigned, IsSaturated,
8828 HasUnsignedPadding);
8829 }
8830
8831 static const llvm::fltSemantics &
readAPFloatSemantics(ASTRecordReader & reader)8832 readAPFloatSemantics(ASTRecordReader &reader) {
8833 return llvm::APFloatBase::EnumToSemantics(
8834 static_cast<llvm::APFloatBase::Semantics>(reader.readInt()));
8835 }
8836
readAPValue()8837 APValue ASTRecordReader::readAPValue() {
8838 unsigned Kind = readInt();
8839 switch ((APValue::ValueKind) Kind) {
8840 case APValue::None:
8841 return APValue();
8842 case APValue::Indeterminate:
8843 return APValue::IndeterminateValue();
8844 case APValue::Int:
8845 return APValue(readAPSInt());
8846 case APValue::Float: {
8847 const llvm::fltSemantics &FloatSema = readAPFloatSemantics(*this);
8848 return APValue(readAPFloat(FloatSema));
8849 }
8850 case APValue::FixedPoint: {
8851 FixedPointSemantics FPSema = ReadFixedPointSemantics(Record, Idx);
8852 return APValue(APFixedPoint(readAPInt(), FPSema));
8853 }
8854 case APValue::ComplexInt: {
8855 llvm::APSInt First = readAPSInt();
8856 return APValue(std::move(First), readAPSInt());
8857 }
8858 case APValue::ComplexFloat: {
8859 const llvm::fltSemantics &FloatSema1 = readAPFloatSemantics(*this);
8860 llvm::APFloat First = readAPFloat(FloatSema1);
8861 const llvm::fltSemantics &FloatSema2 = readAPFloatSemantics(*this);
8862 return APValue(std::move(First), readAPFloat(FloatSema2));
8863 }
8864 case APValue::LValue:
8865 case APValue::Vector:
8866 case APValue::Array:
8867 case APValue::Struct:
8868 case APValue::Union:
8869 case APValue::MemberPointer:
8870 case APValue::AddrLabelDiff:
8871 // TODO : Handle all these APValue::ValueKind.
8872 return APValue();
8873 }
8874 llvm_unreachable("Invalid APValue::ValueKind");
8875 }
8876
8877 /// Read a floating-point value
readAPFloat(const llvm::fltSemantics & Sem)8878 llvm::APFloat ASTRecordReader::readAPFloat(const llvm::fltSemantics &Sem) {
8879 return llvm::APFloat(Sem, readAPInt());
8880 }
8881
8882 // Read a string
ReadString(const RecordData & Record,unsigned & Idx)8883 std::string ASTReader::ReadString(const RecordData &Record, unsigned &Idx) {
8884 unsigned Len = Record[Idx++];
8885 std::string Result(Record.data() + Idx, Record.data() + Idx + Len);
8886 Idx += Len;
8887 return Result;
8888 }
8889
ReadPath(ModuleFile & F,const RecordData & Record,unsigned & Idx)8890 std::string ASTReader::ReadPath(ModuleFile &F, const RecordData &Record,
8891 unsigned &Idx) {
8892 std::string Filename = ReadString(Record, Idx);
8893 ResolveImportedPath(F, Filename);
8894 return Filename;
8895 }
8896
ReadPath(StringRef BaseDirectory,const RecordData & Record,unsigned & Idx)8897 std::string ASTReader::ReadPath(StringRef BaseDirectory,
8898 const RecordData &Record, unsigned &Idx) {
8899 std::string Filename = ReadString(Record, Idx);
8900 if (!BaseDirectory.empty())
8901 ResolveImportedPath(Filename, BaseDirectory);
8902 return Filename;
8903 }
8904
ReadVersionTuple(const RecordData & Record,unsigned & Idx)8905 VersionTuple ASTReader::ReadVersionTuple(const RecordData &Record,
8906 unsigned &Idx) {
8907 unsigned Major = Record[Idx++];
8908 unsigned Minor = Record[Idx++];
8909 unsigned Subminor = Record[Idx++];
8910 if (Minor == 0)
8911 return VersionTuple(Major);
8912 if (Subminor == 0)
8913 return VersionTuple(Major, Minor - 1);
8914 return VersionTuple(Major, Minor - 1, Subminor - 1);
8915 }
8916
ReadCXXTemporary(ModuleFile & F,const RecordData & Record,unsigned & Idx)8917 CXXTemporary *ASTReader::ReadCXXTemporary(ModuleFile &F,
8918 const RecordData &Record,
8919 unsigned &Idx) {
8920 CXXDestructorDecl *Decl = ReadDeclAs<CXXDestructorDecl>(F, Record, Idx);
8921 return CXXTemporary::Create(getContext(), Decl);
8922 }
8923
Diag(unsigned DiagID) const8924 DiagnosticBuilder ASTReader::Diag(unsigned DiagID) const {
8925 return Diag(CurrentImportLoc, DiagID);
8926 }
8927
Diag(SourceLocation Loc,unsigned DiagID) const8928 DiagnosticBuilder ASTReader::Diag(SourceLocation Loc, unsigned DiagID) const {
8929 return Diags.Report(Loc, DiagID);
8930 }
8931
8932 /// Retrieve the identifier table associated with the
8933 /// preprocessor.
getIdentifierTable()8934 IdentifierTable &ASTReader::getIdentifierTable() {
8935 return PP.getIdentifierTable();
8936 }
8937
8938 /// Record that the given ID maps to the given switch-case
8939 /// statement.
RecordSwitchCaseID(SwitchCase * SC,unsigned ID)8940 void ASTReader::RecordSwitchCaseID(SwitchCase *SC, unsigned ID) {
8941 assert((*CurrSwitchCaseStmts)[ID] == nullptr &&
8942 "Already have a SwitchCase with this ID");
8943 (*CurrSwitchCaseStmts)[ID] = SC;
8944 }
8945
8946 /// Retrieve the switch-case statement with the given ID.
getSwitchCaseWithID(unsigned ID)8947 SwitchCase *ASTReader::getSwitchCaseWithID(unsigned ID) {
8948 assert((*CurrSwitchCaseStmts)[ID] != nullptr && "No SwitchCase with this ID");
8949 return (*CurrSwitchCaseStmts)[ID];
8950 }
8951
ClearSwitchCaseIDs()8952 void ASTReader::ClearSwitchCaseIDs() {
8953 CurrSwitchCaseStmts->clear();
8954 }
8955
ReadComments()8956 void ASTReader::ReadComments() {
8957 ASTContext &Context = getContext();
8958 std::vector<RawComment *> Comments;
8959 for (SmallVectorImpl<std::pair<BitstreamCursor,
8960 serialization::ModuleFile *>>::iterator
8961 I = CommentsCursors.begin(),
8962 E = CommentsCursors.end();
8963 I != E; ++I) {
8964 Comments.clear();
8965 BitstreamCursor &Cursor = I->first;
8966 serialization::ModuleFile &F = *I->second;
8967 SavedStreamPosition SavedPosition(Cursor);
8968
8969 RecordData Record;
8970 while (true) {
8971 Expected<llvm::BitstreamEntry> MaybeEntry =
8972 Cursor.advanceSkippingSubblocks(
8973 BitstreamCursor::AF_DontPopBlockAtEnd);
8974 if (!MaybeEntry) {
8975 Error(MaybeEntry.takeError());
8976 return;
8977 }
8978 llvm::BitstreamEntry Entry = MaybeEntry.get();
8979
8980 switch (Entry.Kind) {
8981 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
8982 case llvm::BitstreamEntry::Error:
8983 Error("malformed block record in AST file");
8984 return;
8985 case llvm::BitstreamEntry::EndBlock:
8986 goto NextCursor;
8987 case llvm::BitstreamEntry::Record:
8988 // The interesting case.
8989 break;
8990 }
8991
8992 // Read a record.
8993 Record.clear();
8994 Expected<unsigned> MaybeComment = Cursor.readRecord(Entry.ID, Record);
8995 if (!MaybeComment) {
8996 Error(MaybeComment.takeError());
8997 return;
8998 }
8999 switch ((CommentRecordTypes)MaybeComment.get()) {
9000 case COMMENTS_RAW_COMMENT: {
9001 unsigned Idx = 0;
9002 SourceRange SR = ReadSourceRange(F, Record, Idx);
9003 RawComment::CommentKind Kind =
9004 (RawComment::CommentKind) Record[Idx++];
9005 bool IsTrailingComment = Record[Idx++];
9006 bool IsAlmostTrailingComment = Record[Idx++];
9007 Comments.push_back(new (Context) RawComment(
9008 SR, Kind, IsTrailingComment, IsAlmostTrailingComment));
9009 break;
9010 }
9011 }
9012 }
9013 NextCursor:
9014 llvm::DenseMap<FileID, std::map<unsigned, RawComment *>>
9015 FileToOffsetToComment;
9016 for (RawComment *C : Comments) {
9017 SourceLocation CommentLoc = C->getBeginLoc();
9018 if (CommentLoc.isValid()) {
9019 std::pair<FileID, unsigned> Loc =
9020 SourceMgr.getDecomposedLoc(CommentLoc);
9021 if (Loc.first.isValid())
9022 Context.Comments.OrderedComments[Loc.first].emplace(Loc.second, C);
9023 }
9024 }
9025 }
9026 }
9027
visitInputFiles(serialization::ModuleFile & MF,bool IncludeSystem,bool Complain,llvm::function_ref<void (const serialization::InputFile & IF,bool isSystem)> Visitor)9028 void ASTReader::visitInputFiles(serialization::ModuleFile &MF,
9029 bool IncludeSystem, bool Complain,
9030 llvm::function_ref<void(const serialization::InputFile &IF,
9031 bool isSystem)> Visitor) {
9032 unsigned NumUserInputs = MF.NumUserInputFiles;
9033 unsigned NumInputs = MF.InputFilesLoaded.size();
9034 assert(NumUserInputs <= NumInputs);
9035 unsigned N = IncludeSystem ? NumInputs : NumUserInputs;
9036 for (unsigned I = 0; I < N; ++I) {
9037 bool IsSystem = I >= NumUserInputs;
9038 InputFile IF = getInputFile(MF, I+1, Complain);
9039 Visitor(IF, IsSystem);
9040 }
9041 }
9042
visitTopLevelModuleMaps(serialization::ModuleFile & MF,llvm::function_ref<void (const FileEntry * FE)> Visitor)9043 void ASTReader::visitTopLevelModuleMaps(
9044 serialization::ModuleFile &MF,
9045 llvm::function_ref<void(const FileEntry *FE)> Visitor) {
9046 unsigned NumInputs = MF.InputFilesLoaded.size();
9047 for (unsigned I = 0; I < NumInputs; ++I) {
9048 InputFileInfo IFI = readInputFileInfo(MF, I + 1);
9049 if (IFI.TopLevelModuleMap)
9050 // FIXME: This unnecessarily re-reads the InputFileInfo.
9051 if (auto *FE = getInputFile(MF, I + 1).getFile())
9052 Visitor(FE);
9053 }
9054 }
9055
getOwningModuleNameForDiagnostic(const Decl * D)9056 std::string ASTReader::getOwningModuleNameForDiagnostic(const Decl *D) {
9057 // If we know the owning module, use it.
9058 if (Module *M = D->getImportedOwningModule())
9059 return M->getFullModuleName();
9060
9061 // Otherwise, use the name of the top-level module the decl is within.
9062 if (ModuleFile *M = getOwningModuleFile(D))
9063 return M->ModuleName;
9064
9065 // Not from a module.
9066 return {};
9067 }
9068
finishPendingActions()9069 void ASTReader::finishPendingActions() {
9070 while (!PendingIdentifierInfos.empty() || !PendingFunctionTypes.empty() ||
9071 !PendingIncompleteDeclChains.empty() || !PendingDeclChains.empty() ||
9072 !PendingMacroIDs.empty() || !PendingDeclContextInfos.empty() ||
9073 !PendingUpdateRecords.empty()) {
9074 // If any identifiers with corresponding top-level declarations have
9075 // been loaded, load those declarations now.
9076 using TopLevelDeclsMap =
9077 llvm::DenseMap<IdentifierInfo *, SmallVector<Decl *, 2>>;
9078 TopLevelDeclsMap TopLevelDecls;
9079
9080 while (!PendingIdentifierInfos.empty()) {
9081 IdentifierInfo *II = PendingIdentifierInfos.back().first;
9082 SmallVector<uint32_t, 4> DeclIDs =
9083 std::move(PendingIdentifierInfos.back().second);
9084 PendingIdentifierInfos.pop_back();
9085
9086 SetGloballyVisibleDecls(II, DeclIDs, &TopLevelDecls[II]);
9087 }
9088
9089 // Load each function type that we deferred loading because it was a
9090 // deduced type that might refer to a local type declared within itself.
9091 for (unsigned I = 0; I != PendingFunctionTypes.size(); ++I) {
9092 auto *FD = PendingFunctionTypes[I].first;
9093 FD->setType(GetType(PendingFunctionTypes[I].second));
9094
9095 // If we gave a function a deduced return type, remember that we need to
9096 // propagate that along the redeclaration chain.
9097 auto *DT = FD->getReturnType()->getContainedDeducedType();
9098 if (DT && DT->isDeduced())
9099 PendingDeducedTypeUpdates.insert(
9100 {FD->getCanonicalDecl(), FD->getReturnType()});
9101 }
9102 PendingFunctionTypes.clear();
9103
9104 // For each decl chain that we wanted to complete while deserializing, mark
9105 // it as "still needs to be completed".
9106 for (unsigned I = 0; I != PendingIncompleteDeclChains.size(); ++I) {
9107 markIncompleteDeclChain(PendingIncompleteDeclChains[I]);
9108 }
9109 PendingIncompleteDeclChains.clear();
9110
9111 // Load pending declaration chains.
9112 for (unsigned I = 0; I != PendingDeclChains.size(); ++I)
9113 loadPendingDeclChain(PendingDeclChains[I].first,
9114 PendingDeclChains[I].second);
9115 PendingDeclChains.clear();
9116
9117 // Make the most recent of the top-level declarations visible.
9118 for (TopLevelDeclsMap::iterator TLD = TopLevelDecls.begin(),
9119 TLDEnd = TopLevelDecls.end(); TLD != TLDEnd; ++TLD) {
9120 IdentifierInfo *II = TLD->first;
9121 for (unsigned I = 0, N = TLD->second.size(); I != N; ++I) {
9122 pushExternalDeclIntoScope(cast<NamedDecl>(TLD->second[I]), II);
9123 }
9124 }
9125
9126 // Load any pending macro definitions.
9127 for (unsigned I = 0; I != PendingMacroIDs.size(); ++I) {
9128 IdentifierInfo *II = PendingMacroIDs.begin()[I].first;
9129 SmallVector<PendingMacroInfo, 2> GlobalIDs;
9130 GlobalIDs.swap(PendingMacroIDs.begin()[I].second);
9131 // Initialize the macro history from chained-PCHs ahead of module imports.
9132 for (unsigned IDIdx = 0, NumIDs = GlobalIDs.size(); IDIdx != NumIDs;
9133 ++IDIdx) {
9134 const PendingMacroInfo &Info = GlobalIDs[IDIdx];
9135 if (!Info.M->isModule())
9136 resolvePendingMacro(II, Info);
9137 }
9138 // Handle module imports.
9139 for (unsigned IDIdx = 0, NumIDs = GlobalIDs.size(); IDIdx != NumIDs;
9140 ++IDIdx) {
9141 const PendingMacroInfo &Info = GlobalIDs[IDIdx];
9142 if (Info.M->isModule())
9143 resolvePendingMacro(II, Info);
9144 }
9145 }
9146 PendingMacroIDs.clear();
9147
9148 // Wire up the DeclContexts for Decls that we delayed setting until
9149 // recursive loading is completed.
9150 while (!PendingDeclContextInfos.empty()) {
9151 PendingDeclContextInfo Info = PendingDeclContextInfos.front();
9152 PendingDeclContextInfos.pop_front();
9153 DeclContext *SemaDC = cast<DeclContext>(GetDecl(Info.SemaDC));
9154 DeclContext *LexicalDC = cast<DeclContext>(GetDecl(Info.LexicalDC));
9155 Info.D->setDeclContextsImpl(SemaDC, LexicalDC, getContext());
9156 }
9157
9158 // Perform any pending declaration updates.
9159 while (!PendingUpdateRecords.empty()) {
9160 auto Update = PendingUpdateRecords.pop_back_val();
9161 ReadingKindTracker ReadingKind(Read_Decl, *this);
9162 loadDeclUpdateRecords(Update);
9163 }
9164 }
9165
9166 // At this point, all update records for loaded decls are in place, so any
9167 // fake class definitions should have become real.
9168 assert(PendingFakeDefinitionData.empty() &&
9169 "faked up a class definition but never saw the real one");
9170
9171 // If we deserialized any C++ or Objective-C class definitions, any
9172 // Objective-C protocol definitions, or any redeclarable templates, make sure
9173 // that all redeclarations point to the definitions. Note that this can only
9174 // happen now, after the redeclaration chains have been fully wired.
9175 for (Decl *D : PendingDefinitions) {
9176 if (TagDecl *TD = dyn_cast<TagDecl>(D)) {
9177 if (const TagType *TagT = dyn_cast<TagType>(TD->getTypeForDecl())) {
9178 // Make sure that the TagType points at the definition.
9179 const_cast<TagType*>(TagT)->decl = TD;
9180 }
9181
9182 if (auto RD = dyn_cast<CXXRecordDecl>(D)) {
9183 for (auto *R = getMostRecentExistingDecl(RD); R;
9184 R = R->getPreviousDecl()) {
9185 assert((R == D) ==
9186 cast<CXXRecordDecl>(R)->isThisDeclarationADefinition() &&
9187 "declaration thinks it's the definition but it isn't");
9188 cast<CXXRecordDecl>(R)->DefinitionData = RD->DefinitionData;
9189 }
9190 }
9191
9192 continue;
9193 }
9194
9195 if (auto ID = dyn_cast<ObjCInterfaceDecl>(D)) {
9196 // Make sure that the ObjCInterfaceType points at the definition.
9197 const_cast<ObjCInterfaceType *>(cast<ObjCInterfaceType>(ID->TypeForDecl))
9198 ->Decl = ID;
9199
9200 for (auto *R = getMostRecentExistingDecl(ID); R; R = R->getPreviousDecl())
9201 cast<ObjCInterfaceDecl>(R)->Data = ID->Data;
9202
9203 continue;
9204 }
9205
9206 if (auto PD = dyn_cast<ObjCProtocolDecl>(D)) {
9207 for (auto *R = getMostRecentExistingDecl(PD); R; R = R->getPreviousDecl())
9208 cast<ObjCProtocolDecl>(R)->Data = PD->Data;
9209
9210 continue;
9211 }
9212
9213 auto RTD = cast<RedeclarableTemplateDecl>(D)->getCanonicalDecl();
9214 for (auto *R = getMostRecentExistingDecl(RTD); R; R = R->getPreviousDecl())
9215 cast<RedeclarableTemplateDecl>(R)->Common = RTD->Common;
9216 }
9217 PendingDefinitions.clear();
9218
9219 // Load the bodies of any functions or methods we've encountered. We do
9220 // this now (delayed) so that we can be sure that the declaration chains
9221 // have been fully wired up (hasBody relies on this).
9222 // FIXME: We shouldn't require complete redeclaration chains here.
9223 for (PendingBodiesMap::iterator PB = PendingBodies.begin(),
9224 PBEnd = PendingBodies.end();
9225 PB != PBEnd; ++PB) {
9226 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(PB->first)) {
9227 // For a function defined inline within a class template, force the
9228 // canonical definition to be the one inside the canonical definition of
9229 // the template. This ensures that we instantiate from a correct view
9230 // of the template.
9231 //
9232 // Sadly we can't do this more generally: we can't be sure that all
9233 // copies of an arbitrary class definition will have the same members
9234 // defined (eg, some member functions may not be instantiated, and some
9235 // special members may or may not have been implicitly defined).
9236 if (auto *RD = dyn_cast<CXXRecordDecl>(FD->getLexicalParent()))
9237 if (RD->isDependentContext() && !RD->isThisDeclarationADefinition())
9238 continue;
9239
9240 // FIXME: Check for =delete/=default?
9241 // FIXME: Complain about ODR violations here?
9242 const FunctionDecl *Defn = nullptr;
9243 if (!getContext().getLangOpts().Modules || !FD->hasBody(Defn)) {
9244 FD->setLazyBody(PB->second);
9245 } else {
9246 auto *NonConstDefn = const_cast<FunctionDecl*>(Defn);
9247 mergeDefinitionVisibility(NonConstDefn, FD);
9248
9249 if (!FD->isLateTemplateParsed() &&
9250 !NonConstDefn->isLateTemplateParsed() &&
9251 FD->getODRHash() != NonConstDefn->getODRHash()) {
9252 if (!isa<CXXMethodDecl>(FD)) {
9253 PendingFunctionOdrMergeFailures[FD].push_back(NonConstDefn);
9254 } else if (FD->getLexicalParent()->isFileContext() &&
9255 NonConstDefn->getLexicalParent()->isFileContext()) {
9256 // Only diagnose out-of-line method definitions. If they are
9257 // in class definitions, then an error will be generated when
9258 // processing the class bodies.
9259 PendingFunctionOdrMergeFailures[FD].push_back(NonConstDefn);
9260 }
9261 }
9262 }
9263 continue;
9264 }
9265
9266 ObjCMethodDecl *MD = cast<ObjCMethodDecl>(PB->first);
9267 if (!getContext().getLangOpts().Modules || !MD->hasBody())
9268 MD->setLazyBody(PB->second);
9269 }
9270 PendingBodies.clear();
9271
9272 // Do some cleanup.
9273 for (auto *ND : PendingMergedDefinitionsToDeduplicate)
9274 getContext().deduplicateMergedDefinitonsFor(ND);
9275 PendingMergedDefinitionsToDeduplicate.clear();
9276 }
9277
diagnoseOdrViolations()9278 void ASTReader::diagnoseOdrViolations() {
9279 if (PendingOdrMergeFailures.empty() && PendingOdrMergeChecks.empty() &&
9280 PendingFunctionOdrMergeFailures.empty() &&
9281 PendingEnumOdrMergeFailures.empty())
9282 return;
9283
9284 // Trigger the import of the full definition of each class that had any
9285 // odr-merging problems, so we can produce better diagnostics for them.
9286 // These updates may in turn find and diagnose some ODR failures, so take
9287 // ownership of the set first.
9288 auto OdrMergeFailures = std::move(PendingOdrMergeFailures);
9289 PendingOdrMergeFailures.clear();
9290 for (auto &Merge : OdrMergeFailures) {
9291 Merge.first->buildLookup();
9292 Merge.first->decls_begin();
9293 Merge.first->bases_begin();
9294 Merge.first->vbases_begin();
9295 for (auto &RecordPair : Merge.second) {
9296 auto *RD = RecordPair.first;
9297 RD->decls_begin();
9298 RD->bases_begin();
9299 RD->vbases_begin();
9300 }
9301 }
9302
9303 // Trigger the import of functions.
9304 auto FunctionOdrMergeFailures = std::move(PendingFunctionOdrMergeFailures);
9305 PendingFunctionOdrMergeFailures.clear();
9306 for (auto &Merge : FunctionOdrMergeFailures) {
9307 Merge.first->buildLookup();
9308 Merge.first->decls_begin();
9309 Merge.first->getBody();
9310 for (auto &FD : Merge.second) {
9311 FD->buildLookup();
9312 FD->decls_begin();
9313 FD->getBody();
9314 }
9315 }
9316
9317 // Trigger the import of enums.
9318 auto EnumOdrMergeFailures = std::move(PendingEnumOdrMergeFailures);
9319 PendingEnumOdrMergeFailures.clear();
9320 for (auto &Merge : EnumOdrMergeFailures) {
9321 Merge.first->decls_begin();
9322 for (auto &Enum : Merge.second) {
9323 Enum->decls_begin();
9324 }
9325 }
9326
9327 // For each declaration from a merged context, check that the canonical
9328 // definition of that context also contains a declaration of the same
9329 // entity.
9330 //
9331 // Caution: this loop does things that might invalidate iterators into
9332 // PendingOdrMergeChecks. Don't turn this into a range-based for loop!
9333 while (!PendingOdrMergeChecks.empty()) {
9334 NamedDecl *D = PendingOdrMergeChecks.pop_back_val();
9335
9336 // FIXME: Skip over implicit declarations for now. This matters for things
9337 // like implicitly-declared special member functions. This isn't entirely
9338 // correct; we can end up with multiple unmerged declarations of the same
9339 // implicit entity.
9340 if (D->isImplicit())
9341 continue;
9342
9343 DeclContext *CanonDef = D->getDeclContext();
9344
9345 bool Found = false;
9346 const Decl *DCanon = D->getCanonicalDecl();
9347
9348 for (auto RI : D->redecls()) {
9349 if (RI->getLexicalDeclContext() == CanonDef) {
9350 Found = true;
9351 break;
9352 }
9353 }
9354 if (Found)
9355 continue;
9356
9357 // Quick check failed, time to do the slow thing. Note, we can't just
9358 // look up the name of D in CanonDef here, because the member that is
9359 // in CanonDef might not be found by name lookup (it might have been
9360 // replaced by a more recent declaration in the lookup table), and we
9361 // can't necessarily find it in the redeclaration chain because it might
9362 // be merely mergeable, not redeclarable.
9363 llvm::SmallVector<const NamedDecl*, 4> Candidates;
9364 for (auto *CanonMember : CanonDef->decls()) {
9365 if (CanonMember->getCanonicalDecl() == DCanon) {
9366 // This can happen if the declaration is merely mergeable and not
9367 // actually redeclarable (we looked for redeclarations earlier).
9368 //
9369 // FIXME: We should be able to detect this more efficiently, without
9370 // pulling in all of the members of CanonDef.
9371 Found = true;
9372 break;
9373 }
9374 if (auto *ND = dyn_cast<NamedDecl>(CanonMember))
9375 if (ND->getDeclName() == D->getDeclName())
9376 Candidates.push_back(ND);
9377 }
9378
9379 if (!Found) {
9380 // The AST doesn't like TagDecls becoming invalid after they've been
9381 // completed. We only really need to mark FieldDecls as invalid here.
9382 if (!isa<TagDecl>(D))
9383 D->setInvalidDecl();
9384
9385 // Ensure we don't accidentally recursively enter deserialization while
9386 // we're producing our diagnostic.
9387 Deserializing RecursionGuard(this);
9388
9389 std::string CanonDefModule =
9390 getOwningModuleNameForDiagnostic(cast<Decl>(CanonDef));
9391 Diag(D->getLocation(), diag::err_module_odr_violation_missing_decl)
9392 << D << getOwningModuleNameForDiagnostic(D)
9393 << CanonDef << CanonDefModule.empty() << CanonDefModule;
9394
9395 if (Candidates.empty())
9396 Diag(cast<Decl>(CanonDef)->getLocation(),
9397 diag::note_module_odr_violation_no_possible_decls) << D;
9398 else {
9399 for (unsigned I = 0, N = Candidates.size(); I != N; ++I)
9400 Diag(Candidates[I]->getLocation(),
9401 diag::note_module_odr_violation_possible_decl)
9402 << Candidates[I];
9403 }
9404
9405 DiagnosedOdrMergeFailures.insert(CanonDef);
9406 }
9407 }
9408
9409 if (OdrMergeFailures.empty() && FunctionOdrMergeFailures.empty() &&
9410 EnumOdrMergeFailures.empty())
9411 return;
9412
9413 // Ensure we don't accidentally recursively enter deserialization while
9414 // we're producing our diagnostics.
9415 Deserializing RecursionGuard(this);
9416
9417 // Common code for hashing helpers.
9418 ODRHash Hash;
9419 auto ComputeQualTypeODRHash = [&Hash](QualType Ty) {
9420 Hash.clear();
9421 Hash.AddQualType(Ty);
9422 return Hash.CalculateHash();
9423 };
9424
9425 auto ComputeODRHash = [&Hash](const Stmt *S) {
9426 assert(S);
9427 Hash.clear();
9428 Hash.AddStmt(S);
9429 return Hash.CalculateHash();
9430 };
9431
9432 auto ComputeSubDeclODRHash = [&Hash](const Decl *D) {
9433 assert(D);
9434 Hash.clear();
9435 Hash.AddSubDecl(D);
9436 return Hash.CalculateHash();
9437 };
9438
9439 auto ComputeTemplateArgumentODRHash = [&Hash](const TemplateArgument &TA) {
9440 Hash.clear();
9441 Hash.AddTemplateArgument(TA);
9442 return Hash.CalculateHash();
9443 };
9444
9445 auto ComputeTemplateParameterListODRHash =
9446 [&Hash](const TemplateParameterList *TPL) {
9447 assert(TPL);
9448 Hash.clear();
9449 Hash.AddTemplateParameterList(TPL);
9450 return Hash.CalculateHash();
9451 };
9452
9453 // Issue any pending ODR-failure diagnostics.
9454 for (auto &Merge : OdrMergeFailures) {
9455 // If we've already pointed out a specific problem with this class, don't
9456 // bother issuing a general "something's different" diagnostic.
9457 if (!DiagnosedOdrMergeFailures.insert(Merge.first).second)
9458 continue;
9459
9460 bool Diagnosed = false;
9461 CXXRecordDecl *FirstRecord = Merge.first;
9462 std::string FirstModule = getOwningModuleNameForDiagnostic(FirstRecord);
9463 for (auto &RecordPair : Merge.second) {
9464 CXXRecordDecl *SecondRecord = RecordPair.first;
9465 // Multiple different declarations got merged together; tell the user
9466 // where they came from.
9467 if (FirstRecord == SecondRecord)
9468 continue;
9469
9470 std::string SecondModule = getOwningModuleNameForDiagnostic(SecondRecord);
9471
9472 auto *FirstDD = FirstRecord->DefinitionData;
9473 auto *SecondDD = RecordPair.second;
9474
9475 assert(FirstDD && SecondDD && "Definitions without DefinitionData");
9476
9477 // Diagnostics from DefinitionData are emitted here.
9478 if (FirstDD != SecondDD) {
9479 enum ODRDefinitionDataDifference {
9480 NumBases,
9481 NumVBases,
9482 BaseType,
9483 BaseVirtual,
9484 BaseAccess,
9485 };
9486 auto ODRDiagError = [FirstRecord, &FirstModule,
9487 this](SourceLocation Loc, SourceRange Range,
9488 ODRDefinitionDataDifference DiffType) {
9489 return Diag(Loc, diag::err_module_odr_violation_definition_data)
9490 << FirstRecord << FirstModule.empty() << FirstModule << Range
9491 << DiffType;
9492 };
9493 auto ODRDiagNote = [&SecondModule,
9494 this](SourceLocation Loc, SourceRange Range,
9495 ODRDefinitionDataDifference DiffType) {
9496 return Diag(Loc, diag::note_module_odr_violation_definition_data)
9497 << SecondModule << Range << DiffType;
9498 };
9499
9500 unsigned FirstNumBases = FirstDD->NumBases;
9501 unsigned FirstNumVBases = FirstDD->NumVBases;
9502 unsigned SecondNumBases = SecondDD->NumBases;
9503 unsigned SecondNumVBases = SecondDD->NumVBases;
9504
9505 auto GetSourceRange = [](struct CXXRecordDecl::DefinitionData *DD) {
9506 unsigned NumBases = DD->NumBases;
9507 if (NumBases == 0) return SourceRange();
9508 auto bases = DD->bases();
9509 return SourceRange(bases[0].getBeginLoc(),
9510 bases[NumBases - 1].getEndLoc());
9511 };
9512
9513 if (FirstNumBases != SecondNumBases) {
9514 ODRDiagError(FirstRecord->getLocation(), GetSourceRange(FirstDD),
9515 NumBases)
9516 << FirstNumBases;
9517 ODRDiagNote(SecondRecord->getLocation(), GetSourceRange(SecondDD),
9518 NumBases)
9519 << SecondNumBases;
9520 Diagnosed = true;
9521 break;
9522 }
9523
9524 if (FirstNumVBases != SecondNumVBases) {
9525 ODRDiagError(FirstRecord->getLocation(), GetSourceRange(FirstDD),
9526 NumVBases)
9527 << FirstNumVBases;
9528 ODRDiagNote(SecondRecord->getLocation(), GetSourceRange(SecondDD),
9529 NumVBases)
9530 << SecondNumVBases;
9531 Diagnosed = true;
9532 break;
9533 }
9534
9535 auto FirstBases = FirstDD->bases();
9536 auto SecondBases = SecondDD->bases();
9537 unsigned i = 0;
9538 for (i = 0; i < FirstNumBases; ++i) {
9539 auto FirstBase = FirstBases[i];
9540 auto SecondBase = SecondBases[i];
9541 if (ComputeQualTypeODRHash(FirstBase.getType()) !=
9542 ComputeQualTypeODRHash(SecondBase.getType())) {
9543 ODRDiagError(FirstRecord->getLocation(), FirstBase.getSourceRange(),
9544 BaseType)
9545 << (i + 1) << FirstBase.getType();
9546 ODRDiagNote(SecondRecord->getLocation(),
9547 SecondBase.getSourceRange(), BaseType)
9548 << (i + 1) << SecondBase.getType();
9549 break;
9550 }
9551
9552 if (FirstBase.isVirtual() != SecondBase.isVirtual()) {
9553 ODRDiagError(FirstRecord->getLocation(), FirstBase.getSourceRange(),
9554 BaseVirtual)
9555 << (i + 1) << FirstBase.isVirtual() << FirstBase.getType();
9556 ODRDiagNote(SecondRecord->getLocation(),
9557 SecondBase.getSourceRange(), BaseVirtual)
9558 << (i + 1) << SecondBase.isVirtual() << SecondBase.getType();
9559 break;
9560 }
9561
9562 if (FirstBase.getAccessSpecifierAsWritten() !=
9563 SecondBase.getAccessSpecifierAsWritten()) {
9564 ODRDiagError(FirstRecord->getLocation(), FirstBase.getSourceRange(),
9565 BaseAccess)
9566 << (i + 1) << FirstBase.getType()
9567 << (int)FirstBase.getAccessSpecifierAsWritten();
9568 ODRDiagNote(SecondRecord->getLocation(),
9569 SecondBase.getSourceRange(), BaseAccess)
9570 << (i + 1) << SecondBase.getType()
9571 << (int)SecondBase.getAccessSpecifierAsWritten();
9572 break;
9573 }
9574 }
9575
9576 if (i != FirstNumBases) {
9577 Diagnosed = true;
9578 break;
9579 }
9580 }
9581
9582 using DeclHashes = llvm::SmallVector<std::pair<Decl *, unsigned>, 4>;
9583
9584 const ClassTemplateDecl *FirstTemplate =
9585 FirstRecord->getDescribedClassTemplate();
9586 const ClassTemplateDecl *SecondTemplate =
9587 SecondRecord->getDescribedClassTemplate();
9588
9589 assert(!FirstTemplate == !SecondTemplate &&
9590 "Both pointers should be null or non-null");
9591
9592 enum ODRTemplateDifference {
9593 ParamEmptyName,
9594 ParamName,
9595 ParamSingleDefaultArgument,
9596 ParamDifferentDefaultArgument,
9597 };
9598
9599 if (FirstTemplate && SecondTemplate) {
9600 DeclHashes FirstTemplateHashes;
9601 DeclHashes SecondTemplateHashes;
9602
9603 auto PopulateTemplateParameterHashs =
9604 [&ComputeSubDeclODRHash](DeclHashes &Hashes,
9605 const ClassTemplateDecl *TD) {
9606 for (auto *D : TD->getTemplateParameters()->asArray()) {
9607 Hashes.emplace_back(D, ComputeSubDeclODRHash(D));
9608 }
9609 };
9610
9611 PopulateTemplateParameterHashs(FirstTemplateHashes, FirstTemplate);
9612 PopulateTemplateParameterHashs(SecondTemplateHashes, SecondTemplate);
9613
9614 assert(FirstTemplateHashes.size() == SecondTemplateHashes.size() &&
9615 "Number of template parameters should be equal.");
9616
9617 auto FirstIt = FirstTemplateHashes.begin();
9618 auto FirstEnd = FirstTemplateHashes.end();
9619 auto SecondIt = SecondTemplateHashes.begin();
9620 for (; FirstIt != FirstEnd; ++FirstIt, ++SecondIt) {
9621 if (FirstIt->second == SecondIt->second)
9622 continue;
9623
9624 auto ODRDiagError = [FirstRecord, &FirstModule,
9625 this](SourceLocation Loc, SourceRange Range,
9626 ODRTemplateDifference DiffType) {
9627 return Diag(Loc, diag::err_module_odr_violation_template_parameter)
9628 << FirstRecord << FirstModule.empty() << FirstModule << Range
9629 << DiffType;
9630 };
9631 auto ODRDiagNote = [&SecondModule,
9632 this](SourceLocation Loc, SourceRange Range,
9633 ODRTemplateDifference DiffType) {
9634 return Diag(Loc, diag::note_module_odr_violation_template_parameter)
9635 << SecondModule << Range << DiffType;
9636 };
9637
9638 const NamedDecl* FirstDecl = cast<NamedDecl>(FirstIt->first);
9639 const NamedDecl* SecondDecl = cast<NamedDecl>(SecondIt->first);
9640
9641 assert(FirstDecl->getKind() == SecondDecl->getKind() &&
9642 "Parameter Decl's should be the same kind.");
9643
9644 DeclarationName FirstName = FirstDecl->getDeclName();
9645 DeclarationName SecondName = SecondDecl->getDeclName();
9646
9647 if (FirstName != SecondName) {
9648 const bool FirstNameEmpty =
9649 FirstName.isIdentifier() && !FirstName.getAsIdentifierInfo();
9650 const bool SecondNameEmpty =
9651 SecondName.isIdentifier() && !SecondName.getAsIdentifierInfo();
9652 assert((!FirstNameEmpty || !SecondNameEmpty) &&
9653 "Both template parameters cannot be unnamed.");
9654 ODRDiagError(FirstDecl->getLocation(), FirstDecl->getSourceRange(),
9655 FirstNameEmpty ? ParamEmptyName : ParamName)
9656 << FirstName;
9657 ODRDiagNote(SecondDecl->getLocation(), SecondDecl->getSourceRange(),
9658 SecondNameEmpty ? ParamEmptyName : ParamName)
9659 << SecondName;
9660 break;
9661 }
9662
9663 switch (FirstDecl->getKind()) {
9664 default:
9665 llvm_unreachable("Invalid template parameter type.");
9666 case Decl::TemplateTypeParm: {
9667 const auto *FirstParam = cast<TemplateTypeParmDecl>(FirstDecl);
9668 const auto *SecondParam = cast<TemplateTypeParmDecl>(SecondDecl);
9669 const bool HasFirstDefaultArgument =
9670 FirstParam->hasDefaultArgument() &&
9671 !FirstParam->defaultArgumentWasInherited();
9672 const bool HasSecondDefaultArgument =
9673 SecondParam->hasDefaultArgument() &&
9674 !SecondParam->defaultArgumentWasInherited();
9675
9676 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
9677 ODRDiagError(FirstDecl->getLocation(),
9678 FirstDecl->getSourceRange(),
9679 ParamSingleDefaultArgument)
9680 << HasFirstDefaultArgument;
9681 ODRDiagNote(SecondDecl->getLocation(),
9682 SecondDecl->getSourceRange(),
9683 ParamSingleDefaultArgument)
9684 << HasSecondDefaultArgument;
9685 break;
9686 }
9687
9688 assert(HasFirstDefaultArgument && HasSecondDefaultArgument &&
9689 "Expecting default arguments.");
9690
9691 ODRDiagError(FirstDecl->getLocation(), FirstDecl->getSourceRange(),
9692 ParamDifferentDefaultArgument);
9693 ODRDiagNote(SecondDecl->getLocation(), SecondDecl->getSourceRange(),
9694 ParamDifferentDefaultArgument);
9695
9696 break;
9697 }
9698 case Decl::NonTypeTemplateParm: {
9699 const auto *FirstParam = cast<NonTypeTemplateParmDecl>(FirstDecl);
9700 const auto *SecondParam = cast<NonTypeTemplateParmDecl>(SecondDecl);
9701 const bool HasFirstDefaultArgument =
9702 FirstParam->hasDefaultArgument() &&
9703 !FirstParam->defaultArgumentWasInherited();
9704 const bool HasSecondDefaultArgument =
9705 SecondParam->hasDefaultArgument() &&
9706 !SecondParam->defaultArgumentWasInherited();
9707
9708 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
9709 ODRDiagError(FirstDecl->getLocation(),
9710 FirstDecl->getSourceRange(),
9711 ParamSingleDefaultArgument)
9712 << HasFirstDefaultArgument;
9713 ODRDiagNote(SecondDecl->getLocation(),
9714 SecondDecl->getSourceRange(),
9715 ParamSingleDefaultArgument)
9716 << HasSecondDefaultArgument;
9717 break;
9718 }
9719
9720 assert(HasFirstDefaultArgument && HasSecondDefaultArgument &&
9721 "Expecting default arguments.");
9722
9723 ODRDiagError(FirstDecl->getLocation(), FirstDecl->getSourceRange(),
9724 ParamDifferentDefaultArgument);
9725 ODRDiagNote(SecondDecl->getLocation(), SecondDecl->getSourceRange(),
9726 ParamDifferentDefaultArgument);
9727
9728 break;
9729 }
9730 case Decl::TemplateTemplateParm: {
9731 const auto *FirstParam = cast<TemplateTemplateParmDecl>(FirstDecl);
9732 const auto *SecondParam =
9733 cast<TemplateTemplateParmDecl>(SecondDecl);
9734 const bool HasFirstDefaultArgument =
9735 FirstParam->hasDefaultArgument() &&
9736 !FirstParam->defaultArgumentWasInherited();
9737 const bool HasSecondDefaultArgument =
9738 SecondParam->hasDefaultArgument() &&
9739 !SecondParam->defaultArgumentWasInherited();
9740
9741 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
9742 ODRDiagError(FirstDecl->getLocation(),
9743 FirstDecl->getSourceRange(),
9744 ParamSingleDefaultArgument)
9745 << HasFirstDefaultArgument;
9746 ODRDiagNote(SecondDecl->getLocation(),
9747 SecondDecl->getSourceRange(),
9748 ParamSingleDefaultArgument)
9749 << HasSecondDefaultArgument;
9750 break;
9751 }
9752
9753 assert(HasFirstDefaultArgument && HasSecondDefaultArgument &&
9754 "Expecting default arguments.");
9755
9756 ODRDiagError(FirstDecl->getLocation(), FirstDecl->getSourceRange(),
9757 ParamDifferentDefaultArgument);
9758 ODRDiagNote(SecondDecl->getLocation(), SecondDecl->getSourceRange(),
9759 ParamDifferentDefaultArgument);
9760
9761 break;
9762 }
9763 }
9764
9765 break;
9766 }
9767
9768 if (FirstIt != FirstEnd) {
9769 Diagnosed = true;
9770 break;
9771 }
9772 }
9773
9774 DeclHashes FirstHashes;
9775 DeclHashes SecondHashes;
9776
9777 auto PopulateHashes = [&ComputeSubDeclODRHash, FirstRecord](
9778 DeclHashes &Hashes, CXXRecordDecl *Record) {
9779 for (auto *D : Record->decls()) {
9780 // Due to decl merging, the first CXXRecordDecl is the parent of
9781 // Decls in both records.
9782 if (!ODRHash::isWhitelistedDecl(D, FirstRecord))
9783 continue;
9784 Hashes.emplace_back(D, ComputeSubDeclODRHash(D));
9785 }
9786 };
9787 PopulateHashes(FirstHashes, FirstRecord);
9788 PopulateHashes(SecondHashes, SecondRecord);
9789
9790 // Used with err_module_odr_violation_mismatch_decl and
9791 // note_module_odr_violation_mismatch_decl
9792 // This list should be the same Decl's as in ODRHash::isWhiteListedDecl
9793 enum {
9794 EndOfClass,
9795 PublicSpecifer,
9796 PrivateSpecifer,
9797 ProtectedSpecifer,
9798 StaticAssert,
9799 Field,
9800 CXXMethod,
9801 TypeAlias,
9802 TypeDef,
9803 Var,
9804 Friend,
9805 FunctionTemplate,
9806 Other
9807 } FirstDiffType = Other,
9808 SecondDiffType = Other;
9809
9810 auto DifferenceSelector = [](Decl *D) {
9811 assert(D && "valid Decl required");
9812 switch (D->getKind()) {
9813 default:
9814 return Other;
9815 case Decl::AccessSpec:
9816 switch (D->getAccess()) {
9817 case AS_public:
9818 return PublicSpecifer;
9819 case AS_private:
9820 return PrivateSpecifer;
9821 case AS_protected:
9822 return ProtectedSpecifer;
9823 case AS_none:
9824 break;
9825 }
9826 llvm_unreachable("Invalid access specifier");
9827 case Decl::StaticAssert:
9828 return StaticAssert;
9829 case Decl::Field:
9830 return Field;
9831 case Decl::CXXMethod:
9832 case Decl::CXXConstructor:
9833 case Decl::CXXDestructor:
9834 return CXXMethod;
9835 case Decl::TypeAlias:
9836 return TypeAlias;
9837 case Decl::Typedef:
9838 return TypeDef;
9839 case Decl::Var:
9840 return Var;
9841 case Decl::Friend:
9842 return Friend;
9843 case Decl::FunctionTemplate:
9844 return FunctionTemplate;
9845 }
9846 };
9847
9848 Decl *FirstDecl = nullptr;
9849 Decl *SecondDecl = nullptr;
9850 auto FirstIt = FirstHashes.begin();
9851 auto SecondIt = SecondHashes.begin();
9852
9853 // If there is a diagnoseable difference, FirstDiffType and
9854 // SecondDiffType will not be Other and FirstDecl and SecondDecl will be
9855 // filled in if not EndOfClass.
9856 while (FirstIt != FirstHashes.end() || SecondIt != SecondHashes.end()) {
9857 if (FirstIt != FirstHashes.end() && SecondIt != SecondHashes.end() &&
9858 FirstIt->second == SecondIt->second) {
9859 ++FirstIt;
9860 ++SecondIt;
9861 continue;
9862 }
9863
9864 FirstDecl = FirstIt == FirstHashes.end() ? nullptr : FirstIt->first;
9865 SecondDecl = SecondIt == SecondHashes.end() ? nullptr : SecondIt->first;
9866
9867 FirstDiffType = FirstDecl ? DifferenceSelector(FirstDecl) : EndOfClass;
9868 SecondDiffType =
9869 SecondDecl ? DifferenceSelector(SecondDecl) : EndOfClass;
9870
9871 break;
9872 }
9873
9874 if (FirstDiffType == Other || SecondDiffType == Other) {
9875 // Reaching this point means an unexpected Decl was encountered
9876 // or no difference was detected. This causes a generic error
9877 // message to be emitted.
9878 Diag(FirstRecord->getLocation(),
9879 diag::err_module_odr_violation_different_definitions)
9880 << FirstRecord << FirstModule.empty() << FirstModule;
9881
9882 if (FirstDecl) {
9883 Diag(FirstDecl->getLocation(), diag::note_first_module_difference)
9884 << FirstRecord << FirstDecl->getSourceRange();
9885 }
9886
9887 Diag(SecondRecord->getLocation(),
9888 diag::note_module_odr_violation_different_definitions)
9889 << SecondModule;
9890
9891 if (SecondDecl) {
9892 Diag(SecondDecl->getLocation(), diag::note_second_module_difference)
9893 << SecondDecl->getSourceRange();
9894 }
9895
9896 Diagnosed = true;
9897 break;
9898 }
9899
9900 if (FirstDiffType != SecondDiffType) {
9901 SourceLocation FirstLoc;
9902 SourceRange FirstRange;
9903 if (FirstDiffType == EndOfClass) {
9904 FirstLoc = FirstRecord->getBraceRange().getEnd();
9905 } else {
9906 FirstLoc = FirstIt->first->getLocation();
9907 FirstRange = FirstIt->first->getSourceRange();
9908 }
9909 Diag(FirstLoc, diag::err_module_odr_violation_mismatch_decl)
9910 << FirstRecord << FirstModule.empty() << FirstModule << FirstRange
9911 << FirstDiffType;
9912
9913 SourceLocation SecondLoc;
9914 SourceRange SecondRange;
9915 if (SecondDiffType == EndOfClass) {
9916 SecondLoc = SecondRecord->getBraceRange().getEnd();
9917 } else {
9918 SecondLoc = SecondDecl->getLocation();
9919 SecondRange = SecondDecl->getSourceRange();
9920 }
9921 Diag(SecondLoc, diag::note_module_odr_violation_mismatch_decl)
9922 << SecondModule << SecondRange << SecondDiffType;
9923 Diagnosed = true;
9924 break;
9925 }
9926
9927 assert(FirstDiffType == SecondDiffType);
9928
9929 // Used with err_module_odr_violation_mismatch_decl_diff and
9930 // note_module_odr_violation_mismatch_decl_diff
9931 enum ODRDeclDifference {
9932 StaticAssertCondition,
9933 StaticAssertMessage,
9934 StaticAssertOnlyMessage,
9935 FieldName,
9936 FieldTypeName,
9937 FieldSingleBitField,
9938 FieldDifferentWidthBitField,
9939 FieldSingleMutable,
9940 FieldSingleInitializer,
9941 FieldDifferentInitializers,
9942 MethodName,
9943 MethodDeleted,
9944 MethodDefaulted,
9945 MethodVirtual,
9946 MethodStatic,
9947 MethodVolatile,
9948 MethodConst,
9949 MethodInline,
9950 MethodNumberParameters,
9951 MethodParameterType,
9952 MethodParameterName,
9953 MethodParameterSingleDefaultArgument,
9954 MethodParameterDifferentDefaultArgument,
9955 MethodNoTemplateArguments,
9956 MethodDifferentNumberTemplateArguments,
9957 MethodDifferentTemplateArgument,
9958 MethodSingleBody,
9959 MethodDifferentBody,
9960 TypedefName,
9961 TypedefType,
9962 VarName,
9963 VarType,
9964 VarSingleInitializer,
9965 VarDifferentInitializer,
9966 VarConstexpr,
9967 FriendTypeFunction,
9968 FriendType,
9969 FriendFunction,
9970 FunctionTemplateDifferentNumberParameters,
9971 FunctionTemplateParameterDifferentKind,
9972 FunctionTemplateParameterName,
9973 FunctionTemplateParameterSingleDefaultArgument,
9974 FunctionTemplateParameterDifferentDefaultArgument,
9975 FunctionTemplateParameterDifferentType,
9976 FunctionTemplatePackParameter,
9977 };
9978
9979 // These lambdas have the common portions of the ODR diagnostics. This
9980 // has the same return as Diag(), so addition parameters can be passed
9981 // in with operator<<
9982 auto ODRDiagError = [FirstRecord, &FirstModule, this](
9983 SourceLocation Loc, SourceRange Range, ODRDeclDifference DiffType) {
9984 return Diag(Loc, diag::err_module_odr_violation_mismatch_decl_diff)
9985 << FirstRecord << FirstModule.empty() << FirstModule << Range
9986 << DiffType;
9987 };
9988 auto ODRDiagNote = [&SecondModule, this](
9989 SourceLocation Loc, SourceRange Range, ODRDeclDifference DiffType) {
9990 return Diag(Loc, diag::note_module_odr_violation_mismatch_decl_diff)
9991 << SecondModule << Range << DiffType;
9992 };
9993
9994 switch (FirstDiffType) {
9995 case Other:
9996 case EndOfClass:
9997 case PublicSpecifer:
9998 case PrivateSpecifer:
9999 case ProtectedSpecifer:
10000 llvm_unreachable("Invalid diff type");
10001
10002 case StaticAssert: {
10003 StaticAssertDecl *FirstSA = cast<StaticAssertDecl>(FirstDecl);
10004 StaticAssertDecl *SecondSA = cast<StaticAssertDecl>(SecondDecl);
10005
10006 Expr *FirstExpr = FirstSA->getAssertExpr();
10007 Expr *SecondExpr = SecondSA->getAssertExpr();
10008 unsigned FirstODRHash = ComputeODRHash(FirstExpr);
10009 unsigned SecondODRHash = ComputeODRHash(SecondExpr);
10010 if (FirstODRHash != SecondODRHash) {
10011 ODRDiagError(FirstExpr->getBeginLoc(), FirstExpr->getSourceRange(),
10012 StaticAssertCondition);
10013 ODRDiagNote(SecondExpr->getBeginLoc(), SecondExpr->getSourceRange(),
10014 StaticAssertCondition);
10015 Diagnosed = true;
10016 break;
10017 }
10018
10019 StringLiteral *FirstStr = FirstSA->getMessage();
10020 StringLiteral *SecondStr = SecondSA->getMessage();
10021 assert((FirstStr || SecondStr) && "Both messages cannot be empty");
10022 if ((FirstStr && !SecondStr) || (!FirstStr && SecondStr)) {
10023 SourceLocation FirstLoc, SecondLoc;
10024 SourceRange FirstRange, SecondRange;
10025 if (FirstStr) {
10026 FirstLoc = FirstStr->getBeginLoc();
10027 FirstRange = FirstStr->getSourceRange();
10028 } else {
10029 FirstLoc = FirstSA->getBeginLoc();
10030 FirstRange = FirstSA->getSourceRange();
10031 }
10032 if (SecondStr) {
10033 SecondLoc = SecondStr->getBeginLoc();
10034 SecondRange = SecondStr->getSourceRange();
10035 } else {
10036 SecondLoc = SecondSA->getBeginLoc();
10037 SecondRange = SecondSA->getSourceRange();
10038 }
10039 ODRDiagError(FirstLoc, FirstRange, StaticAssertOnlyMessage)
10040 << (FirstStr == nullptr);
10041 ODRDiagNote(SecondLoc, SecondRange, StaticAssertOnlyMessage)
10042 << (SecondStr == nullptr);
10043 Diagnosed = true;
10044 break;
10045 }
10046
10047 if (FirstStr && SecondStr &&
10048 FirstStr->getString() != SecondStr->getString()) {
10049 ODRDiagError(FirstStr->getBeginLoc(), FirstStr->getSourceRange(),
10050 StaticAssertMessage);
10051 ODRDiagNote(SecondStr->getBeginLoc(), SecondStr->getSourceRange(),
10052 StaticAssertMessage);
10053 Diagnosed = true;
10054 break;
10055 }
10056 break;
10057 }
10058 case Field: {
10059 FieldDecl *FirstField = cast<FieldDecl>(FirstDecl);
10060 FieldDecl *SecondField = cast<FieldDecl>(SecondDecl);
10061 IdentifierInfo *FirstII = FirstField->getIdentifier();
10062 IdentifierInfo *SecondII = SecondField->getIdentifier();
10063 if (FirstII->getName() != SecondII->getName()) {
10064 ODRDiagError(FirstField->getLocation(), FirstField->getSourceRange(),
10065 FieldName)
10066 << FirstII;
10067 ODRDiagNote(SecondField->getLocation(), SecondField->getSourceRange(),
10068 FieldName)
10069 << SecondII;
10070
10071 Diagnosed = true;
10072 break;
10073 }
10074
10075 assert(getContext().hasSameType(FirstField->getType(),
10076 SecondField->getType()));
10077
10078 QualType FirstType = FirstField->getType();
10079 QualType SecondType = SecondField->getType();
10080 if (ComputeQualTypeODRHash(FirstType) !=
10081 ComputeQualTypeODRHash(SecondType)) {
10082 ODRDiagError(FirstField->getLocation(), FirstField->getSourceRange(),
10083 FieldTypeName)
10084 << FirstII << FirstType;
10085 ODRDiagNote(SecondField->getLocation(), SecondField->getSourceRange(),
10086 FieldTypeName)
10087 << SecondII << SecondType;
10088
10089 Diagnosed = true;
10090 break;
10091 }
10092
10093 const bool IsFirstBitField = FirstField->isBitField();
10094 const bool IsSecondBitField = SecondField->isBitField();
10095 if (IsFirstBitField != IsSecondBitField) {
10096 ODRDiagError(FirstField->getLocation(), FirstField->getSourceRange(),
10097 FieldSingleBitField)
10098 << FirstII << IsFirstBitField;
10099 ODRDiagNote(SecondField->getLocation(), SecondField->getSourceRange(),
10100 FieldSingleBitField)
10101 << SecondII << IsSecondBitField;
10102 Diagnosed = true;
10103 break;
10104 }
10105
10106 if (IsFirstBitField && IsSecondBitField) {
10107 unsigned FirstBitWidthHash =
10108 ComputeODRHash(FirstField->getBitWidth());
10109 unsigned SecondBitWidthHash =
10110 ComputeODRHash(SecondField->getBitWidth());
10111 if (FirstBitWidthHash != SecondBitWidthHash) {
10112 ODRDiagError(FirstField->getLocation(),
10113 FirstField->getSourceRange(),
10114 FieldDifferentWidthBitField)
10115 << FirstII << FirstField->getBitWidth()->getSourceRange();
10116 ODRDiagNote(SecondField->getLocation(),
10117 SecondField->getSourceRange(),
10118 FieldDifferentWidthBitField)
10119 << SecondII << SecondField->getBitWidth()->getSourceRange();
10120 Diagnosed = true;
10121 break;
10122 }
10123 }
10124
10125 const bool IsFirstMutable = FirstField->isMutable();
10126 const bool IsSecondMutable = SecondField->isMutable();
10127 if (IsFirstMutable != IsSecondMutable) {
10128 ODRDiagError(FirstField->getLocation(), FirstField->getSourceRange(),
10129 FieldSingleMutable)
10130 << FirstII << IsFirstMutable;
10131 ODRDiagNote(SecondField->getLocation(), SecondField->getSourceRange(),
10132 FieldSingleMutable)
10133 << SecondII << IsSecondMutable;
10134 Diagnosed = true;
10135 break;
10136 }
10137
10138 const Expr *FirstInitializer = FirstField->getInClassInitializer();
10139 const Expr *SecondInitializer = SecondField->getInClassInitializer();
10140 if ((!FirstInitializer && SecondInitializer) ||
10141 (FirstInitializer && !SecondInitializer)) {
10142 ODRDiagError(FirstField->getLocation(), FirstField->getSourceRange(),
10143 FieldSingleInitializer)
10144 << FirstII << (FirstInitializer != nullptr);
10145 ODRDiagNote(SecondField->getLocation(), SecondField->getSourceRange(),
10146 FieldSingleInitializer)
10147 << SecondII << (SecondInitializer != nullptr);
10148 Diagnosed = true;
10149 break;
10150 }
10151
10152 if (FirstInitializer && SecondInitializer) {
10153 unsigned FirstInitHash = ComputeODRHash(FirstInitializer);
10154 unsigned SecondInitHash = ComputeODRHash(SecondInitializer);
10155 if (FirstInitHash != SecondInitHash) {
10156 ODRDiagError(FirstField->getLocation(),
10157 FirstField->getSourceRange(),
10158 FieldDifferentInitializers)
10159 << FirstII << FirstInitializer->getSourceRange();
10160 ODRDiagNote(SecondField->getLocation(),
10161 SecondField->getSourceRange(),
10162 FieldDifferentInitializers)
10163 << SecondII << SecondInitializer->getSourceRange();
10164 Diagnosed = true;
10165 break;
10166 }
10167 }
10168
10169 break;
10170 }
10171 case CXXMethod: {
10172 enum {
10173 DiagMethod,
10174 DiagConstructor,
10175 DiagDestructor,
10176 } FirstMethodType,
10177 SecondMethodType;
10178 auto GetMethodTypeForDiagnostics = [](const CXXMethodDecl* D) {
10179 if (isa<CXXConstructorDecl>(D)) return DiagConstructor;
10180 if (isa<CXXDestructorDecl>(D)) return DiagDestructor;
10181 return DiagMethod;
10182 };
10183 const CXXMethodDecl *FirstMethod = cast<CXXMethodDecl>(FirstDecl);
10184 const CXXMethodDecl *SecondMethod = cast<CXXMethodDecl>(SecondDecl);
10185 FirstMethodType = GetMethodTypeForDiagnostics(FirstMethod);
10186 SecondMethodType = GetMethodTypeForDiagnostics(SecondMethod);
10187 auto FirstName = FirstMethod->getDeclName();
10188 auto SecondName = SecondMethod->getDeclName();
10189 if (FirstMethodType != SecondMethodType || FirstName != SecondName) {
10190 ODRDiagError(FirstMethod->getLocation(),
10191 FirstMethod->getSourceRange(), MethodName)
10192 << FirstMethodType << FirstName;
10193 ODRDiagNote(SecondMethod->getLocation(),
10194 SecondMethod->getSourceRange(), MethodName)
10195 << SecondMethodType << SecondName;
10196
10197 Diagnosed = true;
10198 break;
10199 }
10200
10201 const bool FirstDeleted = FirstMethod->isDeletedAsWritten();
10202 const bool SecondDeleted = SecondMethod->isDeletedAsWritten();
10203 if (FirstDeleted != SecondDeleted) {
10204 ODRDiagError(FirstMethod->getLocation(),
10205 FirstMethod->getSourceRange(), MethodDeleted)
10206 << FirstMethodType << FirstName << FirstDeleted;
10207
10208 ODRDiagNote(SecondMethod->getLocation(),
10209 SecondMethod->getSourceRange(), MethodDeleted)
10210 << SecondMethodType << SecondName << SecondDeleted;
10211 Diagnosed = true;
10212 break;
10213 }
10214
10215 const bool FirstDefaulted = FirstMethod->isExplicitlyDefaulted();
10216 const bool SecondDefaulted = SecondMethod->isExplicitlyDefaulted();
10217 if (FirstDefaulted != SecondDefaulted) {
10218 ODRDiagError(FirstMethod->getLocation(),
10219 FirstMethod->getSourceRange(), MethodDefaulted)
10220 << FirstMethodType << FirstName << FirstDefaulted;
10221
10222 ODRDiagNote(SecondMethod->getLocation(),
10223 SecondMethod->getSourceRange(), MethodDefaulted)
10224 << SecondMethodType << SecondName << SecondDefaulted;
10225 Diagnosed = true;
10226 break;
10227 }
10228
10229 const bool FirstVirtual = FirstMethod->isVirtualAsWritten();
10230 const bool SecondVirtual = SecondMethod->isVirtualAsWritten();
10231 const bool FirstPure = FirstMethod->isPure();
10232 const bool SecondPure = SecondMethod->isPure();
10233 if ((FirstVirtual || SecondVirtual) &&
10234 (FirstVirtual != SecondVirtual || FirstPure != SecondPure)) {
10235 ODRDiagError(FirstMethod->getLocation(),
10236 FirstMethod->getSourceRange(), MethodVirtual)
10237 << FirstMethodType << FirstName << FirstPure << FirstVirtual;
10238 ODRDiagNote(SecondMethod->getLocation(),
10239 SecondMethod->getSourceRange(), MethodVirtual)
10240 << SecondMethodType << SecondName << SecondPure << SecondVirtual;
10241 Diagnosed = true;
10242 break;
10243 }
10244
10245 // CXXMethodDecl::isStatic uses the canonical Decl. With Decl merging,
10246 // FirstDecl is the canonical Decl of SecondDecl, so the storage
10247 // class needs to be checked instead.
10248 const auto FirstStorage = FirstMethod->getStorageClass();
10249 const auto SecondStorage = SecondMethod->getStorageClass();
10250 const bool FirstStatic = FirstStorage == SC_Static;
10251 const bool SecondStatic = SecondStorage == SC_Static;
10252 if (FirstStatic != SecondStatic) {
10253 ODRDiagError(FirstMethod->getLocation(),
10254 FirstMethod->getSourceRange(), MethodStatic)
10255 << FirstMethodType << FirstName << FirstStatic;
10256 ODRDiagNote(SecondMethod->getLocation(),
10257 SecondMethod->getSourceRange(), MethodStatic)
10258 << SecondMethodType << SecondName << SecondStatic;
10259 Diagnosed = true;
10260 break;
10261 }
10262
10263 const bool FirstVolatile = FirstMethod->isVolatile();
10264 const bool SecondVolatile = SecondMethod->isVolatile();
10265 if (FirstVolatile != SecondVolatile) {
10266 ODRDiagError(FirstMethod->getLocation(),
10267 FirstMethod->getSourceRange(), MethodVolatile)
10268 << FirstMethodType << FirstName << FirstVolatile;
10269 ODRDiagNote(SecondMethod->getLocation(),
10270 SecondMethod->getSourceRange(), MethodVolatile)
10271 << SecondMethodType << SecondName << SecondVolatile;
10272 Diagnosed = true;
10273 break;
10274 }
10275
10276 const bool FirstConst = FirstMethod->isConst();
10277 const bool SecondConst = SecondMethod->isConst();
10278 if (FirstConst != SecondConst) {
10279 ODRDiagError(FirstMethod->getLocation(),
10280 FirstMethod->getSourceRange(), MethodConst)
10281 << FirstMethodType << FirstName << FirstConst;
10282 ODRDiagNote(SecondMethod->getLocation(),
10283 SecondMethod->getSourceRange(), MethodConst)
10284 << SecondMethodType << SecondName << SecondConst;
10285 Diagnosed = true;
10286 break;
10287 }
10288
10289 const bool FirstInline = FirstMethod->isInlineSpecified();
10290 const bool SecondInline = SecondMethod->isInlineSpecified();
10291 if (FirstInline != SecondInline) {
10292 ODRDiagError(FirstMethod->getLocation(),
10293 FirstMethod->getSourceRange(), MethodInline)
10294 << FirstMethodType << FirstName << FirstInline;
10295 ODRDiagNote(SecondMethod->getLocation(),
10296 SecondMethod->getSourceRange(), MethodInline)
10297 << SecondMethodType << SecondName << SecondInline;
10298 Diagnosed = true;
10299 break;
10300 }
10301
10302 const unsigned FirstNumParameters = FirstMethod->param_size();
10303 const unsigned SecondNumParameters = SecondMethod->param_size();
10304 if (FirstNumParameters != SecondNumParameters) {
10305 ODRDiagError(FirstMethod->getLocation(),
10306 FirstMethod->getSourceRange(), MethodNumberParameters)
10307 << FirstMethodType << FirstName << FirstNumParameters;
10308 ODRDiagNote(SecondMethod->getLocation(),
10309 SecondMethod->getSourceRange(), MethodNumberParameters)
10310 << SecondMethodType << SecondName << SecondNumParameters;
10311 Diagnosed = true;
10312 break;
10313 }
10314
10315 // Need this status boolean to know when break out of the switch.
10316 bool ParameterMismatch = false;
10317 for (unsigned I = 0; I < FirstNumParameters; ++I) {
10318 const ParmVarDecl *FirstParam = FirstMethod->getParamDecl(I);
10319 const ParmVarDecl *SecondParam = SecondMethod->getParamDecl(I);
10320
10321 QualType FirstParamType = FirstParam->getType();
10322 QualType SecondParamType = SecondParam->getType();
10323 if (FirstParamType != SecondParamType &&
10324 ComputeQualTypeODRHash(FirstParamType) !=
10325 ComputeQualTypeODRHash(SecondParamType)) {
10326 if (const DecayedType *ParamDecayedType =
10327 FirstParamType->getAs<DecayedType>()) {
10328 ODRDiagError(FirstMethod->getLocation(),
10329 FirstMethod->getSourceRange(), MethodParameterType)
10330 << FirstMethodType << FirstName << (I + 1) << FirstParamType
10331 << true << ParamDecayedType->getOriginalType();
10332 } else {
10333 ODRDiagError(FirstMethod->getLocation(),
10334 FirstMethod->getSourceRange(), MethodParameterType)
10335 << FirstMethodType << FirstName << (I + 1) << FirstParamType
10336 << false;
10337 }
10338
10339 if (const DecayedType *ParamDecayedType =
10340 SecondParamType->getAs<DecayedType>()) {
10341 ODRDiagNote(SecondMethod->getLocation(),
10342 SecondMethod->getSourceRange(), MethodParameterType)
10343 << SecondMethodType << SecondName << (I + 1)
10344 << SecondParamType << true
10345 << ParamDecayedType->getOriginalType();
10346 } else {
10347 ODRDiagNote(SecondMethod->getLocation(),
10348 SecondMethod->getSourceRange(), MethodParameterType)
10349 << SecondMethodType << SecondName << (I + 1)
10350 << SecondParamType << false;
10351 }
10352 ParameterMismatch = true;
10353 break;
10354 }
10355
10356 DeclarationName FirstParamName = FirstParam->getDeclName();
10357 DeclarationName SecondParamName = SecondParam->getDeclName();
10358 if (FirstParamName != SecondParamName) {
10359 ODRDiagError(FirstMethod->getLocation(),
10360 FirstMethod->getSourceRange(), MethodParameterName)
10361 << FirstMethodType << FirstName << (I + 1) << FirstParamName;
10362 ODRDiagNote(SecondMethod->getLocation(),
10363 SecondMethod->getSourceRange(), MethodParameterName)
10364 << SecondMethodType << SecondName << (I + 1) << SecondParamName;
10365 ParameterMismatch = true;
10366 break;
10367 }
10368
10369 const Expr *FirstInit = FirstParam->getInit();
10370 const Expr *SecondInit = SecondParam->getInit();
10371 if ((FirstInit == nullptr) != (SecondInit == nullptr)) {
10372 ODRDiagError(FirstMethod->getLocation(),
10373 FirstMethod->getSourceRange(),
10374 MethodParameterSingleDefaultArgument)
10375 << FirstMethodType << FirstName << (I + 1)
10376 << (FirstInit == nullptr)
10377 << (FirstInit ? FirstInit->getSourceRange() : SourceRange());
10378 ODRDiagNote(SecondMethod->getLocation(),
10379 SecondMethod->getSourceRange(),
10380 MethodParameterSingleDefaultArgument)
10381 << SecondMethodType << SecondName << (I + 1)
10382 << (SecondInit == nullptr)
10383 << (SecondInit ? SecondInit->getSourceRange() : SourceRange());
10384 ParameterMismatch = true;
10385 break;
10386 }
10387
10388 if (FirstInit && SecondInit &&
10389 ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
10390 ODRDiagError(FirstMethod->getLocation(),
10391 FirstMethod->getSourceRange(),
10392 MethodParameterDifferentDefaultArgument)
10393 << FirstMethodType << FirstName << (I + 1)
10394 << FirstInit->getSourceRange();
10395 ODRDiagNote(SecondMethod->getLocation(),
10396 SecondMethod->getSourceRange(),
10397 MethodParameterDifferentDefaultArgument)
10398 << SecondMethodType << SecondName << (I + 1)
10399 << SecondInit->getSourceRange();
10400 ParameterMismatch = true;
10401 break;
10402
10403 }
10404 }
10405
10406 if (ParameterMismatch) {
10407 Diagnosed = true;
10408 break;
10409 }
10410
10411 const auto *FirstTemplateArgs =
10412 FirstMethod->getTemplateSpecializationArgs();
10413 const auto *SecondTemplateArgs =
10414 SecondMethod->getTemplateSpecializationArgs();
10415
10416 if ((FirstTemplateArgs && !SecondTemplateArgs) ||
10417 (!FirstTemplateArgs && SecondTemplateArgs)) {
10418 ODRDiagError(FirstMethod->getLocation(),
10419 FirstMethod->getSourceRange(), MethodNoTemplateArguments)
10420 << FirstMethodType << FirstName << (FirstTemplateArgs != nullptr);
10421 ODRDiagNote(SecondMethod->getLocation(),
10422 SecondMethod->getSourceRange(), MethodNoTemplateArguments)
10423 << SecondMethodType << SecondName
10424 << (SecondTemplateArgs != nullptr);
10425
10426 Diagnosed = true;
10427 break;
10428 }
10429
10430 if (FirstTemplateArgs && SecondTemplateArgs) {
10431 // Remove pack expansions from argument list.
10432 auto ExpandTemplateArgumentList =
10433 [](const TemplateArgumentList *TAL) {
10434 llvm::SmallVector<const TemplateArgument *, 8> ExpandedList;
10435 for (const TemplateArgument &TA : TAL->asArray()) {
10436 if (TA.getKind() != TemplateArgument::Pack) {
10437 ExpandedList.push_back(&TA);
10438 continue;
10439 }
10440 for (const TemplateArgument &PackTA : TA.getPackAsArray()) {
10441 ExpandedList.push_back(&PackTA);
10442 }
10443 }
10444 return ExpandedList;
10445 };
10446 llvm::SmallVector<const TemplateArgument *, 8> FirstExpandedList =
10447 ExpandTemplateArgumentList(FirstTemplateArgs);
10448 llvm::SmallVector<const TemplateArgument *, 8> SecondExpandedList =
10449 ExpandTemplateArgumentList(SecondTemplateArgs);
10450
10451 if (FirstExpandedList.size() != SecondExpandedList.size()) {
10452 ODRDiagError(FirstMethod->getLocation(),
10453 FirstMethod->getSourceRange(),
10454 MethodDifferentNumberTemplateArguments)
10455 << FirstMethodType << FirstName
10456 << (unsigned)FirstExpandedList.size();
10457 ODRDiagNote(SecondMethod->getLocation(),
10458 SecondMethod->getSourceRange(),
10459 MethodDifferentNumberTemplateArguments)
10460 << SecondMethodType << SecondName
10461 << (unsigned)SecondExpandedList.size();
10462
10463 Diagnosed = true;
10464 break;
10465 }
10466
10467 bool TemplateArgumentMismatch = false;
10468 for (unsigned i = 0, e = FirstExpandedList.size(); i != e; ++i) {
10469 const TemplateArgument &FirstTA = *FirstExpandedList[i],
10470 &SecondTA = *SecondExpandedList[i];
10471 if (ComputeTemplateArgumentODRHash(FirstTA) ==
10472 ComputeTemplateArgumentODRHash(SecondTA)) {
10473 continue;
10474 }
10475
10476 ODRDiagError(FirstMethod->getLocation(),
10477 FirstMethod->getSourceRange(),
10478 MethodDifferentTemplateArgument)
10479 << FirstMethodType << FirstName << FirstTA << i + 1;
10480 ODRDiagNote(SecondMethod->getLocation(),
10481 SecondMethod->getSourceRange(),
10482 MethodDifferentTemplateArgument)
10483 << SecondMethodType << SecondName << SecondTA << i + 1;
10484
10485 TemplateArgumentMismatch = true;
10486 break;
10487 }
10488
10489 if (TemplateArgumentMismatch) {
10490 Diagnosed = true;
10491 break;
10492 }
10493 }
10494
10495 // Compute the hash of the method as if it has no body.
10496 auto ComputeCXXMethodODRHash = [&Hash](const CXXMethodDecl *D) {
10497 Hash.clear();
10498 Hash.AddFunctionDecl(D, true /*SkipBody*/);
10499 return Hash.CalculateHash();
10500 };
10501
10502 // Compare the hash generated to the hash stored. A difference means
10503 // that a body was present in the original source. Due to merging,
10504 // the stardard way of detecting a body will not work.
10505 const bool HasFirstBody =
10506 ComputeCXXMethodODRHash(FirstMethod) != FirstMethod->getODRHash();
10507 const bool HasSecondBody =
10508 ComputeCXXMethodODRHash(SecondMethod) != SecondMethod->getODRHash();
10509
10510 if (HasFirstBody != HasSecondBody) {
10511 ODRDiagError(FirstMethod->getLocation(),
10512 FirstMethod->getSourceRange(), MethodSingleBody)
10513 << FirstMethodType << FirstName << HasFirstBody;
10514 ODRDiagNote(SecondMethod->getLocation(),
10515 SecondMethod->getSourceRange(), MethodSingleBody)
10516 << SecondMethodType << SecondName << HasSecondBody;
10517 Diagnosed = true;
10518 break;
10519 }
10520
10521 if (HasFirstBody && HasSecondBody) {
10522 ODRDiagError(FirstMethod->getLocation(),
10523 FirstMethod->getSourceRange(), MethodDifferentBody)
10524 << FirstMethodType << FirstName;
10525 ODRDiagNote(SecondMethod->getLocation(),
10526 SecondMethod->getSourceRange(), MethodDifferentBody)
10527 << SecondMethodType << SecondName;
10528 Diagnosed = true;
10529 break;
10530 }
10531
10532 break;
10533 }
10534 case TypeAlias:
10535 case TypeDef: {
10536 TypedefNameDecl *FirstTD = cast<TypedefNameDecl>(FirstDecl);
10537 TypedefNameDecl *SecondTD = cast<TypedefNameDecl>(SecondDecl);
10538 auto FirstName = FirstTD->getDeclName();
10539 auto SecondName = SecondTD->getDeclName();
10540 if (FirstName != SecondName) {
10541 ODRDiagError(FirstTD->getLocation(), FirstTD->getSourceRange(),
10542 TypedefName)
10543 << (FirstDiffType == TypeAlias) << FirstName;
10544 ODRDiagNote(SecondTD->getLocation(), SecondTD->getSourceRange(),
10545 TypedefName)
10546 << (FirstDiffType == TypeAlias) << SecondName;
10547 Diagnosed = true;
10548 break;
10549 }
10550
10551 QualType FirstType = FirstTD->getUnderlyingType();
10552 QualType SecondType = SecondTD->getUnderlyingType();
10553 if (ComputeQualTypeODRHash(FirstType) !=
10554 ComputeQualTypeODRHash(SecondType)) {
10555 ODRDiagError(FirstTD->getLocation(), FirstTD->getSourceRange(),
10556 TypedefType)
10557 << (FirstDiffType == TypeAlias) << FirstName << FirstType;
10558 ODRDiagNote(SecondTD->getLocation(), SecondTD->getSourceRange(),
10559 TypedefType)
10560 << (FirstDiffType == TypeAlias) << SecondName << SecondType;
10561 Diagnosed = true;
10562 break;
10563 }
10564 break;
10565 }
10566 case Var: {
10567 VarDecl *FirstVD = cast<VarDecl>(FirstDecl);
10568 VarDecl *SecondVD = cast<VarDecl>(SecondDecl);
10569 auto FirstName = FirstVD->getDeclName();
10570 auto SecondName = SecondVD->getDeclName();
10571 if (FirstName != SecondName) {
10572 ODRDiagError(FirstVD->getLocation(), FirstVD->getSourceRange(),
10573 VarName)
10574 << FirstName;
10575 ODRDiagNote(SecondVD->getLocation(), SecondVD->getSourceRange(),
10576 VarName)
10577 << SecondName;
10578 Diagnosed = true;
10579 break;
10580 }
10581
10582 QualType FirstType = FirstVD->getType();
10583 QualType SecondType = SecondVD->getType();
10584 if (ComputeQualTypeODRHash(FirstType) !=
10585 ComputeQualTypeODRHash(SecondType)) {
10586 ODRDiagError(FirstVD->getLocation(), FirstVD->getSourceRange(),
10587 VarType)
10588 << FirstName << FirstType;
10589 ODRDiagNote(SecondVD->getLocation(), SecondVD->getSourceRange(),
10590 VarType)
10591 << SecondName << SecondType;
10592 Diagnosed = true;
10593 break;
10594 }
10595
10596 const Expr *FirstInit = FirstVD->getInit();
10597 const Expr *SecondInit = SecondVD->getInit();
10598 if ((FirstInit == nullptr) != (SecondInit == nullptr)) {
10599 ODRDiagError(FirstVD->getLocation(), FirstVD->getSourceRange(),
10600 VarSingleInitializer)
10601 << FirstName << (FirstInit == nullptr)
10602 << (FirstInit ? FirstInit->getSourceRange(): SourceRange());
10603 ODRDiagNote(SecondVD->getLocation(), SecondVD->getSourceRange(),
10604 VarSingleInitializer)
10605 << SecondName << (SecondInit == nullptr)
10606 << (SecondInit ? SecondInit->getSourceRange() : SourceRange());
10607 Diagnosed = true;
10608 break;
10609 }
10610
10611 if (FirstInit && SecondInit &&
10612 ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
10613 ODRDiagError(FirstVD->getLocation(), FirstVD->getSourceRange(),
10614 VarDifferentInitializer)
10615 << FirstName << FirstInit->getSourceRange();
10616 ODRDiagNote(SecondVD->getLocation(), SecondVD->getSourceRange(),
10617 VarDifferentInitializer)
10618 << SecondName << SecondInit->getSourceRange();
10619 Diagnosed = true;
10620 break;
10621 }
10622
10623 const bool FirstIsConstexpr = FirstVD->isConstexpr();
10624 const bool SecondIsConstexpr = SecondVD->isConstexpr();
10625 if (FirstIsConstexpr != SecondIsConstexpr) {
10626 ODRDiagError(FirstVD->getLocation(), FirstVD->getSourceRange(),
10627 VarConstexpr)
10628 << FirstName << FirstIsConstexpr;
10629 ODRDiagNote(SecondVD->getLocation(), SecondVD->getSourceRange(),
10630 VarConstexpr)
10631 << SecondName << SecondIsConstexpr;
10632 Diagnosed = true;
10633 break;
10634 }
10635 break;
10636 }
10637 case Friend: {
10638 FriendDecl *FirstFriend = cast<FriendDecl>(FirstDecl);
10639 FriendDecl *SecondFriend = cast<FriendDecl>(SecondDecl);
10640
10641 NamedDecl *FirstND = FirstFriend->getFriendDecl();
10642 NamedDecl *SecondND = SecondFriend->getFriendDecl();
10643
10644 TypeSourceInfo *FirstTSI = FirstFriend->getFriendType();
10645 TypeSourceInfo *SecondTSI = SecondFriend->getFriendType();
10646
10647 if (FirstND && SecondND) {
10648 ODRDiagError(FirstFriend->getFriendLoc(),
10649 FirstFriend->getSourceRange(), FriendFunction)
10650 << FirstND;
10651 ODRDiagNote(SecondFriend->getFriendLoc(),
10652 SecondFriend->getSourceRange(), FriendFunction)
10653 << SecondND;
10654
10655 Diagnosed = true;
10656 break;
10657 }
10658
10659 if (FirstTSI && SecondTSI) {
10660 QualType FirstFriendType = FirstTSI->getType();
10661 QualType SecondFriendType = SecondTSI->getType();
10662 assert(ComputeQualTypeODRHash(FirstFriendType) !=
10663 ComputeQualTypeODRHash(SecondFriendType));
10664 ODRDiagError(FirstFriend->getFriendLoc(),
10665 FirstFriend->getSourceRange(), FriendType)
10666 << FirstFriendType;
10667 ODRDiagNote(SecondFriend->getFriendLoc(),
10668 SecondFriend->getSourceRange(), FriendType)
10669 << SecondFriendType;
10670 Diagnosed = true;
10671 break;
10672 }
10673
10674 ODRDiagError(FirstFriend->getFriendLoc(), FirstFriend->getSourceRange(),
10675 FriendTypeFunction)
10676 << (FirstTSI == nullptr);
10677 ODRDiagNote(SecondFriend->getFriendLoc(),
10678 SecondFriend->getSourceRange(), FriendTypeFunction)
10679 << (SecondTSI == nullptr);
10680
10681 Diagnosed = true;
10682 break;
10683 }
10684 case FunctionTemplate: {
10685 FunctionTemplateDecl *FirstTemplate =
10686 cast<FunctionTemplateDecl>(FirstDecl);
10687 FunctionTemplateDecl *SecondTemplate =
10688 cast<FunctionTemplateDecl>(SecondDecl);
10689
10690 TemplateParameterList *FirstTPL =
10691 FirstTemplate->getTemplateParameters();
10692 TemplateParameterList *SecondTPL =
10693 SecondTemplate->getTemplateParameters();
10694
10695 if (FirstTPL->size() != SecondTPL->size()) {
10696 ODRDiagError(FirstTemplate->getLocation(),
10697 FirstTemplate->getSourceRange(),
10698 FunctionTemplateDifferentNumberParameters)
10699 << FirstTemplate << FirstTPL->size();
10700 ODRDiagNote(SecondTemplate->getLocation(),
10701 SecondTemplate->getSourceRange(),
10702 FunctionTemplateDifferentNumberParameters)
10703 << SecondTemplate << SecondTPL->size();
10704
10705 Diagnosed = true;
10706 break;
10707 }
10708
10709 bool ParameterMismatch = false;
10710 for (unsigned i = 0, e = FirstTPL->size(); i != e; ++i) {
10711 NamedDecl *FirstParam = FirstTPL->getParam(i);
10712 NamedDecl *SecondParam = SecondTPL->getParam(i);
10713
10714 if (FirstParam->getKind() != SecondParam->getKind()) {
10715 enum {
10716 TemplateTypeParameter,
10717 NonTypeTemplateParameter,
10718 TemplateTemplateParameter,
10719 };
10720 auto GetParamType = [](NamedDecl *D) {
10721 switch (D->getKind()) {
10722 default:
10723 llvm_unreachable("Unexpected template parameter type");
10724 case Decl::TemplateTypeParm:
10725 return TemplateTypeParameter;
10726 case Decl::NonTypeTemplateParm:
10727 return NonTypeTemplateParameter;
10728 case Decl::TemplateTemplateParm:
10729 return TemplateTemplateParameter;
10730 }
10731 };
10732
10733 ODRDiagError(FirstTemplate->getLocation(),
10734 FirstTemplate->getSourceRange(),
10735 FunctionTemplateParameterDifferentKind)
10736 << FirstTemplate << (i + 1) << GetParamType(FirstParam);
10737 ODRDiagNote(SecondTemplate->getLocation(),
10738 SecondTemplate->getSourceRange(),
10739 FunctionTemplateParameterDifferentKind)
10740 << SecondTemplate << (i + 1) << GetParamType(SecondParam);
10741
10742 ParameterMismatch = true;
10743 break;
10744 }
10745
10746 if (FirstParam->getName() != SecondParam->getName()) {
10747 ODRDiagError(FirstTemplate->getLocation(),
10748 FirstTemplate->getSourceRange(),
10749 FunctionTemplateParameterName)
10750 << FirstTemplate << (i + 1) << (bool)FirstParam->getIdentifier()
10751 << FirstParam;
10752 ODRDiagNote(SecondTemplate->getLocation(),
10753 SecondTemplate->getSourceRange(),
10754 FunctionTemplateParameterName)
10755 << SecondTemplate << (i + 1)
10756 << (bool)SecondParam->getIdentifier() << SecondParam;
10757 ParameterMismatch = true;
10758 break;
10759 }
10760
10761 if (isa<TemplateTypeParmDecl>(FirstParam) &&
10762 isa<TemplateTypeParmDecl>(SecondParam)) {
10763 TemplateTypeParmDecl *FirstTTPD =
10764 cast<TemplateTypeParmDecl>(FirstParam);
10765 TemplateTypeParmDecl *SecondTTPD =
10766 cast<TemplateTypeParmDecl>(SecondParam);
10767 bool HasFirstDefaultArgument =
10768 FirstTTPD->hasDefaultArgument() &&
10769 !FirstTTPD->defaultArgumentWasInherited();
10770 bool HasSecondDefaultArgument =
10771 SecondTTPD->hasDefaultArgument() &&
10772 !SecondTTPD->defaultArgumentWasInherited();
10773 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
10774 ODRDiagError(FirstTemplate->getLocation(),
10775 FirstTemplate->getSourceRange(),
10776 FunctionTemplateParameterSingleDefaultArgument)
10777 << FirstTemplate << (i + 1) << HasFirstDefaultArgument;
10778 ODRDiagNote(SecondTemplate->getLocation(),
10779 SecondTemplate->getSourceRange(),
10780 FunctionTemplateParameterSingleDefaultArgument)
10781 << SecondTemplate << (i + 1) << HasSecondDefaultArgument;
10782 ParameterMismatch = true;
10783 break;
10784 }
10785
10786 if (HasFirstDefaultArgument && HasSecondDefaultArgument) {
10787 QualType FirstType = FirstTTPD->getDefaultArgument();
10788 QualType SecondType = SecondTTPD->getDefaultArgument();
10789 if (ComputeQualTypeODRHash(FirstType) !=
10790 ComputeQualTypeODRHash(SecondType)) {
10791 ODRDiagError(FirstTemplate->getLocation(),
10792 FirstTemplate->getSourceRange(),
10793 FunctionTemplateParameterDifferentDefaultArgument)
10794 << FirstTemplate << (i + 1) << FirstType;
10795 ODRDiagNote(SecondTemplate->getLocation(),
10796 SecondTemplate->getSourceRange(),
10797 FunctionTemplateParameterDifferentDefaultArgument)
10798 << SecondTemplate << (i + 1) << SecondType;
10799 ParameterMismatch = true;
10800 break;
10801 }
10802 }
10803
10804 if (FirstTTPD->isParameterPack() !=
10805 SecondTTPD->isParameterPack()) {
10806 ODRDiagError(FirstTemplate->getLocation(),
10807 FirstTemplate->getSourceRange(),
10808 FunctionTemplatePackParameter)
10809 << FirstTemplate << (i + 1) << FirstTTPD->isParameterPack();
10810 ODRDiagNote(SecondTemplate->getLocation(),
10811 SecondTemplate->getSourceRange(),
10812 FunctionTemplatePackParameter)
10813 << SecondTemplate << (i + 1) << SecondTTPD->isParameterPack();
10814 ParameterMismatch = true;
10815 break;
10816 }
10817 }
10818
10819 if (isa<TemplateTemplateParmDecl>(FirstParam) &&
10820 isa<TemplateTemplateParmDecl>(SecondParam)) {
10821 TemplateTemplateParmDecl *FirstTTPD =
10822 cast<TemplateTemplateParmDecl>(FirstParam);
10823 TemplateTemplateParmDecl *SecondTTPD =
10824 cast<TemplateTemplateParmDecl>(SecondParam);
10825
10826 TemplateParameterList *FirstTPL =
10827 FirstTTPD->getTemplateParameters();
10828 TemplateParameterList *SecondTPL =
10829 SecondTTPD->getTemplateParameters();
10830
10831 if (ComputeTemplateParameterListODRHash(FirstTPL) !=
10832 ComputeTemplateParameterListODRHash(SecondTPL)) {
10833 ODRDiagError(FirstTemplate->getLocation(),
10834 FirstTemplate->getSourceRange(),
10835 FunctionTemplateParameterDifferentType)
10836 << FirstTemplate << (i + 1);
10837 ODRDiagNote(SecondTemplate->getLocation(),
10838 SecondTemplate->getSourceRange(),
10839 FunctionTemplateParameterDifferentType)
10840 << SecondTemplate << (i + 1);
10841 ParameterMismatch = true;
10842 break;
10843 }
10844
10845 bool HasFirstDefaultArgument =
10846 FirstTTPD->hasDefaultArgument() &&
10847 !FirstTTPD->defaultArgumentWasInherited();
10848 bool HasSecondDefaultArgument =
10849 SecondTTPD->hasDefaultArgument() &&
10850 !SecondTTPD->defaultArgumentWasInherited();
10851 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
10852 ODRDiagError(FirstTemplate->getLocation(),
10853 FirstTemplate->getSourceRange(),
10854 FunctionTemplateParameterSingleDefaultArgument)
10855 << FirstTemplate << (i + 1) << HasFirstDefaultArgument;
10856 ODRDiagNote(SecondTemplate->getLocation(),
10857 SecondTemplate->getSourceRange(),
10858 FunctionTemplateParameterSingleDefaultArgument)
10859 << SecondTemplate << (i + 1) << HasSecondDefaultArgument;
10860 ParameterMismatch = true;
10861 break;
10862 }
10863
10864 if (HasFirstDefaultArgument && HasSecondDefaultArgument) {
10865 TemplateArgument FirstTA =
10866 FirstTTPD->getDefaultArgument().getArgument();
10867 TemplateArgument SecondTA =
10868 SecondTTPD->getDefaultArgument().getArgument();
10869 if (ComputeTemplateArgumentODRHash(FirstTA) !=
10870 ComputeTemplateArgumentODRHash(SecondTA)) {
10871 ODRDiagError(FirstTemplate->getLocation(),
10872 FirstTemplate->getSourceRange(),
10873 FunctionTemplateParameterDifferentDefaultArgument)
10874 << FirstTemplate << (i + 1) << FirstTA;
10875 ODRDiagNote(SecondTemplate->getLocation(),
10876 SecondTemplate->getSourceRange(),
10877 FunctionTemplateParameterDifferentDefaultArgument)
10878 << SecondTemplate << (i + 1) << SecondTA;
10879 ParameterMismatch = true;
10880 break;
10881 }
10882 }
10883
10884 if (FirstTTPD->isParameterPack() !=
10885 SecondTTPD->isParameterPack()) {
10886 ODRDiagError(FirstTemplate->getLocation(),
10887 FirstTemplate->getSourceRange(),
10888 FunctionTemplatePackParameter)
10889 << FirstTemplate << (i + 1) << FirstTTPD->isParameterPack();
10890 ODRDiagNote(SecondTemplate->getLocation(),
10891 SecondTemplate->getSourceRange(),
10892 FunctionTemplatePackParameter)
10893 << SecondTemplate << (i + 1) << SecondTTPD->isParameterPack();
10894 ParameterMismatch = true;
10895 break;
10896 }
10897 }
10898
10899 if (isa<NonTypeTemplateParmDecl>(FirstParam) &&
10900 isa<NonTypeTemplateParmDecl>(SecondParam)) {
10901 NonTypeTemplateParmDecl *FirstNTTPD =
10902 cast<NonTypeTemplateParmDecl>(FirstParam);
10903 NonTypeTemplateParmDecl *SecondNTTPD =
10904 cast<NonTypeTemplateParmDecl>(SecondParam);
10905
10906 QualType FirstType = FirstNTTPD->getType();
10907 QualType SecondType = SecondNTTPD->getType();
10908 if (ComputeQualTypeODRHash(FirstType) !=
10909 ComputeQualTypeODRHash(SecondType)) {
10910 ODRDiagError(FirstTemplate->getLocation(),
10911 FirstTemplate->getSourceRange(),
10912 FunctionTemplateParameterDifferentType)
10913 << FirstTemplate << (i + 1);
10914 ODRDiagNote(SecondTemplate->getLocation(),
10915 SecondTemplate->getSourceRange(),
10916 FunctionTemplateParameterDifferentType)
10917 << SecondTemplate << (i + 1);
10918 ParameterMismatch = true;
10919 break;
10920 }
10921
10922 bool HasFirstDefaultArgument =
10923 FirstNTTPD->hasDefaultArgument() &&
10924 !FirstNTTPD->defaultArgumentWasInherited();
10925 bool HasSecondDefaultArgument =
10926 SecondNTTPD->hasDefaultArgument() &&
10927 !SecondNTTPD->defaultArgumentWasInherited();
10928 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
10929 ODRDiagError(FirstTemplate->getLocation(),
10930 FirstTemplate->getSourceRange(),
10931 FunctionTemplateParameterSingleDefaultArgument)
10932 << FirstTemplate << (i + 1) << HasFirstDefaultArgument;
10933 ODRDiagNote(SecondTemplate->getLocation(),
10934 SecondTemplate->getSourceRange(),
10935 FunctionTemplateParameterSingleDefaultArgument)
10936 << SecondTemplate << (i + 1) << HasSecondDefaultArgument;
10937 ParameterMismatch = true;
10938 break;
10939 }
10940
10941 if (HasFirstDefaultArgument && HasSecondDefaultArgument) {
10942 Expr *FirstDefaultArgument = FirstNTTPD->getDefaultArgument();
10943 Expr *SecondDefaultArgument = SecondNTTPD->getDefaultArgument();
10944 if (ComputeODRHash(FirstDefaultArgument) !=
10945 ComputeODRHash(SecondDefaultArgument)) {
10946 ODRDiagError(FirstTemplate->getLocation(),
10947 FirstTemplate->getSourceRange(),
10948 FunctionTemplateParameterDifferentDefaultArgument)
10949 << FirstTemplate << (i + 1) << FirstDefaultArgument;
10950 ODRDiagNote(SecondTemplate->getLocation(),
10951 SecondTemplate->getSourceRange(),
10952 FunctionTemplateParameterDifferentDefaultArgument)
10953 << SecondTemplate << (i + 1) << SecondDefaultArgument;
10954 ParameterMismatch = true;
10955 break;
10956 }
10957 }
10958
10959 if (FirstNTTPD->isParameterPack() !=
10960 SecondNTTPD->isParameterPack()) {
10961 ODRDiagError(FirstTemplate->getLocation(),
10962 FirstTemplate->getSourceRange(),
10963 FunctionTemplatePackParameter)
10964 << FirstTemplate << (i + 1) << FirstNTTPD->isParameterPack();
10965 ODRDiagNote(SecondTemplate->getLocation(),
10966 SecondTemplate->getSourceRange(),
10967 FunctionTemplatePackParameter)
10968 << SecondTemplate << (i + 1)
10969 << SecondNTTPD->isParameterPack();
10970 ParameterMismatch = true;
10971 break;
10972 }
10973 }
10974 }
10975
10976 if (ParameterMismatch) {
10977 Diagnosed = true;
10978 break;
10979 }
10980
10981 break;
10982 }
10983 }
10984
10985 if (Diagnosed)
10986 continue;
10987
10988 Diag(FirstDecl->getLocation(),
10989 diag::err_module_odr_violation_mismatch_decl_unknown)
10990 << FirstRecord << FirstModule.empty() << FirstModule << FirstDiffType
10991 << FirstDecl->getSourceRange();
10992 Diag(SecondDecl->getLocation(),
10993 diag::note_module_odr_violation_mismatch_decl_unknown)
10994 << SecondModule << FirstDiffType << SecondDecl->getSourceRange();
10995 Diagnosed = true;
10996 }
10997
10998 if (!Diagnosed) {
10999 // All definitions are updates to the same declaration. This happens if a
11000 // module instantiates the declaration of a class template specialization
11001 // and two or more other modules instantiate its definition.
11002 //
11003 // FIXME: Indicate which modules had instantiations of this definition.
11004 // FIXME: How can this even happen?
11005 Diag(Merge.first->getLocation(),
11006 diag::err_module_odr_violation_different_instantiations)
11007 << Merge.first;
11008 }
11009 }
11010
11011 // Issue ODR failures diagnostics for functions.
11012 for (auto &Merge : FunctionOdrMergeFailures) {
11013 enum ODRFunctionDifference {
11014 ReturnType,
11015 ParameterName,
11016 ParameterType,
11017 ParameterSingleDefaultArgument,
11018 ParameterDifferentDefaultArgument,
11019 FunctionBody,
11020 };
11021
11022 FunctionDecl *FirstFunction = Merge.first;
11023 std::string FirstModule = getOwningModuleNameForDiagnostic(FirstFunction);
11024
11025 bool Diagnosed = false;
11026 for (auto &SecondFunction : Merge.second) {
11027
11028 if (FirstFunction == SecondFunction)
11029 continue;
11030
11031 std::string SecondModule =
11032 getOwningModuleNameForDiagnostic(SecondFunction);
11033
11034 auto ODRDiagError = [FirstFunction, &FirstModule,
11035 this](SourceLocation Loc, SourceRange Range,
11036 ODRFunctionDifference DiffType) {
11037 return Diag(Loc, diag::err_module_odr_violation_function)
11038 << FirstFunction << FirstModule.empty() << FirstModule << Range
11039 << DiffType;
11040 };
11041 auto ODRDiagNote = [&SecondModule, this](SourceLocation Loc,
11042 SourceRange Range,
11043 ODRFunctionDifference DiffType) {
11044 return Diag(Loc, diag::note_module_odr_violation_function)
11045 << SecondModule << Range << DiffType;
11046 };
11047
11048 if (ComputeQualTypeODRHash(FirstFunction->getReturnType()) !=
11049 ComputeQualTypeODRHash(SecondFunction->getReturnType())) {
11050 ODRDiagError(FirstFunction->getReturnTypeSourceRange().getBegin(),
11051 FirstFunction->getReturnTypeSourceRange(), ReturnType)
11052 << FirstFunction->getReturnType();
11053 ODRDiagNote(SecondFunction->getReturnTypeSourceRange().getBegin(),
11054 SecondFunction->getReturnTypeSourceRange(), ReturnType)
11055 << SecondFunction->getReturnType();
11056 Diagnosed = true;
11057 break;
11058 }
11059
11060 assert(FirstFunction->param_size() == SecondFunction->param_size() &&
11061 "Merged functions with different number of parameters");
11062
11063 auto ParamSize = FirstFunction->param_size();
11064 bool ParameterMismatch = false;
11065 for (unsigned I = 0; I < ParamSize; ++I) {
11066 auto *FirstParam = FirstFunction->getParamDecl(I);
11067 auto *SecondParam = SecondFunction->getParamDecl(I);
11068
11069 assert(getContext().hasSameType(FirstParam->getType(),
11070 SecondParam->getType()) &&
11071 "Merged function has different parameter types.");
11072
11073 if (FirstParam->getDeclName() != SecondParam->getDeclName()) {
11074 ODRDiagError(FirstParam->getLocation(), FirstParam->getSourceRange(),
11075 ParameterName)
11076 << I + 1 << FirstParam->getDeclName();
11077 ODRDiagNote(SecondParam->getLocation(), SecondParam->getSourceRange(),
11078 ParameterName)
11079 << I + 1 << SecondParam->getDeclName();
11080 ParameterMismatch = true;
11081 break;
11082 };
11083
11084 QualType FirstParamType = FirstParam->getType();
11085 QualType SecondParamType = SecondParam->getType();
11086 if (FirstParamType != SecondParamType &&
11087 ComputeQualTypeODRHash(FirstParamType) !=
11088 ComputeQualTypeODRHash(SecondParamType)) {
11089 if (const DecayedType *ParamDecayedType =
11090 FirstParamType->getAs<DecayedType>()) {
11091 ODRDiagError(FirstParam->getLocation(),
11092 FirstParam->getSourceRange(), ParameterType)
11093 << (I + 1) << FirstParamType << true
11094 << ParamDecayedType->getOriginalType();
11095 } else {
11096 ODRDiagError(FirstParam->getLocation(),
11097 FirstParam->getSourceRange(), ParameterType)
11098 << (I + 1) << FirstParamType << false;
11099 }
11100
11101 if (const DecayedType *ParamDecayedType =
11102 SecondParamType->getAs<DecayedType>()) {
11103 ODRDiagNote(SecondParam->getLocation(),
11104 SecondParam->getSourceRange(), ParameterType)
11105 << (I + 1) << SecondParamType << true
11106 << ParamDecayedType->getOriginalType();
11107 } else {
11108 ODRDiagNote(SecondParam->getLocation(),
11109 SecondParam->getSourceRange(), ParameterType)
11110 << (I + 1) << SecondParamType << false;
11111 }
11112 ParameterMismatch = true;
11113 break;
11114 }
11115
11116 const Expr *FirstInit = FirstParam->getInit();
11117 const Expr *SecondInit = SecondParam->getInit();
11118 if ((FirstInit == nullptr) != (SecondInit == nullptr)) {
11119 ODRDiagError(FirstParam->getLocation(), FirstParam->getSourceRange(),
11120 ParameterSingleDefaultArgument)
11121 << (I + 1) << (FirstInit == nullptr)
11122 << (FirstInit ? FirstInit->getSourceRange() : SourceRange());
11123 ODRDiagNote(SecondParam->getLocation(), SecondParam->getSourceRange(),
11124 ParameterSingleDefaultArgument)
11125 << (I + 1) << (SecondInit == nullptr)
11126 << (SecondInit ? SecondInit->getSourceRange() : SourceRange());
11127 ParameterMismatch = true;
11128 break;
11129 }
11130
11131 if (FirstInit && SecondInit &&
11132 ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
11133 ODRDiagError(FirstParam->getLocation(), FirstParam->getSourceRange(),
11134 ParameterDifferentDefaultArgument)
11135 << (I + 1) << FirstInit->getSourceRange();
11136 ODRDiagNote(SecondParam->getLocation(), SecondParam->getSourceRange(),
11137 ParameterDifferentDefaultArgument)
11138 << (I + 1) << SecondInit->getSourceRange();
11139 ParameterMismatch = true;
11140 break;
11141 }
11142
11143 assert(ComputeSubDeclODRHash(FirstParam) ==
11144 ComputeSubDeclODRHash(SecondParam) &&
11145 "Undiagnosed parameter difference.");
11146 }
11147
11148 if (ParameterMismatch) {
11149 Diagnosed = true;
11150 break;
11151 }
11152
11153 // If no error has been generated before now, assume the problem is in
11154 // the body and generate a message.
11155 ODRDiagError(FirstFunction->getLocation(),
11156 FirstFunction->getSourceRange(), FunctionBody);
11157 ODRDiagNote(SecondFunction->getLocation(),
11158 SecondFunction->getSourceRange(), FunctionBody);
11159 Diagnosed = true;
11160 break;
11161 }
11162 (void)Diagnosed;
11163 assert(Diagnosed && "Unable to emit ODR diagnostic.");
11164 }
11165
11166 // Issue ODR failures diagnostics for enums.
11167 for (auto &Merge : EnumOdrMergeFailures) {
11168 enum ODREnumDifference {
11169 SingleScopedEnum,
11170 EnumTagKeywordMismatch,
11171 SingleSpecifiedType,
11172 DifferentSpecifiedTypes,
11173 DifferentNumberEnumConstants,
11174 EnumConstantName,
11175 EnumConstantSingleInitilizer,
11176 EnumConstantDifferentInitilizer,
11177 };
11178
11179 // If we've already pointed out a specific problem with this enum, don't
11180 // bother issuing a general "something's different" diagnostic.
11181 if (!DiagnosedOdrMergeFailures.insert(Merge.first).second)
11182 continue;
11183
11184 EnumDecl *FirstEnum = Merge.first;
11185 std::string FirstModule = getOwningModuleNameForDiagnostic(FirstEnum);
11186
11187 using DeclHashes =
11188 llvm::SmallVector<std::pair<EnumConstantDecl *, unsigned>, 4>;
11189 auto PopulateHashes = [&ComputeSubDeclODRHash, FirstEnum](
11190 DeclHashes &Hashes, EnumDecl *Enum) {
11191 for (auto *D : Enum->decls()) {
11192 // Due to decl merging, the first EnumDecl is the parent of
11193 // Decls in both records.
11194 if (!ODRHash::isWhitelistedDecl(D, FirstEnum))
11195 continue;
11196 assert(isa<EnumConstantDecl>(D) && "Unexpected Decl kind");
11197 Hashes.emplace_back(cast<EnumConstantDecl>(D),
11198 ComputeSubDeclODRHash(D));
11199 }
11200 };
11201 DeclHashes FirstHashes;
11202 PopulateHashes(FirstHashes, FirstEnum);
11203 bool Diagnosed = false;
11204 for (auto &SecondEnum : Merge.second) {
11205
11206 if (FirstEnum == SecondEnum)
11207 continue;
11208
11209 std::string SecondModule =
11210 getOwningModuleNameForDiagnostic(SecondEnum);
11211
11212 auto ODRDiagError = [FirstEnum, &FirstModule,
11213 this](SourceLocation Loc, SourceRange Range,
11214 ODREnumDifference DiffType) {
11215 return Diag(Loc, diag::err_module_odr_violation_enum)
11216 << FirstEnum << FirstModule.empty() << FirstModule << Range
11217 << DiffType;
11218 };
11219 auto ODRDiagNote = [&SecondModule, this](SourceLocation Loc,
11220 SourceRange Range,
11221 ODREnumDifference DiffType) {
11222 return Diag(Loc, diag::note_module_odr_violation_enum)
11223 << SecondModule << Range << DiffType;
11224 };
11225
11226 if (FirstEnum->isScoped() != SecondEnum->isScoped()) {
11227 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11228 SingleScopedEnum)
11229 << FirstEnum->isScoped();
11230 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11231 SingleScopedEnum)
11232 << SecondEnum->isScoped();
11233 Diagnosed = true;
11234 continue;
11235 }
11236
11237 if (FirstEnum->isScoped() && SecondEnum->isScoped()) {
11238 if (FirstEnum->isScopedUsingClassTag() !=
11239 SecondEnum->isScopedUsingClassTag()) {
11240 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11241 EnumTagKeywordMismatch)
11242 << FirstEnum->isScopedUsingClassTag();
11243 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11244 EnumTagKeywordMismatch)
11245 << SecondEnum->isScopedUsingClassTag();
11246 Diagnosed = true;
11247 continue;
11248 }
11249 }
11250
11251 QualType FirstUnderlyingType =
11252 FirstEnum->getIntegerTypeSourceInfo()
11253 ? FirstEnum->getIntegerTypeSourceInfo()->getType()
11254 : QualType();
11255 QualType SecondUnderlyingType =
11256 SecondEnum->getIntegerTypeSourceInfo()
11257 ? SecondEnum->getIntegerTypeSourceInfo()->getType()
11258 : QualType();
11259 if (FirstUnderlyingType.isNull() != SecondUnderlyingType.isNull()) {
11260 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11261 SingleSpecifiedType)
11262 << !FirstUnderlyingType.isNull();
11263 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11264 SingleSpecifiedType)
11265 << !SecondUnderlyingType.isNull();
11266 Diagnosed = true;
11267 continue;
11268 }
11269
11270 if (!FirstUnderlyingType.isNull() && !SecondUnderlyingType.isNull()) {
11271 if (ComputeQualTypeODRHash(FirstUnderlyingType) !=
11272 ComputeQualTypeODRHash(SecondUnderlyingType)) {
11273 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11274 DifferentSpecifiedTypes)
11275 << FirstUnderlyingType;
11276 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11277 DifferentSpecifiedTypes)
11278 << SecondUnderlyingType;
11279 Diagnosed = true;
11280 continue;
11281 }
11282 }
11283
11284 DeclHashes SecondHashes;
11285 PopulateHashes(SecondHashes, SecondEnum);
11286
11287 if (FirstHashes.size() != SecondHashes.size()) {
11288 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11289 DifferentNumberEnumConstants)
11290 << (int)FirstHashes.size();
11291 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11292 DifferentNumberEnumConstants)
11293 << (int)SecondHashes.size();
11294 Diagnosed = true;
11295 continue;
11296 }
11297
11298 for (unsigned I = 0; I < FirstHashes.size(); ++I) {
11299 if (FirstHashes[I].second == SecondHashes[I].second)
11300 continue;
11301 const EnumConstantDecl *FirstEnumConstant = FirstHashes[I].first;
11302 const EnumConstantDecl *SecondEnumConstant = SecondHashes[I].first;
11303
11304 if (FirstEnumConstant->getDeclName() !=
11305 SecondEnumConstant->getDeclName()) {
11306
11307 ODRDiagError(FirstEnumConstant->getLocation(),
11308 FirstEnumConstant->getSourceRange(), EnumConstantName)
11309 << I + 1 << FirstEnumConstant;
11310 ODRDiagNote(SecondEnumConstant->getLocation(),
11311 SecondEnumConstant->getSourceRange(), EnumConstantName)
11312 << I + 1 << SecondEnumConstant;
11313 Diagnosed = true;
11314 break;
11315 }
11316
11317 const Expr *FirstInit = FirstEnumConstant->getInitExpr();
11318 const Expr *SecondInit = SecondEnumConstant->getInitExpr();
11319 if (!FirstInit && !SecondInit)
11320 continue;
11321
11322 if (!FirstInit || !SecondInit) {
11323 ODRDiagError(FirstEnumConstant->getLocation(),
11324 FirstEnumConstant->getSourceRange(),
11325 EnumConstantSingleInitilizer)
11326 << I + 1 << FirstEnumConstant << (FirstInit != nullptr);
11327 ODRDiagNote(SecondEnumConstant->getLocation(),
11328 SecondEnumConstant->getSourceRange(),
11329 EnumConstantSingleInitilizer)
11330 << I + 1 << SecondEnumConstant << (SecondInit != nullptr);
11331 Diagnosed = true;
11332 break;
11333 }
11334
11335 if (ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
11336 ODRDiagError(FirstEnumConstant->getLocation(),
11337 FirstEnumConstant->getSourceRange(),
11338 EnumConstantDifferentInitilizer)
11339 << I + 1 << FirstEnumConstant;
11340 ODRDiagNote(SecondEnumConstant->getLocation(),
11341 SecondEnumConstant->getSourceRange(),
11342 EnumConstantDifferentInitilizer)
11343 << I + 1 << SecondEnumConstant;
11344 Diagnosed = true;
11345 break;
11346 }
11347 }
11348 }
11349
11350 (void)Diagnosed;
11351 assert(Diagnosed && "Unable to emit ODR diagnostic.");
11352 }
11353 }
11354
StartedDeserializing()11355 void ASTReader::StartedDeserializing() {
11356 if (++NumCurrentElementsDeserializing == 1 && ReadTimer.get())
11357 ReadTimer->startTimer();
11358 }
11359
FinishedDeserializing()11360 void ASTReader::FinishedDeserializing() {
11361 assert(NumCurrentElementsDeserializing &&
11362 "FinishedDeserializing not paired with StartedDeserializing");
11363 if (NumCurrentElementsDeserializing == 1) {
11364 // We decrease NumCurrentElementsDeserializing only after pending actions
11365 // are finished, to avoid recursively re-calling finishPendingActions().
11366 finishPendingActions();
11367 }
11368 --NumCurrentElementsDeserializing;
11369
11370 if (NumCurrentElementsDeserializing == 0) {
11371 // Propagate exception specification and deduced type updates along
11372 // redeclaration chains.
11373 //
11374 // We do this now rather than in finishPendingActions because we want to
11375 // be able to walk the complete redeclaration chains of the updated decls.
11376 while (!PendingExceptionSpecUpdates.empty() ||
11377 !PendingDeducedTypeUpdates.empty()) {
11378 auto ESUpdates = std::move(PendingExceptionSpecUpdates);
11379 PendingExceptionSpecUpdates.clear();
11380 for (auto Update : ESUpdates) {
11381 ProcessingUpdatesRAIIObj ProcessingUpdates(*this);
11382 auto *FPT = Update.second->getType()->castAs<FunctionProtoType>();
11383 auto ESI = FPT->getExtProtoInfo().ExceptionSpec;
11384 if (auto *Listener = getContext().getASTMutationListener())
11385 Listener->ResolvedExceptionSpec(cast<FunctionDecl>(Update.second));
11386 for (auto *Redecl : Update.second->redecls())
11387 getContext().adjustExceptionSpec(cast<FunctionDecl>(Redecl), ESI);
11388 }
11389
11390 auto DTUpdates = std::move(PendingDeducedTypeUpdates);
11391 PendingDeducedTypeUpdates.clear();
11392 for (auto Update : DTUpdates) {
11393 ProcessingUpdatesRAIIObj ProcessingUpdates(*this);
11394 // FIXME: If the return type is already deduced, check that it matches.
11395 getContext().adjustDeducedFunctionResultType(Update.first,
11396 Update.second);
11397 }
11398 }
11399
11400 if (ReadTimer)
11401 ReadTimer->stopTimer();
11402
11403 diagnoseOdrViolations();
11404
11405 // We are not in recursive loading, so it's safe to pass the "interesting"
11406 // decls to the consumer.
11407 if (Consumer)
11408 PassInterestingDeclsToConsumer();
11409 }
11410 }
11411
pushExternalDeclIntoScope(NamedDecl * D,DeclarationName Name)11412 void ASTReader::pushExternalDeclIntoScope(NamedDecl *D, DeclarationName Name) {
11413 if (IdentifierInfo *II = Name.getAsIdentifierInfo()) {
11414 // Remove any fake results before adding any real ones.
11415 auto It = PendingFakeLookupResults.find(II);
11416 if (It != PendingFakeLookupResults.end()) {
11417 for (auto *ND : It->second)
11418 SemaObj->IdResolver.RemoveDecl(ND);
11419 // FIXME: this works around module+PCH performance issue.
11420 // Rather than erase the result from the map, which is O(n), just clear
11421 // the vector of NamedDecls.
11422 It->second.clear();
11423 }
11424 }
11425
11426 if (SemaObj->IdResolver.tryAddTopLevelDecl(D, Name) && SemaObj->TUScope) {
11427 SemaObj->TUScope->AddDecl(D);
11428 } else if (SemaObj->TUScope) {
11429 // Adding the decl to IdResolver may have failed because it was already in
11430 // (even though it was not added in scope). If it is already in, make sure
11431 // it gets in the scope as well.
11432 if (std::find(SemaObj->IdResolver.begin(Name),
11433 SemaObj->IdResolver.end(), D) != SemaObj->IdResolver.end())
11434 SemaObj->TUScope->AddDecl(D);
11435 }
11436 }
11437
ASTReader(Preprocessor & PP,InMemoryModuleCache & ModuleCache,ASTContext * Context,const PCHContainerReader & PCHContainerRdr,ArrayRef<std::shared_ptr<ModuleFileExtension>> Extensions,StringRef isysroot,bool DisableValidation,bool AllowASTWithCompilerErrors,bool AllowConfigurationMismatch,bool ValidateSystemInputs,bool ValidateASTInputFilesContent,bool UseGlobalIndex,std::unique_ptr<llvm::Timer> ReadTimer)11438 ASTReader::ASTReader(Preprocessor &PP, InMemoryModuleCache &ModuleCache,
11439 ASTContext *Context,
11440 const PCHContainerReader &PCHContainerRdr,
11441 ArrayRef<std::shared_ptr<ModuleFileExtension>> Extensions,
11442 StringRef isysroot, bool DisableValidation,
11443 bool AllowASTWithCompilerErrors,
11444 bool AllowConfigurationMismatch, bool ValidateSystemInputs,
11445 bool ValidateASTInputFilesContent, bool UseGlobalIndex,
11446 std::unique_ptr<llvm::Timer> ReadTimer)
11447 : Listener(DisableValidation
11448 ? cast<ASTReaderListener>(new SimpleASTReaderListener(PP))
11449 : cast<ASTReaderListener>(new PCHValidator(PP, *this))),
11450 SourceMgr(PP.getSourceManager()), FileMgr(PP.getFileManager()),
11451 PCHContainerRdr(PCHContainerRdr), Diags(PP.getDiagnostics()), PP(PP),
11452 ContextObj(Context), ModuleMgr(PP.getFileManager(), ModuleCache,
11453 PCHContainerRdr, PP.getHeaderSearchInfo()),
11454 DummyIdResolver(PP), ReadTimer(std::move(ReadTimer)), isysroot(isysroot),
11455 DisableValidation(DisableValidation),
11456 AllowASTWithCompilerErrors(AllowASTWithCompilerErrors),
11457 AllowConfigurationMismatch(AllowConfigurationMismatch),
11458 ValidateSystemInputs(ValidateSystemInputs),
11459 ValidateASTInputFilesContent(ValidateASTInputFilesContent),
11460 UseGlobalIndex(UseGlobalIndex), CurrSwitchCaseStmts(&SwitchCaseStmts) {
11461 SourceMgr.setExternalSLocEntrySource(this);
11462
11463 for (const auto &Ext : Extensions) {
11464 auto BlockName = Ext->getExtensionMetadata().BlockName;
11465 auto Known = ModuleFileExtensions.find(BlockName);
11466 if (Known != ModuleFileExtensions.end()) {
11467 Diags.Report(diag::warn_duplicate_module_file_extension)
11468 << BlockName;
11469 continue;
11470 }
11471
11472 ModuleFileExtensions.insert({BlockName, Ext});
11473 }
11474 }
11475
~ASTReader()11476 ASTReader::~ASTReader() {
11477 if (OwnsDeserializationListener)
11478 delete DeserializationListener;
11479 }
11480
getIdResolver()11481 IdentifierResolver &ASTReader::getIdResolver() {
11482 return SemaObj ? SemaObj->IdResolver : DummyIdResolver;
11483 }
11484
readRecord(llvm::BitstreamCursor & Cursor,unsigned AbbrevID)11485 Expected<unsigned> ASTRecordReader::readRecord(llvm::BitstreamCursor &Cursor,
11486 unsigned AbbrevID) {
11487 Idx = 0;
11488 Record.clear();
11489 return Cursor.readRecord(AbbrevID, Record);
11490 }
11491 //===----------------------------------------------------------------------===//
11492 //// OMPClauseReader implementation
11493 ////===----------------------------------------------------------------------===//
11494
11495 // This has to be in namespace clang because it's friended by all
11496 // of the OMP clauses.
11497 namespace clang {
11498
11499 class OMPClauseReader : public OMPClauseVisitor<OMPClauseReader> {
11500 ASTRecordReader &Record;
11501 ASTContext &Context;
11502
11503 public:
OMPClauseReader(ASTRecordReader & Record)11504 OMPClauseReader(ASTRecordReader &Record)
11505 : Record(Record), Context(Record.getContext()) {}
11506
11507 #define OPENMP_CLAUSE(Name, Class) void Visit##Class(Class *C);
11508 #include "clang/Basic/OpenMPKinds.def"
11509 OMPClause *readClause();
11510 void VisitOMPClauseWithPreInit(OMPClauseWithPreInit *C);
11511 void VisitOMPClauseWithPostUpdate(OMPClauseWithPostUpdate *C);
11512 };
11513
11514 } // end namespace clang
11515
readOMPClause()11516 OMPClause *ASTRecordReader::readOMPClause() {
11517 return OMPClauseReader(*this).readClause();
11518 }
11519
readClause()11520 OMPClause *OMPClauseReader::readClause() {
11521 OMPClause *C = nullptr;
11522 switch (Record.readInt()) {
11523 case OMPC_if:
11524 C = new (Context) OMPIfClause();
11525 break;
11526 case OMPC_final:
11527 C = new (Context) OMPFinalClause();
11528 break;
11529 case OMPC_num_threads:
11530 C = new (Context) OMPNumThreadsClause();
11531 break;
11532 case OMPC_safelen:
11533 C = new (Context) OMPSafelenClause();
11534 break;
11535 case OMPC_simdlen:
11536 C = new (Context) OMPSimdlenClause();
11537 break;
11538 case OMPC_allocator:
11539 C = new (Context) OMPAllocatorClause();
11540 break;
11541 case OMPC_collapse:
11542 C = new (Context) OMPCollapseClause();
11543 break;
11544 case OMPC_default:
11545 C = new (Context) OMPDefaultClause();
11546 break;
11547 case OMPC_proc_bind:
11548 C = new (Context) OMPProcBindClause();
11549 break;
11550 case OMPC_schedule:
11551 C = new (Context) OMPScheduleClause();
11552 break;
11553 case OMPC_ordered:
11554 C = OMPOrderedClause::CreateEmpty(Context, Record.readInt());
11555 break;
11556 case OMPC_nowait:
11557 C = new (Context) OMPNowaitClause();
11558 break;
11559 case OMPC_untied:
11560 C = new (Context) OMPUntiedClause();
11561 break;
11562 case OMPC_mergeable:
11563 C = new (Context) OMPMergeableClause();
11564 break;
11565 case OMPC_read:
11566 C = new (Context) OMPReadClause();
11567 break;
11568 case OMPC_write:
11569 C = new (Context) OMPWriteClause();
11570 break;
11571 case OMPC_update:
11572 C = new (Context) OMPUpdateClause();
11573 break;
11574 case OMPC_capture:
11575 C = new (Context) OMPCaptureClause();
11576 break;
11577 case OMPC_seq_cst:
11578 C = new (Context) OMPSeqCstClause();
11579 break;
11580 case OMPC_threads:
11581 C = new (Context) OMPThreadsClause();
11582 break;
11583 case OMPC_simd:
11584 C = new (Context) OMPSIMDClause();
11585 break;
11586 case OMPC_nogroup:
11587 C = new (Context) OMPNogroupClause();
11588 break;
11589 case OMPC_unified_address:
11590 C = new (Context) OMPUnifiedAddressClause();
11591 break;
11592 case OMPC_unified_shared_memory:
11593 C = new (Context) OMPUnifiedSharedMemoryClause();
11594 break;
11595 case OMPC_reverse_offload:
11596 C = new (Context) OMPReverseOffloadClause();
11597 break;
11598 case OMPC_dynamic_allocators:
11599 C = new (Context) OMPDynamicAllocatorsClause();
11600 break;
11601 case OMPC_atomic_default_mem_order:
11602 C = new (Context) OMPAtomicDefaultMemOrderClause();
11603 break;
11604 case OMPC_private:
11605 C = OMPPrivateClause::CreateEmpty(Context, Record.readInt());
11606 break;
11607 case OMPC_firstprivate:
11608 C = OMPFirstprivateClause::CreateEmpty(Context, Record.readInt());
11609 break;
11610 case OMPC_lastprivate:
11611 C = OMPLastprivateClause::CreateEmpty(Context, Record.readInt());
11612 break;
11613 case OMPC_shared:
11614 C = OMPSharedClause::CreateEmpty(Context, Record.readInt());
11615 break;
11616 case OMPC_reduction:
11617 C = OMPReductionClause::CreateEmpty(Context, Record.readInt());
11618 break;
11619 case OMPC_task_reduction:
11620 C = OMPTaskReductionClause::CreateEmpty(Context, Record.readInt());
11621 break;
11622 case OMPC_in_reduction:
11623 C = OMPInReductionClause::CreateEmpty(Context, Record.readInt());
11624 break;
11625 case OMPC_linear:
11626 C = OMPLinearClause::CreateEmpty(Context, Record.readInt());
11627 break;
11628 case OMPC_aligned:
11629 C = OMPAlignedClause::CreateEmpty(Context, Record.readInt());
11630 break;
11631 case OMPC_copyin:
11632 C = OMPCopyinClause::CreateEmpty(Context, Record.readInt());
11633 break;
11634 case OMPC_copyprivate:
11635 C = OMPCopyprivateClause::CreateEmpty(Context, Record.readInt());
11636 break;
11637 case OMPC_flush:
11638 C = OMPFlushClause::CreateEmpty(Context, Record.readInt());
11639 break;
11640 case OMPC_depend: {
11641 unsigned NumVars = Record.readInt();
11642 unsigned NumLoops = Record.readInt();
11643 C = OMPDependClause::CreateEmpty(Context, NumVars, NumLoops);
11644 break;
11645 }
11646 case OMPC_device:
11647 C = new (Context) OMPDeviceClause();
11648 break;
11649 case OMPC_map: {
11650 OMPMappableExprListSizeTy Sizes;
11651 Sizes.NumVars = Record.readInt();
11652 Sizes.NumUniqueDeclarations = Record.readInt();
11653 Sizes.NumComponentLists = Record.readInt();
11654 Sizes.NumComponents = Record.readInt();
11655 C = OMPMapClause::CreateEmpty(Context, Sizes);
11656 break;
11657 }
11658 case OMPC_num_teams:
11659 C = new (Context) OMPNumTeamsClause();
11660 break;
11661 case OMPC_thread_limit:
11662 C = new (Context) OMPThreadLimitClause();
11663 break;
11664 case OMPC_priority:
11665 C = new (Context) OMPPriorityClause();
11666 break;
11667 case OMPC_grainsize:
11668 C = new (Context) OMPGrainsizeClause();
11669 break;
11670 case OMPC_num_tasks:
11671 C = new (Context) OMPNumTasksClause();
11672 break;
11673 case OMPC_hint:
11674 C = new (Context) OMPHintClause();
11675 break;
11676 case OMPC_dist_schedule:
11677 C = new (Context) OMPDistScheduleClause();
11678 break;
11679 case OMPC_defaultmap:
11680 C = new (Context) OMPDefaultmapClause();
11681 break;
11682 case OMPC_to: {
11683 OMPMappableExprListSizeTy Sizes;
11684 Sizes.NumVars = Record.readInt();
11685 Sizes.NumUniqueDeclarations = Record.readInt();
11686 Sizes.NumComponentLists = Record.readInt();
11687 Sizes.NumComponents = Record.readInt();
11688 C = OMPToClause::CreateEmpty(Context, Sizes);
11689 break;
11690 }
11691 case OMPC_from: {
11692 OMPMappableExprListSizeTy Sizes;
11693 Sizes.NumVars = Record.readInt();
11694 Sizes.NumUniqueDeclarations = Record.readInt();
11695 Sizes.NumComponentLists = Record.readInt();
11696 Sizes.NumComponents = Record.readInt();
11697 C = OMPFromClause::CreateEmpty(Context, Sizes);
11698 break;
11699 }
11700 case OMPC_use_device_ptr: {
11701 OMPMappableExprListSizeTy Sizes;
11702 Sizes.NumVars = Record.readInt();
11703 Sizes.NumUniqueDeclarations = Record.readInt();
11704 Sizes.NumComponentLists = Record.readInt();
11705 Sizes.NumComponents = Record.readInt();
11706 C = OMPUseDevicePtrClause::CreateEmpty(Context, Sizes);
11707 break;
11708 }
11709 case OMPC_is_device_ptr: {
11710 OMPMappableExprListSizeTy Sizes;
11711 Sizes.NumVars = Record.readInt();
11712 Sizes.NumUniqueDeclarations = Record.readInt();
11713 Sizes.NumComponentLists = Record.readInt();
11714 Sizes.NumComponents = Record.readInt();
11715 C = OMPIsDevicePtrClause::CreateEmpty(Context, Sizes);
11716 break;
11717 }
11718 case OMPC_allocate:
11719 C = OMPAllocateClause::CreateEmpty(Context, Record.readInt());
11720 break;
11721 case OMPC_nontemporal:
11722 C = OMPNontemporalClause::CreateEmpty(Context, Record.readInt());
11723 break;
11724 }
11725 assert(C && "Unknown OMPClause type");
11726
11727 Visit(C);
11728 C->setLocStart(Record.readSourceLocation());
11729 C->setLocEnd(Record.readSourceLocation());
11730
11731 return C;
11732 }
11733
VisitOMPClauseWithPreInit(OMPClauseWithPreInit * C)11734 void OMPClauseReader::VisitOMPClauseWithPreInit(OMPClauseWithPreInit *C) {
11735 C->setPreInitStmt(Record.readSubStmt(),
11736 static_cast<OpenMPDirectiveKind>(Record.readInt()));
11737 }
11738
VisitOMPClauseWithPostUpdate(OMPClauseWithPostUpdate * C)11739 void OMPClauseReader::VisitOMPClauseWithPostUpdate(OMPClauseWithPostUpdate *C) {
11740 VisitOMPClauseWithPreInit(C);
11741 C->setPostUpdateExpr(Record.readSubExpr());
11742 }
11743
VisitOMPIfClause(OMPIfClause * C)11744 void OMPClauseReader::VisitOMPIfClause(OMPIfClause *C) {
11745 VisitOMPClauseWithPreInit(C);
11746 C->setNameModifier(static_cast<OpenMPDirectiveKind>(Record.readInt()));
11747 C->setNameModifierLoc(Record.readSourceLocation());
11748 C->setColonLoc(Record.readSourceLocation());
11749 C->setCondition(Record.readSubExpr());
11750 C->setLParenLoc(Record.readSourceLocation());
11751 }
11752
VisitOMPFinalClause(OMPFinalClause * C)11753 void OMPClauseReader::VisitOMPFinalClause(OMPFinalClause *C) {
11754 VisitOMPClauseWithPreInit(C);
11755 C->setCondition(Record.readSubExpr());
11756 C->setLParenLoc(Record.readSourceLocation());
11757 }
11758
VisitOMPNumThreadsClause(OMPNumThreadsClause * C)11759 void OMPClauseReader::VisitOMPNumThreadsClause(OMPNumThreadsClause *C) {
11760 VisitOMPClauseWithPreInit(C);
11761 C->setNumThreads(Record.readSubExpr());
11762 C->setLParenLoc(Record.readSourceLocation());
11763 }
11764
VisitOMPSafelenClause(OMPSafelenClause * C)11765 void OMPClauseReader::VisitOMPSafelenClause(OMPSafelenClause *C) {
11766 C->setSafelen(Record.readSubExpr());
11767 C->setLParenLoc(Record.readSourceLocation());
11768 }
11769
VisitOMPSimdlenClause(OMPSimdlenClause * C)11770 void OMPClauseReader::VisitOMPSimdlenClause(OMPSimdlenClause *C) {
11771 C->setSimdlen(Record.readSubExpr());
11772 C->setLParenLoc(Record.readSourceLocation());
11773 }
11774
VisitOMPAllocatorClause(OMPAllocatorClause * C)11775 void OMPClauseReader::VisitOMPAllocatorClause(OMPAllocatorClause *C) {
11776 C->setAllocator(Record.readExpr());
11777 C->setLParenLoc(Record.readSourceLocation());
11778 }
11779
VisitOMPCollapseClause(OMPCollapseClause * C)11780 void OMPClauseReader::VisitOMPCollapseClause(OMPCollapseClause *C) {
11781 C->setNumForLoops(Record.readSubExpr());
11782 C->setLParenLoc(Record.readSourceLocation());
11783 }
11784
VisitOMPDefaultClause(OMPDefaultClause * C)11785 void OMPClauseReader::VisitOMPDefaultClause(OMPDefaultClause *C) {
11786 C->setDefaultKind(
11787 static_cast<OpenMPDefaultClauseKind>(Record.readInt()));
11788 C->setLParenLoc(Record.readSourceLocation());
11789 C->setDefaultKindKwLoc(Record.readSourceLocation());
11790 }
11791
VisitOMPProcBindClause(OMPProcBindClause * C)11792 void OMPClauseReader::VisitOMPProcBindClause(OMPProcBindClause *C) {
11793 C->setProcBindKind(static_cast<llvm::omp::ProcBindKind>(Record.readInt()));
11794 C->setLParenLoc(Record.readSourceLocation());
11795 C->setProcBindKindKwLoc(Record.readSourceLocation());
11796 }
11797
VisitOMPScheduleClause(OMPScheduleClause * C)11798 void OMPClauseReader::VisitOMPScheduleClause(OMPScheduleClause *C) {
11799 VisitOMPClauseWithPreInit(C);
11800 C->setScheduleKind(
11801 static_cast<OpenMPScheduleClauseKind>(Record.readInt()));
11802 C->setFirstScheduleModifier(
11803 static_cast<OpenMPScheduleClauseModifier>(Record.readInt()));
11804 C->setSecondScheduleModifier(
11805 static_cast<OpenMPScheduleClauseModifier>(Record.readInt()));
11806 C->setChunkSize(Record.readSubExpr());
11807 C->setLParenLoc(Record.readSourceLocation());
11808 C->setFirstScheduleModifierLoc(Record.readSourceLocation());
11809 C->setSecondScheduleModifierLoc(Record.readSourceLocation());
11810 C->setScheduleKindLoc(Record.readSourceLocation());
11811 C->setCommaLoc(Record.readSourceLocation());
11812 }
11813
VisitOMPOrderedClause(OMPOrderedClause * C)11814 void OMPClauseReader::VisitOMPOrderedClause(OMPOrderedClause *C) {
11815 C->setNumForLoops(Record.readSubExpr());
11816 for (unsigned I = 0, E = C->NumberOfLoops; I < E; ++I)
11817 C->setLoopNumIterations(I, Record.readSubExpr());
11818 for (unsigned I = 0, E = C->NumberOfLoops; I < E; ++I)
11819 C->setLoopCounter(I, Record.readSubExpr());
11820 C->setLParenLoc(Record.readSourceLocation());
11821 }
11822
VisitOMPNowaitClause(OMPNowaitClause *)11823 void OMPClauseReader::VisitOMPNowaitClause(OMPNowaitClause *) {}
11824
VisitOMPUntiedClause(OMPUntiedClause *)11825 void OMPClauseReader::VisitOMPUntiedClause(OMPUntiedClause *) {}
11826
VisitOMPMergeableClause(OMPMergeableClause *)11827 void OMPClauseReader::VisitOMPMergeableClause(OMPMergeableClause *) {}
11828
VisitOMPReadClause(OMPReadClause *)11829 void OMPClauseReader::VisitOMPReadClause(OMPReadClause *) {}
11830
VisitOMPWriteClause(OMPWriteClause *)11831 void OMPClauseReader::VisitOMPWriteClause(OMPWriteClause *) {}
11832
VisitOMPUpdateClause(OMPUpdateClause *)11833 void OMPClauseReader::VisitOMPUpdateClause(OMPUpdateClause *) {}
11834
VisitOMPCaptureClause(OMPCaptureClause *)11835 void OMPClauseReader::VisitOMPCaptureClause(OMPCaptureClause *) {}
11836
VisitOMPSeqCstClause(OMPSeqCstClause *)11837 void OMPClauseReader::VisitOMPSeqCstClause(OMPSeqCstClause *) {}
11838
VisitOMPThreadsClause(OMPThreadsClause *)11839 void OMPClauseReader::VisitOMPThreadsClause(OMPThreadsClause *) {}
11840
VisitOMPSIMDClause(OMPSIMDClause *)11841 void OMPClauseReader::VisitOMPSIMDClause(OMPSIMDClause *) {}
11842
VisitOMPNogroupClause(OMPNogroupClause *)11843 void OMPClauseReader::VisitOMPNogroupClause(OMPNogroupClause *) {}
11844
VisitOMPUnifiedAddressClause(OMPUnifiedAddressClause *)11845 void OMPClauseReader::VisitOMPUnifiedAddressClause(OMPUnifiedAddressClause *) {}
11846
VisitOMPUnifiedSharedMemoryClause(OMPUnifiedSharedMemoryClause *)11847 void OMPClauseReader::VisitOMPUnifiedSharedMemoryClause(
11848 OMPUnifiedSharedMemoryClause *) {}
11849
VisitOMPReverseOffloadClause(OMPReverseOffloadClause *)11850 void OMPClauseReader::VisitOMPReverseOffloadClause(OMPReverseOffloadClause *) {}
11851
11852 void
VisitOMPDynamicAllocatorsClause(OMPDynamicAllocatorsClause *)11853 OMPClauseReader::VisitOMPDynamicAllocatorsClause(OMPDynamicAllocatorsClause *) {
11854 }
11855
VisitOMPAtomicDefaultMemOrderClause(OMPAtomicDefaultMemOrderClause * C)11856 void OMPClauseReader::VisitOMPAtomicDefaultMemOrderClause(
11857 OMPAtomicDefaultMemOrderClause *C) {
11858 C->setAtomicDefaultMemOrderKind(
11859 static_cast<OpenMPAtomicDefaultMemOrderClauseKind>(Record.readInt()));
11860 C->setLParenLoc(Record.readSourceLocation());
11861 C->setAtomicDefaultMemOrderKindKwLoc(Record.readSourceLocation());
11862 }
11863
VisitOMPPrivateClause(OMPPrivateClause * C)11864 void OMPClauseReader::VisitOMPPrivateClause(OMPPrivateClause *C) {
11865 C->setLParenLoc(Record.readSourceLocation());
11866 unsigned NumVars = C->varlist_size();
11867 SmallVector<Expr *, 16> Vars;
11868 Vars.reserve(NumVars);
11869 for (unsigned i = 0; i != NumVars; ++i)
11870 Vars.push_back(Record.readSubExpr());
11871 C->setVarRefs(Vars);
11872 Vars.clear();
11873 for (unsigned i = 0; i != NumVars; ++i)
11874 Vars.push_back(Record.readSubExpr());
11875 C->setPrivateCopies(Vars);
11876 }
11877
VisitOMPFirstprivateClause(OMPFirstprivateClause * C)11878 void OMPClauseReader::VisitOMPFirstprivateClause(OMPFirstprivateClause *C) {
11879 VisitOMPClauseWithPreInit(C);
11880 C->setLParenLoc(Record.readSourceLocation());
11881 unsigned NumVars = C->varlist_size();
11882 SmallVector<Expr *, 16> Vars;
11883 Vars.reserve(NumVars);
11884 for (unsigned i = 0; i != NumVars; ++i)
11885 Vars.push_back(Record.readSubExpr());
11886 C->setVarRefs(Vars);
11887 Vars.clear();
11888 for (unsigned i = 0; i != NumVars; ++i)
11889 Vars.push_back(Record.readSubExpr());
11890 C->setPrivateCopies(Vars);
11891 Vars.clear();
11892 for (unsigned i = 0; i != NumVars; ++i)
11893 Vars.push_back(Record.readSubExpr());
11894 C->setInits(Vars);
11895 }
11896
VisitOMPLastprivateClause(OMPLastprivateClause * C)11897 void OMPClauseReader::VisitOMPLastprivateClause(OMPLastprivateClause *C) {
11898 VisitOMPClauseWithPostUpdate(C);
11899 C->setLParenLoc(Record.readSourceLocation());
11900 C->setKind(Record.readEnum<OpenMPLastprivateModifier>());
11901 C->setKindLoc(Record.readSourceLocation());
11902 C->setColonLoc(Record.readSourceLocation());
11903 unsigned NumVars = C->varlist_size();
11904 SmallVector<Expr *, 16> Vars;
11905 Vars.reserve(NumVars);
11906 for (unsigned i = 0; i != NumVars; ++i)
11907 Vars.push_back(Record.readSubExpr());
11908 C->setVarRefs(Vars);
11909 Vars.clear();
11910 for (unsigned i = 0; i != NumVars; ++i)
11911 Vars.push_back(Record.readSubExpr());
11912 C->setPrivateCopies(Vars);
11913 Vars.clear();
11914 for (unsigned i = 0; i != NumVars; ++i)
11915 Vars.push_back(Record.readSubExpr());
11916 C->setSourceExprs(Vars);
11917 Vars.clear();
11918 for (unsigned i = 0; i != NumVars; ++i)
11919 Vars.push_back(Record.readSubExpr());
11920 C->setDestinationExprs(Vars);
11921 Vars.clear();
11922 for (unsigned i = 0; i != NumVars; ++i)
11923 Vars.push_back(Record.readSubExpr());
11924 C->setAssignmentOps(Vars);
11925 }
11926
VisitOMPSharedClause(OMPSharedClause * C)11927 void OMPClauseReader::VisitOMPSharedClause(OMPSharedClause *C) {
11928 C->setLParenLoc(Record.readSourceLocation());
11929 unsigned NumVars = C->varlist_size();
11930 SmallVector<Expr *, 16> Vars;
11931 Vars.reserve(NumVars);
11932 for (unsigned i = 0; i != NumVars; ++i)
11933 Vars.push_back(Record.readSubExpr());
11934 C->setVarRefs(Vars);
11935 }
11936
VisitOMPReductionClause(OMPReductionClause * C)11937 void OMPClauseReader::VisitOMPReductionClause(OMPReductionClause *C) {
11938 VisitOMPClauseWithPostUpdate(C);
11939 C->setLParenLoc(Record.readSourceLocation());
11940 C->setColonLoc(Record.readSourceLocation());
11941 NestedNameSpecifierLoc NNSL = Record.readNestedNameSpecifierLoc();
11942 DeclarationNameInfo DNI = Record.readDeclarationNameInfo();
11943 C->setQualifierLoc(NNSL);
11944 C->setNameInfo(DNI);
11945
11946 unsigned NumVars = C->varlist_size();
11947 SmallVector<Expr *, 16> Vars;
11948 Vars.reserve(NumVars);
11949 for (unsigned i = 0; i != NumVars; ++i)
11950 Vars.push_back(Record.readSubExpr());
11951 C->setVarRefs(Vars);
11952 Vars.clear();
11953 for (unsigned i = 0; i != NumVars; ++i)
11954 Vars.push_back(Record.readSubExpr());
11955 C->setPrivates(Vars);
11956 Vars.clear();
11957 for (unsigned i = 0; i != NumVars; ++i)
11958 Vars.push_back(Record.readSubExpr());
11959 C->setLHSExprs(Vars);
11960 Vars.clear();
11961 for (unsigned i = 0; i != NumVars; ++i)
11962 Vars.push_back(Record.readSubExpr());
11963 C->setRHSExprs(Vars);
11964 Vars.clear();
11965 for (unsigned i = 0; i != NumVars; ++i)
11966 Vars.push_back(Record.readSubExpr());
11967 C->setReductionOps(Vars);
11968 }
11969
VisitOMPTaskReductionClause(OMPTaskReductionClause * C)11970 void OMPClauseReader::VisitOMPTaskReductionClause(OMPTaskReductionClause *C) {
11971 VisitOMPClauseWithPostUpdate(C);
11972 C->setLParenLoc(Record.readSourceLocation());
11973 C->setColonLoc(Record.readSourceLocation());
11974 NestedNameSpecifierLoc NNSL = Record.readNestedNameSpecifierLoc();
11975 DeclarationNameInfo DNI = Record.readDeclarationNameInfo();
11976 C->setQualifierLoc(NNSL);
11977 C->setNameInfo(DNI);
11978
11979 unsigned NumVars = C->varlist_size();
11980 SmallVector<Expr *, 16> Vars;
11981 Vars.reserve(NumVars);
11982 for (unsigned I = 0; I != NumVars; ++I)
11983 Vars.push_back(Record.readSubExpr());
11984 C->setVarRefs(Vars);
11985 Vars.clear();
11986 for (unsigned I = 0; I != NumVars; ++I)
11987 Vars.push_back(Record.readSubExpr());
11988 C->setPrivates(Vars);
11989 Vars.clear();
11990 for (unsigned I = 0; I != NumVars; ++I)
11991 Vars.push_back(Record.readSubExpr());
11992 C->setLHSExprs(Vars);
11993 Vars.clear();
11994 for (unsigned I = 0; I != NumVars; ++I)
11995 Vars.push_back(Record.readSubExpr());
11996 C->setRHSExprs(Vars);
11997 Vars.clear();
11998 for (unsigned I = 0; I != NumVars; ++I)
11999 Vars.push_back(Record.readSubExpr());
12000 C->setReductionOps(Vars);
12001 }
12002
VisitOMPInReductionClause(OMPInReductionClause * C)12003 void OMPClauseReader::VisitOMPInReductionClause(OMPInReductionClause *C) {
12004 VisitOMPClauseWithPostUpdate(C);
12005 C->setLParenLoc(Record.readSourceLocation());
12006 C->setColonLoc(Record.readSourceLocation());
12007 NestedNameSpecifierLoc NNSL = Record.readNestedNameSpecifierLoc();
12008 DeclarationNameInfo DNI = Record.readDeclarationNameInfo();
12009 C->setQualifierLoc(NNSL);
12010 C->setNameInfo(DNI);
12011
12012 unsigned NumVars = C->varlist_size();
12013 SmallVector<Expr *, 16> Vars;
12014 Vars.reserve(NumVars);
12015 for (unsigned I = 0; I != NumVars; ++I)
12016 Vars.push_back(Record.readSubExpr());
12017 C->setVarRefs(Vars);
12018 Vars.clear();
12019 for (unsigned I = 0; I != NumVars; ++I)
12020 Vars.push_back(Record.readSubExpr());
12021 C->setPrivates(Vars);
12022 Vars.clear();
12023 for (unsigned I = 0; I != NumVars; ++I)
12024 Vars.push_back(Record.readSubExpr());
12025 C->setLHSExprs(Vars);
12026 Vars.clear();
12027 for (unsigned I = 0; I != NumVars; ++I)
12028 Vars.push_back(Record.readSubExpr());
12029 C->setRHSExprs(Vars);
12030 Vars.clear();
12031 for (unsigned I = 0; I != NumVars; ++I)
12032 Vars.push_back(Record.readSubExpr());
12033 C->setReductionOps(Vars);
12034 Vars.clear();
12035 for (unsigned I = 0; I != NumVars; ++I)
12036 Vars.push_back(Record.readSubExpr());
12037 C->setTaskgroupDescriptors(Vars);
12038 }
12039
VisitOMPLinearClause(OMPLinearClause * C)12040 void OMPClauseReader::VisitOMPLinearClause(OMPLinearClause *C) {
12041 VisitOMPClauseWithPostUpdate(C);
12042 C->setLParenLoc(Record.readSourceLocation());
12043 C->setColonLoc(Record.readSourceLocation());
12044 C->setModifier(static_cast<OpenMPLinearClauseKind>(Record.readInt()));
12045 C->setModifierLoc(Record.readSourceLocation());
12046 unsigned NumVars = C->varlist_size();
12047 SmallVector<Expr *, 16> Vars;
12048 Vars.reserve(NumVars);
12049 for (unsigned i = 0; i != NumVars; ++i)
12050 Vars.push_back(Record.readSubExpr());
12051 C->setVarRefs(Vars);
12052 Vars.clear();
12053 for (unsigned i = 0; i != NumVars; ++i)
12054 Vars.push_back(Record.readSubExpr());
12055 C->setPrivates(Vars);
12056 Vars.clear();
12057 for (unsigned i = 0; i != NumVars; ++i)
12058 Vars.push_back(Record.readSubExpr());
12059 C->setInits(Vars);
12060 Vars.clear();
12061 for (unsigned i = 0; i != NumVars; ++i)
12062 Vars.push_back(Record.readSubExpr());
12063 C->setUpdates(Vars);
12064 Vars.clear();
12065 for (unsigned i = 0; i != NumVars; ++i)
12066 Vars.push_back(Record.readSubExpr());
12067 C->setFinals(Vars);
12068 C->setStep(Record.readSubExpr());
12069 C->setCalcStep(Record.readSubExpr());
12070 Vars.clear();
12071 for (unsigned I = 0; I != NumVars + 1; ++I)
12072 Vars.push_back(Record.readSubExpr());
12073 C->setUsedExprs(Vars);
12074 }
12075
VisitOMPAlignedClause(OMPAlignedClause * C)12076 void OMPClauseReader::VisitOMPAlignedClause(OMPAlignedClause *C) {
12077 C->setLParenLoc(Record.readSourceLocation());
12078 C->setColonLoc(Record.readSourceLocation());
12079 unsigned NumVars = C->varlist_size();
12080 SmallVector<Expr *, 16> Vars;
12081 Vars.reserve(NumVars);
12082 for (unsigned i = 0; i != NumVars; ++i)
12083 Vars.push_back(Record.readSubExpr());
12084 C->setVarRefs(Vars);
12085 C->setAlignment(Record.readSubExpr());
12086 }
12087
VisitOMPCopyinClause(OMPCopyinClause * C)12088 void OMPClauseReader::VisitOMPCopyinClause(OMPCopyinClause *C) {
12089 C->setLParenLoc(Record.readSourceLocation());
12090 unsigned NumVars = C->varlist_size();
12091 SmallVector<Expr *, 16> Exprs;
12092 Exprs.reserve(NumVars);
12093 for (unsigned i = 0; i != NumVars; ++i)
12094 Exprs.push_back(Record.readSubExpr());
12095 C->setVarRefs(Exprs);
12096 Exprs.clear();
12097 for (unsigned i = 0; i != NumVars; ++i)
12098 Exprs.push_back(Record.readSubExpr());
12099 C->setSourceExprs(Exprs);
12100 Exprs.clear();
12101 for (unsigned i = 0; i != NumVars; ++i)
12102 Exprs.push_back(Record.readSubExpr());
12103 C->setDestinationExprs(Exprs);
12104 Exprs.clear();
12105 for (unsigned i = 0; i != NumVars; ++i)
12106 Exprs.push_back(Record.readSubExpr());
12107 C->setAssignmentOps(Exprs);
12108 }
12109
VisitOMPCopyprivateClause(OMPCopyprivateClause * C)12110 void OMPClauseReader::VisitOMPCopyprivateClause(OMPCopyprivateClause *C) {
12111 C->setLParenLoc(Record.readSourceLocation());
12112 unsigned NumVars = C->varlist_size();
12113 SmallVector<Expr *, 16> Exprs;
12114 Exprs.reserve(NumVars);
12115 for (unsigned i = 0; i != NumVars; ++i)
12116 Exprs.push_back(Record.readSubExpr());
12117 C->setVarRefs(Exprs);
12118 Exprs.clear();
12119 for (unsigned i = 0; i != NumVars; ++i)
12120 Exprs.push_back(Record.readSubExpr());
12121 C->setSourceExprs(Exprs);
12122 Exprs.clear();
12123 for (unsigned i = 0; i != NumVars; ++i)
12124 Exprs.push_back(Record.readSubExpr());
12125 C->setDestinationExprs(Exprs);
12126 Exprs.clear();
12127 for (unsigned i = 0; i != NumVars; ++i)
12128 Exprs.push_back(Record.readSubExpr());
12129 C->setAssignmentOps(Exprs);
12130 }
12131
VisitOMPFlushClause(OMPFlushClause * C)12132 void OMPClauseReader::VisitOMPFlushClause(OMPFlushClause *C) {
12133 C->setLParenLoc(Record.readSourceLocation());
12134 unsigned NumVars = C->varlist_size();
12135 SmallVector<Expr *, 16> Vars;
12136 Vars.reserve(NumVars);
12137 for (unsigned i = 0; i != NumVars; ++i)
12138 Vars.push_back(Record.readSubExpr());
12139 C->setVarRefs(Vars);
12140 }
12141
VisitOMPDependClause(OMPDependClause * C)12142 void OMPClauseReader::VisitOMPDependClause(OMPDependClause *C) {
12143 C->setLParenLoc(Record.readSourceLocation());
12144 C->setDependencyKind(
12145 static_cast<OpenMPDependClauseKind>(Record.readInt()));
12146 C->setDependencyLoc(Record.readSourceLocation());
12147 C->setColonLoc(Record.readSourceLocation());
12148 unsigned NumVars = C->varlist_size();
12149 SmallVector<Expr *, 16> Vars;
12150 Vars.reserve(NumVars);
12151 for (unsigned I = 0; I != NumVars; ++I)
12152 Vars.push_back(Record.readSubExpr());
12153 C->setVarRefs(Vars);
12154 for (unsigned I = 0, E = C->getNumLoops(); I < E; ++I)
12155 C->setLoopData(I, Record.readSubExpr());
12156 }
12157
VisitOMPDeviceClause(OMPDeviceClause * C)12158 void OMPClauseReader::VisitOMPDeviceClause(OMPDeviceClause *C) {
12159 VisitOMPClauseWithPreInit(C);
12160 C->setDevice(Record.readSubExpr());
12161 C->setLParenLoc(Record.readSourceLocation());
12162 }
12163
VisitOMPMapClause(OMPMapClause * C)12164 void OMPClauseReader::VisitOMPMapClause(OMPMapClause *C) {
12165 C->setLParenLoc(Record.readSourceLocation());
12166 for (unsigned I = 0; I < OMPMapClause::NumberOfModifiers; ++I) {
12167 C->setMapTypeModifier(
12168 I, static_cast<OpenMPMapModifierKind>(Record.readInt()));
12169 C->setMapTypeModifierLoc(I, Record.readSourceLocation());
12170 }
12171 C->setMapperQualifierLoc(Record.readNestedNameSpecifierLoc());
12172 C->setMapperIdInfo(Record.readDeclarationNameInfo());
12173 C->setMapType(
12174 static_cast<OpenMPMapClauseKind>(Record.readInt()));
12175 C->setMapLoc(Record.readSourceLocation());
12176 C->setColonLoc(Record.readSourceLocation());
12177 auto NumVars = C->varlist_size();
12178 auto UniqueDecls = C->getUniqueDeclarationsNum();
12179 auto TotalLists = C->getTotalComponentListNum();
12180 auto TotalComponents = C->getTotalComponentsNum();
12181
12182 SmallVector<Expr *, 16> Vars;
12183 Vars.reserve(NumVars);
12184 for (unsigned i = 0; i != NumVars; ++i)
12185 Vars.push_back(Record.readExpr());
12186 C->setVarRefs(Vars);
12187
12188 SmallVector<Expr *, 16> UDMappers;
12189 UDMappers.reserve(NumVars);
12190 for (unsigned I = 0; I < NumVars; ++I)
12191 UDMappers.push_back(Record.readExpr());
12192 C->setUDMapperRefs(UDMappers);
12193
12194 SmallVector<ValueDecl *, 16> Decls;
12195 Decls.reserve(UniqueDecls);
12196 for (unsigned i = 0; i < UniqueDecls; ++i)
12197 Decls.push_back(Record.readDeclAs<ValueDecl>());
12198 C->setUniqueDecls(Decls);
12199
12200 SmallVector<unsigned, 16> ListsPerDecl;
12201 ListsPerDecl.reserve(UniqueDecls);
12202 for (unsigned i = 0; i < UniqueDecls; ++i)
12203 ListsPerDecl.push_back(Record.readInt());
12204 C->setDeclNumLists(ListsPerDecl);
12205
12206 SmallVector<unsigned, 32> ListSizes;
12207 ListSizes.reserve(TotalLists);
12208 for (unsigned i = 0; i < TotalLists; ++i)
12209 ListSizes.push_back(Record.readInt());
12210 C->setComponentListSizes(ListSizes);
12211
12212 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12213 Components.reserve(TotalComponents);
12214 for (unsigned i = 0; i < TotalComponents; ++i) {
12215 Expr *AssociatedExpr = Record.readExpr();
12216 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12217 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12218 AssociatedExpr, AssociatedDecl));
12219 }
12220 C->setComponents(Components, ListSizes);
12221 }
12222
VisitOMPAllocateClause(OMPAllocateClause * C)12223 void OMPClauseReader::VisitOMPAllocateClause(OMPAllocateClause *C) {
12224 C->setLParenLoc(Record.readSourceLocation());
12225 C->setColonLoc(Record.readSourceLocation());
12226 C->setAllocator(Record.readSubExpr());
12227 unsigned NumVars = C->varlist_size();
12228 SmallVector<Expr *, 16> Vars;
12229 Vars.reserve(NumVars);
12230 for (unsigned i = 0; i != NumVars; ++i)
12231 Vars.push_back(Record.readSubExpr());
12232 C->setVarRefs(Vars);
12233 }
12234
VisitOMPNumTeamsClause(OMPNumTeamsClause * C)12235 void OMPClauseReader::VisitOMPNumTeamsClause(OMPNumTeamsClause *C) {
12236 VisitOMPClauseWithPreInit(C);
12237 C->setNumTeams(Record.readSubExpr());
12238 C->setLParenLoc(Record.readSourceLocation());
12239 }
12240
VisitOMPThreadLimitClause(OMPThreadLimitClause * C)12241 void OMPClauseReader::VisitOMPThreadLimitClause(OMPThreadLimitClause *C) {
12242 VisitOMPClauseWithPreInit(C);
12243 C->setThreadLimit(Record.readSubExpr());
12244 C->setLParenLoc(Record.readSourceLocation());
12245 }
12246
VisitOMPPriorityClause(OMPPriorityClause * C)12247 void OMPClauseReader::VisitOMPPriorityClause(OMPPriorityClause *C) {
12248 VisitOMPClauseWithPreInit(C);
12249 C->setPriority(Record.readSubExpr());
12250 C->setLParenLoc(Record.readSourceLocation());
12251 }
12252
VisitOMPGrainsizeClause(OMPGrainsizeClause * C)12253 void OMPClauseReader::VisitOMPGrainsizeClause(OMPGrainsizeClause *C) {
12254 VisitOMPClauseWithPreInit(C);
12255 C->setGrainsize(Record.readSubExpr());
12256 C->setLParenLoc(Record.readSourceLocation());
12257 }
12258
VisitOMPNumTasksClause(OMPNumTasksClause * C)12259 void OMPClauseReader::VisitOMPNumTasksClause(OMPNumTasksClause *C) {
12260 VisitOMPClauseWithPreInit(C);
12261 C->setNumTasks(Record.readSubExpr());
12262 C->setLParenLoc(Record.readSourceLocation());
12263 }
12264
VisitOMPHintClause(OMPHintClause * C)12265 void OMPClauseReader::VisitOMPHintClause(OMPHintClause *C) {
12266 C->setHint(Record.readSubExpr());
12267 C->setLParenLoc(Record.readSourceLocation());
12268 }
12269
VisitOMPDistScheduleClause(OMPDistScheduleClause * C)12270 void OMPClauseReader::VisitOMPDistScheduleClause(OMPDistScheduleClause *C) {
12271 VisitOMPClauseWithPreInit(C);
12272 C->setDistScheduleKind(
12273 static_cast<OpenMPDistScheduleClauseKind>(Record.readInt()));
12274 C->setChunkSize(Record.readSubExpr());
12275 C->setLParenLoc(Record.readSourceLocation());
12276 C->setDistScheduleKindLoc(Record.readSourceLocation());
12277 C->setCommaLoc(Record.readSourceLocation());
12278 }
12279
VisitOMPDefaultmapClause(OMPDefaultmapClause * C)12280 void OMPClauseReader::VisitOMPDefaultmapClause(OMPDefaultmapClause *C) {
12281 C->setDefaultmapKind(
12282 static_cast<OpenMPDefaultmapClauseKind>(Record.readInt()));
12283 C->setDefaultmapModifier(
12284 static_cast<OpenMPDefaultmapClauseModifier>(Record.readInt()));
12285 C->setLParenLoc(Record.readSourceLocation());
12286 C->setDefaultmapModifierLoc(Record.readSourceLocation());
12287 C->setDefaultmapKindLoc(Record.readSourceLocation());
12288 }
12289
VisitOMPToClause(OMPToClause * C)12290 void OMPClauseReader::VisitOMPToClause(OMPToClause *C) {
12291 C->setLParenLoc(Record.readSourceLocation());
12292 C->setMapperQualifierLoc(Record.readNestedNameSpecifierLoc());
12293 C->setMapperIdInfo(Record.readDeclarationNameInfo());
12294 auto NumVars = C->varlist_size();
12295 auto UniqueDecls = C->getUniqueDeclarationsNum();
12296 auto TotalLists = C->getTotalComponentListNum();
12297 auto TotalComponents = C->getTotalComponentsNum();
12298
12299 SmallVector<Expr *, 16> Vars;
12300 Vars.reserve(NumVars);
12301 for (unsigned i = 0; i != NumVars; ++i)
12302 Vars.push_back(Record.readSubExpr());
12303 C->setVarRefs(Vars);
12304
12305 SmallVector<Expr *, 16> UDMappers;
12306 UDMappers.reserve(NumVars);
12307 for (unsigned I = 0; I < NumVars; ++I)
12308 UDMappers.push_back(Record.readSubExpr());
12309 C->setUDMapperRefs(UDMappers);
12310
12311 SmallVector<ValueDecl *, 16> Decls;
12312 Decls.reserve(UniqueDecls);
12313 for (unsigned i = 0; i < UniqueDecls; ++i)
12314 Decls.push_back(Record.readDeclAs<ValueDecl>());
12315 C->setUniqueDecls(Decls);
12316
12317 SmallVector<unsigned, 16> ListsPerDecl;
12318 ListsPerDecl.reserve(UniqueDecls);
12319 for (unsigned i = 0; i < UniqueDecls; ++i)
12320 ListsPerDecl.push_back(Record.readInt());
12321 C->setDeclNumLists(ListsPerDecl);
12322
12323 SmallVector<unsigned, 32> ListSizes;
12324 ListSizes.reserve(TotalLists);
12325 for (unsigned i = 0; i < TotalLists; ++i)
12326 ListSizes.push_back(Record.readInt());
12327 C->setComponentListSizes(ListSizes);
12328
12329 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12330 Components.reserve(TotalComponents);
12331 for (unsigned i = 0; i < TotalComponents; ++i) {
12332 Expr *AssociatedExpr = Record.readSubExpr();
12333 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12334 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12335 AssociatedExpr, AssociatedDecl));
12336 }
12337 C->setComponents(Components, ListSizes);
12338 }
12339
VisitOMPFromClause(OMPFromClause * C)12340 void OMPClauseReader::VisitOMPFromClause(OMPFromClause *C) {
12341 C->setLParenLoc(Record.readSourceLocation());
12342 C->setMapperQualifierLoc(Record.readNestedNameSpecifierLoc());
12343 C->setMapperIdInfo(Record.readDeclarationNameInfo());
12344 auto NumVars = C->varlist_size();
12345 auto UniqueDecls = C->getUniqueDeclarationsNum();
12346 auto TotalLists = C->getTotalComponentListNum();
12347 auto TotalComponents = C->getTotalComponentsNum();
12348
12349 SmallVector<Expr *, 16> Vars;
12350 Vars.reserve(NumVars);
12351 for (unsigned i = 0; i != NumVars; ++i)
12352 Vars.push_back(Record.readSubExpr());
12353 C->setVarRefs(Vars);
12354
12355 SmallVector<Expr *, 16> UDMappers;
12356 UDMappers.reserve(NumVars);
12357 for (unsigned I = 0; I < NumVars; ++I)
12358 UDMappers.push_back(Record.readSubExpr());
12359 C->setUDMapperRefs(UDMappers);
12360
12361 SmallVector<ValueDecl *, 16> Decls;
12362 Decls.reserve(UniqueDecls);
12363 for (unsigned i = 0; i < UniqueDecls; ++i)
12364 Decls.push_back(Record.readDeclAs<ValueDecl>());
12365 C->setUniqueDecls(Decls);
12366
12367 SmallVector<unsigned, 16> ListsPerDecl;
12368 ListsPerDecl.reserve(UniqueDecls);
12369 for (unsigned i = 0; i < UniqueDecls; ++i)
12370 ListsPerDecl.push_back(Record.readInt());
12371 C->setDeclNumLists(ListsPerDecl);
12372
12373 SmallVector<unsigned, 32> ListSizes;
12374 ListSizes.reserve(TotalLists);
12375 for (unsigned i = 0; i < TotalLists; ++i)
12376 ListSizes.push_back(Record.readInt());
12377 C->setComponentListSizes(ListSizes);
12378
12379 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12380 Components.reserve(TotalComponents);
12381 for (unsigned i = 0; i < TotalComponents; ++i) {
12382 Expr *AssociatedExpr = Record.readSubExpr();
12383 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12384 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12385 AssociatedExpr, AssociatedDecl));
12386 }
12387 C->setComponents(Components, ListSizes);
12388 }
12389
VisitOMPUseDevicePtrClause(OMPUseDevicePtrClause * C)12390 void OMPClauseReader::VisitOMPUseDevicePtrClause(OMPUseDevicePtrClause *C) {
12391 C->setLParenLoc(Record.readSourceLocation());
12392 auto NumVars = C->varlist_size();
12393 auto UniqueDecls = C->getUniqueDeclarationsNum();
12394 auto TotalLists = C->getTotalComponentListNum();
12395 auto TotalComponents = C->getTotalComponentsNum();
12396
12397 SmallVector<Expr *, 16> Vars;
12398 Vars.reserve(NumVars);
12399 for (unsigned i = 0; i != NumVars; ++i)
12400 Vars.push_back(Record.readSubExpr());
12401 C->setVarRefs(Vars);
12402 Vars.clear();
12403 for (unsigned i = 0; i != NumVars; ++i)
12404 Vars.push_back(Record.readSubExpr());
12405 C->setPrivateCopies(Vars);
12406 Vars.clear();
12407 for (unsigned i = 0; i != NumVars; ++i)
12408 Vars.push_back(Record.readSubExpr());
12409 C->setInits(Vars);
12410
12411 SmallVector<ValueDecl *, 16> Decls;
12412 Decls.reserve(UniqueDecls);
12413 for (unsigned i = 0; i < UniqueDecls; ++i)
12414 Decls.push_back(Record.readDeclAs<ValueDecl>());
12415 C->setUniqueDecls(Decls);
12416
12417 SmallVector<unsigned, 16> ListsPerDecl;
12418 ListsPerDecl.reserve(UniqueDecls);
12419 for (unsigned i = 0; i < UniqueDecls; ++i)
12420 ListsPerDecl.push_back(Record.readInt());
12421 C->setDeclNumLists(ListsPerDecl);
12422
12423 SmallVector<unsigned, 32> ListSizes;
12424 ListSizes.reserve(TotalLists);
12425 for (unsigned i = 0; i < TotalLists; ++i)
12426 ListSizes.push_back(Record.readInt());
12427 C->setComponentListSizes(ListSizes);
12428
12429 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12430 Components.reserve(TotalComponents);
12431 for (unsigned i = 0; i < TotalComponents; ++i) {
12432 Expr *AssociatedExpr = Record.readSubExpr();
12433 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12434 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12435 AssociatedExpr, AssociatedDecl));
12436 }
12437 C->setComponents(Components, ListSizes);
12438 }
12439
VisitOMPIsDevicePtrClause(OMPIsDevicePtrClause * C)12440 void OMPClauseReader::VisitOMPIsDevicePtrClause(OMPIsDevicePtrClause *C) {
12441 C->setLParenLoc(Record.readSourceLocation());
12442 auto NumVars = C->varlist_size();
12443 auto UniqueDecls = C->getUniqueDeclarationsNum();
12444 auto TotalLists = C->getTotalComponentListNum();
12445 auto TotalComponents = C->getTotalComponentsNum();
12446
12447 SmallVector<Expr *, 16> Vars;
12448 Vars.reserve(NumVars);
12449 for (unsigned i = 0; i != NumVars; ++i)
12450 Vars.push_back(Record.readSubExpr());
12451 C->setVarRefs(Vars);
12452 Vars.clear();
12453
12454 SmallVector<ValueDecl *, 16> Decls;
12455 Decls.reserve(UniqueDecls);
12456 for (unsigned i = 0; i < UniqueDecls; ++i)
12457 Decls.push_back(Record.readDeclAs<ValueDecl>());
12458 C->setUniqueDecls(Decls);
12459
12460 SmallVector<unsigned, 16> ListsPerDecl;
12461 ListsPerDecl.reserve(UniqueDecls);
12462 for (unsigned i = 0; i < UniqueDecls; ++i)
12463 ListsPerDecl.push_back(Record.readInt());
12464 C->setDeclNumLists(ListsPerDecl);
12465
12466 SmallVector<unsigned, 32> ListSizes;
12467 ListSizes.reserve(TotalLists);
12468 for (unsigned i = 0; i < TotalLists; ++i)
12469 ListSizes.push_back(Record.readInt());
12470 C->setComponentListSizes(ListSizes);
12471
12472 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12473 Components.reserve(TotalComponents);
12474 for (unsigned i = 0; i < TotalComponents; ++i) {
12475 Expr *AssociatedExpr = Record.readSubExpr();
12476 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12477 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12478 AssociatedExpr, AssociatedDecl));
12479 }
12480 C->setComponents(Components, ListSizes);
12481 }
12482
VisitOMPNontemporalClause(OMPNontemporalClause * C)12483 void OMPClauseReader::VisitOMPNontemporalClause(OMPNontemporalClause *C) {
12484 C->setLParenLoc(Record.readSourceLocation());
12485 unsigned NumVars = C->varlist_size();
12486 SmallVector<Expr *, 16> Vars;
12487 Vars.reserve(NumVars);
12488 for (unsigned i = 0; i != NumVars; ++i)
12489 Vars.push_back(Record.readSubExpr());
12490 C->setVarRefs(Vars);
12491 Vars.clear();
12492 Vars.reserve(NumVars);
12493 for (unsigned i = 0; i != NumVars; ++i)
12494 Vars.push_back(Record.readSubExpr());
12495 C->setPrivateRefs(Vars);
12496 }
12497