blob: 187665be52556086c3f515ff811f23918475302b [file] [log] [blame]
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001//===- ASTReader.cpp - AST File Reader ------------------------------------===//
Guy Benyei11169dd2012-12-18 14:30:41 +00002//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// 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
Guy Benyei11169dd2012-12-18 14:30:41 +00006//
7//===----------------------------------------------------------------------===//
8//
9// This file defines the ASTReader class, which reads AST files.
10//
11//===----------------------------------------------------------------------===//
12
Alexey Bataev93dc40d2019-12-20 11:04:57 -050013#include "clang/Basic/OpenMPKinds.h"
John McCallc2f18312019-12-14 03:01:28 -050014#include "clang/Serialization/ASTRecordReader.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000015#include "ASTCommon.h"
16#include "ASTReaderInternals.h"
John McCalld505e572019-12-13 21:54:44 -050017#include "clang/AST/AbstractTypeReader.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000018#include "clang/AST/ASTConsumer.h"
19#include "clang/AST/ASTContext.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000020#include "clang/AST/ASTMutationListener.h"
21#include "clang/AST/ASTUnresolvedSet.h"
22#include "clang/AST/Decl.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000023#include "clang/AST/DeclBase.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000024#include "clang/AST/DeclCXX.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000025#include "clang/AST/DeclFriend.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000026#include "clang/AST/DeclGroup.h"
27#include "clang/AST/DeclObjC.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000028#include "clang/AST/DeclTemplate.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000029#include "clang/AST/DeclarationName.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000030#include "clang/AST/Expr.h"
31#include "clang/AST/ExprCXX.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000032#include "clang/AST/ExternalASTSource.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000033#include "clang/AST/NestedNameSpecifier.h"
John McCallc2f18312019-12-14 03:01:28 -050034#include "clang/AST/OpenMPClause.h"
Richard Trieue7f7ed22017-02-22 01:11:25 +000035#include "clang/AST/ODRHash.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000036#include "clang/AST/RawCommentList.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000037#include "clang/AST/TemplateBase.h"
38#include "clang/AST/TemplateName.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000039#include "clang/AST/Type.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000040#include "clang/AST/TypeLoc.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000041#include "clang/AST/TypeLocVisitor.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000042#include "clang/AST/UnresolvedSet.h"
43#include "clang/Basic/CommentOptions.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000044#include "clang/Basic/Diagnostic.h"
Benjamin Kramerf3ca26982014-05-10 16:31:55 +000045#include "clang/Basic/DiagnosticOptions.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000046#include "clang/Basic/ExceptionSpecificationType.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000047#include "clang/Basic/FileManager.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000048#include "clang/Basic/FileSystemOptions.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000049#include "clang/Basic/IdentifierTable.h"
50#include "clang/Basic/LLVM.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000051#include "clang/Basic/LangOptions.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000052#include "clang/Basic/Module.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000053#include "clang/Basic/ObjCRuntime.h"
54#include "clang/Basic/OperatorKinds.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000055#include "clang/Basic/PragmaKinds.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000056#include "clang/Basic/Sanitizers.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000057#include "clang/Basic/SourceLocation.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000058#include "clang/Basic/SourceManager.h"
59#include "clang/Basic/SourceManagerInternals.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000060#include "clang/Basic/Specifiers.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000061#include "clang/Basic/TargetInfo.h"
62#include "clang/Basic/TargetOptions.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000063#include "clang/Basic/TokenKinds.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000064#include "clang/Basic/Version.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000065#include "clang/Lex/HeaderSearch.h"
66#include "clang/Lex/HeaderSearchOptions.h"
67#include "clang/Lex/MacroInfo.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000068#include "clang/Lex/ModuleMap.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000069#include "clang/Lex/PreprocessingRecord.h"
70#include "clang/Lex/Preprocessor.h"
71#include "clang/Lex/PreprocessorOptions.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000072#include "clang/Lex/Token.h"
73#include "clang/Sema/ObjCMethodList.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000074#include "clang/Sema/Scope.h"
75#include "clang/Sema/Sema.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000076#include "clang/Sema/Weak.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000077#include "clang/Serialization/ASTBitCodes.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000078#include "clang/Serialization/ASTDeserializationListener.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000079#include "clang/Serialization/ContinuousRangeMap.h"
Douglas Gregore060e572013-01-25 01:03:03 +000080#include "clang/Serialization/GlobalModuleIndex.h"
Duncan P. N. Exon Smith8bef5cd2019-03-09 17:33:56 +000081#include "clang/Serialization/InMemoryModuleCache.h"
Duncan P. N. Exon Smithf7170d12019-11-21 18:49:05 -080082#include "clang/Serialization/ModuleFile.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000083#include "clang/Serialization/ModuleFileExtension.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000084#include "clang/Serialization/ModuleManager.h"
Richard Trieuf3b00462018-12-12 02:53:59 +000085#include "clang/Serialization/PCHContainerOperations.h"
Guy Benyei11169dd2012-12-18 14:30:41 +000086#include "clang/Serialization/SerializationDiagnostic.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +000087#include "llvm/ADT/APFloat.h"
88#include "llvm/ADT/APInt.h"
89#include "llvm/ADT/APSInt.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000090#include "llvm/ADT/ArrayRef.h"
91#include "llvm/ADT/DenseMap.h"
Serge Pavlovc7ff5b32020-03-26 14:51:09 +070092#include "llvm/ADT/FloatingPointMode.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000093#include "llvm/ADT/FoldingSet.h"
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +000094#include "llvm/ADT/Hashing.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000095#include "llvm/ADT/IntrusiveRefCntPtr.h"
96#include "llvm/ADT/None.h"
97#include "llvm/ADT/Optional.h"
98#include "llvm/ADT/STLExtras.h"
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +000099#include "llvm/ADT/ScopeExit.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000100#include "llvm/ADT/SmallPtrSet.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000101#include "llvm/ADT/SmallString.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000102#include "llvm/ADT/SmallVector.h"
Vedant Kumar48b4f762018-04-14 01:40:48 +0000103#include "llvm/ADT/StringExtras.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000104#include "llvm/ADT/StringMap.h"
105#include "llvm/ADT/StringRef.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000106#include "llvm/ADT/Triple.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000107#include "llvm/ADT/iterator_range.h"
Francis Visoiu Mistrihe0308272019-07-03 22:40:07 +0000108#include "llvm/Bitstream/BitstreamReader.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000109#include "llvm/Support/Casting.h"
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000110#include "llvm/Support/Compiler.h"
Pavel Labathd8c62902018-06-11 10:28:04 +0000111#include "llvm/Support/Compression.h"
Jonas Devlieghere560ce2c2018-02-26 15:16:42 +0000112#include "llvm/Support/DJB.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000113#include "llvm/Support/Endian.h"
George Rimarc39f5492017-01-17 15:45:31 +0000114#include "llvm/Support/Error.h"
Guy Benyei11169dd2012-12-18 14:30:41 +0000115#include "llvm/Support/ErrorHandling.h"
116#include "llvm/Support/FileSystem.h"
117#include "llvm/Support/MemoryBuffer.h"
118#include "llvm/Support/Path.h"
119#include "llvm/Support/SaveAndRestore.h"
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000120#include "llvm/Support/Timer.h"
Pavel Labathd8c62902018-06-11 10:28:04 +0000121#include "llvm/Support/VersionTuple.h"
Dmitri Gribenkof430da42014-02-12 10:33:14 +0000122#include "llvm/Support/raw_ostream.h"
Guy Benyei11169dd2012-12-18 14:30:41 +0000123#include <algorithm>
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000124#include <cassert>
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000125#include <cstddef>
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000126#include <cstdint>
Chris Lattner91f373e2013-01-20 00:57:52 +0000127#include <cstdio>
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000128#include <ctime>
Guy Benyei11169dd2012-12-18 14:30:41 +0000129#include <iterator>
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000130#include <limits>
131#include <map>
132#include <memory>
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000133#include <string>
Rafael Espindola8a8e5542014-06-12 17:19:42 +0000134#include <system_error>
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000135#include <tuple>
136#include <utility>
137#include <vector>
Guy Benyei11169dd2012-12-18 14:30:41 +0000138
139using namespace clang;
Vedant Kumar48b4f762018-04-14 01:40:48 +0000140using namespace clang::serialization;
141using namespace clang::serialization::reader;
Chris Lattner7fb3bef2013-01-20 00:56:42 +0000142using llvm::BitstreamCursor;
Serge Pavlovc7ff5b32020-03-26 14:51:09 +0700143using llvm::RoundingMode;
Guy Benyei11169dd2012-12-18 14:30:41 +0000144
Ben Langmuircb69b572014-03-07 06:40:32 +0000145//===----------------------------------------------------------------------===//
146// ChainedASTReaderListener implementation
147//===----------------------------------------------------------------------===//
148
149bool
150ChainedASTReaderListener::ReadFullVersionInformation(StringRef FullVersion) {
151 return First->ReadFullVersionInformation(FullVersion) ||
152 Second->ReadFullVersionInformation(FullVersion);
153}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000154
Ben Langmuir4f5212a2014-04-14 22:12:44 +0000155void ChainedASTReaderListener::ReadModuleName(StringRef ModuleName) {
156 First->ReadModuleName(ModuleName);
157 Second->ReadModuleName(ModuleName);
158}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000159
Ben Langmuir4f5212a2014-04-14 22:12:44 +0000160void ChainedASTReaderListener::ReadModuleMapFile(StringRef ModuleMapPath) {
161 First->ReadModuleMapFile(ModuleMapPath);
162 Second->ReadModuleMapFile(ModuleMapPath);
163}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000164
Richard Smith1e2cf0d2014-10-31 02:28:58 +0000165bool
166ChainedASTReaderListener::ReadLanguageOptions(const LangOptions &LangOpts,
167 bool Complain,
168 bool AllowCompatibleDifferences) {
169 return First->ReadLanguageOptions(LangOpts, Complain,
170 AllowCompatibleDifferences) ||
171 Second->ReadLanguageOptions(LangOpts, Complain,
172 AllowCompatibleDifferences);
Ben Langmuircb69b572014-03-07 06:40:32 +0000173}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000174
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000175bool ChainedASTReaderListener::ReadTargetOptions(
176 const TargetOptions &TargetOpts, bool Complain,
177 bool AllowCompatibleDifferences) {
178 return First->ReadTargetOptions(TargetOpts, Complain,
179 AllowCompatibleDifferences) ||
180 Second->ReadTargetOptions(TargetOpts, Complain,
181 AllowCompatibleDifferences);
Ben Langmuircb69b572014-03-07 06:40:32 +0000182}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000183
Ben Langmuircb69b572014-03-07 06:40:32 +0000184bool ChainedASTReaderListener::ReadDiagnosticOptions(
Ben Langmuirb92de022014-04-29 16:25:26 +0000185 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts, bool Complain) {
Ben Langmuircb69b572014-03-07 06:40:32 +0000186 return First->ReadDiagnosticOptions(DiagOpts, Complain) ||
187 Second->ReadDiagnosticOptions(DiagOpts, Complain);
188}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000189
Ben Langmuircb69b572014-03-07 06:40:32 +0000190bool
191ChainedASTReaderListener::ReadFileSystemOptions(const FileSystemOptions &FSOpts,
192 bool Complain) {
193 return First->ReadFileSystemOptions(FSOpts, Complain) ||
194 Second->ReadFileSystemOptions(FSOpts, Complain);
195}
196
197bool ChainedASTReaderListener::ReadHeaderSearchOptions(
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +0000198 const HeaderSearchOptions &HSOpts, StringRef SpecificModuleCachePath,
199 bool Complain) {
200 return First->ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
201 Complain) ||
202 Second->ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
203 Complain);
Ben Langmuircb69b572014-03-07 06:40:32 +0000204}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000205
Ben Langmuircb69b572014-03-07 06:40:32 +0000206bool ChainedASTReaderListener::ReadPreprocessorOptions(
207 const PreprocessorOptions &PPOpts, bool Complain,
208 std::string &SuggestedPredefines) {
209 return First->ReadPreprocessorOptions(PPOpts, Complain,
210 SuggestedPredefines) ||
211 Second->ReadPreprocessorOptions(PPOpts, Complain, SuggestedPredefines);
212}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000213
Ben Langmuircb69b572014-03-07 06:40:32 +0000214void ChainedASTReaderListener::ReadCounter(const serialization::ModuleFile &M,
215 unsigned Value) {
216 First->ReadCounter(M, Value);
217 Second->ReadCounter(M, Value);
218}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000219
Ben Langmuircb69b572014-03-07 06:40:32 +0000220bool ChainedASTReaderListener::needsInputFileVisitation() {
221 return First->needsInputFileVisitation() ||
222 Second->needsInputFileVisitation();
223}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000224
Ben Langmuircb69b572014-03-07 06:40:32 +0000225bool ChainedASTReaderListener::needsSystemInputFileVisitation() {
226 return First->needsSystemInputFileVisitation() ||
227 Second->needsSystemInputFileVisitation();
228}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000229
Richard Smith216a3bd2015-08-13 17:57:10 +0000230void ChainedASTReaderListener::visitModuleFile(StringRef Filename,
231 ModuleKind Kind) {
232 First->visitModuleFile(Filename, Kind);
233 Second->visitModuleFile(Filename, Kind);
Argyrios Kyrtzidis6d0753d2014-03-14 03:07:38 +0000234}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000235
Ben Langmuircb69b572014-03-07 06:40:32 +0000236bool ChainedASTReaderListener::visitInputFile(StringRef Filename,
Argyrios Kyrtzidis68ccbe02014-03-14 02:26:31 +0000237 bool isSystem,
Richard Smith216a3bd2015-08-13 17:57:10 +0000238 bool isOverridden,
239 bool isExplicitModule) {
Justin Bognerc65a66d2014-05-22 06:04:59 +0000240 bool Continue = false;
241 if (First->needsInputFileVisitation() &&
242 (!isSystem || First->needsSystemInputFileVisitation()))
Richard Smith216a3bd2015-08-13 17:57:10 +0000243 Continue |= First->visitInputFile(Filename, isSystem, isOverridden,
244 isExplicitModule);
Justin Bognerc65a66d2014-05-22 06:04:59 +0000245 if (Second->needsInputFileVisitation() &&
246 (!isSystem || Second->needsSystemInputFileVisitation()))
Richard Smith216a3bd2015-08-13 17:57:10 +0000247 Continue |= Second->visitInputFile(Filename, isSystem, isOverridden,
248 isExplicitModule);
Justin Bognerc65a66d2014-05-22 06:04:59 +0000249 return Continue;
Ben Langmuircb69b572014-03-07 06:40:32 +0000250}
251
Douglas Gregor6623e1f2015-11-03 18:33:07 +0000252void ChainedASTReaderListener::readModuleFileExtension(
253 const ModuleFileExtensionMetadata &Metadata) {
254 First->readModuleFileExtension(Metadata);
255 Second->readModuleFileExtension(Metadata);
256}
257
Guy Benyei11169dd2012-12-18 14:30:41 +0000258//===----------------------------------------------------------------------===//
259// PCH validator implementation
260//===----------------------------------------------------------------------===//
261
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000262ASTReaderListener::~ASTReaderListener() = default;
Guy Benyei11169dd2012-12-18 14:30:41 +0000263
Adrian Prantl9fc8faf2018-05-09 01:00:01 +0000264/// Compare the given set of language options against an existing set of
Guy Benyei11169dd2012-12-18 14:30:41 +0000265/// language options.
266///
267/// \param Diags If non-NULL, diagnostics will be emitted via this engine.
Richard Smith1e2cf0d2014-10-31 02:28:58 +0000268/// \param AllowCompatibleDifferences If true, differences between compatible
269/// language options will be permitted.
Guy Benyei11169dd2012-12-18 14:30:41 +0000270///
271/// \returns true if the languagae options mis-match, false otherwise.
272static bool checkLanguageOptions(const LangOptions &LangOpts,
273 const LangOptions &ExistingLangOpts,
Richard Smith1e2cf0d2014-10-31 02:28:58 +0000274 DiagnosticsEngine *Diags,
275 bool AllowCompatibleDifferences = true) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000276#define LANGOPT(Name, Bits, Default, Description) \
277 if (ExistingLangOpts.Name != LangOpts.Name) { \
278 if (Diags) \
279 Diags->Report(diag::err_pch_langopt_mismatch) \
280 << Description << LangOpts.Name << ExistingLangOpts.Name; \
281 return true; \
282 }
283
284#define VALUE_LANGOPT(Name, Bits, Default, Description) \
285 if (ExistingLangOpts.Name != LangOpts.Name) { \
286 if (Diags) \
287 Diags->Report(diag::err_pch_langopt_value_mismatch) \
288 << Description; \
289 return true; \
290 }
291
292#define ENUM_LANGOPT(Name, Type, Bits, Default, Description) \
293 if (ExistingLangOpts.get##Name() != LangOpts.get##Name()) { \
294 if (Diags) \
295 Diags->Report(diag::err_pch_langopt_value_mismatch) \
296 << Description; \
297 return true; \
298 }
299
Richard Smith1e2cf0d2014-10-31 02:28:58 +0000300#define COMPATIBLE_LANGOPT(Name, Bits, Default, Description) \
301 if (!AllowCompatibleDifferences) \
302 LANGOPT(Name, Bits, Default, Description)
303
304#define COMPATIBLE_ENUM_LANGOPT(Name, Bits, Default, Description) \
305 if (!AllowCompatibleDifferences) \
306 ENUM_LANGOPT(Name, Bits, Default, Description)
307
Richard Smitha1ddf5e2016-04-07 20:47:37 +0000308#define COMPATIBLE_VALUE_LANGOPT(Name, Bits, Default, Description) \
309 if (!AllowCompatibleDifferences) \
310 VALUE_LANGOPT(Name, Bits, Default, Description)
311
Guy Benyei11169dd2012-12-18 14:30:41 +0000312#define BENIGN_LANGOPT(Name, Bits, Default, Description)
313#define BENIGN_ENUM_LANGOPT(Name, Type, Bits, Default, Description)
Richard Smitha1ddf5e2016-04-07 20:47:37 +0000314#define BENIGN_VALUE_LANGOPT(Name, Type, Bits, Default, Description)
Guy Benyei11169dd2012-12-18 14:30:41 +0000315#include "clang/Basic/LangOptions.def"
316
Ben Langmuircd98cb72015-06-23 18:20:18 +0000317 if (ExistingLangOpts.ModuleFeatures != LangOpts.ModuleFeatures) {
318 if (Diags)
319 Diags->Report(diag::err_pch_langopt_value_mismatch) << "module features";
320 return true;
321 }
322
Guy Benyei11169dd2012-12-18 14:30:41 +0000323 if (ExistingLangOpts.ObjCRuntime != LangOpts.ObjCRuntime) {
324 if (Diags)
325 Diags->Report(diag::err_pch_langopt_value_mismatch)
326 << "target Objective-C runtime";
327 return true;
328 }
329
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +0000330 if (ExistingLangOpts.CommentOpts.BlockCommandNames !=
331 LangOpts.CommentOpts.BlockCommandNames) {
332 if (Diags)
333 Diags->Report(diag::err_pch_langopt_value_mismatch)
334 << "block command names";
335 return true;
336 }
337
Vedant Kumar85a83c22017-06-01 20:01:01 +0000338 // Sanitizer feature mismatches are treated as compatible differences. If
339 // compatible differences aren't allowed, we still only want to check for
340 // mismatches of non-modular sanitizers (the only ones which can affect AST
341 // generation).
342 if (!AllowCompatibleDifferences) {
343 SanitizerMask ModularSanitizers = getPPTransparentSanitizers();
344 SanitizerSet ExistingSanitizers = ExistingLangOpts.Sanitize;
345 SanitizerSet ImportedSanitizers = LangOpts.Sanitize;
346 ExistingSanitizers.clear(ModularSanitizers);
347 ImportedSanitizers.clear(ModularSanitizers);
348 if (ExistingSanitizers.Mask != ImportedSanitizers.Mask) {
349 const std::string Flag = "-fsanitize=";
350 if (Diags) {
351#define SANITIZER(NAME, ID) \
352 { \
353 bool InExistingModule = ExistingSanitizers.has(SanitizerKind::ID); \
354 bool InImportedModule = ImportedSanitizers.has(SanitizerKind::ID); \
355 if (InExistingModule != InImportedModule) \
356 Diags->Report(diag::err_pch_targetopt_feature_mismatch) \
357 << InExistingModule << (Flag + NAME); \
358 }
359#include "clang/Basic/Sanitizers.def"
360 }
361 return true;
362 }
363 }
364
Guy Benyei11169dd2012-12-18 14:30:41 +0000365 return false;
366}
367
Adrian Prantl9fc8faf2018-05-09 01:00:01 +0000368/// Compare the given set of target options against an existing set of
Guy Benyei11169dd2012-12-18 14:30:41 +0000369/// target options.
370///
371/// \param Diags If non-NULL, diagnostics will be emitted via this engine.
372///
373/// \returns true if the target options mis-match, false otherwise.
374static bool checkTargetOptions(const TargetOptions &TargetOpts,
375 const TargetOptions &ExistingTargetOpts,
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000376 DiagnosticsEngine *Diags,
377 bool AllowCompatibleDifferences = true) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000378#define CHECK_TARGET_OPT(Field, Name) \
379 if (TargetOpts.Field != ExistingTargetOpts.Field) { \
380 if (Diags) \
381 Diags->Report(diag::err_pch_targetopt_mismatch) \
382 << Name << TargetOpts.Field << ExistingTargetOpts.Field; \
383 return true; \
384 }
385
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000386 // The triple and ABI must match exactly.
Guy Benyei11169dd2012-12-18 14:30:41 +0000387 CHECK_TARGET_OPT(Triple, "target");
Guy Benyei11169dd2012-12-18 14:30:41 +0000388 CHECK_TARGET_OPT(ABI, "target ABI");
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000389
390 // We can tolerate different CPUs in many cases, notably when one CPU
391 // supports a strict superset of another. When allowing compatible
392 // differences skip this check.
393 if (!AllowCompatibleDifferences)
394 CHECK_TARGET_OPT(CPU, "target CPU");
395
Guy Benyei11169dd2012-12-18 14:30:41 +0000396#undef CHECK_TARGET_OPT
397
398 // Compare feature sets.
399 SmallVector<StringRef, 4> ExistingFeatures(
400 ExistingTargetOpts.FeaturesAsWritten.begin(),
401 ExistingTargetOpts.FeaturesAsWritten.end());
402 SmallVector<StringRef, 4> ReadFeatures(TargetOpts.FeaturesAsWritten.begin(),
403 TargetOpts.FeaturesAsWritten.end());
Fangrui Song55fab262018-09-26 22:16:28 +0000404 llvm::sort(ExistingFeatures);
405 llvm::sort(ReadFeatures);
Guy Benyei11169dd2012-12-18 14:30:41 +0000406
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000407 // We compute the set difference in both directions explicitly so that we can
408 // diagnose the differences differently.
409 SmallVector<StringRef, 4> UnmatchedExistingFeatures, UnmatchedReadFeatures;
410 std::set_difference(
411 ExistingFeatures.begin(), ExistingFeatures.end(), ReadFeatures.begin(),
412 ReadFeatures.end(), std::back_inserter(UnmatchedExistingFeatures));
413 std::set_difference(ReadFeatures.begin(), ReadFeatures.end(),
414 ExistingFeatures.begin(), ExistingFeatures.end(),
415 std::back_inserter(UnmatchedReadFeatures));
Guy Benyei11169dd2012-12-18 14:30:41 +0000416
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000417 // If we are allowing compatible differences and the read feature set is
418 // a strict subset of the existing feature set, there is nothing to diagnose.
419 if (AllowCompatibleDifferences && UnmatchedReadFeatures.empty())
420 return false;
Guy Benyei11169dd2012-12-18 14:30:41 +0000421
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000422 if (Diags) {
423 for (StringRef Feature : UnmatchedReadFeatures)
Guy Benyei11169dd2012-12-18 14:30:41 +0000424 Diags->Report(diag::err_pch_targetopt_feature_mismatch)
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000425 << /* is-existing-feature */ false << Feature;
426 for (StringRef Feature : UnmatchedExistingFeatures)
427 Diags->Report(diag::err_pch_targetopt_feature_mismatch)
428 << /* is-existing-feature */ true << Feature;
Guy Benyei11169dd2012-12-18 14:30:41 +0000429 }
430
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000431 return !UnmatchedReadFeatures.empty() || !UnmatchedExistingFeatures.empty();
Guy Benyei11169dd2012-12-18 14:30:41 +0000432}
433
434bool
435PCHValidator::ReadLanguageOptions(const LangOptions &LangOpts,
Richard Smith1e2cf0d2014-10-31 02:28:58 +0000436 bool Complain,
437 bool AllowCompatibleDifferences) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000438 const LangOptions &ExistingLangOpts = PP.getLangOpts();
439 return checkLanguageOptions(LangOpts, ExistingLangOpts,
Richard Smith1e2cf0d2014-10-31 02:28:58 +0000440 Complain ? &Reader.Diags : nullptr,
441 AllowCompatibleDifferences);
Guy Benyei11169dd2012-12-18 14:30:41 +0000442}
443
444bool PCHValidator::ReadTargetOptions(const TargetOptions &TargetOpts,
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000445 bool Complain,
446 bool AllowCompatibleDifferences) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000447 const TargetOptions &ExistingTargetOpts = PP.getTargetInfo().getTargetOpts();
448 return checkTargetOptions(TargetOpts, ExistingTargetOpts,
Chandler Carruth0d745bc2015-03-14 04:47:43 +0000449 Complain ? &Reader.Diags : nullptr,
450 AllowCompatibleDifferences);
Guy Benyei11169dd2012-12-18 14:30:41 +0000451}
452
453namespace {
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000454
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000455using MacroDefinitionsMap =
456 llvm::StringMap<std::pair<StringRef, bool /*IsUndef*/>>;
457using DeclsMap = llvm::DenseMap<DeclarationName, SmallVector<NamedDecl *, 8>>;
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +0000458
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000459} // namespace
Guy Benyei11169dd2012-12-18 14:30:41 +0000460
Ben Langmuirb92de022014-04-29 16:25:26 +0000461static bool checkDiagnosticGroupMappings(DiagnosticsEngine &StoredDiags,
462 DiagnosticsEngine &Diags,
463 bool Complain) {
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000464 using Level = DiagnosticsEngine::Level;
Ben Langmuirb92de022014-04-29 16:25:26 +0000465
466 // Check current mappings for new -Werror mappings, and the stored mappings
467 // for cases that were explicitly mapped to *not* be errors that are now
468 // errors because of options like -Werror.
469 DiagnosticsEngine *MappingSources[] = { &Diags, &StoredDiags };
470
Vedant Kumar48b4f762018-04-14 01:40:48 +0000471 for (DiagnosticsEngine *MappingSource : MappingSources) {
Ben Langmuirb92de022014-04-29 16:25:26 +0000472 for (auto DiagIDMappingPair : MappingSource->getDiagnosticMappings()) {
473 diag::kind DiagID = DiagIDMappingPair.first;
474 Level CurLevel = Diags.getDiagnosticLevel(DiagID, SourceLocation());
475 if (CurLevel < DiagnosticsEngine::Error)
476 continue; // not significant
477 Level StoredLevel =
478 StoredDiags.getDiagnosticLevel(DiagID, SourceLocation());
479 if (StoredLevel < DiagnosticsEngine::Error) {
480 if (Complain)
481 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Werror=" +
482 Diags.getDiagnosticIDs()->getWarningOptionForDiag(DiagID).str();
483 return true;
484 }
485 }
486 }
487
488 return false;
489}
490
Alp Tokerac4e8e52014-06-22 21:58:33 +0000491static bool isExtHandlingFromDiagsError(DiagnosticsEngine &Diags) {
492 diag::Severity Ext = Diags.getExtensionHandlingBehavior();
493 if (Ext == diag::Severity::Warning && Diags.getWarningsAsErrors())
494 return true;
495 return Ext >= diag::Severity::Error;
Ben Langmuirb92de022014-04-29 16:25:26 +0000496}
497
498static bool checkDiagnosticMappings(DiagnosticsEngine &StoredDiags,
499 DiagnosticsEngine &Diags,
500 bool IsSystem, bool Complain) {
501 // Top-level options
502 if (IsSystem) {
503 if (Diags.getSuppressSystemWarnings())
504 return false;
505 // If -Wsystem-headers was not enabled before, be conservative
506 if (StoredDiags.getSuppressSystemWarnings()) {
507 if (Complain)
508 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Wsystem-headers";
509 return true;
510 }
511 }
512
513 if (Diags.getWarningsAsErrors() && !StoredDiags.getWarningsAsErrors()) {
514 if (Complain)
515 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Werror";
516 return true;
517 }
518
519 if (Diags.getWarningsAsErrors() && Diags.getEnableAllWarnings() &&
520 !StoredDiags.getEnableAllWarnings()) {
521 if (Complain)
522 Diags.Report(diag::err_pch_diagopt_mismatch) << "-Weverything -Werror";
523 return true;
524 }
525
526 if (isExtHandlingFromDiagsError(Diags) &&
527 !isExtHandlingFromDiagsError(StoredDiags)) {
528 if (Complain)
529 Diags.Report(diag::err_pch_diagopt_mismatch) << "-pedantic-errors";
530 return true;
531 }
532
533 return checkDiagnosticGroupMappings(StoredDiags, Diags, Complain);
534}
535
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +0000536/// Return the top import module if it is implicit, nullptr otherwise.
537static Module *getTopImportImplicitModule(ModuleManager &ModuleMgr,
538 Preprocessor &PP) {
539 // If the original import came from a file explicitly generated by the user,
540 // don't check the diagnostic mappings.
541 // FIXME: currently this is approximated by checking whether this is not a
542 // module import of an implicitly-loaded module file.
543 // Note: ModuleMgr.rbegin() may not be the current module, but it must be in
544 // the transitive closure of its imports, since unrelated modules cannot be
545 // imported until after this module finishes validation.
546 ModuleFile *TopImport = &*ModuleMgr.rbegin();
547 while (!TopImport->ImportedBy.empty())
548 TopImport = TopImport->ImportedBy[0];
549 if (TopImport->Kind != MK_ImplicitModule)
550 return nullptr;
551
552 StringRef ModuleName = TopImport->ModuleName;
553 assert(!ModuleName.empty() && "diagnostic options read before module name");
554
555 Module *M = PP.getHeaderSearchInfo().lookupModule(ModuleName);
556 assert(M && "missing module");
557 return M;
558}
559
Ben Langmuirb92de022014-04-29 16:25:26 +0000560bool PCHValidator::ReadDiagnosticOptions(
561 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts, bool Complain) {
562 DiagnosticsEngine &ExistingDiags = PP.getDiagnostics();
563 IntrusiveRefCntPtr<DiagnosticIDs> DiagIDs(ExistingDiags.getDiagnosticIDs());
564 IntrusiveRefCntPtr<DiagnosticsEngine> Diags(
Alp Tokerf994cef2014-07-05 03:08:06 +0000565 new DiagnosticsEngine(DiagIDs, DiagOpts.get()));
Ben Langmuirb92de022014-04-29 16:25:26 +0000566 // This should never fail, because we would have processed these options
567 // before writing them to an ASTFile.
568 ProcessWarningOptions(*Diags, *DiagOpts, /*Report*/false);
569
570 ModuleManager &ModuleMgr = Reader.getModuleManager();
571 assert(ModuleMgr.size() >= 1 && "what ASTFile is this then");
572
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +0000573 Module *TopM = getTopImportImplicitModule(ModuleMgr, PP);
574 if (!TopM)
Ben Langmuirb92de022014-04-29 16:25:26 +0000575 return false;
576
Ben Langmuirb92de022014-04-29 16:25:26 +0000577 // FIXME: if the diagnostics are incompatible, save a DiagnosticOptions that
578 // contains the union of their flags.
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +0000579 return checkDiagnosticMappings(*Diags, ExistingDiags, TopM->IsSystem,
580 Complain);
Ben Langmuirb92de022014-04-29 16:25:26 +0000581}
582
Adrian Prantl9fc8faf2018-05-09 01:00:01 +0000583/// Collect the macro definitions provided by the given preprocessor
Guy Benyei11169dd2012-12-18 14:30:41 +0000584/// options.
Craig Toppera13603a2014-05-22 05:54:18 +0000585static void
586collectMacroDefinitions(const PreprocessorOptions &PPOpts,
587 MacroDefinitionsMap &Macros,
588 SmallVectorImpl<StringRef> *MacroNames = nullptr) {
Vedant Kumar48b4f762018-04-14 01:40:48 +0000589 for (unsigned I = 0, N = PPOpts.Macros.size(); I != N; ++I) {
590 StringRef Macro = PPOpts.Macros[I].first;
591 bool IsUndef = PPOpts.Macros[I].second;
Guy Benyei11169dd2012-12-18 14:30:41 +0000592
593 std::pair<StringRef, StringRef> MacroPair = Macro.split('=');
594 StringRef MacroName = MacroPair.first;
595 StringRef MacroBody = MacroPair.second;
596
597 // For an #undef'd macro, we only care about the name.
598 if (IsUndef) {
599 if (MacroNames && !Macros.count(MacroName))
600 MacroNames->push_back(MacroName);
601
602 Macros[MacroName] = std::make_pair("", true);
603 continue;
604 }
605
606 // For a #define'd macro, figure out the actual definition.
607 if (MacroName.size() == Macro.size())
608 MacroBody = "1";
609 else {
610 // Note: GCC drops anything following an end-of-line character.
611 StringRef::size_type End = MacroBody.find_first_of("\n\r");
612 MacroBody = MacroBody.substr(0, End);
613 }
614
615 if (MacroNames && !Macros.count(MacroName))
616 MacroNames->push_back(MacroName);
617 Macros[MacroName] = std::make_pair(MacroBody, false);
618 }
619}
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +0000620
Adrian Prantl9fc8faf2018-05-09 01:00:01 +0000621/// Check the preprocessor options deserialized from the control block
Guy Benyei11169dd2012-12-18 14:30:41 +0000622/// against the preprocessor options in an existing preprocessor.
623///
624/// \param Diags If non-null, produce diagnostics for any mismatches incurred.
Yaxun Liu43712e02016-09-07 18:40:20 +0000625/// \param Validate If true, validate preprocessor options. If false, allow
626/// macros defined by \p ExistingPPOpts to override those defined by
627/// \p PPOpts in SuggestedPredefines.
Guy Benyei11169dd2012-12-18 14:30:41 +0000628static bool checkPreprocessorOptions(const PreprocessorOptions &PPOpts,
629 const PreprocessorOptions &ExistingPPOpts,
630 DiagnosticsEngine *Diags,
631 FileManager &FileMgr,
Argyrios Kyrtzidisd3afa0c2013-04-26 21:33:40 +0000632 std::string &SuggestedPredefines,
Yaxun Liu43712e02016-09-07 18:40:20 +0000633 const LangOptions &LangOpts,
634 bool Validate = true) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000635 // Check macro definitions.
636 MacroDefinitionsMap ASTFileMacros;
637 collectMacroDefinitions(PPOpts, ASTFileMacros);
638 MacroDefinitionsMap ExistingMacros;
639 SmallVector<StringRef, 4> ExistingMacroNames;
640 collectMacroDefinitions(ExistingPPOpts, ExistingMacros, &ExistingMacroNames);
641
Vedant Kumar48b4f762018-04-14 01:40:48 +0000642 for (unsigned I = 0, N = ExistingMacroNames.size(); I != N; ++I) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000643 // Dig out the macro definition in the existing preprocessor options.
Vedant Kumar48b4f762018-04-14 01:40:48 +0000644 StringRef MacroName = ExistingMacroNames[I];
Guy Benyei11169dd2012-12-18 14:30:41 +0000645 std::pair<StringRef, bool> Existing = ExistingMacros[MacroName];
646
647 // Check whether we know anything about this macro name or not.
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000648 llvm::StringMap<std::pair<StringRef, bool /*IsUndef*/>>::iterator Known =
649 ASTFileMacros.find(MacroName);
Yaxun Liu43712e02016-09-07 18:40:20 +0000650 if (!Validate || Known == ASTFileMacros.end()) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000651 // FIXME: Check whether this identifier was referenced anywhere in the
652 // AST file. If so, we should reject the AST file. Unfortunately, this
653 // information isn't in the control block. What shall we do about it?
654
655 if (Existing.second) {
656 SuggestedPredefines += "#undef ";
657 SuggestedPredefines += MacroName.str();
658 SuggestedPredefines += '\n';
659 } else {
660 SuggestedPredefines += "#define ";
661 SuggestedPredefines += MacroName.str();
662 SuggestedPredefines += ' ';
663 SuggestedPredefines += Existing.first.str();
664 SuggestedPredefines += '\n';
665 }
666 continue;
667 }
668
669 // If the macro was defined in one but undef'd in the other, we have a
670 // conflict.
671 if (Existing.second != Known->second.second) {
672 if (Diags) {
673 Diags->Report(diag::err_pch_macro_def_undef)
674 << MacroName << Known->second.second;
675 }
676 return true;
677 }
678
679 // If the macro was #undef'd in both, or if the macro bodies are identical,
680 // it's fine.
681 if (Existing.second || Existing.first == Known->second.first)
682 continue;
683
684 // The macro bodies differ; complain.
685 if (Diags) {
686 Diags->Report(diag::err_pch_macro_def_conflict)
687 << MacroName << Known->second.first << Existing.first;
688 }
689 return true;
690 }
691
692 // Check whether we're using predefines.
Yaxun Liu43712e02016-09-07 18:40:20 +0000693 if (PPOpts.UsePredefines != ExistingPPOpts.UsePredefines && Validate) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000694 if (Diags) {
695 Diags->Report(diag::err_pch_undef) << ExistingPPOpts.UsePredefines;
696 }
697 return true;
698 }
699
Argyrios Kyrtzidisd3afa0c2013-04-26 21:33:40 +0000700 // Detailed record is important since it is used for the module cache hash.
701 if (LangOpts.Modules &&
Yaxun Liu43712e02016-09-07 18:40:20 +0000702 PPOpts.DetailedRecord != ExistingPPOpts.DetailedRecord && Validate) {
Argyrios Kyrtzidisd3afa0c2013-04-26 21:33:40 +0000703 if (Diags) {
704 Diags->Report(diag::err_pch_pp_detailed_record) << PPOpts.DetailedRecord;
705 }
706 return true;
707 }
708
Guy Benyei11169dd2012-12-18 14:30:41 +0000709 // Compute the #include and #include_macros lines we need.
Vedant Kumar48b4f762018-04-14 01:40:48 +0000710 for (unsigned I = 0, N = ExistingPPOpts.Includes.size(); I != N; ++I) {
711 StringRef File = ExistingPPOpts.Includes[I];
Erich Keane76675de2018-07-05 17:22:13 +0000712
713 if (!ExistingPPOpts.ImplicitPCHInclude.empty() &&
714 !ExistingPPOpts.PCHThroughHeader.empty()) {
715 // In case the through header is an include, we must add all the includes
716 // to the predefines so the start point can be determined.
717 SuggestedPredefines += "#include \"";
718 SuggestedPredefines += File;
719 SuggestedPredefines += "\"\n";
720 continue;
721 }
722
Guy Benyei11169dd2012-12-18 14:30:41 +0000723 if (File == ExistingPPOpts.ImplicitPCHInclude)
724 continue;
725
726 if (std::find(PPOpts.Includes.begin(), PPOpts.Includes.end(), File)
727 != PPOpts.Includes.end())
728 continue;
729
730 SuggestedPredefines += "#include \"";
Manuel Klimek9af34ae2014-08-12 08:25:57 +0000731 SuggestedPredefines += File;
Guy Benyei11169dd2012-12-18 14:30:41 +0000732 SuggestedPredefines += "\"\n";
733 }
734
Vedant Kumar48b4f762018-04-14 01:40:48 +0000735 for (unsigned I = 0, N = ExistingPPOpts.MacroIncludes.size(); I != N; ++I) {
736 StringRef File = ExistingPPOpts.MacroIncludes[I];
Guy Benyei11169dd2012-12-18 14:30:41 +0000737 if (std::find(PPOpts.MacroIncludes.begin(), PPOpts.MacroIncludes.end(),
738 File)
739 != PPOpts.MacroIncludes.end())
740 continue;
741
742 SuggestedPredefines += "#__include_macros \"";
Manuel Klimek9af34ae2014-08-12 08:25:57 +0000743 SuggestedPredefines += File;
Guy Benyei11169dd2012-12-18 14:30:41 +0000744 SuggestedPredefines += "\"\n##\n";
745 }
746
747 return false;
748}
749
750bool PCHValidator::ReadPreprocessorOptions(const PreprocessorOptions &PPOpts,
751 bool Complain,
752 std::string &SuggestedPredefines) {
753 const PreprocessorOptions &ExistingPPOpts = PP.getPreprocessorOpts();
754
755 return checkPreprocessorOptions(PPOpts, ExistingPPOpts,
Craig Toppera13603a2014-05-22 05:54:18 +0000756 Complain? &Reader.Diags : nullptr,
Guy Benyei11169dd2012-12-18 14:30:41 +0000757 PP.getFileManager(),
Argyrios Kyrtzidisd3afa0c2013-04-26 21:33:40 +0000758 SuggestedPredefines,
759 PP.getLangOpts());
Guy Benyei11169dd2012-12-18 14:30:41 +0000760}
761
Yaxun Liu43712e02016-09-07 18:40:20 +0000762bool SimpleASTReaderListener::ReadPreprocessorOptions(
763 const PreprocessorOptions &PPOpts,
764 bool Complain,
765 std::string &SuggestedPredefines) {
766 return checkPreprocessorOptions(PPOpts,
767 PP.getPreprocessorOpts(),
768 nullptr,
769 PP.getFileManager(),
770 SuggestedPredefines,
771 PP.getLangOpts(),
772 false);
773}
774
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +0000775/// Check the header search options deserialized from the control block
776/// against the header search options in an existing preprocessor.
777///
778/// \param Diags If non-null, produce diagnostics for any mismatches incurred.
779static bool checkHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
780 StringRef SpecificModuleCachePath,
781 StringRef ExistingModuleCachePath,
782 DiagnosticsEngine *Diags,
783 const LangOptions &LangOpts) {
784 if (LangOpts.Modules) {
785 if (SpecificModuleCachePath != ExistingModuleCachePath) {
786 if (Diags)
787 Diags->Report(diag::err_pch_modulecache_mismatch)
788 << SpecificModuleCachePath << ExistingModuleCachePath;
789 return true;
790 }
791 }
792
793 return false;
794}
795
796bool PCHValidator::ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
797 StringRef SpecificModuleCachePath,
798 bool Complain) {
799 return checkHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
800 PP.getHeaderSearchInfo().getModuleCachePath(),
801 Complain ? &Reader.Diags : nullptr,
802 PP.getLangOpts());
803}
804
Guy Benyei11169dd2012-12-18 14:30:41 +0000805void PCHValidator::ReadCounter(const ModuleFile &M, unsigned Value) {
806 PP.setCounterValue(Value);
807}
808
809//===----------------------------------------------------------------------===//
810// AST reader implementation
811//===----------------------------------------------------------------------===//
812
Nico Weber824285e2014-05-08 04:26:47 +0000813void ASTReader::setDeserializationListener(ASTDeserializationListener *Listener,
814 bool TakeOwnership) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000815 DeserializationListener = Listener;
Nico Weber824285e2014-05-08 04:26:47 +0000816 OwnsDeserializationListener = TakeOwnership;
Guy Benyei11169dd2012-12-18 14:30:41 +0000817}
818
Guy Benyei11169dd2012-12-18 14:30:41 +0000819unsigned ASTSelectorLookupTrait::ComputeHash(Selector Sel) {
820 return serialization::ComputeHash(Sel);
821}
822
Guy Benyei11169dd2012-12-18 14:30:41 +0000823std::pair<unsigned, unsigned>
824ASTSelectorLookupTrait::ReadKeyDataLength(const unsigned char*& d) {
Justin Bogner57ba0b22014-03-28 22:03:24 +0000825 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000826
Justin Bogner57ba0b22014-03-28 22:03:24 +0000827 unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
828 unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
Guy Benyei11169dd2012-12-18 14:30:41 +0000829 return std::make_pair(KeyLen, DataLen);
830}
831
David L. Jonesc4808b9e2016-12-15 20:53:26 +0000832ASTSelectorLookupTrait::internal_key_type
Guy Benyei11169dd2012-12-18 14:30:41 +0000833ASTSelectorLookupTrait::ReadKey(const unsigned char* d, unsigned) {
Justin Bogner57ba0b22014-03-28 22:03:24 +0000834 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000835
Guy Benyei11169dd2012-12-18 14:30:41 +0000836 SelectorTable &SelTable = Reader.getContext().Selectors;
Justin Bogner57ba0b22014-03-28 22:03:24 +0000837 unsigned N = endian::readNext<uint16_t, little, unaligned>(d);
838 IdentifierInfo *FirstII = Reader.getLocalIdentifier(
839 F, endian::readNext<uint32_t, little, unaligned>(d));
Guy Benyei11169dd2012-12-18 14:30:41 +0000840 if (N == 0)
841 return SelTable.getNullarySelector(FirstII);
842 else if (N == 1)
843 return SelTable.getUnarySelector(FirstII);
844
845 SmallVector<IdentifierInfo *, 16> Args;
846 Args.push_back(FirstII);
847 for (unsigned I = 1; I != N; ++I)
Justin Bogner57ba0b22014-03-28 22:03:24 +0000848 Args.push_back(Reader.getLocalIdentifier(
849 F, endian::readNext<uint32_t, little, unaligned>(d)));
Guy Benyei11169dd2012-12-18 14:30:41 +0000850
851 return SelTable.getSelector(N, Args.data());
852}
853
David L. Jonesc4808b9e2016-12-15 20:53:26 +0000854ASTSelectorLookupTrait::data_type
855ASTSelectorLookupTrait::ReadData(Selector, const unsigned char* d,
Guy Benyei11169dd2012-12-18 14:30:41 +0000856 unsigned DataLen) {
Justin Bogner57ba0b22014-03-28 22:03:24 +0000857 using namespace llvm::support;
Guy Benyei11169dd2012-12-18 14:30:41 +0000858
859 data_type Result;
860
Justin Bogner57ba0b22014-03-28 22:03:24 +0000861 Result.ID = Reader.getGlobalSelectorID(
862 F, endian::readNext<uint32_t, little, unaligned>(d));
Nico Weberff4b35e2014-12-27 22:14:15 +0000863 unsigned FullInstanceBits = endian::readNext<uint16_t, little, unaligned>(d);
864 unsigned FullFactoryBits = endian::readNext<uint16_t, little, unaligned>(d);
865 Result.InstanceBits = FullInstanceBits & 0x3;
866 Result.InstanceHasMoreThanOneDecl = (FullInstanceBits >> 2) & 0x1;
867 Result.FactoryBits = FullFactoryBits & 0x3;
868 Result.FactoryHasMoreThanOneDecl = (FullFactoryBits >> 2) & 0x1;
869 unsigned NumInstanceMethods = FullInstanceBits >> 3;
870 unsigned NumFactoryMethods = FullFactoryBits >> 3;
Guy Benyei11169dd2012-12-18 14:30:41 +0000871
872 // Load instance methods
873 for (unsigned I = 0; I != NumInstanceMethods; ++I) {
Vedant Kumar48b4f762018-04-14 01:40:48 +0000874 if (ObjCMethodDecl *Method = Reader.GetLocalDeclAs<ObjCMethodDecl>(
Justin Bogner57ba0b22014-03-28 22:03:24 +0000875 F, endian::readNext<uint32_t, little, unaligned>(d)))
Guy Benyei11169dd2012-12-18 14:30:41 +0000876 Result.Instance.push_back(Method);
877 }
878
879 // Load factory methods
880 for (unsigned I = 0; I != NumFactoryMethods; ++I) {
Vedant Kumar48b4f762018-04-14 01:40:48 +0000881 if (ObjCMethodDecl *Method = Reader.GetLocalDeclAs<ObjCMethodDecl>(
Justin Bogner57ba0b22014-03-28 22:03:24 +0000882 F, endian::readNext<uint32_t, little, unaligned>(d)))
Guy Benyei11169dd2012-12-18 14:30:41 +0000883 Result.Factory.push_back(Method);
884 }
885
886 return Result;
887}
888
Douglas Gregorbfd73d72013-01-23 18:53:14 +0000889unsigned ASTIdentifierLookupTraitBase::ComputeHash(const internal_key_type& a) {
Jonas Devlieghere560ce2c2018-02-26 15:16:42 +0000890 return llvm::djbHash(a);
Guy Benyei11169dd2012-12-18 14:30:41 +0000891}
892
893std::pair<unsigned, unsigned>
Douglas Gregorbfd73d72013-01-23 18:53:14 +0000894ASTIdentifierLookupTraitBase::ReadKeyDataLength(const unsigned char*& d) {
Justin Bogner57ba0b22014-03-28 22:03:24 +0000895 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000896
Justin Bogner57ba0b22014-03-28 22:03:24 +0000897 unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
898 unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
Guy Benyei11169dd2012-12-18 14:30:41 +0000899 return std::make_pair(KeyLen, DataLen);
900}
901
Douglas Gregorbfd73d72013-01-23 18:53:14 +0000902ASTIdentifierLookupTraitBase::internal_key_type
903ASTIdentifierLookupTraitBase::ReadKey(const unsigned char* d, unsigned n) {
Guy Benyei11169dd2012-12-18 14:30:41 +0000904 assert(n >= 2 && d[n-1] == '\0');
Douglas Gregorbfd73d72013-01-23 18:53:14 +0000905 return StringRef((const char*) d, n-1);
Guy Benyei11169dd2012-12-18 14:30:41 +0000906}
907
Adrian Prantl9fc8faf2018-05-09 01:00:01 +0000908/// Whether the given identifier is "interesting".
Richard Smitha534a312015-07-21 23:54:07 +0000909static bool isInterestingIdentifier(ASTReader &Reader, IdentifierInfo &II,
910 bool IsModule) {
Richard Smithcab89802015-07-17 20:19:56 +0000911 return II.hadMacroDefinition() ||
912 II.isPoisoned() ||
Richard Smith9c254182015-07-19 21:41:12 +0000913 (IsModule ? II.hasRevertedBuiltin() : II.getObjCOrBuiltinID()) ||
Douglas Gregordcf25082013-02-11 18:16:18 +0000914 II.hasRevertedTokenIDToIdentifier() ||
Richard Smithdbafb6c2017-06-29 23:23:46 +0000915 (!(IsModule && Reader.getPreprocessor().getLangOpts().CPlusPlus) &&
Bruno Ricci366ba732018-09-21 12:53:22 +0000916 II.getFETokenInfo());
Douglas Gregordcf25082013-02-11 18:16:18 +0000917}
918
Richard Smith76c2f2c2015-07-17 20:09:43 +0000919static bool readBit(unsigned &Bits) {
920 bool Value = Bits & 0x1;
921 Bits >>= 1;
922 return Value;
923}
924
Richard Smith79bf9202015-08-24 03:33:22 +0000925IdentID ASTIdentifierLookupTrait::ReadIdentifierID(const unsigned char *d) {
926 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000927
Richard Smith79bf9202015-08-24 03:33:22 +0000928 unsigned RawID = endian::readNext<uint32_t, little, unaligned>(d);
929 return Reader.getGlobalIdentifierID(F, RawID >> 1);
930}
931
Richard Smitheb4b58f62016-02-05 01:40:54 +0000932static void markIdentifierFromAST(ASTReader &Reader, IdentifierInfo &II) {
933 if (!II.isFromAST()) {
934 II.setIsFromAST();
935 bool IsModule = Reader.getPreprocessor().getCurrentModule() != nullptr;
936 if (isInterestingIdentifier(Reader, II, IsModule))
937 II.setChangedSinceDeserialization();
938 }
939}
940
Guy Benyei11169dd2012-12-18 14:30:41 +0000941IdentifierInfo *ASTIdentifierLookupTrait::ReadData(const internal_key_type& k,
942 const unsigned char* d,
943 unsigned DataLen) {
Justin Bogner57ba0b22014-03-28 22:03:24 +0000944 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +0000945
Justin Bogner57ba0b22014-03-28 22:03:24 +0000946 unsigned RawID = endian::readNext<uint32_t, little, unaligned>(d);
Guy Benyei11169dd2012-12-18 14:30:41 +0000947 bool IsInteresting = RawID & 0x01;
948
949 // Wipe out the "is interesting" bit.
950 RawID = RawID >> 1;
951
Richard Smith76c2f2c2015-07-17 20:09:43 +0000952 // Build the IdentifierInfo and link the identifier ID with it.
953 IdentifierInfo *II = KnownII;
954 if (!II) {
955 II = &Reader.getIdentifierTable().getOwn(k);
956 KnownII = II;
957 }
Richard Smitheb4b58f62016-02-05 01:40:54 +0000958 markIdentifierFromAST(Reader, *II);
Richard Smith76c2f2c2015-07-17 20:09:43 +0000959 Reader.markIdentifierUpToDate(II);
960
Guy Benyei11169dd2012-12-18 14:30:41 +0000961 IdentID ID = Reader.getGlobalIdentifierID(F, RawID);
962 if (!IsInteresting) {
Richard Smith76c2f2c2015-07-17 20:09:43 +0000963 // For uninteresting identifiers, there's nothing else to do. Just notify
964 // the reader that we've finished loading this identifier.
Guy Benyei11169dd2012-12-18 14:30:41 +0000965 Reader.SetIdentifierInfo(ID, II);
Guy Benyei11169dd2012-12-18 14:30:41 +0000966 return II;
967 }
968
Justin Bogner57ba0b22014-03-28 22:03:24 +0000969 unsigned ObjCOrBuiltinID = endian::readNext<uint16_t, little, unaligned>(d);
970 unsigned Bits = endian::readNext<uint16_t, little, unaligned>(d);
Richard Smith76c2f2c2015-07-17 20:09:43 +0000971 bool CPlusPlusOperatorKeyword = readBit(Bits);
972 bool HasRevertedTokenIDToIdentifier = readBit(Bits);
Richard Smith9c254182015-07-19 21:41:12 +0000973 bool HasRevertedBuiltin = readBit(Bits);
Richard Smith76c2f2c2015-07-17 20:09:43 +0000974 bool Poisoned = readBit(Bits);
975 bool ExtensionToken = readBit(Bits);
976 bool HadMacroDefinition = readBit(Bits);
Guy Benyei11169dd2012-12-18 14:30:41 +0000977
978 assert(Bits == 0 && "Extra bits in the identifier?");
979 DataLen -= 8;
980
Guy Benyei11169dd2012-12-18 14:30:41 +0000981 // Set or check the various bits in the IdentifierInfo structure.
982 // Token IDs are read-only.
Argyrios Kyrtzidisddee8c92013-02-27 01:13:51 +0000983 if (HasRevertedTokenIDToIdentifier && II->getTokenID() != tok::identifier)
Richard Smith9c254182015-07-19 21:41:12 +0000984 II->revertTokenIDToIdentifier();
985 if (!F.isModule())
986 II->setObjCOrBuiltinID(ObjCOrBuiltinID);
987 else if (HasRevertedBuiltin && II->getBuiltinID()) {
988 II->revertBuiltin();
989 assert((II->hasRevertedBuiltin() ||
990 II->getObjCOrBuiltinID() == ObjCOrBuiltinID) &&
991 "Incorrect ObjC keyword or builtin ID");
992 }
Guy Benyei11169dd2012-12-18 14:30:41 +0000993 assert(II->isExtensionToken() == ExtensionToken &&
994 "Incorrect extension token flag");
995 (void)ExtensionToken;
996 if (Poisoned)
997 II->setIsPoisoned(true);
998 assert(II->isCPlusPlusOperatorKeyword() == CPlusPlusOperatorKeyword &&
999 "Incorrect C++ operator keyword flag");
1000 (void)CPlusPlusOperatorKeyword;
1001
1002 // If this identifier is a macro, deserialize the macro
1003 // definition.
Richard Smith76c2f2c2015-07-17 20:09:43 +00001004 if (HadMacroDefinition) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001005 uint32_t MacroDirectivesOffset =
1006 endian::readNext<uint32_t, little, unaligned>(d);
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001007 DataLen -= 4;
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001008
Richard Smithd7329392015-04-21 21:46:32 +00001009 Reader.addPendingMacro(II, &F, MacroDirectivesOffset);
Guy Benyei11169dd2012-12-18 14:30:41 +00001010 }
1011
1012 Reader.SetIdentifierInfo(ID, II);
1013
1014 // Read all of the declarations visible at global scope with this
1015 // name.
1016 if (DataLen > 0) {
1017 SmallVector<uint32_t, 4> DeclIDs;
1018 for (; DataLen > 0; DataLen -= 4)
Justin Bogner57ba0b22014-03-28 22:03:24 +00001019 DeclIDs.push_back(Reader.getGlobalDeclID(
1020 F, endian::readNext<uint32_t, little, unaligned>(d)));
Guy Benyei11169dd2012-12-18 14:30:41 +00001021 Reader.SetGloballyVisibleDecls(II, DeclIDs);
1022 }
1023
1024 return II;
1025}
1026
Richard Smitha06c7e62015-08-26 23:55:49 +00001027DeclarationNameKey::DeclarationNameKey(DeclarationName Name)
1028 : Kind(Name.getNameKind()) {
1029 switch (Kind) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001030 case DeclarationName::Identifier:
Richard Smitha06c7e62015-08-26 23:55:49 +00001031 Data = (uint64_t)Name.getAsIdentifierInfo();
Guy Benyei11169dd2012-12-18 14:30:41 +00001032 break;
1033 case DeclarationName::ObjCZeroArgSelector:
1034 case DeclarationName::ObjCOneArgSelector:
1035 case DeclarationName::ObjCMultiArgSelector:
Richard Smitha06c7e62015-08-26 23:55:49 +00001036 Data = (uint64_t)Name.getObjCSelector().getAsOpaquePtr();
Guy Benyei11169dd2012-12-18 14:30:41 +00001037 break;
1038 case DeclarationName::CXXOperatorName:
Richard Smitha06c7e62015-08-26 23:55:49 +00001039 Data = Name.getCXXOverloadedOperator();
1040 break;
1041 case DeclarationName::CXXLiteralOperatorName:
1042 Data = (uint64_t)Name.getCXXLiteralIdentifier();
1043 break;
Richard Smith35845152017-02-07 01:37:30 +00001044 case DeclarationName::CXXDeductionGuideName:
1045 Data = (uint64_t)Name.getCXXDeductionGuideTemplate()
1046 ->getDeclName().getAsIdentifierInfo();
1047 break;
Richard Smitha06c7e62015-08-26 23:55:49 +00001048 case DeclarationName::CXXConstructorName:
1049 case DeclarationName::CXXDestructorName:
1050 case DeclarationName::CXXConversionFunctionName:
1051 case DeclarationName::CXXUsingDirective:
1052 Data = 0;
1053 break;
1054 }
1055}
1056
1057unsigned DeclarationNameKey::getHash() const {
1058 llvm::FoldingSetNodeID ID;
1059 ID.AddInteger(Kind);
1060
1061 switch (Kind) {
1062 case DeclarationName::Identifier:
1063 case DeclarationName::CXXLiteralOperatorName:
Richard Smith35845152017-02-07 01:37:30 +00001064 case DeclarationName::CXXDeductionGuideName:
Richard Smitha06c7e62015-08-26 23:55:49 +00001065 ID.AddString(((IdentifierInfo*)Data)->getName());
1066 break;
1067 case DeclarationName::ObjCZeroArgSelector:
1068 case DeclarationName::ObjCOneArgSelector:
1069 case DeclarationName::ObjCMultiArgSelector:
1070 ID.AddInteger(serialization::ComputeHash(Selector(Data)));
1071 break;
1072 case DeclarationName::CXXOperatorName:
1073 ID.AddInteger((OverloadedOperatorKind)Data);
Guy Benyei11169dd2012-12-18 14:30:41 +00001074 break;
1075 case DeclarationName::CXXConstructorName:
1076 case DeclarationName::CXXDestructorName:
1077 case DeclarationName::CXXConversionFunctionName:
1078 case DeclarationName::CXXUsingDirective:
1079 break;
1080 }
1081
1082 return ID.ComputeHash();
1083}
1084
Richard Smithd88a7f12015-09-01 20:35:42 +00001085ModuleFile *
1086ASTDeclContextNameLookupTrait::ReadFileRef(const unsigned char *&d) {
1087 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001088
Richard Smithd88a7f12015-09-01 20:35:42 +00001089 uint32_t ModuleFileID = endian::readNext<uint32_t, little, unaligned>(d);
1090 return Reader.getLocalModuleFile(F, ModuleFileID);
1091}
1092
Guy Benyei11169dd2012-12-18 14:30:41 +00001093std::pair<unsigned, unsigned>
Richard Smitha06c7e62015-08-26 23:55:49 +00001094ASTDeclContextNameLookupTrait::ReadKeyDataLength(const unsigned char *&d) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001095 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001096
Justin Bogner57ba0b22014-03-28 22:03:24 +00001097 unsigned KeyLen = endian::readNext<uint16_t, little, unaligned>(d);
1098 unsigned DataLen = endian::readNext<uint16_t, little, unaligned>(d);
Guy Benyei11169dd2012-12-18 14:30:41 +00001099 return std::make_pair(KeyLen, DataLen);
1100}
1101
Richard Smitha06c7e62015-08-26 23:55:49 +00001102ASTDeclContextNameLookupTrait::internal_key_type
1103ASTDeclContextNameLookupTrait::ReadKey(const unsigned char *d, unsigned) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001104 using namespace llvm::support;
Guy Benyei11169dd2012-12-18 14:30:41 +00001105
Vedant Kumar48b4f762018-04-14 01:40:48 +00001106 auto Kind = (DeclarationName::NameKind)*d++;
Richard Smitha06c7e62015-08-26 23:55:49 +00001107 uint64_t Data;
1108 switch (Kind) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001109 case DeclarationName::Identifier:
Richard Smith35845152017-02-07 01:37:30 +00001110 case DeclarationName::CXXLiteralOperatorName:
1111 case DeclarationName::CXXDeductionGuideName:
Richard Smitha06c7e62015-08-26 23:55:49 +00001112 Data = (uint64_t)Reader.getLocalIdentifier(
Justin Bogner57ba0b22014-03-28 22:03:24 +00001113 F, endian::readNext<uint32_t, little, unaligned>(d));
Guy Benyei11169dd2012-12-18 14:30:41 +00001114 break;
1115 case DeclarationName::ObjCZeroArgSelector:
1116 case DeclarationName::ObjCOneArgSelector:
1117 case DeclarationName::ObjCMultiArgSelector:
Richard Smitha06c7e62015-08-26 23:55:49 +00001118 Data =
Justin Bogner57ba0b22014-03-28 22:03:24 +00001119 (uint64_t)Reader.getLocalSelector(
1120 F, endian::readNext<uint32_t, little, unaligned>(
1121 d)).getAsOpaquePtr();
Guy Benyei11169dd2012-12-18 14:30:41 +00001122 break;
1123 case DeclarationName::CXXOperatorName:
Richard Smitha06c7e62015-08-26 23:55:49 +00001124 Data = *d++; // OverloadedOperatorKind
Guy Benyei11169dd2012-12-18 14:30:41 +00001125 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00001126 case DeclarationName::CXXConstructorName:
1127 case DeclarationName::CXXDestructorName:
1128 case DeclarationName::CXXConversionFunctionName:
1129 case DeclarationName::CXXUsingDirective:
Richard Smitha06c7e62015-08-26 23:55:49 +00001130 Data = 0;
Guy Benyei11169dd2012-12-18 14:30:41 +00001131 break;
1132 }
1133
Richard Smitha06c7e62015-08-26 23:55:49 +00001134 return DeclarationNameKey(Kind, Data);
Guy Benyei11169dd2012-12-18 14:30:41 +00001135}
1136
Richard Smithd88a7f12015-09-01 20:35:42 +00001137void ASTDeclContextNameLookupTrait::ReadDataInto(internal_key_type,
1138 const unsigned char *d,
1139 unsigned DataLen,
1140 data_type_builder &Val) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001141 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001142
Richard Smithd88a7f12015-09-01 20:35:42 +00001143 for (unsigned NumDecls = DataLen / 4; NumDecls; --NumDecls) {
1144 uint32_t LocalID = endian::readNext<uint32_t, little, unaligned>(d);
1145 Val.insert(Reader.getGlobalDeclID(F, LocalID));
1146 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001147}
1148
Richard Smith0f4e2c42015-08-06 04:23:48 +00001149bool ASTReader::ReadLexicalDeclContextStorage(ModuleFile &M,
1150 BitstreamCursor &Cursor,
1151 uint64_t Offset,
1152 DeclContext *DC) {
1153 assert(Offset != 0);
1154
Guy Benyei11169dd2012-12-18 14:30:41 +00001155 SavedStreamPosition SavedPosition(Cursor);
JF Bastien0e828952019-06-26 19:50:12 +00001156 if (llvm::Error Err = Cursor.JumpToBit(Offset)) {
1157 Error(std::move(Err));
1158 return true;
1159 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001160
Richard Smith0f4e2c42015-08-06 04:23:48 +00001161 RecordData Record;
1162 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00001163 Expected<unsigned> MaybeCode = Cursor.ReadCode();
1164 if (!MaybeCode) {
1165 Error(MaybeCode.takeError());
1166 return true;
1167 }
1168 unsigned Code = MaybeCode.get();
1169
1170 Expected<unsigned> MaybeRecCode = Cursor.readRecord(Code, Record, &Blob);
1171 if (!MaybeRecCode) {
1172 Error(MaybeRecCode.takeError());
1173 return true;
1174 }
1175 unsigned RecCode = MaybeRecCode.get();
Richard Smith0f4e2c42015-08-06 04:23:48 +00001176 if (RecCode != DECL_CONTEXT_LEXICAL) {
1177 Error("Expected lexical block");
1178 return true;
Guy Benyei11169dd2012-12-18 14:30:41 +00001179 }
1180
Richard Smith82f8fcd2015-08-06 22:07:25 +00001181 assert(!isa<TranslationUnitDecl>(DC) &&
1182 "expected a TU_UPDATE_LEXICAL record for TU");
Richard Smith9c9173d2015-08-11 22:00:24 +00001183 // If we are handling a C++ class template instantiation, we can see multiple
1184 // lexical updates for the same record. It's important that we select only one
1185 // of them, so that field numbering works properly. Just pick the first one we
1186 // see.
1187 auto &Lex = LexicalDecls[DC];
1188 if (!Lex.first) {
1189 Lex = std::make_pair(
1190 &M, llvm::makeArrayRef(
1191 reinterpret_cast<const llvm::support::unaligned_uint32_t *>(
1192 Blob.data()),
1193 Blob.size() / 4));
1194 }
Richard Smith0f4e2c42015-08-06 04:23:48 +00001195 DC->setHasExternalLexicalStorage(true);
1196 return false;
1197}
Guy Benyei11169dd2012-12-18 14:30:41 +00001198
Richard Smith0f4e2c42015-08-06 04:23:48 +00001199bool ASTReader::ReadVisibleDeclContextStorage(ModuleFile &M,
1200 BitstreamCursor &Cursor,
1201 uint64_t Offset,
1202 DeclID ID) {
1203 assert(Offset != 0);
1204
1205 SavedStreamPosition SavedPosition(Cursor);
JF Bastien0e828952019-06-26 19:50:12 +00001206 if (llvm::Error Err = Cursor.JumpToBit(Offset)) {
1207 Error(std::move(Err));
1208 return true;
1209 }
Richard Smith0f4e2c42015-08-06 04:23:48 +00001210
1211 RecordData Record;
1212 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00001213 Expected<unsigned> MaybeCode = Cursor.ReadCode();
1214 if (!MaybeCode) {
1215 Error(MaybeCode.takeError());
1216 return true;
1217 }
1218 unsigned Code = MaybeCode.get();
1219
1220 Expected<unsigned> MaybeRecCode = Cursor.readRecord(Code, Record, &Blob);
1221 if (!MaybeRecCode) {
1222 Error(MaybeRecCode.takeError());
1223 return true;
1224 }
1225 unsigned RecCode = MaybeRecCode.get();
Richard Smith0f4e2c42015-08-06 04:23:48 +00001226 if (RecCode != DECL_CONTEXT_VISIBLE) {
1227 Error("Expected visible lookup table block");
1228 return true;
Guy Benyei11169dd2012-12-18 14:30:41 +00001229 }
1230
Richard Smith0f4e2c42015-08-06 04:23:48 +00001231 // We can't safely determine the primary context yet, so delay attaching the
1232 // lookup table until we're done with recursive deserialization.
Richard Smithd88a7f12015-09-01 20:35:42 +00001233 auto *Data = (const unsigned char*)Blob.data();
1234 PendingVisibleUpdates[ID].push_back(PendingVisibleUpdate{&M, Data});
Guy Benyei11169dd2012-12-18 14:30:41 +00001235 return false;
1236}
1237
Richard Smith37a93df2017-02-18 00:32:02 +00001238void ASTReader::Error(StringRef Msg) const {
Guy Benyei11169dd2012-12-18 14:30:41 +00001239 Error(diag::err_fe_pch_malformed, Msg);
Richard Smithdbafb6c2017-06-29 23:23:46 +00001240 if (PP.getLangOpts().Modules && !Diags.isDiagnosticInFlight() &&
Richard Smithfb1e7f72015-08-14 05:02:58 +00001241 !PP.getHeaderSearchInfo().getModuleCachePath().empty()) {
Douglas Gregor940e8052013-05-10 22:15:13 +00001242 Diag(diag::note_module_cache_path)
1243 << PP.getHeaderSearchInfo().getModuleCachePath();
1244 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001245}
1246
Duncan P. N. Exon Smitheef69022019-11-10 11:17:42 -08001247void ASTReader::Error(unsigned DiagID, StringRef Arg1, StringRef Arg2,
1248 StringRef Arg3) const {
Guy Benyei11169dd2012-12-18 14:30:41 +00001249 if (Diags.isDiagnosticInFlight())
Duncan P. N. Exon Smitheef69022019-11-10 11:17:42 -08001250 Diags.SetDelayedDiagnostic(DiagID, Arg1, Arg2, Arg3);
Guy Benyei11169dd2012-12-18 14:30:41 +00001251 else
Duncan P. N. Exon Smitheef69022019-11-10 11:17:42 -08001252 Diag(DiagID) << Arg1 << Arg2 << Arg3;
Guy Benyei11169dd2012-12-18 14:30:41 +00001253}
1254
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00001255void ASTReader::Error(unsigned DiagID, StringRef Arg1, StringRef Arg2,
1256 unsigned Select) const {
1257 if (!Diags.isDiagnosticInFlight())
1258 Diag(DiagID) << Arg1 << Arg2 << Select;
1259}
1260
JF Bastien0e828952019-06-26 19:50:12 +00001261void ASTReader::Error(llvm::Error &&Err) const {
1262 Error(toString(std::move(Err)));
1263}
1264
Guy Benyei11169dd2012-12-18 14:30:41 +00001265//===----------------------------------------------------------------------===//
1266// Source Manager Deserialization
1267//===----------------------------------------------------------------------===//
1268
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00001269/// Read the line table in the source manager block.
Guy Benyei11169dd2012-12-18 14:30:41 +00001270/// \returns true if there was an error.
1271bool ASTReader::ParseLineTable(ModuleFile &F,
Richard Smith7ed1bc92014-12-05 22:42:13 +00001272 const RecordData &Record) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001273 unsigned Idx = 0;
1274 LineTableInfo &LineTable = SourceMgr.getLineTable();
1275
1276 // Parse the file names
1277 std::map<int, int> FileIDs;
Hans Wennborg14487362017-12-04 22:28:45 +00001278 FileIDs[-1] = -1; // For unspecified filenames.
Richard Smith63078492015-09-01 07:41:55 +00001279 for (unsigned I = 0; Record[Idx]; ++I) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001280 // Extract the file name
Richard Smith7ed1bc92014-12-05 22:42:13 +00001281 auto Filename = ReadPath(F, Record, Idx);
Guy Benyei11169dd2012-12-18 14:30:41 +00001282 FileIDs[I] = LineTable.getLineTableFilenameID(Filename);
1283 }
Richard Smith63078492015-09-01 07:41:55 +00001284 ++Idx;
Guy Benyei11169dd2012-12-18 14:30:41 +00001285
1286 // Parse the line entries
1287 std::vector<LineEntry> Entries;
1288 while (Idx < Record.size()) {
1289 int FID = Record[Idx++];
1290 assert(FID >= 0 && "Serialized line entries for non-local file.");
1291 // Remap FileID from 1-based old view.
1292 FID += F.SLocEntryBaseID - 1;
1293
1294 // Extract the line entries
1295 unsigned NumEntries = Record[Idx++];
Richard Smith63078492015-09-01 07:41:55 +00001296 assert(NumEntries && "no line entries for file ID");
Guy Benyei11169dd2012-12-18 14:30:41 +00001297 Entries.clear();
1298 Entries.reserve(NumEntries);
1299 for (unsigned I = 0; I != NumEntries; ++I) {
1300 unsigned FileOffset = Record[Idx++];
1301 unsigned LineNo = Record[Idx++];
1302 int FilenameID = FileIDs[Record[Idx++]];
Vedant Kumar48b4f762018-04-14 01:40:48 +00001303 SrcMgr::CharacteristicKind FileKind
1304 = (SrcMgr::CharacteristicKind)Record[Idx++];
Guy Benyei11169dd2012-12-18 14:30:41 +00001305 unsigned IncludeOffset = Record[Idx++];
1306 Entries.push_back(LineEntry::get(FileOffset, LineNo, FilenameID,
1307 FileKind, IncludeOffset));
1308 }
1309 LineTable.AddEntry(FileID::get(FID), Entries);
1310 }
1311
1312 return false;
1313}
1314
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00001315/// Read a source manager block
Guy Benyei11169dd2012-12-18 14:30:41 +00001316bool ASTReader::ReadSourceManagerBlock(ModuleFile &F) {
1317 using namespace SrcMgr;
1318
Chris Lattner7fb3bef2013-01-20 00:56:42 +00001319 BitstreamCursor &SLocEntryCursor = F.SLocEntryCursor;
Guy Benyei11169dd2012-12-18 14:30:41 +00001320
1321 // Set the source-location entry cursor to the current position in
1322 // the stream. This cursor will be used to read the contents of the
1323 // source manager block initially, and then lazily read
1324 // source-location entries as needed.
1325 SLocEntryCursor = F.Stream;
1326
1327 // The stream itself is going to skip over the source manager block.
JF Bastien0e828952019-06-26 19:50:12 +00001328 if (llvm::Error Err = F.Stream.SkipBlock()) {
1329 Error(std::move(Err));
Guy Benyei11169dd2012-12-18 14:30:41 +00001330 return true;
1331 }
1332
1333 // Enter the source manager block.
JF Bastien0e828952019-06-26 19:50:12 +00001334 if (llvm::Error Err =
1335 SLocEntryCursor.EnterSubBlock(SOURCE_MANAGER_BLOCK_ID)) {
1336 Error(std::move(Err));
Guy Benyei11169dd2012-12-18 14:30:41 +00001337 return true;
1338 }
1339
1340 RecordData Record;
1341 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00001342 Expected<llvm::BitstreamEntry> MaybeE =
1343 SLocEntryCursor.advanceSkippingSubblocks();
1344 if (!MaybeE) {
1345 Error(MaybeE.takeError());
1346 return true;
1347 }
1348 llvm::BitstreamEntry E = MaybeE.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001349
Chris Lattnere7b154b2013-01-19 21:39:22 +00001350 switch (E.Kind) {
1351 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1352 case llvm::BitstreamEntry::Error:
1353 Error("malformed block record in AST file");
1354 return true;
1355 case llvm::BitstreamEntry::EndBlock:
Guy Benyei11169dd2012-12-18 14:30:41 +00001356 return false;
Chris Lattnere7b154b2013-01-19 21:39:22 +00001357 case llvm::BitstreamEntry::Record:
1358 // The interesting case.
1359 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00001360 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001361
Guy Benyei11169dd2012-12-18 14:30:41 +00001362 // Read a record.
Guy Benyei11169dd2012-12-18 14:30:41 +00001363 Record.clear();
Chris Lattner15c3e7d2013-01-21 18:28:26 +00001364 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00001365 Expected<unsigned> MaybeRecord =
1366 SLocEntryCursor.readRecord(E.ID, Record, &Blob);
1367 if (!MaybeRecord) {
1368 Error(MaybeRecord.takeError());
1369 return true;
1370 }
1371 switch (MaybeRecord.get()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001372 default: // Default behavior: ignore.
1373 break;
1374
1375 case SM_SLOC_FILE_ENTRY:
1376 case SM_SLOC_BUFFER_ENTRY:
1377 case SM_SLOC_EXPANSION_ENTRY:
1378 // Once we hit one of the source location entries, we're done.
1379 return false;
1380 }
1381 }
1382}
1383
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00001384/// If a header file is not found at the path that we expect it to be
Guy Benyei11169dd2012-12-18 14:30:41 +00001385/// and the PCH file was moved from its original location, try to resolve the
1386/// file by assuming that header+PCH were moved together and the header is in
1387/// the same place relative to the PCH.
1388static std::string
1389resolveFileRelativeToOriginalDir(const std::string &Filename,
1390 const std::string &OriginalDir,
1391 const std::string &CurrDir) {
1392 assert(OriginalDir != CurrDir &&
1393 "No point trying to resolve the file if the PCH dir didn't change");
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001394
Guy Benyei11169dd2012-12-18 14:30:41 +00001395 using namespace llvm::sys;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001396
Guy Benyei11169dd2012-12-18 14:30:41 +00001397 SmallString<128> filePath(Filename);
1398 fs::make_absolute(filePath);
1399 assert(path::is_absolute(OriginalDir));
1400 SmallString<128> currPCHPath(CurrDir);
1401
1402 path::const_iterator fileDirI = path::begin(path::parent_path(filePath)),
1403 fileDirE = path::end(path::parent_path(filePath));
1404 path::const_iterator origDirI = path::begin(OriginalDir),
1405 origDirE = path::end(OriginalDir);
1406 // Skip the common path components from filePath and OriginalDir.
1407 while (fileDirI != fileDirE && origDirI != origDirE &&
1408 *fileDirI == *origDirI) {
1409 ++fileDirI;
1410 ++origDirI;
1411 }
1412 for (; origDirI != origDirE; ++origDirI)
1413 path::append(currPCHPath, "..");
1414 path::append(currPCHPath, fileDirI, fileDirE);
1415 path::append(currPCHPath, path::filename(Filename));
Benjamin Krameradcd0262020-01-28 20:23:46 +01001416 return std::string(currPCHPath.str());
Guy Benyei11169dd2012-12-18 14:30:41 +00001417}
1418
1419bool ASTReader::ReadSLocEntry(int ID) {
1420 if (ID == 0)
1421 return false;
1422
1423 if (unsigned(-ID) - 2 >= getTotalNumSLocs() || ID > 0) {
1424 Error("source location entry ID out-of-range for AST file");
1425 return true;
1426 }
1427
Richard Smithaada85c2016-02-06 02:06:43 +00001428 // Local helper to read the (possibly-compressed) buffer data following the
1429 // entry record.
1430 auto ReadBuffer = [this](
1431 BitstreamCursor &SLocEntryCursor,
1432 StringRef Name) -> std::unique_ptr<llvm::MemoryBuffer> {
1433 RecordData Record;
1434 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00001435 Expected<unsigned> MaybeCode = SLocEntryCursor.ReadCode();
1436 if (!MaybeCode) {
1437 Error(MaybeCode.takeError());
1438 return nullptr;
1439 }
1440 unsigned Code = MaybeCode.get();
1441
1442 Expected<unsigned> MaybeRecCode =
1443 SLocEntryCursor.readRecord(Code, Record, &Blob);
1444 if (!MaybeRecCode) {
1445 Error(MaybeRecCode.takeError());
1446 return nullptr;
1447 }
1448 unsigned RecCode = MaybeRecCode.get();
Richard Smithaada85c2016-02-06 02:06:43 +00001449
1450 if (RecCode == SM_SLOC_BUFFER_BLOB_COMPRESSED) {
George Rimarc39f5492017-01-17 15:45:31 +00001451 if (!llvm::zlib::isAvailable()) {
1452 Error("zlib is not available");
1453 return nullptr;
1454 }
Richard Smithaada85c2016-02-06 02:06:43 +00001455 SmallString<0> Uncompressed;
George Rimarc39f5492017-01-17 15:45:31 +00001456 if (llvm::Error E =
1457 llvm::zlib::uncompress(Blob, Uncompressed, Record[0])) {
1458 Error("could not decompress embedded file contents: " +
1459 llvm::toString(std::move(E)));
Richard Smithaada85c2016-02-06 02:06:43 +00001460 return nullptr;
1461 }
1462 return llvm::MemoryBuffer::getMemBufferCopy(Uncompressed, Name);
1463 } else if (RecCode == SM_SLOC_BUFFER_BLOB) {
1464 return llvm::MemoryBuffer::getMemBuffer(Blob.drop_back(1), Name, true);
1465 } else {
1466 Error("AST record has invalid code");
1467 return nullptr;
1468 }
1469 };
1470
Guy Benyei11169dd2012-12-18 14:30:41 +00001471 ModuleFile *F = GlobalSLocEntryMap.find(-ID)->second;
JF Bastien0e828952019-06-26 19:50:12 +00001472 if (llvm::Error Err = F->SLocEntryCursor.JumpToBit(
Dmitry Polukhina7afb212020-04-16 09:24:46 -07001473 F->SLocEntryOffsetsBase +
JF Bastien0e828952019-06-26 19:50:12 +00001474 F->SLocEntryOffsets[ID - F->SLocEntryBaseID])) {
1475 Error(std::move(Err));
1476 return true;
1477 }
1478
Chris Lattner7fb3bef2013-01-20 00:56:42 +00001479 BitstreamCursor &SLocEntryCursor = F->SLocEntryCursor;
Guy Benyei11169dd2012-12-18 14:30:41 +00001480 unsigned BaseOffset = F->SLocEntryBaseOffset;
1481
1482 ++NumSLocEntriesRead;
JF Bastien0e828952019-06-26 19:50:12 +00001483 Expected<llvm::BitstreamEntry> MaybeEntry = SLocEntryCursor.advance();
1484 if (!MaybeEntry) {
1485 Error(MaybeEntry.takeError());
1486 return true;
1487 }
1488 llvm::BitstreamEntry Entry = MaybeEntry.get();
1489
Chris Lattnere7b154b2013-01-19 21:39:22 +00001490 if (Entry.Kind != llvm::BitstreamEntry::Record) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001491 Error("incorrectly-formatted source location entry in AST file");
1492 return true;
1493 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001494
Guy Benyei11169dd2012-12-18 14:30:41 +00001495 RecordData Record;
Chris Lattner0e6c9402013-01-20 02:38:54 +00001496 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00001497 Expected<unsigned> MaybeSLOC =
1498 SLocEntryCursor.readRecord(Entry.ID, Record, &Blob);
1499 if (!MaybeSLOC) {
1500 Error(MaybeSLOC.takeError());
1501 return true;
1502 }
1503 switch (MaybeSLOC.get()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001504 default:
1505 Error("incorrectly-formatted source location entry in AST file");
1506 return true;
1507
1508 case SM_SLOC_FILE_ENTRY: {
1509 // We will detect whether a file changed and return 'Failure' for it, but
1510 // we will also try to fail gracefully by setting up the SLocEntry.
1511 unsigned InputID = Record[4];
1512 InputFile IF = getInputFile(*F, InputID);
Argyrios Kyrtzidis61c3d872013-03-01 03:26:04 +00001513 const FileEntry *File = IF.getFile();
1514 bool OverriddenBuffer = IF.isOverridden();
Guy Benyei11169dd2012-12-18 14:30:41 +00001515
Argyrios Kyrtzidis61c3d872013-03-01 03:26:04 +00001516 // Note that we only check if a File was returned. If it was out-of-date
1517 // we have complained but we will continue creating a FileID to recover
1518 // gracefully.
1519 if (!File)
Guy Benyei11169dd2012-12-18 14:30:41 +00001520 return true;
1521
1522 SourceLocation IncludeLoc = ReadSourceLocation(*F, Record[1]);
1523 if (IncludeLoc.isInvalid() && F->Kind != MK_MainFile) {
1524 // This is the module's main file.
1525 IncludeLoc = getImportLocation(F);
1526 }
Vedant Kumar48b4f762018-04-14 01:40:48 +00001527 SrcMgr::CharacteristicKind
1528 FileCharacter = (SrcMgr::CharacteristicKind)Record[2];
Alex Lorenz4dc55732019-08-22 18:15:50 +00001529 // FIXME: The FileID should be created from the FileEntryRef.
Guy Benyei11169dd2012-12-18 14:30:41 +00001530 FileID FID = SourceMgr.createFileID(File, IncludeLoc, FileCharacter,
1531 ID, BaseOffset + Record[0]);
Vedant Kumar48b4f762018-04-14 01:40:48 +00001532 SrcMgr::FileInfo &FileInfo =
1533 const_cast<SrcMgr::FileInfo&>(SourceMgr.getSLocEntry(FID).getFile());
Guy Benyei11169dd2012-12-18 14:30:41 +00001534 FileInfo.NumCreatedFIDs = Record[5];
1535 if (Record[3])
1536 FileInfo.setHasLineDirectives();
1537
Guy Benyei11169dd2012-12-18 14:30:41 +00001538 unsigned NumFileDecls = Record[7];
Richard Smithdbafb6c2017-06-29 23:23:46 +00001539 if (NumFileDecls && ContextObj) {
Roman Lebedevbf4f1e02019-10-10 12:22:42 +00001540 const DeclID *FirstDecl = F->FileSortedDecls + Record[6];
Guy Benyei11169dd2012-12-18 14:30:41 +00001541 assert(F->FileSortedDecls && "FILE_SORTED_DECLS not encountered yet ?");
1542 FileDeclIDs[FID] = FileDeclsInfo(F, llvm::makeArrayRef(FirstDecl,
1543 NumFileDecls));
1544 }
Richard Smithaada85c2016-02-06 02:06:43 +00001545
Guy Benyei11169dd2012-12-18 14:30:41 +00001546 const SrcMgr::ContentCache *ContentCache
Richard Smithf3f84612017-06-29 02:19:42 +00001547 = SourceMgr.getOrCreateContentCache(File, isSystem(FileCharacter));
Guy Benyei11169dd2012-12-18 14:30:41 +00001548 if (OverriddenBuffer && !ContentCache->BufferOverridden &&
Richard Smitha8cfffa2015-11-26 02:04:16 +00001549 ContentCache->ContentsEntry == ContentCache->OrigEntry &&
1550 !ContentCache->getRawBuffer()) {
Richard Smithaada85c2016-02-06 02:06:43 +00001551 auto Buffer = ReadBuffer(SLocEntryCursor, File->getName());
1552 if (!Buffer)
Guy Benyei11169dd2012-12-18 14:30:41 +00001553 return true;
David Blaikie49cc3182014-08-27 20:54:45 +00001554 SourceMgr.overrideFileContents(File, std::move(Buffer));
Guy Benyei11169dd2012-12-18 14:30:41 +00001555 }
1556
1557 break;
1558 }
1559
1560 case SM_SLOC_BUFFER_ENTRY: {
Chris Lattner0e6c9402013-01-20 02:38:54 +00001561 const char *Name = Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00001562 unsigned Offset = Record[0];
Vedant Kumar48b4f762018-04-14 01:40:48 +00001563 SrcMgr::CharacteristicKind
1564 FileCharacter = (SrcMgr::CharacteristicKind)Record[2];
Guy Benyei11169dd2012-12-18 14:30:41 +00001565 SourceLocation IncludeLoc = ReadSourceLocation(*F, Record[1]);
Manman Ren11f2a472016-08-18 17:42:15 +00001566 if (IncludeLoc.isInvalid() && F->isModule()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00001567 IncludeLoc = getImportLocation(F);
1568 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001569
Richard Smithaada85c2016-02-06 02:06:43 +00001570 auto Buffer = ReadBuffer(SLocEntryCursor, Name);
1571 if (!Buffer)
Guy Benyei11169dd2012-12-18 14:30:41 +00001572 return true;
David Blaikie50a5f972014-08-29 07:59:55 +00001573 SourceMgr.createFileID(std::move(Buffer), FileCharacter, ID,
Rafael Espindolad87f8d72014-08-27 20:03:29 +00001574 BaseOffset + Offset, IncludeLoc);
Guy Benyei11169dd2012-12-18 14:30:41 +00001575 break;
1576 }
1577
1578 case SM_SLOC_EXPANSION_ENTRY: {
1579 SourceLocation SpellingLoc = ReadSourceLocation(*F, Record[1]);
1580 SourceMgr.createExpansionLoc(SpellingLoc,
1581 ReadSourceLocation(*F, Record[2]),
1582 ReadSourceLocation(*F, Record[3]),
Richard Smithb5f81712018-04-30 05:25:48 +00001583 Record[5],
Guy Benyei11169dd2012-12-18 14:30:41 +00001584 Record[4],
1585 ID,
1586 BaseOffset + Record[0]);
1587 break;
1588 }
1589 }
1590
1591 return false;
1592}
1593
1594std::pair<SourceLocation, StringRef> ASTReader::getModuleImportLoc(int ID) {
1595 if (ID == 0)
1596 return std::make_pair(SourceLocation(), "");
1597
1598 if (unsigned(-ID) - 2 >= getTotalNumSLocs() || ID > 0) {
1599 Error("source location entry ID out-of-range for AST file");
1600 return std::make_pair(SourceLocation(), "");
1601 }
1602
1603 // Find which module file this entry lands in.
1604 ModuleFile *M = GlobalSLocEntryMap.find(-ID)->second;
Manman Ren11f2a472016-08-18 17:42:15 +00001605 if (!M->isModule())
Guy Benyei11169dd2012-12-18 14:30:41 +00001606 return std::make_pair(SourceLocation(), "");
1607
1608 // FIXME: Can we map this down to a particular submodule? That would be
1609 // ideal.
Ben Langmuirbeee15e2014-04-14 18:00:01 +00001610 return std::make_pair(M->ImportLoc, StringRef(M->ModuleName));
Guy Benyei11169dd2012-12-18 14:30:41 +00001611}
1612
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00001613/// Find the location where the module F is imported.
Guy Benyei11169dd2012-12-18 14:30:41 +00001614SourceLocation ASTReader::getImportLocation(ModuleFile *F) {
1615 if (F->ImportLoc.isValid())
1616 return F->ImportLoc;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001617
Guy Benyei11169dd2012-12-18 14:30:41 +00001618 // Otherwise we have a PCH. It's considered to be "imported" at the first
1619 // location of its includer.
1620 if (F->ImportedBy.empty() || !F->ImportedBy[0]) {
Ben Langmuirbeee15e2014-04-14 18:00:01 +00001621 // Main file is the importer.
Yaron Keren8b563662015-10-03 10:46:20 +00001622 assert(SourceMgr.getMainFileID().isValid() && "missing main file");
Ben Langmuirbeee15e2014-04-14 18:00:01 +00001623 return SourceMgr.getLocForStartOfFile(SourceMgr.getMainFileID());
Guy Benyei11169dd2012-12-18 14:30:41 +00001624 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001625 return F->ImportedBy[0]->FirstLoc;
1626}
1627
JF Bastien0e828952019-06-26 19:50:12 +00001628/// Enter a subblock of the specified BlockID with the specified cursor. Read
1629/// the abbreviations that are at the top of the block and then leave the cursor
1630/// pointing into the block.
Chris Lattner7fb3bef2013-01-20 00:56:42 +00001631bool ASTReader::ReadBlockAbbrevs(BitstreamCursor &Cursor, unsigned BlockID) {
JF Bastien0e828952019-06-26 19:50:12 +00001632 if (llvm::Error Err = Cursor.EnterSubBlock(BlockID)) {
1633 // FIXME this drops errors on the floor.
1634 consumeError(std::move(Err));
Richard Smith0516b182015-09-08 19:40:14 +00001635 return true;
JF Bastien0e828952019-06-26 19:50:12 +00001636 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001637
1638 while (true) {
1639 uint64_t Offset = Cursor.GetCurrentBitNo();
JF Bastien0e828952019-06-26 19:50:12 +00001640 Expected<unsigned> MaybeCode = Cursor.ReadCode();
1641 if (!MaybeCode) {
1642 // FIXME this drops errors on the floor.
1643 consumeError(MaybeCode.takeError());
1644 return true;
1645 }
1646 unsigned Code = MaybeCode.get();
Guy Benyei11169dd2012-12-18 14:30:41 +00001647
1648 // We expect all abbrevs to be at the start of the block.
1649 if (Code != llvm::bitc::DEFINE_ABBREV) {
JF Bastien0e828952019-06-26 19:50:12 +00001650 if (llvm::Error Err = Cursor.JumpToBit(Offset)) {
1651 // FIXME this drops errors on the floor.
1652 consumeError(std::move(Err));
1653 return true;
1654 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001655 return false;
1656 }
JF Bastien0e828952019-06-26 19:50:12 +00001657 if (llvm::Error Err = Cursor.ReadAbbrevRecord()) {
1658 // FIXME this drops errors on the floor.
1659 consumeError(std::move(Err));
1660 return true;
1661 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001662 }
1663}
1664
Richard Smithe40f2ba2013-08-07 21:41:30 +00001665Token ASTReader::ReadToken(ModuleFile &F, const RecordDataImpl &Record,
John McCallf413f5e2013-05-03 00:10:13 +00001666 unsigned &Idx) {
1667 Token Tok;
1668 Tok.startToken();
1669 Tok.setLocation(ReadSourceLocation(F, Record, Idx));
1670 Tok.setLength(Record[Idx++]);
1671 if (IdentifierInfo *II = getLocalIdentifier(F, Record[Idx++]))
1672 Tok.setIdentifierInfo(II);
1673 Tok.setKind((tok::TokenKind)Record[Idx++]);
1674 Tok.setFlag((Token::TokenFlags)Record[Idx++]);
1675 return Tok;
1676}
1677
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001678MacroInfo *ASTReader::ReadMacroRecord(ModuleFile &F, uint64_t Offset) {
Chris Lattner7fb3bef2013-01-20 00:56:42 +00001679 BitstreamCursor &Stream = F.MacroCursor;
Guy Benyei11169dd2012-12-18 14:30:41 +00001680
1681 // Keep track of where we are in the stream, then jump back there
1682 // after reading this macro.
1683 SavedStreamPosition SavedPosition(Stream);
1684
JF Bastien0e828952019-06-26 19:50:12 +00001685 if (llvm::Error Err = Stream.JumpToBit(Offset)) {
1686 // FIXME this drops errors on the floor.
1687 consumeError(std::move(Err));
1688 return nullptr;
1689 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001690 RecordData Record;
Faisal Valiac506d72017-07-17 17:18:43 +00001691 SmallVector<IdentifierInfo*, 16> MacroParams;
Craig Toppera13603a2014-05-22 05:54:18 +00001692 MacroInfo *Macro = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00001693
Guy Benyei11169dd2012-12-18 14:30:41 +00001694 while (true) {
Chris Lattnerefa77172013-01-20 00:00:22 +00001695 // Advance to the next record, but if we get to the end of the block, don't
1696 // pop it (removing all the abbreviations from the cursor) since we want to
1697 // be able to reseek within the block and read entries.
Chris Lattner7fb3bef2013-01-20 00:56:42 +00001698 unsigned Flags = BitstreamCursor::AF_DontPopBlockAtEnd;
JF Bastien0e828952019-06-26 19:50:12 +00001699 Expected<llvm::BitstreamEntry> MaybeEntry =
1700 Stream.advanceSkippingSubblocks(Flags);
1701 if (!MaybeEntry) {
1702 Error(MaybeEntry.takeError());
1703 return Macro;
1704 }
1705 llvm::BitstreamEntry Entry = MaybeEntry.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001706
Chris Lattnerefa77172013-01-20 00:00:22 +00001707 switch (Entry.Kind) {
1708 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1709 case llvm::BitstreamEntry::Error:
1710 Error("malformed block record in AST file");
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001711 return Macro;
Chris Lattnerefa77172013-01-20 00:00:22 +00001712 case llvm::BitstreamEntry::EndBlock:
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001713 return Macro;
Chris Lattnerefa77172013-01-20 00:00:22 +00001714 case llvm::BitstreamEntry::Record:
1715 // The interesting case.
1716 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00001717 }
1718
1719 // Read a record.
Guy Benyei11169dd2012-12-18 14:30:41 +00001720 Record.clear();
JF Bastien0e828952019-06-26 19:50:12 +00001721 PreprocessorRecordTypes RecType;
1722 if (Expected<unsigned> MaybeRecType = Stream.readRecord(Entry.ID, Record))
1723 RecType = (PreprocessorRecordTypes)MaybeRecType.get();
1724 else {
1725 Error(MaybeRecType.takeError());
1726 return Macro;
1727 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001728 switch (RecType) {
Richard Smithd7329392015-04-21 21:46:32 +00001729 case PP_MODULE_MACRO:
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001730 case PP_MACRO_DIRECTIVE_HISTORY:
1731 return Macro;
1732
Guy Benyei11169dd2012-12-18 14:30:41 +00001733 case PP_MACRO_OBJECT_LIKE:
1734 case PP_MACRO_FUNCTION_LIKE: {
1735 // If we already have a macro, that means that we've hit the end
1736 // of the definition of the macro we were looking for. We're
1737 // done.
1738 if (Macro)
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001739 return Macro;
Guy Benyei11169dd2012-12-18 14:30:41 +00001740
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001741 unsigned NextIndex = 1; // Skip identifier ID.
Guy Benyei11169dd2012-12-18 14:30:41 +00001742 SourceLocation Loc = ReadSourceLocation(F, Record, NextIndex);
Richard Smith3f6dd7a2017-05-12 23:40:52 +00001743 MacroInfo *MI = PP.AllocateMacroInfo(Loc);
Argyrios Kyrtzidis7572be22013-01-07 19:16:23 +00001744 MI->setDefinitionEndLoc(ReadSourceLocation(F, Record, NextIndex));
Guy Benyei11169dd2012-12-18 14:30:41 +00001745 MI->setIsUsed(Record[NextIndex++]);
Argyrios Kyrtzidis9ef53ce2014-04-09 18:21:23 +00001746 MI->setUsedForHeaderGuard(Record[NextIndex++]);
Guy Benyei11169dd2012-12-18 14:30:41 +00001747
Guy Benyei11169dd2012-12-18 14:30:41 +00001748 if (RecType == PP_MACRO_FUNCTION_LIKE) {
1749 // Decode function-like macro info.
1750 bool isC99VarArgs = Record[NextIndex++];
1751 bool isGNUVarArgs = Record[NextIndex++];
1752 bool hasCommaPasting = Record[NextIndex++];
Faisal Valiac506d72017-07-17 17:18:43 +00001753 MacroParams.clear();
Guy Benyei11169dd2012-12-18 14:30:41 +00001754 unsigned NumArgs = Record[NextIndex++];
1755 for (unsigned i = 0; i != NumArgs; ++i)
Faisal Valiac506d72017-07-17 17:18:43 +00001756 MacroParams.push_back(getLocalIdentifier(F, Record[NextIndex++]));
Guy Benyei11169dd2012-12-18 14:30:41 +00001757
1758 // Install function-like macro info.
1759 MI->setIsFunctionLike();
1760 if (isC99VarArgs) MI->setIsC99Varargs();
1761 if (isGNUVarArgs) MI->setIsGNUVarargs();
1762 if (hasCommaPasting) MI->setHasCommaPasting();
Faisal Valiac506d72017-07-17 17:18:43 +00001763 MI->setParameterList(MacroParams, PP.getPreprocessorAllocator());
Guy Benyei11169dd2012-12-18 14:30:41 +00001764 }
1765
Guy Benyei11169dd2012-12-18 14:30:41 +00001766 // Remember that we saw this macro last so that we add the tokens that
1767 // form its body to it.
1768 Macro = MI;
1769
1770 if (NextIndex + 1 == Record.size() && PP.getPreprocessingRecord() &&
1771 Record[NextIndex]) {
1772 // We have a macro definition. Register the association
1773 PreprocessedEntityID
1774 GlobalID = getGlobalPreprocessedEntityID(F, Record[NextIndex]);
1775 PreprocessingRecord &PPRec = *PP.getPreprocessingRecord();
Richard Smith66a81862015-05-04 02:25:31 +00001776 PreprocessingRecord::PPEntityID PPID =
1777 PPRec.getPPEntityID(GlobalID - 1, /*isLoaded=*/true);
Vedant Kumar48b4f762018-04-14 01:40:48 +00001778 MacroDefinitionRecord *PPDef = cast_or_null<MacroDefinitionRecord>(
Richard Smith66a81862015-05-04 02:25:31 +00001779 PPRec.getPreprocessedEntity(PPID));
Argyrios Kyrtzidis832de9f2013-02-22 18:35:59 +00001780 if (PPDef)
1781 PPRec.RegisterMacroDefinition(Macro, PPDef);
Guy Benyei11169dd2012-12-18 14:30:41 +00001782 }
1783
1784 ++NumMacrosRead;
1785 break;
1786 }
1787
1788 case PP_TOKEN: {
1789 // If we see a TOKEN before a PP_MACRO_*, then the file is
1790 // erroneous, just pretend we didn't see this.
Craig Toppera13603a2014-05-22 05:54:18 +00001791 if (!Macro) break;
Guy Benyei11169dd2012-12-18 14:30:41 +00001792
John McCallf413f5e2013-05-03 00:10:13 +00001793 unsigned Idx = 0;
1794 Token Tok = ReadToken(F, Record, Idx);
Guy Benyei11169dd2012-12-18 14:30:41 +00001795 Macro->AddTokenToBody(Tok);
1796 break;
1797 }
1798 }
1799 }
1800}
1801
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001802PreprocessedEntityID
Richard Smith37a93df2017-02-18 00:32:02 +00001803ASTReader::getGlobalPreprocessedEntityID(ModuleFile &M,
1804 unsigned LocalID) const {
1805 if (!M.ModuleOffsetMap.empty())
1806 ReadModuleOffsetMap(M);
1807
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001808 ContinuousRangeMap<uint32_t, int, 2>::const_iterator
Guy Benyei11169dd2012-12-18 14:30:41 +00001809 I = M.PreprocessedEntityRemap.find(LocalID - NUM_PREDEF_PP_ENTITY_IDS);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001810 assert(I != M.PreprocessedEntityRemap.end()
Guy Benyei11169dd2012-12-18 14:30:41 +00001811 && "Invalid index into preprocessed entity index remap");
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001812
Guy Benyei11169dd2012-12-18 14:30:41 +00001813 return LocalID + I->second;
1814}
1815
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001816unsigned HeaderFileInfoTrait::ComputeHash(internal_key_ref ikey) {
1817 return llvm::hash_combine(ikey.Size, ikey.ModTime);
Guy Benyei11169dd2012-12-18 14:30:41 +00001818}
Richard Smith7ed1bc92014-12-05 22:42:13 +00001819
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001820HeaderFileInfoTrait::internal_key_type
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001821HeaderFileInfoTrait::GetInternalKey(const FileEntry *FE) {
Richard Smithe75ee0f2015-08-17 07:13:32 +00001822 internal_key_type ikey = {FE->getSize(),
1823 M.HasTimestamps ? FE->getModificationTime() : 0,
1824 FE->getName(), /*Imported*/ false};
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001825 return ikey;
1826}
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001827
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001828bool HeaderFileInfoTrait::EqualKey(internal_key_ref a, internal_key_ref b) {
Richard Smithe75ee0f2015-08-17 07:13:32 +00001829 if (a.Size != b.Size || (a.ModTime && b.ModTime && a.ModTime != b.ModTime))
Guy Benyei11169dd2012-12-18 14:30:41 +00001830 return false;
1831
Mehdi Amini004b9c72016-10-10 22:52:47 +00001832 if (llvm::sys::path::is_absolute(a.Filename) && a.Filename == b.Filename)
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001833 return true;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001834
Guy Benyei11169dd2012-12-18 14:30:41 +00001835 // Determine whether the actual files are equivalent.
Argyrios Kyrtzidis2a513e82013-03-04 20:33:40 +00001836 FileManager &FileMgr = Reader.getFileManager();
Richard Smith7ed1bc92014-12-05 22:42:13 +00001837 auto GetFile = [&](const internal_key_type &Key) -> const FileEntry* {
Harlan Haskins8d323d12019-08-01 21:31:56 +00001838 if (!Key.Imported) {
1839 if (auto File = FileMgr.getFile(Key.Filename))
1840 return *File;
1841 return nullptr;
1842 }
Richard Smith7ed1bc92014-12-05 22:42:13 +00001843
Benjamin Krameradcd0262020-01-28 20:23:46 +01001844 std::string Resolved = std::string(Key.Filename);
Richard Smith7ed1bc92014-12-05 22:42:13 +00001845 Reader.ResolveImportedPath(M, Resolved);
Harlan Haskins8d323d12019-08-01 21:31:56 +00001846 if (auto File = FileMgr.getFile(Resolved))
1847 return *File;
1848 return nullptr;
Richard Smith7ed1bc92014-12-05 22:42:13 +00001849 };
1850
1851 const FileEntry *FEA = GetFile(a);
1852 const FileEntry *FEB = GetFile(b);
1853 return FEA && FEA == FEB;
Guy Benyei11169dd2012-12-18 14:30:41 +00001854}
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001855
Guy Benyei11169dd2012-12-18 14:30:41 +00001856std::pair<unsigned, unsigned>
1857HeaderFileInfoTrait::ReadKeyDataLength(const unsigned char*& d) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001858 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001859
Vedant Kumar48b4f762018-04-14 01:40:48 +00001860 unsigned KeyLen = (unsigned) endian::readNext<uint16_t, little, unaligned>(d);
1861 unsigned DataLen = (unsigned) *d++;
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001862 return std::make_pair(KeyLen, DataLen);
Guy Benyei11169dd2012-12-18 14:30:41 +00001863}
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001864
1865HeaderFileInfoTrait::internal_key_type
1866HeaderFileInfoTrait::ReadKey(const unsigned char *d, unsigned) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001867 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001868
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001869 internal_key_type ikey;
Justin Bogner57ba0b22014-03-28 22:03:24 +00001870 ikey.Size = off_t(endian::readNext<uint64_t, little, unaligned>(d));
1871 ikey.ModTime = time_t(endian::readNext<uint64_t, little, unaligned>(d));
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001872 ikey.Filename = (const char *)d;
Richard Smith7ed1bc92014-12-05 22:42:13 +00001873 ikey.Imported = true;
Argyrios Kyrtzidis5c2a3452013-03-06 18:12:47 +00001874 return ikey;
1875}
1876
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001877HeaderFileInfoTrait::data_type
Argyrios Kyrtzidisb146baa2013-03-13 21:13:51 +00001878HeaderFileInfoTrait::ReadData(internal_key_ref key, const unsigned char *d,
Guy Benyei11169dd2012-12-18 14:30:41 +00001879 unsigned DataLen) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001880 using namespace llvm::support;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00001881
1882 const unsigned char *End = d + DataLen;
Guy Benyei11169dd2012-12-18 14:30:41 +00001883 HeaderFileInfo HFI;
1884 unsigned Flags = *d++;
Richard Smith386bb072015-08-18 23:42:23 +00001885 // FIXME: Refactor with mergeHeaderFileInfo in HeaderSearch.cpp.
Richard Smithf3f84612017-06-29 02:19:42 +00001886 HFI.isImport |= (Flags >> 5) & 0x01;
1887 HFI.isPragmaOnce |= (Flags >> 4) & 0x01;
1888 HFI.DirInfo = (Flags >> 1) & 0x07;
Guy Benyei11169dd2012-12-18 14:30:41 +00001889 HFI.IndexHeaderMapHeader = Flags & 0x01;
Richard Smith386bb072015-08-18 23:42:23 +00001890 // FIXME: Find a better way to handle this. Maybe just store a
1891 // "has been included" flag?
1892 HFI.NumIncludes = std::max(endian::readNext<uint16_t, little, unaligned>(d),
1893 HFI.NumIncludes);
Justin Bogner57ba0b22014-03-28 22:03:24 +00001894 HFI.ControllingMacroID = Reader.getGlobalIdentifierID(
1895 M, endian::readNext<uint32_t, little, unaligned>(d));
1896 if (unsigned FrameworkOffset =
1897 endian::readNext<uint32_t, little, unaligned>(d)) {
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001898 // The framework offset is 1 greater than the actual offset,
Guy Benyei11169dd2012-12-18 14:30:41 +00001899 // since 0 is used as an indicator for "no framework name".
1900 StringRef FrameworkName(FrameworkStrings + FrameworkOffset - 1);
1901 HFI.Framework = HS->getUniqueFrameworkName(FrameworkName);
1902 }
Richard Smith386bb072015-08-18 23:42:23 +00001903
1904 assert((End - d) % 4 == 0 &&
1905 "Wrong data length in HeaderFileInfo deserialization");
1906 while (d != End) {
Justin Bogner57ba0b22014-03-28 22:03:24 +00001907 uint32_t LocalSMID = endian::readNext<uint32_t, little, unaligned>(d);
Richard Smith386bb072015-08-18 23:42:23 +00001908 auto HeaderRole = static_cast<ModuleMap::ModuleHeaderRole>(LocalSMID & 3);
1909 LocalSMID >>= 2;
1910
1911 // This header is part of a module. Associate it with the module to enable
1912 // implicit module import.
1913 SubmoduleID GlobalSMID = Reader.getGlobalSubmoduleID(M, LocalSMID);
1914 Module *Mod = Reader.getSubmodule(GlobalSMID);
1915 FileManager &FileMgr = Reader.getFileManager();
1916 ModuleMap &ModMap =
1917 Reader.getPreprocessor().getHeaderSearchInfo().getModuleMap();
1918
Benjamin Krameradcd0262020-01-28 20:23:46 +01001919 std::string Filename = std::string(key.Filename);
Richard Smith386bb072015-08-18 23:42:23 +00001920 if (key.Imported)
1921 Reader.ResolveImportedPath(M, Filename);
1922 // FIXME: This is not always the right filename-as-written, but we're not
1923 // going to use this information to rebuild the module, so it doesn't make
1924 // a lot of difference.
Benjamin Krameradcd0262020-01-28 20:23:46 +01001925 Module::Header H = {std::string(key.Filename), *FileMgr.getFile(Filename)};
Richard Smithd8879c82015-08-24 21:59:32 +00001926 ModMap.addHeader(Mod, H, HeaderRole, /*Imported*/true);
1927 HFI.isModuleHeader |= !(HeaderRole & ModuleMap::TextualHeader);
Argyrios Kyrtzidisb146baa2013-03-13 21:13:51 +00001928 }
1929
Guy Benyei11169dd2012-12-18 14:30:41 +00001930 // This HeaderFileInfo was externally loaded.
1931 HFI.External = true;
Richard Smithd8879c82015-08-24 21:59:32 +00001932 HFI.IsValid = true;
Guy Benyei11169dd2012-12-18 14:30:41 +00001933 return HFI;
1934}
1935
Dmitry Polukhina7afb212020-04-16 09:24:46 -07001936void ASTReader::addPendingMacro(IdentifierInfo *II, ModuleFile *M,
1937 uint32_t MacroDirectivesOffset) {
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00001938 assert(NumCurrentElementsDeserializing > 0 &&"Missing deserialization guard");
1939 PendingMacroIDs[II].push_back(PendingMacroInfo(M, MacroDirectivesOffset));
Guy Benyei11169dd2012-12-18 14:30:41 +00001940}
1941
1942void ASTReader::ReadDefinedMacros() {
1943 // Note that we are loading defined macros.
1944 Deserializing Macros(this);
1945
Vedant Kumar48b4f762018-04-14 01:40:48 +00001946 for (ModuleFile &I : llvm::reverse(ModuleMgr)) {
Duncan P. N. Exon Smith96a06e02017-01-28 22:15:22 +00001947 BitstreamCursor &MacroCursor = I.MacroCursor;
Guy Benyei11169dd2012-12-18 14:30:41 +00001948
1949 // If there was no preprocessor block, skip this file.
Peter Collingbourne77c89b62016-11-08 04:17:11 +00001950 if (MacroCursor.getBitcodeBytes().empty())
Guy Benyei11169dd2012-12-18 14:30:41 +00001951 continue;
1952
Chris Lattner7fb3bef2013-01-20 00:56:42 +00001953 BitstreamCursor Cursor = MacroCursor;
JF Bastien0e828952019-06-26 19:50:12 +00001954 if (llvm::Error Err = Cursor.JumpToBit(I.MacroStartOffset)) {
1955 Error(std::move(Err));
1956 return;
1957 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001958
1959 RecordData Record;
1960 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00001961 Expected<llvm::BitstreamEntry> MaybeE = Cursor.advanceSkippingSubblocks();
1962 if (!MaybeE) {
1963 Error(MaybeE.takeError());
1964 return;
1965 }
1966 llvm::BitstreamEntry E = MaybeE.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001967
Chris Lattnere7b154b2013-01-19 21:39:22 +00001968 switch (E.Kind) {
1969 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1970 case llvm::BitstreamEntry::Error:
1971 Error("malformed block record in AST file");
1972 return;
1973 case llvm::BitstreamEntry::EndBlock:
1974 goto NextCursor;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001975
JF Bastien0e828952019-06-26 19:50:12 +00001976 case llvm::BitstreamEntry::Record: {
Chris Lattnere7b154b2013-01-19 21:39:22 +00001977 Record.clear();
JF Bastien0e828952019-06-26 19:50:12 +00001978 Expected<unsigned> MaybeRecord = Cursor.readRecord(E.ID, Record);
1979 if (!MaybeRecord) {
1980 Error(MaybeRecord.takeError());
1981 return;
1982 }
1983 switch (MaybeRecord.get()) {
Chris Lattnere7b154b2013-01-19 21:39:22 +00001984 default: // Default behavior: ignore.
1985 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001986
Chris Lattnere7b154b2013-01-19 21:39:22 +00001987 case PP_MACRO_OBJECT_LIKE:
Sean Callananf3682a72016-05-14 06:24:14 +00001988 case PP_MACRO_FUNCTION_LIKE: {
Duncan P. N. Exon Smith96a06e02017-01-28 22:15:22 +00001989 IdentifierInfo *II = getLocalIdentifier(I, Record[0]);
Sean Callananf3682a72016-05-14 06:24:14 +00001990 if (II->isOutOfDate())
1991 updateOutOfDateIdentifier(*II);
Chris Lattnere7b154b2013-01-19 21:39:22 +00001992 break;
Sean Callananf3682a72016-05-14 06:24:14 +00001993 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00001994
Chris Lattnere7b154b2013-01-19 21:39:22 +00001995 case PP_TOKEN:
1996 // Ignore tokens.
1997 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00001998 }
Guy Benyei11169dd2012-12-18 14:30:41 +00001999 break;
2000 }
JF Bastien0e828952019-06-26 19:50:12 +00002001 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002002 }
Chris Lattnere7b154b2013-01-19 21:39:22 +00002003 NextCursor: ;
Guy Benyei11169dd2012-12-18 14:30:41 +00002004 }
2005}
2006
2007namespace {
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00002008
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00002009 /// Visitor class used to look up identifirs in an AST file.
Guy Benyei11169dd2012-12-18 14:30:41 +00002010 class IdentifierLookupVisitor {
2011 StringRef Name;
Richard Smith3b637412015-07-14 18:42:41 +00002012 unsigned NameHash;
Guy Benyei11169dd2012-12-18 14:30:41 +00002013 unsigned PriorGeneration;
Douglas Gregor00a50f72013-01-25 00:38:33 +00002014 unsigned &NumIdentifierLookups;
2015 unsigned &NumIdentifierLookupHits;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00002016 IdentifierInfo *Found = nullptr;
Douglas Gregor00a50f72013-01-25 00:38:33 +00002017
Guy Benyei11169dd2012-12-18 14:30:41 +00002018 public:
Douglas Gregor00a50f72013-01-25 00:38:33 +00002019 IdentifierLookupVisitor(StringRef Name, unsigned PriorGeneration,
2020 unsigned &NumIdentifierLookups,
2021 unsigned &NumIdentifierLookupHits)
Richard Smith3b637412015-07-14 18:42:41 +00002022 : Name(Name), NameHash(ASTIdentifierLookupTrait::ComputeHash(Name)),
2023 PriorGeneration(PriorGeneration),
Douglas Gregor00a50f72013-01-25 00:38:33 +00002024 NumIdentifierLookups(NumIdentifierLookups),
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00002025 NumIdentifierLookupHits(NumIdentifierLookupHits) {}
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00002026
2027 bool operator()(ModuleFile &M) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002028 // If we've already searched this module file, skip it now.
Richard Smithbdf2d932015-07-30 03:37:16 +00002029 if (M.Generation <= PriorGeneration)
Guy Benyei11169dd2012-12-18 14:30:41 +00002030 return true;
Douglas Gregore060e572013-01-25 01:03:03 +00002031
Vedant Kumar48b4f762018-04-14 01:40:48 +00002032 ASTIdentifierLookupTable *IdTable
2033 = (ASTIdentifierLookupTable *)M.IdentifierLookupTable;
Guy Benyei11169dd2012-12-18 14:30:41 +00002034 if (!IdTable)
2035 return false;
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00002036
2037 ASTIdentifierLookupTrait Trait(IdTable->getInfoObj().getReader(), M,
Richard Smithbdf2d932015-07-30 03:37:16 +00002038 Found);
2039 ++NumIdentifierLookups;
Richard Smith3b637412015-07-14 18:42:41 +00002040 ASTIdentifierLookupTable::iterator Pos =
Richard Smithbdf2d932015-07-30 03:37:16 +00002041 IdTable->find_hashed(Name, NameHash, &Trait);
Guy Benyei11169dd2012-12-18 14:30:41 +00002042 if (Pos == IdTable->end())
2043 return false;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002044
Guy Benyei11169dd2012-12-18 14:30:41 +00002045 // Dereferencing the iterator has the effect of building the
2046 // IdentifierInfo node and populating it with the various
2047 // declarations it needs.
Richard Smithbdf2d932015-07-30 03:37:16 +00002048 ++NumIdentifierLookupHits;
2049 Found = *Pos;
Guy Benyei11169dd2012-12-18 14:30:41 +00002050 return true;
2051 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002052
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00002053 // Retrieve the identifier info found within the module
Guy Benyei11169dd2012-12-18 14:30:41 +00002054 // files.
2055 IdentifierInfo *getIdentifierInfo() const { return Found; }
2056 };
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00002057
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00002058} // namespace
Guy Benyei11169dd2012-12-18 14:30:41 +00002059
2060void ASTReader::updateOutOfDateIdentifier(IdentifierInfo &II) {
2061 // Note that we are loading an identifier.
2062 Deserializing AnIdentifier(this);
2063
2064 unsigned PriorGeneration = 0;
2065 if (getContext().getLangOpts().Modules)
2066 PriorGeneration = IdentifierGeneration[&II];
Douglas Gregore060e572013-01-25 01:03:03 +00002067
2068 // If there is a global index, look there first to determine which modules
2069 // provably do not have any results for this identifier.
Douglas Gregor7211ac12013-01-25 23:32:03 +00002070 GlobalModuleIndex::HitSet Hits;
Craig Toppera13603a2014-05-22 05:54:18 +00002071 GlobalModuleIndex::HitSet *HitsPtr = nullptr;
Douglas Gregore060e572013-01-25 01:03:03 +00002072 if (!loadGlobalIndex()) {
Douglas Gregor7211ac12013-01-25 23:32:03 +00002073 if (GlobalIndex->lookupIdentifier(II.getName(), Hits)) {
2074 HitsPtr = &Hits;
Douglas Gregore060e572013-01-25 01:03:03 +00002075 }
2076 }
2077
Douglas Gregor7211ac12013-01-25 23:32:03 +00002078 IdentifierLookupVisitor Visitor(II.getName(), PriorGeneration,
Douglas Gregor00a50f72013-01-25 00:38:33 +00002079 NumIdentifierLookups,
2080 NumIdentifierLookupHits);
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00002081 ModuleMgr.visit(Visitor, HitsPtr);
Guy Benyei11169dd2012-12-18 14:30:41 +00002082 markIdentifierUpToDate(&II);
2083}
2084
2085void ASTReader::markIdentifierUpToDate(IdentifierInfo *II) {
2086 if (!II)
2087 return;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002088
Guy Benyei11169dd2012-12-18 14:30:41 +00002089 II->setOutOfDate(false);
2090
2091 // Update the generation for this identifier.
2092 if (getContext().getLangOpts().Modules)
Richard Smith053f6c62014-05-16 23:01:30 +00002093 IdentifierGeneration[II] = getGeneration();
Guy Benyei11169dd2012-12-18 14:30:41 +00002094}
2095
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002096void ASTReader::resolvePendingMacro(IdentifierInfo *II,
2097 const PendingMacroInfo &PMInfo) {
Richard Smithd7329392015-04-21 21:46:32 +00002098 ModuleFile &M = *PMInfo.M;
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002099
2100 BitstreamCursor &Cursor = M.MacroCursor;
2101 SavedStreamPosition SavedPosition(Cursor);
Dmitry Polukhina7afb212020-04-16 09:24:46 -07002102 if (llvm::Error Err =
2103 Cursor.JumpToBit(M.MacroOffsetsBase + PMInfo.MacroDirectivesOffset)) {
JF Bastien0e828952019-06-26 19:50:12 +00002104 Error(std::move(Err));
2105 return;
2106 }
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002107
Richard Smith713369b2015-04-23 20:40:50 +00002108 struct ModuleMacroRecord {
2109 SubmoduleID SubModID;
2110 MacroInfo *MI;
2111 SmallVector<SubmoduleID, 8> Overrides;
2112 };
2113 llvm::SmallVector<ModuleMacroRecord, 8> ModuleMacros;
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002114
Richard Smithd7329392015-04-21 21:46:32 +00002115 // We expect to see a sequence of PP_MODULE_MACRO records listing exported
2116 // macros, followed by a PP_MACRO_DIRECTIVE_HISTORY record with the complete
2117 // macro histroy.
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002118 RecordData Record;
Richard Smithd7329392015-04-21 21:46:32 +00002119 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00002120 Expected<llvm::BitstreamEntry> MaybeEntry =
Richard Smithd7329392015-04-21 21:46:32 +00002121 Cursor.advance(BitstreamCursor::AF_DontPopBlockAtEnd);
JF Bastien0e828952019-06-26 19:50:12 +00002122 if (!MaybeEntry) {
2123 Error(MaybeEntry.takeError());
2124 return;
2125 }
2126 llvm::BitstreamEntry Entry = MaybeEntry.get();
2127
Richard Smithd7329392015-04-21 21:46:32 +00002128 if (Entry.Kind != llvm::BitstreamEntry::Record) {
2129 Error("malformed block record in AST file");
2130 return;
2131 }
2132
2133 Record.clear();
JF Bastien0e828952019-06-26 19:50:12 +00002134 Expected<unsigned> MaybePP = Cursor.readRecord(Entry.ID, Record);
2135 if (!MaybePP) {
2136 Error(MaybePP.takeError());
2137 return;
2138 }
2139 switch ((PreprocessorRecordTypes)MaybePP.get()) {
Richard Smithd7329392015-04-21 21:46:32 +00002140 case PP_MACRO_DIRECTIVE_HISTORY:
2141 break;
2142
2143 case PP_MODULE_MACRO: {
Richard Smith713369b2015-04-23 20:40:50 +00002144 ModuleMacros.push_back(ModuleMacroRecord());
2145 auto &Info = ModuleMacros.back();
Richard Smithe56c8bc2015-04-22 00:26:11 +00002146 Info.SubModID = getGlobalSubmoduleID(M, Record[0]);
2147 Info.MI = getMacro(getGlobalMacroID(M, Record[1]));
Richard Smith713369b2015-04-23 20:40:50 +00002148 for (int I = 2, N = Record.size(); I != N; ++I)
2149 Info.Overrides.push_back(getGlobalSubmoduleID(M, Record[I]));
Richard Smithd7329392015-04-21 21:46:32 +00002150 continue;
2151 }
2152
2153 default:
2154 Error("malformed block record in AST file");
2155 return;
2156 }
2157
2158 // We found the macro directive history; that's the last record
2159 // for this macro.
2160 break;
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002161 }
2162
Richard Smithd7329392015-04-21 21:46:32 +00002163 // Module macros are listed in reverse dependency order.
Richard Smithe56c8bc2015-04-22 00:26:11 +00002164 {
2165 std::reverse(ModuleMacros.begin(), ModuleMacros.end());
Richard Smithe56c8bc2015-04-22 00:26:11 +00002166 llvm::SmallVector<ModuleMacro*, 8> Overrides;
Richard Smith713369b2015-04-23 20:40:50 +00002167 for (auto &MMR : ModuleMacros) {
Richard Smithe56c8bc2015-04-22 00:26:11 +00002168 Overrides.clear();
Vedant Kumar48b4f762018-04-14 01:40:48 +00002169 for (unsigned ModID : MMR.Overrides) {
Richard Smithb8b2ed62015-04-23 18:18:26 +00002170 Module *Mod = getSubmodule(ModID);
2171 auto *Macro = PP.getModuleMacro(Mod, II);
Richard Smithe56c8bc2015-04-22 00:26:11 +00002172 assert(Macro && "missing definition for overridden macro");
Richard Smith5dbef922015-04-22 02:09:43 +00002173 Overrides.push_back(Macro);
Richard Smithe56c8bc2015-04-22 00:26:11 +00002174 }
2175
2176 bool Inserted = false;
Richard Smith713369b2015-04-23 20:40:50 +00002177 Module *Owner = getSubmodule(MMR.SubModID);
Richard Smith20e883e2015-04-29 23:20:19 +00002178 PP.addModuleMacro(Owner, II, MMR.MI, Overrides, Inserted);
Richard Smithd7329392015-04-21 21:46:32 +00002179 }
2180 }
2181
2182 // Don't read the directive history for a module; we don't have anywhere
2183 // to put it.
Manman Ren11f2a472016-08-18 17:42:15 +00002184 if (M.isModule())
Richard Smithd7329392015-04-21 21:46:32 +00002185 return;
2186
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002187 // Deserialize the macro directives history in reverse source-order.
Craig Toppera13603a2014-05-22 05:54:18 +00002188 MacroDirective *Latest = nullptr, *Earliest = nullptr;
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002189 unsigned Idx = 0, N = Record.size();
2190 while (Idx < N) {
Craig Toppera13603a2014-05-22 05:54:18 +00002191 MacroDirective *MD = nullptr;
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002192 SourceLocation Loc = ReadSourceLocation(M, Record, Idx);
Vedant Kumar48b4f762018-04-14 01:40:48 +00002193 MacroDirective::Kind K = (MacroDirective::Kind)Record[Idx++];
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00002194 switch (K) {
2195 case MacroDirective::MD_Define: {
Richard Smith713369b2015-04-23 20:40:50 +00002196 MacroInfo *MI = getMacro(getGlobalMacroID(M, Record[Idx++]));
Richard Smith3981b172015-04-30 02:16:23 +00002197 MD = PP.AllocateDefMacroDirective(MI, Loc);
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00002198 break;
2199 }
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00002200 case MacroDirective::MD_Undefine:
Richard Smith3981b172015-04-30 02:16:23 +00002201 MD = PP.AllocateUndefMacroDirective(Loc);
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00002202 break;
Richard Smithdaa69e02014-07-25 04:40:03 +00002203 case MacroDirective::MD_Visibility:
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00002204 bool isPublic = Record[Idx++];
2205 MD = PP.AllocateVisibilityMacroDirective(Loc, isPublic);
2206 break;
2207 }
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002208
2209 if (!Latest)
2210 Latest = MD;
2211 if (Earliest)
2212 Earliest->setPrevious(MD);
2213 Earliest = MD;
2214 }
2215
Richard Smithd6e8c0d2015-05-04 19:58:00 +00002216 if (Latest)
Nico Weberfd870702016-12-09 17:32:52 +00002217 PP.setLoadedMacroDirective(II, Earliest, Latest);
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00002218}
2219
Argyrios Kyrtzidisce9b49e2014-03-14 02:26:27 +00002220ASTReader::InputFileInfo
2221ASTReader::readInputFileInfo(ModuleFile &F, unsigned ID) {
Ben Langmuir198c1682014-03-07 07:27:49 +00002222 // Go find this input file.
2223 BitstreamCursor &Cursor = F.InputFilesCursor;
2224 SavedStreamPosition SavedPosition(Cursor);
JF Bastien0e828952019-06-26 19:50:12 +00002225 if (llvm::Error Err = Cursor.JumpToBit(F.InputFileOffsets[ID - 1])) {
2226 // FIXME this drops errors on the floor.
2227 consumeError(std::move(Err));
2228 }
Ben Langmuir198c1682014-03-07 07:27:49 +00002229
JF Bastien0e828952019-06-26 19:50:12 +00002230 Expected<unsigned> MaybeCode = Cursor.ReadCode();
2231 if (!MaybeCode) {
2232 // FIXME this drops errors on the floor.
2233 consumeError(MaybeCode.takeError());
2234 }
2235 unsigned Code = MaybeCode.get();
Ben Langmuir198c1682014-03-07 07:27:49 +00002236 RecordData Record;
2237 StringRef Blob;
2238
JF Bastien0e828952019-06-26 19:50:12 +00002239 if (Expected<unsigned> Maybe = Cursor.readRecord(Code, Record, &Blob))
2240 assert(static_cast<InputFileRecordTypes>(Maybe.get()) == INPUT_FILE &&
2241 "invalid record type for input file");
2242 else {
2243 // FIXME this drops errors on the floor.
2244 consumeError(Maybe.takeError());
2245 }
Ben Langmuir198c1682014-03-07 07:27:49 +00002246
2247 assert(Record[0] == ID && "Bogus stored ID or offset");
Richard Smitha8cfffa2015-11-26 02:04:16 +00002248 InputFileInfo R;
2249 R.StoredSize = static_cast<off_t>(Record[1]);
2250 R.StoredTime = static_cast<time_t>(Record[2]);
2251 R.Overridden = static_cast<bool>(Record[3]);
2252 R.Transient = static_cast<bool>(Record[4]);
Richard Smithf3f84612017-06-29 02:19:42 +00002253 R.TopLevelModuleMap = static_cast<bool>(Record[5]);
Benjamin Krameradcd0262020-01-28 20:23:46 +01002254 R.Filename = std::string(Blob);
Richard Smitha8cfffa2015-11-26 02:04:16 +00002255 ResolveImportedPath(F, R.Filename);
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002256
2257 Expected<llvm::BitstreamEntry> MaybeEntry = Cursor.advance();
2258 if (!MaybeEntry) // FIXME this drops errors on the floor.
2259 consumeError(MaybeEntry.takeError());
2260 llvm::BitstreamEntry Entry = MaybeEntry.get();
2261 assert(Entry.Kind == llvm::BitstreamEntry::Record &&
2262 "expected record type for input file hash");
2263
2264 Record.clear();
2265 if (Expected<unsigned> Maybe = Cursor.readRecord(Entry.ID, Record))
2266 assert(static_cast<InputFileRecordTypes>(Maybe.get()) == INPUT_FILE_HASH &&
2267 "invalid record type for input file hash");
2268 else {
2269 // FIXME this drops errors on the floor.
2270 consumeError(Maybe.takeError());
2271 }
2272 R.ContentHash = (static_cast<uint64_t>(Record[1]) << 32) |
2273 static_cast<uint64_t>(Record[0]);
Hans Wennborg73945142014-03-14 17:45:06 +00002274 return R;
Ben Langmuir198c1682014-03-07 07:27:49 +00002275}
2276
Manman Renc8c94152016-10-21 23:35:03 +00002277static unsigned moduleKindForDiagnostic(ModuleKind Kind);
Argyrios Kyrtzidis61c3d872013-03-01 03:26:04 +00002278InputFile ASTReader::getInputFile(ModuleFile &F, unsigned ID, bool Complain) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002279 // If this ID is bogus, just return an empty input file.
2280 if (ID == 0 || ID > F.InputFilesLoaded.size())
2281 return InputFile();
2282
2283 // If we've already loaded this input file, return it.
Argyrios Kyrtzidis61c3d872013-03-01 03:26:04 +00002284 if (F.InputFilesLoaded[ID-1].getFile())
Guy Benyei11169dd2012-12-18 14:30:41 +00002285 return F.InputFilesLoaded[ID-1];
2286
Argyrios Kyrtzidis9308f0a2014-01-08 19:13:34 +00002287 if (F.InputFilesLoaded[ID-1].isNotFound())
2288 return InputFile();
2289
Guy Benyei11169dd2012-12-18 14:30:41 +00002290 // Go find this input file.
Chris Lattner7fb3bef2013-01-20 00:56:42 +00002291 BitstreamCursor &Cursor = F.InputFilesCursor;
Guy Benyei11169dd2012-12-18 14:30:41 +00002292 SavedStreamPosition SavedPosition(Cursor);
JF Bastien0e828952019-06-26 19:50:12 +00002293 if (llvm::Error Err = Cursor.JumpToBit(F.InputFileOffsets[ID - 1])) {
2294 // FIXME this drops errors on the floor.
2295 consumeError(std::move(Err));
2296 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002297
Argyrios Kyrtzidisce9b49e2014-03-14 02:26:27 +00002298 InputFileInfo FI = readInputFileInfo(F, ID);
2299 off_t StoredSize = FI.StoredSize;
2300 time_t StoredTime = FI.StoredTime;
2301 bool Overridden = FI.Overridden;
Richard Smitha8cfffa2015-11-26 02:04:16 +00002302 bool Transient = FI.Transient;
Argyrios Kyrtzidisce9b49e2014-03-14 02:26:27 +00002303 StringRef Filename = FI.Filename;
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002304 uint64_t StoredContentHash = FI.ContentHash;
Argyrios Kyrtzidis61c3d872013-03-01 03:26:04 +00002305
Harlan Haskins8d323d12019-08-01 21:31:56 +00002306 const FileEntry *File = nullptr;
2307 if (auto FE = FileMgr.getFile(Filename, /*OpenFile=*/false))
2308 File = *FE;
2309
Ben Langmuir198c1682014-03-07 07:27:49 +00002310 // If we didn't find the file, resolve it relative to the
2311 // original directory from which this AST file was created.
Manuel Klimek1b29b4f2017-07-25 10:22:06 +00002312 if (File == nullptr && !F.OriginalDir.empty() && !F.BaseDirectory.empty() &&
2313 F.OriginalDir != F.BaseDirectory) {
2314 std::string Resolved = resolveFileRelativeToOriginalDir(
Benjamin Krameradcd0262020-01-28 20:23:46 +01002315 std::string(Filename), F.OriginalDir, F.BaseDirectory);
Ben Langmuir198c1682014-03-07 07:27:49 +00002316 if (!Resolved.empty())
Harlan Haskins8d323d12019-08-01 21:31:56 +00002317 if (auto FE = FileMgr.getFile(Resolved))
2318 File = *FE;
Ben Langmuir198c1682014-03-07 07:27:49 +00002319 }
2320
2321 // For an overridden file, create a virtual file with the stored
2322 // size/timestamp.
Richard Smitha8cfffa2015-11-26 02:04:16 +00002323 if ((Overridden || Transient) && File == nullptr)
Ben Langmuir198c1682014-03-07 07:27:49 +00002324 File = FileMgr.getVirtualFile(Filename, StoredSize, StoredTime);
Ben Langmuir198c1682014-03-07 07:27:49 +00002325
Craig Toppera13603a2014-05-22 05:54:18 +00002326 if (File == nullptr) {
Ben Langmuir198c1682014-03-07 07:27:49 +00002327 if (Complain) {
2328 std::string ErrorStr = "could not find file '";
2329 ErrorStr += Filename;
Richard Smith68142212015-10-13 01:26:26 +00002330 ErrorStr += "' referenced by AST file '";
2331 ErrorStr += F.FileName;
2332 ErrorStr += "'";
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00002333 Error(ErrorStr);
Guy Benyei11169dd2012-12-18 14:30:41 +00002334 }
Ben Langmuir198c1682014-03-07 07:27:49 +00002335 // Record that we didn't find the file.
2336 F.InputFilesLoaded[ID-1] = InputFile::getNotFound();
2337 return InputFile();
2338 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002339
Ben Langmuir198c1682014-03-07 07:27:49 +00002340 // Check if there was a request to override the contents of the file
Alexander Kornienko2a8c18d2018-04-06 15:14:32 +00002341 // that was part of the precompiled header. Overriding such a file
Ben Langmuir198c1682014-03-07 07:27:49 +00002342 // can lead to problems when lexing using the source locations from the
2343 // PCH.
2344 SourceManager &SM = getSourceManager();
Richard Smith64daf7b2015-12-01 03:32:49 +00002345 // FIXME: Reject if the overrides are different.
2346 if ((!Overridden && !Transient) && SM.isFileOverridden(File)) {
Ben Langmuir198c1682014-03-07 07:27:49 +00002347 if (Complain)
2348 Error(diag::err_fe_pch_file_overridden, Filename);
Duncan P. N. Exon Smithe1b7f222019-08-30 22:59:25 +00002349
2350 // After emitting the diagnostic, bypass the overriding file to recover
2351 // (this creates a separate FileEntry).
2352 File = SM.bypassFileContentsOverride(*File);
2353 if (!File) {
2354 F.InputFilesLoaded[ID - 1] = InputFile::getNotFound();
2355 return InputFile();
2356 }
Ben Langmuir198c1682014-03-07 07:27:49 +00002357 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002358
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002359 enum ModificationType {
2360 Size,
2361 ModTime,
2362 Content,
2363 None,
2364 };
2365 auto HasInputFileChanged = [&]() {
2366 if (StoredSize != File->getSize())
2367 return ModificationType::Size;
2368 if (!DisableValidation && StoredTime &&
2369 StoredTime != File->getModificationTime()) {
2370 // In case the modification time changes but not the content,
2371 // accept the cached file as legit.
2372 if (ValidateASTInputFilesContent &&
2373 StoredContentHash != static_cast<uint64_t>(llvm::hash_code(-1))) {
2374 auto MemBuffOrError = FileMgr.getBufferForFile(File);
2375 if (!MemBuffOrError) {
2376 if (!Complain)
2377 return ModificationType::ModTime;
2378 std::string ErrorStr = "could not get buffer for file '";
2379 ErrorStr += File->getName();
2380 ErrorStr += "'";
2381 Error(ErrorStr);
2382 return ModificationType::ModTime;
2383 }
Eric Christopher3be91692019-10-14 23:14:24 +00002384
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002385 auto ContentHash = hash_value(MemBuffOrError.get()->getBuffer());
2386 if (StoredContentHash == static_cast<uint64_t>(ContentHash))
2387 return ModificationType::None;
2388 return ModificationType::Content;
2389 }
2390 return ModificationType::ModTime;
2391 }
2392 return ModificationType::None;
2393 };
2394
2395 bool IsOutOfDate = false;
2396 auto FileChange = HasInputFileChanged();
Ben Langmuir198c1682014-03-07 07:27:49 +00002397 // For an overridden file, there is nothing to validate.
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002398 if (!Overridden && FileChange != ModificationType::None) {
Ben Langmuir198c1682014-03-07 07:27:49 +00002399 if (Complain) {
2400 // Build a list of the PCH imports that got us here (in reverse).
2401 SmallVector<ModuleFile *, 4> ImportStack(1, &F);
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00002402 while (!ImportStack.back()->ImportedBy.empty())
Ben Langmuir198c1682014-03-07 07:27:49 +00002403 ImportStack.push_back(ImportStack.back()->ImportedBy[0]);
Ben Langmuire82630d2014-01-17 00:19:09 +00002404
Ben Langmuir198c1682014-03-07 07:27:49 +00002405 // The top-level PCH is stale.
2406 StringRef TopLevelPCHName(ImportStack.back()->FileName);
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002407 unsigned DiagnosticKind =
2408 moduleKindForDiagnostic(ImportStack.back()->Kind);
Manman Renc8c94152016-10-21 23:35:03 +00002409 if (DiagnosticKind == 0)
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002410 Error(diag::err_fe_pch_file_modified, Filename, TopLevelPCHName,
2411 (unsigned)FileChange);
Manman Renc8c94152016-10-21 23:35:03 +00002412 else if (DiagnosticKind == 1)
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002413 Error(diag::err_fe_module_file_modified, Filename, TopLevelPCHName,
2414 (unsigned)FileChange);
Manman Renc8c94152016-10-21 23:35:03 +00002415 else
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00002416 Error(diag::err_fe_ast_file_modified, Filename, TopLevelPCHName,
2417 (unsigned)FileChange);
Ben Langmuire82630d2014-01-17 00:19:09 +00002418
Ben Langmuir198c1682014-03-07 07:27:49 +00002419 // Print the import stack.
2420 if (ImportStack.size() > 1 && !Diags.isDiagnosticInFlight()) {
2421 Diag(diag::note_pch_required_by)
2422 << Filename << ImportStack[0]->FileName;
2423 for (unsigned I = 1; I < ImportStack.size(); ++I)
Ben Langmuire82630d2014-01-17 00:19:09 +00002424 Diag(diag::note_pch_required_by)
Ben Langmuir198c1682014-03-07 07:27:49 +00002425 << ImportStack[I-1]->FileName << ImportStack[I]->FileName;
Douglas Gregor7029ce12013-03-19 00:28:20 +00002426 }
2427
Ben Langmuir198c1682014-03-07 07:27:49 +00002428 if (!Diags.isDiagnosticInFlight())
2429 Diag(diag::note_pch_rebuild_required) << TopLevelPCHName;
Guy Benyei11169dd2012-12-18 14:30:41 +00002430 }
2431
Ben Langmuir198c1682014-03-07 07:27:49 +00002432 IsOutOfDate = true;
Guy Benyei11169dd2012-12-18 14:30:41 +00002433 }
Richard Smitha8cfffa2015-11-26 02:04:16 +00002434 // FIXME: If the file is overridden and we've already opened it,
2435 // issue an error (or split it into a separate FileEntry).
Guy Benyei11169dd2012-12-18 14:30:41 +00002436
Richard Smitha8cfffa2015-11-26 02:04:16 +00002437 InputFile IF = InputFile(File, Overridden || Transient, IsOutOfDate);
Ben Langmuir198c1682014-03-07 07:27:49 +00002438
2439 // Note that we've loaded this input file.
2440 F.InputFilesLoaded[ID-1] = IF;
2441 return IF;
Guy Benyei11169dd2012-12-18 14:30:41 +00002442}
2443
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00002444/// If we are loading a relocatable PCH or module file, and the filename
Richard Smith7ed1bc92014-12-05 22:42:13 +00002445/// is not an absolute path, add the system or module root to the beginning of
2446/// the file name.
2447void ASTReader::ResolveImportedPath(ModuleFile &M, std::string &Filename) {
2448 // Resolve relative to the base directory, if we have one.
2449 if (!M.BaseDirectory.empty())
2450 return ResolveImportedPath(Filename, M.BaseDirectory);
Guy Benyei11169dd2012-12-18 14:30:41 +00002451}
2452
Richard Smith7ed1bc92014-12-05 22:42:13 +00002453void ASTReader::ResolveImportedPath(std::string &Filename, StringRef Prefix) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002454 if (Filename.empty() || llvm::sys::path::is_absolute(Filename))
2455 return;
2456
Richard Smith7ed1bc92014-12-05 22:42:13 +00002457 SmallString<128> Buffer;
2458 llvm::sys::path::append(Buffer, Prefix, Filename);
2459 Filename.assign(Buffer.begin(), Buffer.end());
Guy Benyei11169dd2012-12-18 14:30:41 +00002460}
2461
Richard Smith0f99d6a2015-08-09 08:48:41 +00002462static bool isDiagnosedResult(ASTReader::ASTReadResult ARR, unsigned Caps) {
2463 switch (ARR) {
2464 case ASTReader::Failure: return true;
2465 case ASTReader::Missing: return !(Caps & ASTReader::ARR_Missing);
2466 case ASTReader::OutOfDate: return !(Caps & ASTReader::ARR_OutOfDate);
2467 case ASTReader::VersionMismatch: return !(Caps & ASTReader::ARR_VersionMismatch);
2468 case ASTReader::ConfigurationMismatch:
2469 return !(Caps & ASTReader::ARR_ConfigurationMismatch);
2470 case ASTReader::HadErrors: return true;
2471 case ASTReader::Success: return false;
2472 }
2473
2474 llvm_unreachable("unknown ASTReadResult");
2475}
2476
Richard Smith0516b182015-09-08 19:40:14 +00002477ASTReader::ASTReadResult ASTReader::ReadOptionsBlock(
2478 BitstreamCursor &Stream, unsigned ClientLoadCapabilities,
2479 bool AllowCompatibleConfigurationMismatch, ASTReaderListener &Listener,
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00002480 std::string &SuggestedPredefines) {
JF Bastien0e828952019-06-26 19:50:12 +00002481 if (llvm::Error Err = Stream.EnterSubBlock(OPTIONS_BLOCK_ID)) {
2482 // FIXME this drops errors on the floor.
2483 consumeError(std::move(Err));
Richard Smith0516b182015-09-08 19:40:14 +00002484 return Failure;
JF Bastien0e828952019-06-26 19:50:12 +00002485 }
Richard Smith0516b182015-09-08 19:40:14 +00002486
2487 // Read all of the records in the options block.
2488 RecordData Record;
2489 ASTReadResult Result = Success;
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00002490 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00002491 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
2492 if (!MaybeEntry) {
2493 // FIXME this drops errors on the floor.
2494 consumeError(MaybeEntry.takeError());
2495 return Failure;
2496 }
2497 llvm::BitstreamEntry Entry = MaybeEntry.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002498
Richard Smith0516b182015-09-08 19:40:14 +00002499 switch (Entry.Kind) {
2500 case llvm::BitstreamEntry::Error:
2501 case llvm::BitstreamEntry::SubBlock:
2502 return Failure;
2503
2504 case llvm::BitstreamEntry::EndBlock:
2505 return Result;
2506
2507 case llvm::BitstreamEntry::Record:
2508 // The interesting case.
2509 break;
2510 }
2511
2512 // Read and process a record.
2513 Record.clear();
JF Bastien0e828952019-06-26 19:50:12 +00002514 Expected<unsigned> MaybeRecordType = Stream.readRecord(Entry.ID, Record);
2515 if (!MaybeRecordType) {
2516 // FIXME this drops errors on the floor.
2517 consumeError(MaybeRecordType.takeError());
2518 return Failure;
2519 }
2520 switch ((OptionsRecordTypes)MaybeRecordType.get()) {
Richard Smith0516b182015-09-08 19:40:14 +00002521 case LANGUAGE_OPTIONS: {
2522 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2523 if (ParseLanguageOptions(Record, Complain, Listener,
2524 AllowCompatibleConfigurationMismatch))
2525 Result = ConfigurationMismatch;
2526 break;
2527 }
2528
2529 case TARGET_OPTIONS: {
2530 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2531 if (ParseTargetOptions(Record, Complain, Listener,
2532 AllowCompatibleConfigurationMismatch))
2533 Result = ConfigurationMismatch;
2534 break;
2535 }
2536
Richard Smith0516b182015-09-08 19:40:14 +00002537 case FILE_SYSTEM_OPTIONS: {
2538 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2539 if (!AllowCompatibleConfigurationMismatch &&
2540 ParseFileSystemOptions(Record, Complain, Listener))
2541 Result = ConfigurationMismatch;
2542 break;
2543 }
2544
2545 case HEADER_SEARCH_OPTIONS: {
2546 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2547 if (!AllowCompatibleConfigurationMismatch &&
2548 ParseHeaderSearchOptions(Record, Complain, Listener))
2549 Result = ConfigurationMismatch;
2550 break;
2551 }
2552
2553 case PREPROCESSOR_OPTIONS:
2554 bool Complain = (ClientLoadCapabilities & ARR_ConfigurationMismatch) == 0;
2555 if (!AllowCompatibleConfigurationMismatch &&
2556 ParsePreprocessorOptions(Record, Complain, Listener,
2557 SuggestedPredefines))
2558 Result = ConfigurationMismatch;
2559 break;
2560 }
2561 }
2562}
2563
Guy Benyei11169dd2012-12-18 14:30:41 +00002564ASTReader::ASTReadResult
2565ASTReader::ReadControlBlock(ModuleFile &F,
Dmitri Gribenkof8579502013-01-12 19:30:44 +00002566 SmallVectorImpl<ImportedModule> &Loaded,
Ben Langmuirbeee15e2014-04-14 18:00:01 +00002567 const ModuleFile *ImportedBy,
Guy Benyei11169dd2012-12-18 14:30:41 +00002568 unsigned ClientLoadCapabilities) {
Chris Lattner7fb3bef2013-01-20 00:56:42 +00002569 BitstreamCursor &Stream = F.Stream;
Guy Benyei11169dd2012-12-18 14:30:41 +00002570
JF Bastien0e828952019-06-26 19:50:12 +00002571 if (llvm::Error Err = Stream.EnterSubBlock(CONTROL_BLOCK_ID)) {
2572 Error(std::move(Err));
Guy Benyei11169dd2012-12-18 14:30:41 +00002573 return Failure;
2574 }
2575
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00002576 // Lambda to read the unhashed control block the first time it's called.
2577 //
2578 // For PCM files, the unhashed control block cannot be read until after the
2579 // MODULE_NAME record. However, PCH files have no MODULE_NAME, and yet still
2580 // need to look ahead before reading the IMPORTS record. For consistency,
2581 // this block is always read somehow (see BitstreamEntry::EndBlock).
2582 bool HasReadUnhashedControlBlock = false;
2583 auto readUnhashedControlBlockOnce = [&]() {
2584 if (!HasReadUnhashedControlBlock) {
2585 HasReadUnhashedControlBlock = true;
2586 if (ASTReadResult Result =
2587 readUnhashedControlBlock(F, ImportedBy, ClientLoadCapabilities))
2588 return Result;
2589 }
2590 return Success;
2591 };
2592
Guy Benyei11169dd2012-12-18 14:30:41 +00002593 // Read all of the records and blocks in the control block.
2594 RecordData Record;
Richard Smitha1825302014-10-23 22:18:29 +00002595 unsigned NumInputs = 0;
2596 unsigned NumUserInputs = 0;
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00002597 StringRef BaseDirectoryAsWritten;
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00002598 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00002599 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
2600 if (!MaybeEntry) {
2601 Error(MaybeEntry.takeError());
2602 return Failure;
2603 }
2604 llvm::BitstreamEntry Entry = MaybeEntry.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002605
Chris Lattnere7b154b2013-01-19 21:39:22 +00002606 switch (Entry.Kind) {
2607 case llvm::BitstreamEntry::Error:
2608 Error("malformed block record in AST file");
2609 return Failure;
Dmitri Gribenkof430da42014-02-12 10:33:14 +00002610 case llvm::BitstreamEntry::EndBlock: {
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00002611 // Validate the module before returning. This call catches an AST with
2612 // no module name and no imports.
2613 if (ASTReadResult Result = readUnhashedControlBlockOnce())
2614 return Result;
2615
Dmitri Gribenkof430da42014-02-12 10:33:14 +00002616 // Validate input files.
2617 const HeaderSearchOptions &HSOpts =
2618 PP.getHeaderSearchInfo().getHeaderSearchOpts();
Ben Langmuircb69b572014-03-07 06:40:32 +00002619
Richard Smitha1825302014-10-23 22:18:29 +00002620 // All user input files reside at the index range [0, NumUserInputs), and
Richard Smith0f99d6a2015-08-09 08:48:41 +00002621 // system input files reside at [NumUserInputs, NumInputs). For explicitly
2622 // loaded module files, ignore missing inputs.
Manman Ren11f2a472016-08-18 17:42:15 +00002623 if (!DisableValidation && F.Kind != MK_ExplicitModule &&
2624 F.Kind != MK_PrebuiltModule) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002625 bool Complain = (ClientLoadCapabilities & ARR_OutOfDate) == 0;
Ben Langmuircb69b572014-03-07 06:40:32 +00002626
Dmitri Gribenkof430da42014-02-12 10:33:14 +00002627 // If we are reading a module, we will create a verification timestamp,
2628 // so we verify all input files. Otherwise, verify only user input
2629 // files.
Ben Langmuircb69b572014-03-07 06:40:32 +00002630
2631 unsigned N = NumUserInputs;
2632 if (ValidateSystemInputs ||
Richard Smithe842a472014-10-22 02:05:46 +00002633 (HSOpts.ModulesValidateOncePerBuildSession &&
Ben Langmuiracb803e2014-11-10 22:13:10 +00002634 F.InputFilesValidationTimestamp <= HSOpts.BuildSessionTimestamp &&
Richard Smithe842a472014-10-22 02:05:46 +00002635 F.Kind == MK_ImplicitModule))
Ben Langmuircb69b572014-03-07 06:40:32 +00002636 N = NumInputs;
2637
Ben Langmuir3d4417c2014-02-07 17:31:11 +00002638 for (unsigned I = 0; I < N; ++I) {
Argyrios Kyrtzidis61c3d872013-03-01 03:26:04 +00002639 InputFile IF = getInputFile(F, I+1, Complain);
2640 if (!IF.getFile() || IF.isOutOfDate())
Guy Benyei11169dd2012-12-18 14:30:41 +00002641 return OutOfDate;
Argyrios Kyrtzidis61c3d872013-03-01 03:26:04 +00002642 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002643 }
Ben Langmuircb69b572014-03-07 06:40:32 +00002644
Argyrios Kyrtzidis6d0753d2014-03-14 03:07:38 +00002645 if (Listener)
Richard Smith216a3bd2015-08-13 17:57:10 +00002646 Listener->visitModuleFile(F.FileName, F.Kind);
Argyrios Kyrtzidis6d0753d2014-03-14 03:07:38 +00002647
Ben Langmuircb69b572014-03-07 06:40:32 +00002648 if (Listener && Listener->needsInputFileVisitation()) {
2649 unsigned N = Listener->needsSystemInputFileVisitation() ? NumInputs
2650 : NumUserInputs;
Argyrios Kyrtzidis68ccbe02014-03-14 02:26:31 +00002651 for (unsigned I = 0; I < N; ++I) {
2652 bool IsSystem = I >= NumUserInputs;
2653 InputFileInfo FI = readInputFileInfo(F, I+1);
Richard Smith216a3bd2015-08-13 17:57:10 +00002654 Listener->visitInputFile(FI.Filename, IsSystem, FI.Overridden,
Manman Ren11f2a472016-08-18 17:42:15 +00002655 F.Kind == MK_ExplicitModule ||
2656 F.Kind == MK_PrebuiltModule);
Argyrios Kyrtzidis68ccbe02014-03-14 02:26:31 +00002657 }
Ben Langmuircb69b572014-03-07 06:40:32 +00002658 }
2659
Duncan P. N. Exon Smith69242e92019-11-19 14:44:22 -08002660 return Success;
Dmitri Gribenkof430da42014-02-12 10:33:14 +00002661 }
2662
Chris Lattnere7b154b2013-01-19 21:39:22 +00002663 case llvm::BitstreamEntry::SubBlock:
2664 switch (Entry.ID) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002665 case INPUT_FILES_BLOCK_ID:
2666 F.InputFilesCursor = Stream;
JF Bastien0e828952019-06-26 19:50:12 +00002667 if (llvm::Error Err = Stream.SkipBlock()) {
2668 Error(std::move(Err));
2669 return Failure;
2670 }
2671 if (ReadBlockAbbrevs(F.InputFilesCursor, INPUT_FILES_BLOCK_ID)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002672 Error("malformed block record in AST file");
2673 return Failure;
2674 }
2675 continue;
Richard Smith0516b182015-09-08 19:40:14 +00002676
2677 case OPTIONS_BLOCK_ID:
2678 // If we're reading the first module for this group, check its options
2679 // are compatible with ours. For modules it imports, no further checking
2680 // is required, because we checked them when we built it.
2681 if (Listener && !ImportedBy) {
2682 // Should we allow the configuration of the module file to differ from
2683 // the configuration of the current translation unit in a compatible
2684 // way?
2685 //
2686 // FIXME: Allow this for files explicitly specified with -include-pch.
2687 bool AllowCompatibleConfigurationMismatch =
Manman Ren11f2a472016-08-18 17:42:15 +00002688 F.Kind == MK_ExplicitModule || F.Kind == MK_PrebuiltModule;
Richard Smith0516b182015-09-08 19:40:14 +00002689
Duncan P. N. Exon Smith69242e92019-11-19 14:44:22 -08002690 ASTReadResult Result =
2691 ReadOptionsBlock(Stream, ClientLoadCapabilities,
2692 AllowCompatibleConfigurationMismatch, *Listener,
2693 SuggestedPredefines);
Richard Smith0516b182015-09-08 19:40:14 +00002694 if (Result == Failure) {
2695 Error("malformed block record in AST file");
2696 return Result;
2697 }
2698
Richard Smith8a308ec2015-11-05 00:54:55 +00002699 if (DisableValidation ||
2700 (AllowConfigurationMismatch && Result == ConfigurationMismatch))
2701 Result = Success;
2702
Ben Langmuir9b1e442e2016-02-11 18:54:02 +00002703 // If we can't load the module, exit early since we likely
2704 // will rebuild the module anyway. The stream may be in the
2705 // middle of a block.
2706 if (Result != Success)
Richard Smith0516b182015-09-08 19:40:14 +00002707 return Result;
JF Bastien0e828952019-06-26 19:50:12 +00002708 } else if (llvm::Error Err = Stream.SkipBlock()) {
2709 Error(std::move(Err));
Richard Smith0516b182015-09-08 19:40:14 +00002710 return Failure;
2711 }
2712 continue;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002713
Guy Benyei11169dd2012-12-18 14:30:41 +00002714 default:
JF Bastien0e828952019-06-26 19:50:12 +00002715 if (llvm::Error Err = Stream.SkipBlock()) {
2716 Error(std::move(Err));
Chris Lattnere7b154b2013-01-19 21:39:22 +00002717 return Failure;
2718 }
2719 continue;
Guy Benyei11169dd2012-12-18 14:30:41 +00002720 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002721
Chris Lattnere7b154b2013-01-19 21:39:22 +00002722 case llvm::BitstreamEntry::Record:
2723 // The interesting case.
2724 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00002725 }
2726
2727 // Read and process a record.
2728 Record.clear();
Chris Lattner0e6c9402013-01-20 02:38:54 +00002729 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00002730 Expected<unsigned> MaybeRecordType =
2731 Stream.readRecord(Entry.ID, Record, &Blob);
2732 if (!MaybeRecordType) {
2733 Error(MaybeRecordType.takeError());
2734 return Failure;
2735 }
2736 switch ((ControlRecordTypes)MaybeRecordType.get()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002737 case METADATA: {
2738 if (Record[0] != VERSION_MAJOR && !DisableValidation) {
2739 if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
Dmitri Gribenko2228cd32014-02-11 15:40:09 +00002740 Diag(Record[0] < VERSION_MAJOR? diag::err_pch_version_too_old
2741 : diag::err_pch_version_too_new);
Guy Benyei11169dd2012-12-18 14:30:41 +00002742 return VersionMismatch;
2743 }
2744
Hans Wennborg08c5a7b2018-06-25 13:23:49 +00002745 bool hasErrors = Record[7];
Guy Benyei11169dd2012-12-18 14:30:41 +00002746 if (hasErrors && !DisableValidation && !AllowASTWithCompilerErrors) {
2747 Diag(diag::err_pch_with_compiler_errors);
2748 return HadErrors;
2749 }
Argyrios Kyrtzidis70ec1c72016-07-13 20:35:26 +00002750 if (hasErrors) {
2751 Diags.ErrorOccurred = true;
2752 Diags.UncompilableErrorOccurred = true;
2753 Diags.UnrecoverableErrorOccurred = true;
2754 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002755
2756 F.RelocatablePCH = Record[4];
Richard Smith7ed1bc92014-12-05 22:42:13 +00002757 // Relative paths in a relocatable PCH are relative to our sysroot.
2758 if (F.RelocatablePCH)
2759 F.BaseDirectory = isysroot.empty() ? "/" : isysroot;
Guy Benyei11169dd2012-12-18 14:30:41 +00002760
Richard Smithe75ee0f2015-08-17 07:13:32 +00002761 F.HasTimestamps = Record[5];
2762
Hans Wennborg08c5a7b2018-06-25 13:23:49 +00002763 F.PCHHasObjectFile = Record[6];
2764
Guy Benyei11169dd2012-12-18 14:30:41 +00002765 const std::string &CurBranch = getClangFullRepositoryVersion();
Chris Lattner0e6c9402013-01-20 02:38:54 +00002766 StringRef ASTBranch = Blob;
Guy Benyei11169dd2012-12-18 14:30:41 +00002767 if (StringRef(CurBranch) != ASTBranch && !DisableValidation) {
2768 if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
Dmitri Gribenko2228cd32014-02-11 15:40:09 +00002769 Diag(diag::err_pch_different_branch) << ASTBranch << CurBranch;
Guy Benyei11169dd2012-12-18 14:30:41 +00002770 return VersionMismatch;
2771 }
2772 break;
2773 }
2774
2775 case IMPORTS: {
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00002776 // Validate the AST before processing any imports (otherwise, untangling
2777 // them can be error-prone and expensive). A module will have a name and
2778 // will already have been validated, but this catches the PCH case.
2779 if (ASTReadResult Result = readUnhashedControlBlockOnce())
2780 return Result;
2781
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002782 // Load each of the imported PCH files.
Guy Benyei11169dd2012-12-18 14:30:41 +00002783 unsigned Idx = 0, N = Record.size();
2784 while (Idx < N) {
2785 // Read information about the AST file.
Vedant Kumar48b4f762018-04-14 01:40:48 +00002786 ModuleKind ImportedKind = (ModuleKind)Record[Idx++];
Guy Benyei11169dd2012-12-18 14:30:41 +00002787 // The import location will be the local one for now; we will adjust
2788 // all import locations of module imports after the global source
Richard Smithb22a1d12016-03-27 20:13:24 +00002789 // location info are setup, in ReadAST.
Guy Benyei11169dd2012-12-18 14:30:41 +00002790 SourceLocation ImportLoc =
Richard Smithb22a1d12016-03-27 20:13:24 +00002791 ReadUntranslatedSourceLocation(Record[Idx++]);
Vedant Kumar48b4f762018-04-14 01:40:48 +00002792 off_t StoredSize = (off_t)Record[Idx++];
2793 time_t StoredModTime = (time_t)Record[Idx++];
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00002794 ASTFileSignature StoredSignature = {
2795 {{(uint32_t)Record[Idx++], (uint32_t)Record[Idx++],
2796 (uint32_t)Record[Idx++], (uint32_t)Record[Idx++],
2797 (uint32_t)Record[Idx++]}}};
Boris Kolpackovd30446f2017-08-31 06:26:43 +00002798
2799 std::string ImportedName = ReadString(Record, Idx);
2800 std::string ImportedFile;
2801
2802 // For prebuilt and explicit modules first consult the file map for
2803 // an override. Note that here we don't search prebuilt module
2804 // directories, only the explicit name to file mappings. Also, we will
2805 // still verify the size/signature making sure it is essentially the
2806 // same file but perhaps in a different location.
2807 if (ImportedKind == MK_PrebuiltModule || ImportedKind == MK_ExplicitModule)
2808 ImportedFile = PP.getHeaderSearchInfo().getPrebuiltModuleFileName(
2809 ImportedName, /*FileMapOnly*/ true);
2810
2811 if (ImportedFile.empty())
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00002812 // Use BaseDirectoryAsWritten to ensure we use the same path in the
2813 // ModuleCache as when writing.
2814 ImportedFile = ReadPath(BaseDirectoryAsWritten, Record, Idx);
Boris Kolpackovd30446f2017-08-31 06:26:43 +00002815 else
2816 SkipPath(Record, Idx);
Guy Benyei11169dd2012-12-18 14:30:41 +00002817
Richard Smith0f99d6a2015-08-09 08:48:41 +00002818 // If our client can't cope with us being out of date, we can't cope with
2819 // our dependency being missing.
2820 unsigned Capabilities = ClientLoadCapabilities;
2821 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
2822 Capabilities &= ~ARR_Missing;
2823
Guy Benyei11169dd2012-12-18 14:30:41 +00002824 // Load the AST file.
Richard Smith0f99d6a2015-08-09 08:48:41 +00002825 auto Result = ReadASTCore(ImportedFile, ImportedKind, ImportLoc, &F,
2826 Loaded, StoredSize, StoredModTime,
2827 StoredSignature, Capabilities);
2828
2829 // If we diagnosed a problem, produce a backtrace.
2830 if (isDiagnosedResult(Result, Capabilities))
2831 Diag(diag::note_module_file_imported_by)
2832 << F.FileName << !F.ModuleName.empty() << F.ModuleName;
2833
2834 switch (Result) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002835 case Failure: return Failure;
2836 // If we have to ignore the dependency, we'll have to ignore this too.
Douglas Gregor2f1806e2013-03-19 00:38:50 +00002837 case Missing:
Guy Benyei11169dd2012-12-18 14:30:41 +00002838 case OutOfDate: return OutOfDate;
2839 case VersionMismatch: return VersionMismatch;
2840 case ConfigurationMismatch: return ConfigurationMismatch;
2841 case HadErrors: return HadErrors;
2842 case Success: break;
2843 }
2844 }
2845 break;
2846 }
2847
Guy Benyei11169dd2012-12-18 14:30:41 +00002848 case ORIGINAL_FILE:
2849 F.OriginalSourceFileID = FileID::get(Record[0]);
Benjamin Krameradcd0262020-01-28 20:23:46 +01002850 F.ActualOriginalSourceFileName = std::string(Blob);
Guy Benyei11169dd2012-12-18 14:30:41 +00002851 F.OriginalSourceFileName = F.ActualOriginalSourceFileName;
Richard Smith7ed1bc92014-12-05 22:42:13 +00002852 ResolveImportedPath(F, F.OriginalSourceFileName);
Guy Benyei11169dd2012-12-18 14:30:41 +00002853 break;
2854
2855 case ORIGINAL_FILE_ID:
2856 F.OriginalSourceFileID = FileID::get(Record[0]);
2857 break;
2858
2859 case ORIGINAL_PCH_DIR:
Benjamin Krameradcd0262020-01-28 20:23:46 +01002860 F.OriginalDir = std::string(Blob);
Guy Benyei11169dd2012-12-18 14:30:41 +00002861 break;
2862
Ben Langmuirbeee15e2014-04-14 18:00:01 +00002863 case MODULE_NAME:
Benjamin Krameradcd0262020-01-28 20:23:46 +01002864 F.ModuleName = std::string(Blob);
Duncan P. N. Exon Smith9dda8f52019-03-06 02:50:46 +00002865 Diag(diag::remark_module_import)
2866 << F.ModuleName << F.FileName << (ImportedBy ? true : false)
2867 << (ImportedBy ? StringRef(ImportedBy->ModuleName) : StringRef());
Ben Langmuir4f5212a2014-04-14 22:12:44 +00002868 if (Listener)
2869 Listener->ReadModuleName(F.ModuleName);
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00002870
2871 // Validate the AST as soon as we have a name so we can exit early on
2872 // failure.
2873 if (ASTReadResult Result = readUnhashedControlBlockOnce())
2874 return Result;
Vedant Kumar48b4f762018-04-14 01:40:48 +00002875
Ben Langmuirbeee15e2014-04-14 18:00:01 +00002876 break;
2877
Richard Smith223d3f22014-12-06 03:21:08 +00002878 case MODULE_DIRECTORY: {
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00002879 // Save the BaseDirectory as written in the PCM for computing the module
2880 // filename for the ModuleCache.
2881 BaseDirectoryAsWritten = Blob;
Richard Smith223d3f22014-12-06 03:21:08 +00002882 assert(!F.ModuleName.empty() &&
2883 "MODULE_DIRECTORY found before MODULE_NAME");
2884 // If we've already loaded a module map file covering this module, we may
2885 // have a better path for it (relative to the current build).
Bruno Cardoso Lopes52431f32018-07-18 23:21:19 +00002886 Module *M = PP.getHeaderSearchInfo().lookupModule(
2887 F.ModuleName, /*AllowSearch*/ true,
2888 /*AllowExtraModuleMapSearch*/ true);
Richard Smith223d3f22014-12-06 03:21:08 +00002889 if (M && M->Directory) {
2890 // If we're implicitly loading a module, the base directory can't
2891 // change between the build and use.
Yuka Takahashid8baec22018-08-01 09:50:02 +00002892 // Don't emit module relocation error if we have -fno-validate-pch
2893 if (!PP.getPreprocessorOpts().DisablePCHValidation &&
2894 F.Kind != MK_ExplicitModule && F.Kind != MK_PrebuiltModule) {
Harlan Haskins8d323d12019-08-01 21:31:56 +00002895 auto BuildDir = PP.getFileManager().getDirectory(Blob);
2896 if (!BuildDir || *BuildDir != M->Directory) {
Richard Smith223d3f22014-12-06 03:21:08 +00002897 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
2898 Diag(diag::err_imported_module_relocated)
2899 << F.ModuleName << Blob << M->Directory->getName();
2900 return OutOfDate;
2901 }
2902 }
Benjamin Krameradcd0262020-01-28 20:23:46 +01002903 F.BaseDirectory = std::string(M->Directory->getName());
Richard Smith223d3f22014-12-06 03:21:08 +00002904 } else {
Benjamin Krameradcd0262020-01-28 20:23:46 +01002905 F.BaseDirectory = std::string(Blob);
Richard Smith223d3f22014-12-06 03:21:08 +00002906 }
Richard Smith7ed1bc92014-12-05 22:42:13 +00002907 break;
Richard Smith223d3f22014-12-06 03:21:08 +00002908 }
Richard Smith7ed1bc92014-12-05 22:42:13 +00002909
Ben Langmuirbeee15e2014-04-14 18:00:01 +00002910 case MODULE_MAP_FILE:
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00002911 if (ASTReadResult Result =
2912 ReadModuleMapFileBlock(Record, F, ImportedBy, ClientLoadCapabilities))
2913 return Result;
Ben Langmuir264ea152014-11-08 00:06:39 +00002914 break;
2915
Justin Bognerca9c0cc2015-06-21 20:32:36 +00002916 case INPUT_FILE_OFFSETS:
Richard Smitha1825302014-10-23 22:18:29 +00002917 NumInputs = Record[0];
2918 NumUserInputs = Record[1];
Justin Bogner4c183242015-06-21 20:32:40 +00002919 F.InputFileOffsets =
2920 (const llvm::support::unaligned_uint64_t *)Blob.data();
Richard Smitha1825302014-10-23 22:18:29 +00002921 F.InputFilesLoaded.resize(NumInputs);
Argyrios Kyrtzidisa38cb202017-01-30 06:05:58 +00002922 F.NumUserInputFiles = NumUserInputs;
Guy Benyei11169dd2012-12-18 14:30:41 +00002923 break;
2924 }
2925 }
Guy Benyei11169dd2012-12-18 14:30:41 +00002926}
2927
Ben Langmuir2c9af442014-04-10 17:57:43 +00002928ASTReader::ASTReadResult
2929ASTReader::ReadASTBlock(ModuleFile &F, unsigned ClientLoadCapabilities) {
Chris Lattner7fb3bef2013-01-20 00:56:42 +00002930 BitstreamCursor &Stream = F.Stream;
Guy Benyei11169dd2012-12-18 14:30:41 +00002931
JF Bastien0e828952019-06-26 19:50:12 +00002932 if (llvm::Error Err = Stream.EnterSubBlock(AST_BLOCK_ID)) {
2933 Error(std::move(Err));
Ben Langmuir2c9af442014-04-10 17:57:43 +00002934 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00002935 }
2936
2937 // Read all of the records and blocks for the AST file.
2938 RecordData Record;
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00002939 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00002940 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
2941 if (!MaybeEntry) {
2942 Error(MaybeEntry.takeError());
2943 return Failure;
2944 }
2945 llvm::BitstreamEntry Entry = MaybeEntry.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002946
Chris Lattnere7b154b2013-01-19 21:39:22 +00002947 switch (Entry.Kind) {
2948 case llvm::BitstreamEntry::Error:
2949 Error("error at end of module block in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00002950 return Failure;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00002951 case llvm::BitstreamEntry::EndBlock:
Richard Smithc0fbba72013-04-03 22:49:41 +00002952 // Outside of C++, we do not store a lookup map for the translation unit.
2953 // Instead, mark it as needing a lookup map to be built if this module
2954 // contains any declarations lexically within it (which it always does!).
2955 // This usually has no cost, since we very rarely need the lookup map for
2956 // the translation unit outside C++.
Richard Smithdbafb6c2017-06-29 23:23:46 +00002957 if (ASTContext *Ctx = ContextObj) {
2958 DeclContext *DC = Ctx->getTranslationUnitDecl();
2959 if (DC->hasExternalLexicalStorage() && !Ctx->getLangOpts().CPlusPlus)
2960 DC->setMustBuildLookupTable();
2961 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002962
Ben Langmuir2c9af442014-04-10 17:57:43 +00002963 return Success;
Chris Lattnere7b154b2013-01-19 21:39:22 +00002964 case llvm::BitstreamEntry::SubBlock:
2965 switch (Entry.ID) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002966 case DECLTYPES_BLOCK_ID:
2967 // We lazily load the decls block, but we want to set up the
2968 // DeclsCursor cursor to point into it. Clone our current bitcode
2969 // cursor to it, enter the block and read the abbrevs in that block.
2970 // With the main cursor, we just skip over it.
2971 F.DeclsCursor = Stream;
JF Bastien0e828952019-06-26 19:50:12 +00002972 if (llvm::Error Err = Stream.SkipBlock()) {
2973 Error(std::move(Err));
2974 return Failure;
2975 }
2976 if (ReadBlockAbbrevs(F.DeclsCursor, DECLTYPES_BLOCK_ID)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002977 Error("malformed block record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00002978 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00002979 }
2980 break;
Richard Smithb9eab6d2014-03-20 19:44:17 +00002981
Guy Benyei11169dd2012-12-18 14:30:41 +00002982 case PREPROCESSOR_BLOCK_ID:
2983 F.MacroCursor = Stream;
2984 if (!PP.getExternalSource())
2985 PP.setExternalSource(this);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002986
JF Bastien0e828952019-06-26 19:50:12 +00002987 if (llvm::Error Err = Stream.SkipBlock()) {
2988 Error(std::move(Err));
2989 return Failure;
2990 }
2991 if (ReadBlockAbbrevs(F.MacroCursor, PREPROCESSOR_BLOCK_ID)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00002992 Error("malformed block record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00002993 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00002994 }
2995 F.MacroStartOffset = F.MacroCursor.GetCurrentBitNo();
2996 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00002997
Guy Benyei11169dd2012-12-18 14:30:41 +00002998 case PREPROCESSOR_DETAIL_BLOCK_ID:
2999 F.PreprocessorDetailCursor = Stream;
JF Bastien0e828952019-06-26 19:50:12 +00003000
3001 if (llvm::Error Err = Stream.SkipBlock()) {
3002 Error(std::move(Err));
3003 return Failure;
3004 }
3005 if (ReadBlockAbbrevs(F.PreprocessorDetailCursor,
Guy Benyei11169dd2012-12-18 14:30:41 +00003006 PREPROCESSOR_DETAIL_BLOCK_ID)) {
JF Bastien0e828952019-06-26 19:50:12 +00003007 Error("malformed preprocessor detail record in AST file");
3008 return Failure;
3009 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003010 F.PreprocessorDetailStartOffset
Chris Lattnere7b154b2013-01-19 21:39:22 +00003011 = F.PreprocessorDetailCursor.GetCurrentBitNo();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003012
Guy Benyei11169dd2012-12-18 14:30:41 +00003013 if (!PP.getPreprocessingRecord())
3014 PP.createPreprocessingRecord();
3015 if (!PP.getPreprocessingRecord()->getExternalSource())
3016 PP.getPreprocessingRecord()->SetExternalSource(*this);
3017 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003018
Guy Benyei11169dd2012-12-18 14:30:41 +00003019 case SOURCE_MANAGER_BLOCK_ID:
3020 if (ReadSourceManagerBlock(F))
Ben Langmuir2c9af442014-04-10 17:57:43 +00003021 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003022 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003023
Guy Benyei11169dd2012-12-18 14:30:41 +00003024 case SUBMODULE_BLOCK_ID:
David Blaikie9ffe5a32017-01-30 05:00:26 +00003025 if (ASTReadResult Result =
3026 ReadSubmoduleBlock(F, ClientLoadCapabilities))
Ben Langmuir2c9af442014-04-10 17:57:43 +00003027 return Result;
Guy Benyei11169dd2012-12-18 14:30:41 +00003028 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003029
Guy Benyei11169dd2012-12-18 14:30:41 +00003030 case COMMENTS_BLOCK_ID: {
Chris Lattner7fb3bef2013-01-20 00:56:42 +00003031 BitstreamCursor C = Stream;
JF Bastien0e828952019-06-26 19:50:12 +00003032
3033 if (llvm::Error Err = Stream.SkipBlock()) {
3034 Error(std::move(Err));
3035 return Failure;
3036 }
3037 if (ReadBlockAbbrevs(C, COMMENTS_BLOCK_ID)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003038 Error("malformed comments block in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003039 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003040 }
3041 CommentsCursors.push_back(std::make_pair(C, &F));
3042 break;
3043 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003044
Guy Benyei11169dd2012-12-18 14:30:41 +00003045 default:
JF Bastien0e828952019-06-26 19:50:12 +00003046 if (llvm::Error Err = Stream.SkipBlock()) {
3047 Error(std::move(Err));
Ben Langmuir2c9af442014-04-10 17:57:43 +00003048 return Failure;
Chris Lattnere7b154b2013-01-19 21:39:22 +00003049 }
3050 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00003051 }
3052 continue;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003053
Chris Lattnere7b154b2013-01-19 21:39:22 +00003054 case llvm::BitstreamEntry::Record:
3055 // The interesting case.
3056 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00003057 }
3058
3059 // Read and process a record.
3060 Record.clear();
Chris Lattner0e6c9402013-01-20 02:38:54 +00003061 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00003062 Expected<unsigned> MaybeRecordType =
3063 Stream.readRecord(Entry.ID, Record, &Blob);
3064 if (!MaybeRecordType) {
3065 Error(MaybeRecordType.takeError());
3066 return Failure;
3067 }
3068 ASTRecordTypes RecordType = (ASTRecordTypes)MaybeRecordType.get();
Richard Smithdbafb6c2017-06-29 23:23:46 +00003069
3070 // If we're not loading an AST context, we don't care about most records.
3071 if (!ContextObj) {
3072 switch (RecordType) {
3073 case IDENTIFIER_TABLE:
3074 case IDENTIFIER_OFFSET:
3075 case INTERESTING_IDENTIFIERS:
3076 case STATISTICS:
3077 case PP_CONDITIONAL_STACK:
3078 case PP_COUNTER_VALUE:
3079 case SOURCE_LOCATION_OFFSETS:
3080 case MODULE_OFFSET_MAP:
3081 case SOURCE_MANAGER_LINE_TABLE:
3082 case SOURCE_LOCATION_PRELOADS:
3083 case PPD_ENTITIES_OFFSETS:
3084 case HEADER_SEARCH_TABLE:
3085 case IMPORTED_MODULES:
3086 case MACRO_OFFSET:
3087 break;
3088 default:
3089 continue;
3090 }
3091 }
3092
3093 switch (RecordType) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003094 default: // Default behavior: ignore.
3095 break;
3096
3097 case TYPE_OFFSET: {
3098 if (F.LocalNumTypes != 0) {
3099 Error("duplicate TYPE_OFFSET record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003100 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003101 }
Dmitry Polukhina7afb212020-04-16 09:24:46 -07003102 F.TypeOffsets = reinterpret_cast<const UnderalignedInt64 *>(Blob.data());
Guy Benyei11169dd2012-12-18 14:30:41 +00003103 F.LocalNumTypes = Record[0];
3104 unsigned LocalBaseTypeIndex = Record[1];
3105 F.BaseTypeIndex = getTotalNumTypes();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003106
Guy Benyei11169dd2012-12-18 14:30:41 +00003107 if (F.LocalNumTypes > 0) {
3108 // Introduce the global -> local mapping for types within this module.
3109 GlobalTypeMap.insert(std::make_pair(getTotalNumTypes(), &F));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003110
Guy Benyei11169dd2012-12-18 14:30:41 +00003111 // Introduce the local -> global mapping for types within this module.
3112 F.TypeRemap.insertOrReplace(
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003113 std::make_pair(LocalBaseTypeIndex,
Guy Benyei11169dd2012-12-18 14:30:41 +00003114 F.BaseTypeIndex - LocalBaseTypeIndex));
Ben Langmuir52ca6782014-10-20 16:27:32 +00003115
3116 TypesLoaded.resize(TypesLoaded.size() + F.LocalNumTypes);
Guy Benyei11169dd2012-12-18 14:30:41 +00003117 }
3118 break;
3119 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003120
Guy Benyei11169dd2012-12-18 14:30:41 +00003121 case DECL_OFFSET: {
3122 if (F.LocalNumDecls != 0) {
3123 Error("duplicate DECL_OFFSET record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003124 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003125 }
Chris Lattner0e6c9402013-01-20 02:38:54 +00003126 F.DeclOffsets = (const DeclOffset *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003127 F.LocalNumDecls = Record[0];
3128 unsigned LocalBaseDeclID = Record[1];
3129 F.BaseDeclID = getTotalNumDecls();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003130
Guy Benyei11169dd2012-12-18 14:30:41 +00003131 if (F.LocalNumDecls > 0) {
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003132 // Introduce the global -> local mapping for declarations within this
Guy Benyei11169dd2012-12-18 14:30:41 +00003133 // module.
3134 GlobalDeclMap.insert(
3135 std::make_pair(getTotalNumDecls() + NUM_PREDEF_DECL_IDS, &F));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003136
Guy Benyei11169dd2012-12-18 14:30:41 +00003137 // Introduce the local -> global mapping for declarations within this
3138 // module.
3139 F.DeclRemap.insertOrReplace(
3140 std::make_pair(LocalBaseDeclID, F.BaseDeclID - LocalBaseDeclID));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003141
Guy Benyei11169dd2012-12-18 14:30:41 +00003142 // Introduce the global -> local mapping for declarations within this
3143 // module.
3144 F.GlobalToLocalDeclIDs[&F] = LocalBaseDeclID;
Ben Langmuirfe971d92014-08-16 04:54:18 +00003145
Ben Langmuir52ca6782014-10-20 16:27:32 +00003146 DeclsLoaded.resize(DeclsLoaded.size() + F.LocalNumDecls);
3147 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003148 break;
3149 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003150
Guy Benyei11169dd2012-12-18 14:30:41 +00003151 case TU_UPDATE_LEXICAL: {
Richard Smithdbafb6c2017-06-29 23:23:46 +00003152 DeclContext *TU = ContextObj->getTranslationUnitDecl();
Richard Smith82f8fcd2015-08-06 22:07:25 +00003153 LexicalContents Contents(
3154 reinterpret_cast<const llvm::support::unaligned_uint32_t *>(
3155 Blob.data()),
3156 static_cast<unsigned int>(Blob.size() / 4));
3157 TULexicalDecls.push_back(std::make_pair(&F, Contents));
Guy Benyei11169dd2012-12-18 14:30:41 +00003158 TU->setHasExternalLexicalStorage(true);
3159 break;
3160 }
3161
3162 case UPDATE_VISIBLE: {
3163 unsigned Idx = 0;
3164 serialization::DeclID ID = ReadDeclID(F, Record, Idx);
Richard Smith0f4e2c42015-08-06 04:23:48 +00003165 auto *Data = (const unsigned char*)Blob.data();
Richard Smithd88a7f12015-09-01 20:35:42 +00003166 PendingVisibleUpdates[ID].push_back(PendingVisibleUpdate{&F, Data});
Richard Smith0f4e2c42015-08-06 04:23:48 +00003167 // If we've already loaded the decl, perform the updates when we finish
3168 // loading this block.
3169 if (Decl *D = GetExistingDecl(ID))
Vassil Vassilev74c3e8c2017-05-19 16:46:06 +00003170 PendingUpdateRecords.push_back(
3171 PendingUpdateRecord(ID, D, /*JustLoaded=*/false));
Guy Benyei11169dd2012-12-18 14:30:41 +00003172 break;
3173 }
3174
3175 case IDENTIFIER_TABLE:
Chris Lattner0e6c9402013-01-20 02:38:54 +00003176 F.IdentifierTableData = Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003177 if (Record[0]) {
Justin Bognerda4e6502014-04-14 16:34:29 +00003178 F.IdentifierLookupTable = ASTIdentifierLookupTable::Create(
3179 (const unsigned char *)F.IdentifierTableData + Record[0],
3180 (const unsigned char *)F.IdentifierTableData + sizeof(uint32_t),
3181 (const unsigned char *)F.IdentifierTableData,
3182 ASTIdentifierLookupTrait(*this, F));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003183
Guy Benyei11169dd2012-12-18 14:30:41 +00003184 PP.getIdentifierTable().setExternalIdentifierLookup(this);
3185 }
3186 break;
3187
3188 case IDENTIFIER_OFFSET: {
3189 if (F.LocalNumIdentifiers != 0) {
3190 Error("duplicate IDENTIFIER_OFFSET record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003191 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003192 }
Chris Lattner0e6c9402013-01-20 02:38:54 +00003193 F.IdentifierOffsets = (const uint32_t *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003194 F.LocalNumIdentifiers = Record[0];
3195 unsigned LocalBaseIdentifierID = Record[1];
3196 F.BaseIdentifierID = getTotalNumIdentifiers();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003197
Guy Benyei11169dd2012-12-18 14:30:41 +00003198 if (F.LocalNumIdentifiers > 0) {
3199 // Introduce the global -> local mapping for identifiers within this
3200 // module.
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003201 GlobalIdentifierMap.insert(std::make_pair(getTotalNumIdentifiers() + 1,
Guy Benyei11169dd2012-12-18 14:30:41 +00003202 &F));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003203
Guy Benyei11169dd2012-12-18 14:30:41 +00003204 // Introduce the local -> global mapping for identifiers within this
3205 // module.
3206 F.IdentifierRemap.insertOrReplace(
3207 std::make_pair(LocalBaseIdentifierID,
3208 F.BaseIdentifierID - LocalBaseIdentifierID));
Ben Langmuirfe971d92014-08-16 04:54:18 +00003209
Ben Langmuir52ca6782014-10-20 16:27:32 +00003210 IdentifiersLoaded.resize(IdentifiersLoaded.size()
3211 + F.LocalNumIdentifiers);
3212 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003213 break;
3214 }
3215
Richard Smith33e0f7e2015-07-22 02:08:40 +00003216 case INTERESTING_IDENTIFIERS:
3217 F.PreloadIdentifierOffsets.assign(Record.begin(), Record.end());
3218 break;
3219
Ben Langmuir332aafe2014-01-31 01:06:56 +00003220 case EAGERLY_DESERIALIZED_DECLS:
Richard Smith9e2341d2015-03-23 03:25:59 +00003221 // FIXME: Skip reading this record if our ASTConsumer doesn't care
3222 // about "interesting" decls (for instance, if we're building a module).
Guy Benyei11169dd2012-12-18 14:30:41 +00003223 for (unsigned I = 0, N = Record.size(); I != N; ++I)
Ben Langmuir332aafe2014-01-31 01:06:56 +00003224 EagerlyDeserializedDecls.push_back(getGlobalDeclID(F, Record[I]));
Guy Benyei11169dd2012-12-18 14:30:41 +00003225 break;
3226
David Blaikie9ffe5a32017-01-30 05:00:26 +00003227 case MODULAR_CODEGEN_DECLS:
3228 // FIXME: Skip reading this record if our ASTConsumer doesn't care about
3229 // them (ie: if we're not codegenerating this module).
Hans Wennborg7ea9a6e2020-02-27 14:33:43 +01003230 if (F.Kind == MK_MainFile)
David Blaikie9ffe5a32017-01-30 05:00:26 +00003231 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3232 EagerlyDeserializedDecls.push_back(getGlobalDeclID(F, Record[I]));
3233 break;
3234
Guy Benyei11169dd2012-12-18 14:30:41 +00003235 case SPECIAL_TYPES:
Douglas Gregor44180f82013-02-01 23:45:03 +00003236 if (SpecialTypes.empty()) {
3237 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3238 SpecialTypes.push_back(getGlobalTypeID(F, Record[I]));
3239 break;
3240 }
3241
3242 if (SpecialTypes.size() != Record.size()) {
3243 Error("invalid special-types record");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003244 return Failure;
Douglas Gregor44180f82013-02-01 23:45:03 +00003245 }
3246
3247 for (unsigned I = 0, N = Record.size(); I != N; ++I) {
3248 serialization::TypeID ID = getGlobalTypeID(F, Record[I]);
3249 if (!SpecialTypes[I])
3250 SpecialTypes[I] = ID;
3251 // FIXME: If ID && SpecialTypes[I] != ID, do we need a separate
3252 // merge step?
3253 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003254 break;
3255
3256 case STATISTICS:
3257 TotalNumStatements += Record[0];
3258 TotalNumMacros += Record[1];
3259 TotalLexicalDeclContexts += Record[2];
3260 TotalVisibleDeclContexts += Record[3];
3261 break;
3262
3263 case UNUSED_FILESCOPED_DECLS:
3264 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3265 UnusedFileScopedDecls.push_back(getGlobalDeclID(F, Record[I]));
3266 break;
3267
3268 case DELEGATING_CTORS:
3269 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3270 DelegatingCtorDecls.push_back(getGlobalDeclID(F, Record[I]));
3271 break;
3272
3273 case WEAK_UNDECLARED_IDENTIFIERS:
3274 if (Record.size() % 4 != 0) {
3275 Error("invalid weak identifiers record");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003276 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003277 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003278
3279 // FIXME: Ignore weak undeclared identifiers from non-original PCH
Guy Benyei11169dd2012-12-18 14:30:41 +00003280 // files. This isn't the way to do it :)
3281 WeakUndeclaredIdentifiers.clear();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003282
Guy Benyei11169dd2012-12-18 14:30:41 +00003283 // Translate the weak, undeclared identifiers into global IDs.
3284 for (unsigned I = 0, N = Record.size(); I < N; /* in loop */) {
3285 WeakUndeclaredIdentifiers.push_back(
3286 getGlobalIdentifierID(F, Record[I++]));
3287 WeakUndeclaredIdentifiers.push_back(
3288 getGlobalIdentifierID(F, Record[I++]));
3289 WeakUndeclaredIdentifiers.push_back(
3290 ReadSourceLocation(F, Record, I).getRawEncoding());
3291 WeakUndeclaredIdentifiers.push_back(Record[I++]);
3292 }
3293 break;
3294
Guy Benyei11169dd2012-12-18 14:30:41 +00003295 case SELECTOR_OFFSETS: {
Chris Lattner0e6c9402013-01-20 02:38:54 +00003296 F.SelectorOffsets = (const uint32_t *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003297 F.LocalNumSelectors = Record[0];
3298 unsigned LocalBaseSelectorID = Record[1];
3299 F.BaseSelectorID = getTotalNumSelectors();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003300
Guy Benyei11169dd2012-12-18 14:30:41 +00003301 if (F.LocalNumSelectors > 0) {
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003302 // Introduce the global -> local mapping for selectors within this
Guy Benyei11169dd2012-12-18 14:30:41 +00003303 // module.
3304 GlobalSelectorMap.insert(std::make_pair(getTotalNumSelectors()+1, &F));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003305
3306 // Introduce the local -> global mapping for selectors within this
Guy Benyei11169dd2012-12-18 14:30:41 +00003307 // module.
3308 F.SelectorRemap.insertOrReplace(
3309 std::make_pair(LocalBaseSelectorID,
3310 F.BaseSelectorID - LocalBaseSelectorID));
Ben Langmuir52ca6782014-10-20 16:27:32 +00003311
3312 SelectorsLoaded.resize(SelectorsLoaded.size() + F.LocalNumSelectors);
Guy Benyei11169dd2012-12-18 14:30:41 +00003313 }
3314 break;
3315 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003316
Guy Benyei11169dd2012-12-18 14:30:41 +00003317 case METHOD_POOL:
Chris Lattner0e6c9402013-01-20 02:38:54 +00003318 F.SelectorLookupTableData = (const unsigned char *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003319 if (Record[0])
3320 F.SelectorLookupTable
3321 = ASTSelectorLookupTable::Create(
3322 F.SelectorLookupTableData + Record[0],
3323 F.SelectorLookupTableData,
3324 ASTSelectorLookupTrait(*this, F));
3325 TotalNumMethodPoolEntries += Record[1];
3326 break;
3327
3328 case REFERENCED_SELECTOR_POOL:
3329 if (!Record.empty()) {
3330 for (unsigned Idx = 0, N = Record.size() - 1; Idx < N; /* in loop */) {
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003331 ReferencedSelectorsData.push_back(getGlobalSelectorID(F,
Guy Benyei11169dd2012-12-18 14:30:41 +00003332 Record[Idx++]));
3333 ReferencedSelectorsData.push_back(ReadSourceLocation(F, Record, Idx).
3334 getRawEncoding());
3335 }
3336 }
3337 break;
3338
Erik Verbruggenb34c79f2017-05-30 11:54:55 +00003339 case PP_CONDITIONAL_STACK:
3340 if (!Record.empty()) {
Erik Verbruggen4d1eb2d2017-11-03 09:40:07 +00003341 unsigned Idx = 0, End = Record.size() - 1;
3342 bool ReachedEOFWhileSkipping = Record[Idx++];
3343 llvm::Optional<Preprocessor::PreambleSkipInfo> SkipInfo;
3344 if (ReachedEOFWhileSkipping) {
3345 SourceLocation HashToken = ReadSourceLocation(F, Record, Idx);
3346 SourceLocation IfTokenLoc = ReadSourceLocation(F, Record, Idx);
3347 bool FoundNonSkipPortion = Record[Idx++];
3348 bool FoundElse = Record[Idx++];
3349 SourceLocation ElseLoc = ReadSourceLocation(F, Record, Idx);
3350 SkipInfo.emplace(HashToken, IfTokenLoc, FoundNonSkipPortion,
3351 FoundElse, ElseLoc);
3352 }
Erik Verbruggenb34c79f2017-05-30 11:54:55 +00003353 SmallVector<PPConditionalInfo, 4> ConditionalStack;
Erik Verbruggen4d1eb2d2017-11-03 09:40:07 +00003354 while (Idx < End) {
Erik Verbruggenb34c79f2017-05-30 11:54:55 +00003355 auto Loc = ReadSourceLocation(F, Record, Idx);
3356 bool WasSkipping = Record[Idx++];
3357 bool FoundNonSkip = Record[Idx++];
3358 bool FoundElse = Record[Idx++];
3359 ConditionalStack.push_back(
3360 {Loc, WasSkipping, FoundNonSkip, FoundElse});
3361 }
Erik Verbruggen4d1eb2d2017-11-03 09:40:07 +00003362 PP.setReplayablePreambleConditionalStack(ConditionalStack, SkipInfo);
Erik Verbruggenb34c79f2017-05-30 11:54:55 +00003363 }
3364 break;
3365
Guy Benyei11169dd2012-12-18 14:30:41 +00003366 case PP_COUNTER_VALUE:
3367 if (!Record.empty() && Listener)
3368 Listener->ReadCounter(F, Record[0]);
3369 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003370
Guy Benyei11169dd2012-12-18 14:30:41 +00003371 case FILE_SORTED_DECLS:
Chris Lattner0e6c9402013-01-20 02:38:54 +00003372 F.FileSortedDecls = (const DeclID *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003373 F.NumFileSortedDecls = Record[0];
3374 break;
3375
3376 case SOURCE_LOCATION_OFFSETS: {
Chris Lattner0e6c9402013-01-20 02:38:54 +00003377 F.SLocEntryOffsets = (const uint32_t *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003378 F.LocalNumSLocEntries = Record[0];
3379 unsigned SLocSpaceSize = Record[1];
Dmitry Polukhina7afb212020-04-16 09:24:46 -07003380 F.SLocEntryOffsetsBase = Record[2];
Benjamin Kramer867ea1d2014-03-02 13:01:17 +00003381 std::tie(F.SLocEntryBaseID, F.SLocEntryBaseOffset) =
Ben Langmuir52ca6782014-10-20 16:27:32 +00003382 SourceMgr.AllocateLoadedSLocEntries(F.LocalNumSLocEntries,
Guy Benyei11169dd2012-12-18 14:30:41 +00003383 SLocSpaceSize);
Richard Smith78d81ec2015-08-12 22:25:24 +00003384 if (!F.SLocEntryBaseID) {
3385 Error("ran out of source locations");
3386 break;
3387 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003388 // Make our entry in the range map. BaseID is negative and growing, so
3389 // we invert it. Because we invert it, though, we need the other end of
3390 // the range.
3391 unsigned RangeStart =
3392 unsigned(-F.SLocEntryBaseID) - F.LocalNumSLocEntries + 1;
3393 GlobalSLocEntryMap.insert(std::make_pair(RangeStart, &F));
3394 F.FirstLoc = SourceLocation::getFromRawEncoding(F.SLocEntryBaseOffset);
3395
3396 // SLocEntryBaseOffset is lower than MaxLoadedOffset and decreasing.
3397 assert((F.SLocEntryBaseOffset & (1U << 31U)) == 0);
3398 GlobalSLocOffsetMap.insert(
3399 std::make_pair(SourceManager::MaxLoadedOffset - F.SLocEntryBaseOffset
3400 - SLocSpaceSize,&F));
3401
3402 // Initialize the remapping table.
3403 // Invalid stays invalid.
Richard Smithb9eab6d2014-03-20 19:44:17 +00003404 F.SLocRemap.insertOrReplace(std::make_pair(0U, 0));
Guy Benyei11169dd2012-12-18 14:30:41 +00003405 // This module. Base was 2 when being compiled.
Richard Smithb9eab6d2014-03-20 19:44:17 +00003406 F.SLocRemap.insertOrReplace(std::make_pair(2U,
Guy Benyei11169dd2012-12-18 14:30:41 +00003407 static_cast<int>(F.SLocEntryBaseOffset - 2)));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003408
Guy Benyei11169dd2012-12-18 14:30:41 +00003409 TotalNumSLocEntries += F.LocalNumSLocEntries;
3410 break;
3411 }
3412
Richard Smith37a93df2017-02-18 00:32:02 +00003413 case MODULE_OFFSET_MAP:
3414 F.ModuleOffsetMap = Blob;
Guy Benyei11169dd2012-12-18 14:30:41 +00003415 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00003416
3417 case SOURCE_MANAGER_LINE_TABLE:
Duncan P. N. Exon Smith8e2c1922019-11-10 11:07:20 -08003418 if (ParseLineTable(F, Record)) {
3419 Error("malformed SOURCE_MANAGER_LINE_TABLE in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003420 return Failure;
Duncan P. N. Exon Smith8e2c1922019-11-10 11:07:20 -08003421 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003422 break;
3423
3424 case SOURCE_LOCATION_PRELOADS: {
3425 // Need to transform from the local view (1-based IDs) to the global view,
3426 // which is based off F.SLocEntryBaseID.
3427 if (!F.PreloadSLocEntries.empty()) {
3428 Error("Multiple SOURCE_LOCATION_PRELOADS records in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003429 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003430 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003431
Guy Benyei11169dd2012-12-18 14:30:41 +00003432 F.PreloadSLocEntries.swap(Record);
3433 break;
3434 }
3435
3436 case EXT_VECTOR_DECLS:
3437 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3438 ExtVectorDecls.push_back(getGlobalDeclID(F, Record[I]));
3439 break;
3440
3441 case VTABLE_USES:
3442 if (Record.size() % 3 != 0) {
3443 Error("Invalid VTABLE_USES record");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003444 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003445 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003446
Guy Benyei11169dd2012-12-18 14:30:41 +00003447 // Later tables overwrite earlier ones.
3448 // FIXME: Modules will have some trouble with this. This is clearly not
3449 // the right way to do this.
3450 VTableUses.clear();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003451
Guy Benyei11169dd2012-12-18 14:30:41 +00003452 for (unsigned Idx = 0, N = Record.size(); Idx != N; /* In loop */) {
3453 VTableUses.push_back(getGlobalDeclID(F, Record[Idx++]));
3454 VTableUses.push_back(
3455 ReadSourceLocation(F, Record, Idx).getRawEncoding());
3456 VTableUses.push_back(Record[Idx++]);
3457 }
3458 break;
3459
Guy Benyei11169dd2012-12-18 14:30:41 +00003460 case PENDING_IMPLICIT_INSTANTIATIONS:
3461 if (PendingInstantiations.size() % 2 != 0) {
3462 Error("Invalid existing PendingInstantiations");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003463 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003464 }
3465
3466 if (Record.size() % 2 != 0) {
3467 Error("Invalid PENDING_IMPLICIT_INSTANTIATIONS block");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003468 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003469 }
3470
3471 for (unsigned I = 0, N = Record.size(); I != N; /* in loop */) {
3472 PendingInstantiations.push_back(getGlobalDeclID(F, Record[I++]));
3473 PendingInstantiations.push_back(
3474 ReadSourceLocation(F, Record, I).getRawEncoding());
3475 }
3476 break;
3477
3478 case SEMA_DECL_REFS:
Richard Smith96269c52016-09-29 22:49:46 +00003479 if (Record.size() != 3) {
Richard Smith3d8e97e2013-10-18 06:54:39 +00003480 Error("Invalid SEMA_DECL_REFS block");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003481 return Failure;
Richard Smith3d8e97e2013-10-18 06:54:39 +00003482 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003483 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3484 SemaDeclRefs.push_back(getGlobalDeclID(F, Record[I]));
3485 break;
3486
3487 case PPD_ENTITIES_OFFSETS: {
Chris Lattner0e6c9402013-01-20 02:38:54 +00003488 F.PreprocessedEntityOffsets = (const PPEntityOffset *)Blob.data();
3489 assert(Blob.size() % sizeof(PPEntityOffset) == 0);
3490 F.NumPreprocessedEntities = Blob.size() / sizeof(PPEntityOffset);
Guy Benyei11169dd2012-12-18 14:30:41 +00003491
3492 unsigned LocalBasePreprocessedEntityID = Record[0];
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003493
Guy Benyei11169dd2012-12-18 14:30:41 +00003494 unsigned StartingID;
3495 if (!PP.getPreprocessingRecord())
3496 PP.createPreprocessingRecord();
3497 if (!PP.getPreprocessingRecord()->getExternalSource())
3498 PP.getPreprocessingRecord()->SetExternalSource(*this);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003499 StartingID
Guy Benyei11169dd2012-12-18 14:30:41 +00003500 = PP.getPreprocessingRecord()
Ben Langmuir52ca6782014-10-20 16:27:32 +00003501 ->allocateLoadedEntities(F.NumPreprocessedEntities);
Guy Benyei11169dd2012-12-18 14:30:41 +00003502 F.BasePreprocessedEntityID = StartingID;
3503
3504 if (F.NumPreprocessedEntities > 0) {
3505 // Introduce the global -> local mapping for preprocessed entities in
3506 // this module.
3507 GlobalPreprocessedEntityMap.insert(std::make_pair(StartingID, &F));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003508
Guy Benyei11169dd2012-12-18 14:30:41 +00003509 // Introduce the local -> global mapping for preprocessed entities in
3510 // this module.
3511 F.PreprocessedEntityRemap.insertOrReplace(
3512 std::make_pair(LocalBasePreprocessedEntityID,
3513 F.BasePreprocessedEntityID - LocalBasePreprocessedEntityID));
3514 }
3515
3516 break;
3517 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003518
Cameron Desrochersb60f1b62018-01-15 19:14:16 +00003519 case PPD_SKIPPED_RANGES: {
3520 F.PreprocessedSkippedRangeOffsets = (const PPSkippedRange*)Blob.data();
3521 assert(Blob.size() % sizeof(PPSkippedRange) == 0);
3522 F.NumPreprocessedSkippedRanges = Blob.size() / sizeof(PPSkippedRange);
3523
3524 if (!PP.getPreprocessingRecord())
3525 PP.createPreprocessingRecord();
3526 if (!PP.getPreprocessingRecord()->getExternalSource())
3527 PP.getPreprocessingRecord()->SetExternalSource(*this);
3528 F.BasePreprocessedSkippedRangeID = PP.getPreprocessingRecord()
3529 ->allocateSkippedRanges(F.NumPreprocessedSkippedRanges);
Jonas Devlieghere560ce2c2018-02-26 15:16:42 +00003530
Cameron Desrochersb60f1b62018-01-15 19:14:16 +00003531 if (F.NumPreprocessedSkippedRanges > 0)
3532 GlobalSkippedRangeMap.insert(
3533 std::make_pair(F.BasePreprocessedSkippedRangeID, &F));
3534 break;
3535 }
3536
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00003537 case DECL_UPDATE_OFFSETS:
Guy Benyei11169dd2012-12-18 14:30:41 +00003538 if (Record.size() % 2 != 0) {
3539 Error("invalid DECL_UPDATE_OFFSETS block in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003540 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003541 }
Richard Smithcd45dbc2014-04-19 03:48:30 +00003542 for (unsigned I = 0, N = Record.size(); I != N; I += 2) {
3543 GlobalDeclID ID = getGlobalDeclID(F, Record[I]);
3544 DeclUpdateOffsets[ID].push_back(std::make_pair(&F, Record[I + 1]));
3545
3546 // If we've already loaded the decl, perform the updates when we finish
3547 // loading this block.
3548 if (Decl *D = GetExistingDecl(ID))
Vassil Vassilev74c3e8c2017-05-19 16:46:06 +00003549 PendingUpdateRecords.push_back(
3550 PendingUpdateRecord(ID, D, /*JustLoaded=*/false));
Richard Smithcd45dbc2014-04-19 03:48:30 +00003551 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003552 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00003553
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00003554 case OBJC_CATEGORIES_MAP:
Guy Benyei11169dd2012-12-18 14:30:41 +00003555 if (F.LocalNumObjCCategoriesInMap != 0) {
3556 Error("duplicate OBJC_CATEGORIES_MAP record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003557 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003558 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003559
Guy Benyei11169dd2012-12-18 14:30:41 +00003560 F.LocalNumObjCCategoriesInMap = Record[0];
Chris Lattner0e6c9402013-01-20 02:38:54 +00003561 F.ObjCCategoriesMap = (const ObjCCategoriesInfo *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003562 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003563
Guy Benyei11169dd2012-12-18 14:30:41 +00003564 case OBJC_CATEGORIES:
3565 F.ObjCCategories.swap(Record);
3566 break;
Richard Smithc2bb8182015-03-24 06:36:48 +00003567
Guy Benyei11169dd2012-12-18 14:30:41 +00003568 case CUDA_SPECIAL_DECL_REFS:
3569 // Later tables overwrite earlier ones.
3570 // FIXME: Modules will have trouble with this.
3571 CUDASpecialDeclRefs.clear();
3572 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3573 CUDASpecialDeclRefs.push_back(getGlobalDeclID(F, Record[I]));
3574 break;
3575
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00003576 case HEADER_SEARCH_TABLE:
Chris Lattner0e6c9402013-01-20 02:38:54 +00003577 F.HeaderFileInfoTableData = Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003578 F.LocalNumHeaderFileInfos = Record[1];
Guy Benyei11169dd2012-12-18 14:30:41 +00003579 if (Record[0]) {
3580 F.HeaderFileInfoTable
3581 = HeaderFileInfoLookupTable::Create(
3582 (const unsigned char *)F.HeaderFileInfoTableData + Record[0],
3583 (const unsigned char *)F.HeaderFileInfoTableData,
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003584 HeaderFileInfoTrait(*this, F,
Guy Benyei11169dd2012-12-18 14:30:41 +00003585 &PP.getHeaderSearchInfo(),
Chris Lattner0e6c9402013-01-20 02:38:54 +00003586 Blob.data() + Record[2]));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003587
Guy Benyei11169dd2012-12-18 14:30:41 +00003588 PP.getHeaderSearchInfo().SetExternalSource(this);
3589 if (!PP.getHeaderSearchInfo().getExternalLookup())
3590 PP.getHeaderSearchInfo().SetExternalLookup(this);
3591 }
3592 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003593
Guy Benyei11169dd2012-12-18 14:30:41 +00003594 case FP_PRAGMA_OPTIONS:
3595 // Later tables overwrite earlier ones.
3596 FPPragmaOptions.swap(Record);
3597 break;
3598
3599 case OPENCL_EXTENSIONS:
Yaxun Liu5b746652016-12-18 05:18:55 +00003600 for (unsigned I = 0, E = Record.size(); I != E; ) {
3601 auto Name = ReadString(Record, I);
3602 auto &Opt = OpenCLExtensions.OptMap[Name];
Yaxun Liucc2741c2016-12-18 06:35:06 +00003603 Opt.Supported = Record[I++] != 0;
3604 Opt.Enabled = Record[I++] != 0;
Yaxun Liu5b746652016-12-18 05:18:55 +00003605 Opt.Avail = Record[I++];
3606 Opt.Core = Record[I++];
3607 }
3608 break;
3609
3610 case OPENCL_EXTENSION_TYPES:
3611 for (unsigned I = 0, E = Record.size(); I != E;) {
3612 auto TypeID = static_cast<::TypeID>(Record[I++]);
3613 auto *Type = GetType(TypeID).getTypePtr();
3614 auto NumExt = static_cast<unsigned>(Record[I++]);
3615 for (unsigned II = 0; II != NumExt; ++II) {
3616 auto Ext = ReadString(Record, I);
3617 OpenCLTypeExtMap[Type].insert(Ext);
3618 }
3619 }
3620 break;
3621
3622 case OPENCL_EXTENSION_DECLS:
3623 for (unsigned I = 0, E = Record.size(); I != E;) {
3624 auto DeclID = static_cast<::DeclID>(Record[I++]);
3625 auto *Decl = GetDecl(DeclID);
3626 auto NumExt = static_cast<unsigned>(Record[I++]);
3627 for (unsigned II = 0; II != NumExt; ++II) {
3628 auto Ext = ReadString(Record, I);
3629 OpenCLDeclExtMap[Decl].insert(Ext);
3630 }
3631 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003632 break;
3633
3634 case TENTATIVE_DEFINITIONS:
3635 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3636 TentativeDefinitions.push_back(getGlobalDeclID(F, Record[I]));
3637 break;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00003638
Guy Benyei11169dd2012-12-18 14:30:41 +00003639 case KNOWN_NAMESPACES:
3640 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3641 KnownNamespaces.push_back(getGlobalDeclID(F, Record[I]));
3642 break;
Nick Lewycky8334af82013-01-26 00:35:08 +00003643
Nick Lewycky9c7eb1d2013-02-01 08:13:20 +00003644 case UNDEFINED_BUT_USED:
3645 if (UndefinedButUsed.size() % 2 != 0) {
3646 Error("Invalid existing UndefinedButUsed");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003647 return Failure;
Nick Lewycky8334af82013-01-26 00:35:08 +00003648 }
3649
3650 if (Record.size() % 2 != 0) {
Nick Lewycky9c7eb1d2013-02-01 08:13:20 +00003651 Error("invalid undefined-but-used record");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003652 return Failure;
Nick Lewycky8334af82013-01-26 00:35:08 +00003653 }
3654 for (unsigned I = 0, N = Record.size(); I != N; /* in loop */) {
Nick Lewycky9c7eb1d2013-02-01 08:13:20 +00003655 UndefinedButUsed.push_back(getGlobalDeclID(F, Record[I++]));
3656 UndefinedButUsed.push_back(
Nick Lewycky8334af82013-01-26 00:35:08 +00003657 ReadSourceLocation(F, Record, I).getRawEncoding());
3658 }
3659 break;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00003660
Ismail Pazarbasie5768d12015-05-18 19:59:11 +00003661 case DELETE_EXPRS_TO_ANALYZE:
3662 for (unsigned I = 0, N = Record.size(); I != N;) {
3663 DelayedDeleteExprs.push_back(getGlobalDeclID(F, Record[I++]));
3664 const uint64_t Count = Record[I++];
3665 DelayedDeleteExprs.push_back(Count);
3666 for (uint64_t C = 0; C < Count; ++C) {
3667 DelayedDeleteExprs.push_back(ReadSourceLocation(F, Record, I).getRawEncoding());
3668 bool IsArrayForm = Record[I++] == 1;
3669 DelayedDeleteExprs.push_back(IsArrayForm);
3670 }
3671 }
3672 break;
Nick Lewycky8334af82013-01-26 00:35:08 +00003673
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00003674 case IMPORTED_MODULES:
Manman Ren11f2a472016-08-18 17:42:15 +00003675 if (!F.isModule()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00003676 // If we aren't loading a module (which has its own exports), make
3677 // all of the imported modules visible.
3678 // FIXME: Deal with macros-only imports.
Richard Smith56be7542014-03-21 00:33:59 +00003679 for (unsigned I = 0, N = Record.size(); I != N; /**/) {
3680 unsigned GlobalID = getGlobalSubmoduleID(F, Record[I++]);
3681 SourceLocation Loc = ReadSourceLocation(F, Record, I);
Graydon Hoare9c982442017-01-18 20:36:59 +00003682 if (GlobalID) {
Aaron Ballman4f45b712014-03-21 15:22:56 +00003683 ImportedModules.push_back(ImportedSubmodule(GlobalID, Loc));
Graydon Hoare9c982442017-01-18 20:36:59 +00003684 if (DeserializationListener)
3685 DeserializationListener->ModuleImportRead(GlobalID, Loc);
3686 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003687 }
3688 }
3689 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00003690
Guy Benyei11169dd2012-12-18 14:30:41 +00003691 case MACRO_OFFSET: {
3692 if (F.LocalNumMacros != 0) {
3693 Error("duplicate MACRO_OFFSET record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00003694 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00003695 }
Chris Lattner0e6c9402013-01-20 02:38:54 +00003696 F.MacroOffsets = (const uint32_t *)Blob.data();
Guy Benyei11169dd2012-12-18 14:30:41 +00003697 F.LocalNumMacros = Record[0];
3698 unsigned LocalBaseMacroID = Record[1];
Dmitry Polukhina7afb212020-04-16 09:24:46 -07003699 F.MacroOffsetsBase = Record[2];
Guy Benyei11169dd2012-12-18 14:30:41 +00003700 F.BaseMacroID = getTotalNumMacros();
3701
3702 if (F.LocalNumMacros > 0) {
3703 // Introduce the global -> local mapping for macros within this module.
3704 GlobalMacroMap.insert(std::make_pair(getTotalNumMacros() + 1, &F));
3705
3706 // Introduce the local -> global mapping for macros within this module.
3707 F.MacroRemap.insertOrReplace(
3708 std::make_pair(LocalBaseMacroID,
3709 F.BaseMacroID - LocalBaseMacroID));
Ben Langmuir52ca6782014-10-20 16:27:32 +00003710
3711 MacrosLoaded.resize(MacrosLoaded.size() + F.LocalNumMacros);
Guy Benyei11169dd2012-12-18 14:30:41 +00003712 }
3713 break;
3714 }
3715
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00003716 case LATE_PARSED_TEMPLATE:
Richard Smithe40f2ba2013-08-07 21:41:30 +00003717 LateParsedTemplates.append(Record.begin(), Record.end());
3718 break;
Dario Domizioli13a0a382014-05-23 12:13:25 +00003719
3720 case OPTIMIZE_PRAGMA_OPTIONS:
3721 if (Record.size() != 1) {
3722 Error("invalid pragma optimize record");
3723 return Failure;
3724 }
3725 OptimizeOffPragmaLocation = ReadSourceLocation(F, Record[0]);
3726 break;
Nico Weber72889432014-09-06 01:25:55 +00003727
Nico Weber779355f2016-03-02 23:22:00 +00003728 case MSSTRUCT_PRAGMA_OPTIONS:
3729 if (Record.size() != 1) {
3730 Error("invalid pragma ms_struct record");
3731 return Failure;
3732 }
3733 PragmaMSStructState = Record[0];
3734 break;
3735
Nico Weber42932312016-03-03 00:17:35 +00003736 case POINTERS_TO_MEMBERS_PRAGMA_OPTIONS:
3737 if (Record.size() != 2) {
3738 Error("invalid pragma ms_struct record");
3739 return Failure;
3740 }
3741 PragmaMSPointersToMembersState = Record[0];
3742 PointersToMembersPragmaLocation = ReadSourceLocation(F, Record[1]);
3743 break;
3744
Nico Weber72889432014-09-06 01:25:55 +00003745 case UNUSED_LOCAL_TYPEDEF_NAME_CANDIDATES:
3746 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3747 UnusedLocalTypedefNameCandidates.push_back(
3748 getGlobalDeclID(F, Record[I]));
3749 break;
Justin Lebar67a78a62016-10-08 22:15:58 +00003750
3751 case CUDA_PRAGMA_FORCE_HOST_DEVICE_DEPTH:
3752 if (Record.size() != 1) {
3753 Error("invalid cuda pragma options record");
3754 return Failure;
3755 }
3756 ForceCUDAHostDeviceDepth = Record[0];
3757 break;
Alex Lorenz7d7e1e02017-03-31 15:36:21 +00003758
3759 case PACK_PRAGMA_OPTIONS: {
3760 if (Record.size() < 3) {
3761 Error("invalid pragma pack record");
3762 return Failure;
3763 }
3764 PragmaPackCurrentValue = Record[0];
3765 PragmaPackCurrentLocation = ReadSourceLocation(F, Record[1]);
3766 unsigned NumStackEntries = Record[2];
3767 unsigned Idx = 3;
3768 // Reset the stack when importing a new module.
3769 PragmaPackStack.clear();
3770 for (unsigned I = 0; I < NumStackEntries; ++I) {
3771 PragmaPackStackEntry Entry;
3772 Entry.Value = Record[Idx++];
3773 Entry.Location = ReadSourceLocation(F, Record[Idx++]);
Alex Lorenz45b40142017-07-28 14:41:21 +00003774 Entry.PushLocation = ReadSourceLocation(F, Record[Idx++]);
Alex Lorenz7d7e1e02017-03-31 15:36:21 +00003775 PragmaPackStrings.push_back(ReadString(Record, Idx));
3776 Entry.SlotLabel = PragmaPackStrings.back();
3777 PragmaPackStack.push_back(Entry);
3778 }
3779 break;
3780 }
Yaxun (Sam) Liub670ab72020-02-26 10:57:39 -05003781
Melanie Blowerf5360d42020-05-01 10:32:06 -07003782 case FLOAT_CONTROL_PRAGMA_OPTIONS: {
3783 if (Record.size() < 3) {
3784 Error("invalid pragma pack record");
3785 return Failure;
3786 }
3787 FpPragmaCurrentValue = Record[0];
3788 FpPragmaCurrentLocation = ReadSourceLocation(F, Record[1]);
3789 unsigned NumStackEntries = Record[2];
3790 unsigned Idx = 3;
3791 // Reset the stack when importing a new module.
3792 FpPragmaStack.clear();
3793 for (unsigned I = 0; I < NumStackEntries; ++I) {
3794 FpPragmaStackEntry Entry;
3795 Entry.Value = Record[Idx++];
3796 Entry.Location = ReadSourceLocation(F, Record[Idx++]);
3797 Entry.PushLocation = ReadSourceLocation(F, Record[Idx++]);
3798 FpPragmaStrings.push_back(ReadString(Record, Idx));
3799 Entry.SlotLabel = FpPragmaStrings.back();
3800 FpPragmaStack.push_back(Entry);
3801 }
3802 break;
3803 }
3804
Yaxun (Sam) Liub670ab72020-02-26 10:57:39 -05003805 case DECLS_TO_CHECK_FOR_DEFERRED_DIAGS:
3806 for (unsigned I = 0, N = Record.size(); I != N; ++I)
3807 DeclsToCheckForDeferredDiags.push_back(getGlobalDeclID(F, Record[I]));
3808 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00003809 }
3810 }
Guy Benyei11169dd2012-12-18 14:30:41 +00003811}
3812
Richard Smith37a93df2017-02-18 00:32:02 +00003813void ASTReader::ReadModuleOffsetMap(ModuleFile &F) const {
3814 assert(!F.ModuleOffsetMap.empty() && "no module offset map to read");
3815
3816 // Additional remapping information.
Vedant Kumar48b4f762018-04-14 01:40:48 +00003817 const unsigned char *Data = (const unsigned char*)F.ModuleOffsetMap.data();
Richard Smith37a93df2017-02-18 00:32:02 +00003818 const unsigned char *DataEnd = Data + F.ModuleOffsetMap.size();
3819 F.ModuleOffsetMap = StringRef();
3820
3821 // If we see this entry before SOURCE_LOCATION_OFFSETS, add placeholders.
3822 if (F.SLocRemap.find(0) == F.SLocRemap.end()) {
3823 F.SLocRemap.insert(std::make_pair(0U, 0));
3824 F.SLocRemap.insert(std::make_pair(2U, 1));
3825 }
3826
3827 // Continuous range maps we may be updating in our module.
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00003828 using RemapBuilder = ContinuousRangeMap<uint32_t, int, 2>::Builder;
Richard Smith37a93df2017-02-18 00:32:02 +00003829 RemapBuilder SLocRemap(F.SLocRemap);
3830 RemapBuilder IdentifierRemap(F.IdentifierRemap);
3831 RemapBuilder MacroRemap(F.MacroRemap);
3832 RemapBuilder PreprocessedEntityRemap(F.PreprocessedEntityRemap);
3833 RemapBuilder SubmoduleRemap(F.SubmoduleRemap);
3834 RemapBuilder SelectorRemap(F.SelectorRemap);
3835 RemapBuilder DeclRemap(F.DeclRemap);
3836 RemapBuilder TypeRemap(F.TypeRemap);
3837
3838 while (Data < DataEnd) {
Boris Kolpackovd30446f2017-08-31 06:26:43 +00003839 // FIXME: Looking up dependency modules by filename is horrible. Let's
3840 // start fixing this with prebuilt and explicit modules and see how it
3841 // goes...
Richard Smith37a93df2017-02-18 00:32:02 +00003842 using namespace llvm::support;
Vedant Kumar48b4f762018-04-14 01:40:48 +00003843 ModuleKind Kind = static_cast<ModuleKind>(
3844 endian::readNext<uint8_t, little, unaligned>(Data));
Richard Smith37a93df2017-02-18 00:32:02 +00003845 uint16_t Len = endian::readNext<uint16_t, little, unaligned>(Data);
3846 StringRef Name = StringRef((const char*)Data, Len);
3847 Data += Len;
Boris Kolpackovd30446f2017-08-31 06:26:43 +00003848 ModuleFile *OM = (Kind == MK_PrebuiltModule || Kind == MK_ExplicitModule
3849 ? ModuleMgr.lookupByModuleName(Name)
3850 : ModuleMgr.lookupByFileName(Name));
Richard Smith37a93df2017-02-18 00:32:02 +00003851 if (!OM) {
3852 std::string Msg =
3853 "SourceLocation remap refers to unknown module, cannot find ";
Benjamin Krameradcd0262020-01-28 20:23:46 +01003854 Msg.append(std::string(Name));
Richard Smith37a93df2017-02-18 00:32:02 +00003855 Error(Msg);
3856 return;
3857 }
3858
3859 uint32_t SLocOffset =
3860 endian::readNext<uint32_t, little, unaligned>(Data);
3861 uint32_t IdentifierIDOffset =
3862 endian::readNext<uint32_t, little, unaligned>(Data);
3863 uint32_t MacroIDOffset =
3864 endian::readNext<uint32_t, little, unaligned>(Data);
3865 uint32_t PreprocessedEntityIDOffset =
3866 endian::readNext<uint32_t, little, unaligned>(Data);
3867 uint32_t SubmoduleIDOffset =
3868 endian::readNext<uint32_t, little, unaligned>(Data);
3869 uint32_t SelectorIDOffset =
3870 endian::readNext<uint32_t, little, unaligned>(Data);
3871 uint32_t DeclIDOffset =
3872 endian::readNext<uint32_t, little, unaligned>(Data);
3873 uint32_t TypeIndexOffset =
3874 endian::readNext<uint32_t, little, unaligned>(Data);
3875
3876 uint32_t None = std::numeric_limits<uint32_t>::max();
3877
3878 auto mapOffset = [&](uint32_t Offset, uint32_t BaseOffset,
3879 RemapBuilder &Remap) {
3880 if (Offset != None)
3881 Remap.insert(std::make_pair(Offset,
3882 static_cast<int>(BaseOffset - Offset)));
3883 };
3884 mapOffset(SLocOffset, OM->SLocEntryBaseOffset, SLocRemap);
3885 mapOffset(IdentifierIDOffset, OM->BaseIdentifierID, IdentifierRemap);
3886 mapOffset(MacroIDOffset, OM->BaseMacroID, MacroRemap);
3887 mapOffset(PreprocessedEntityIDOffset, OM->BasePreprocessedEntityID,
3888 PreprocessedEntityRemap);
3889 mapOffset(SubmoduleIDOffset, OM->BaseSubmoduleID, SubmoduleRemap);
3890 mapOffset(SelectorIDOffset, OM->BaseSelectorID, SelectorRemap);
3891 mapOffset(DeclIDOffset, OM->BaseDeclID, DeclRemap);
3892 mapOffset(TypeIndexOffset, OM->BaseTypeIndex, TypeRemap);
3893
3894 // Global -> local mappings.
3895 F.GlobalToLocalDeclIDs[OM] = DeclIDOffset;
3896 }
3897}
3898
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003899ASTReader::ASTReadResult
3900ASTReader::ReadModuleMapFileBlock(RecordData &Record, ModuleFile &F,
3901 const ModuleFile *ImportedBy,
3902 unsigned ClientLoadCapabilities) {
3903 unsigned Idx = 0;
Richard Smith7ed1bc92014-12-05 22:42:13 +00003904 F.ModuleMapPath = ReadPath(F, Record, Idx);
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003905
3906 // Try to resolve ModuleName in the current header search context and
3907 // verify that it is found in the same module map file as we saved. If the
3908 // top-level AST file is a main file, skip this check because there is no
3909 // usable header search context.
3910 assert(!F.ModuleName.empty() &&
Richard Smithe842a472014-10-22 02:05:46 +00003911 "MODULE_NAME should come before MODULE_MAP_FILE");
Duncan P. N. Exon Smith96a06e02017-01-28 22:15:22 +00003912 if (F.Kind == MK_ImplicitModule && ModuleMgr.begin()->Kind != MK_MainFile) {
Richard Smithe842a472014-10-22 02:05:46 +00003913 // An implicitly-loaded module file should have its module listed in some
3914 // module map file that we've already loaded.
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003915 Module *M = PP.getHeaderSearchInfo().lookupModule(F.ModuleName);
Richard Smithe842a472014-10-22 02:05:46 +00003916 auto &Map = PP.getHeaderSearchInfo().getModuleMap();
3917 const FileEntry *ModMap = M ? Map.getModuleMapFileForUniquing(M) : nullptr;
Yuka Takahashid8baec22018-08-01 09:50:02 +00003918 // Don't emit module relocation error if we have -fno-validate-pch
3919 if (!PP.getPreprocessorOpts().DisablePCHValidation && !ModMap) {
Richard Smith0f99d6a2015-08-09 08:48:41 +00003920 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0) {
Bruno Cardoso Lopesa66a3252017-11-17 03:24:11 +00003921 if (auto *ASTFE = M ? M->getASTFile() : nullptr) {
Richard Smith0f99d6a2015-08-09 08:48:41 +00003922 // This module was defined by an imported (explicit) module.
3923 Diag(diag::err_module_file_conflict) << F.ModuleName << F.FileName
3924 << ASTFE->getName();
Bruno Cardoso Lopesa66a3252017-11-17 03:24:11 +00003925 } else {
Richard Smith0f99d6a2015-08-09 08:48:41 +00003926 // This module was built with a different module map.
3927 Diag(diag::err_imported_module_not_found)
Bruno Cardoso Lopes4625c182019-08-29 23:14:08 +00003928 << F.ModuleName << F.FileName
3929 << (ImportedBy ? ImportedBy->FileName : "") << F.ModuleMapPath
3930 << !ImportedBy;
Bruno Cardoso Lopesa66a3252017-11-17 03:24:11 +00003931 // In case it was imported by a PCH, there's a chance the user is
3932 // just missing to include the search path to the directory containing
3933 // the modulemap.
Bruno Cardoso Lopes4625c182019-08-29 23:14:08 +00003934 if (ImportedBy && ImportedBy->Kind == MK_PCH)
Bruno Cardoso Lopesa66a3252017-11-17 03:24:11 +00003935 Diag(diag::note_imported_by_pch_module_not_found)
3936 << llvm::sys::path::parent_path(F.ModuleMapPath);
3937 }
Richard Smith0f99d6a2015-08-09 08:48:41 +00003938 }
3939 return OutOfDate;
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003940 }
3941
Richard Smithe842a472014-10-22 02:05:46 +00003942 assert(M->Name == F.ModuleName && "found module with different name");
3943
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003944 // Check the primary module map file.
Harlan Haskins8d323d12019-08-01 21:31:56 +00003945 auto StoredModMap = FileMgr.getFile(F.ModuleMapPath);
3946 if (!StoredModMap || *StoredModMap != ModMap) {
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003947 assert(ModMap && "found module is missing module map file");
Bruno Cardoso Lopes4625c182019-08-29 23:14:08 +00003948 assert((ImportedBy || F.Kind == MK_ImplicitModule) &&
3949 "top-level import should be verified");
3950 bool NotImported = F.Kind == MK_ImplicitModule && !ImportedBy;
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003951 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3952 Diag(diag::err_imported_module_modmap_changed)
Bruno Cardoso Lopes4625c182019-08-29 23:14:08 +00003953 << F.ModuleName << (NotImported ? F.FileName : ImportedBy->FileName)
3954 << ModMap->getName() << F.ModuleMapPath << NotImported;
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003955 return OutOfDate;
3956 }
3957
3958 llvm::SmallPtrSet<const FileEntry *, 1> AdditionalStoredMaps;
3959 for (unsigned I = 0, N = Record[Idx++]; I < N; ++I) {
3960 // FIXME: we should use input files rather than storing names.
Richard Smith7ed1bc92014-12-05 22:42:13 +00003961 std::string Filename = ReadPath(F, Record, Idx);
Harlan Haskins8d323d12019-08-01 21:31:56 +00003962 auto F = FileMgr.getFile(Filename, false, false);
3963 if (!F) {
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003964 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3965 Error("could not find file '" + Filename +"' referenced by AST file");
3966 return OutOfDate;
3967 }
Harlan Haskins8d323d12019-08-01 21:31:56 +00003968 AdditionalStoredMaps.insert(*F);
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003969 }
3970
3971 // Check any additional module map files (e.g. module.private.modulemap)
3972 // that are not in the pcm.
3973 if (auto *AdditionalModuleMaps = Map.getAdditionalModuleMapFiles(M)) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00003974 for (const FileEntry *ModMap : *AdditionalModuleMaps) {
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003975 // Remove files that match
3976 // Note: SmallPtrSet::erase is really remove
3977 if (!AdditionalStoredMaps.erase(ModMap)) {
3978 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3979 Diag(diag::err_module_different_modmap)
3980 << F.ModuleName << /*new*/0 << ModMap->getName();
3981 return OutOfDate;
3982 }
3983 }
3984 }
3985
3986 // Check any additional module map files that are in the pcm, but not
3987 // found in header search. Cases that match are already removed.
Vedant Kumar48b4f762018-04-14 01:40:48 +00003988 for (const FileEntry *ModMap : AdditionalStoredMaps) {
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00003989 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
3990 Diag(diag::err_module_different_modmap)
3991 << F.ModuleName << /*not new*/1 << ModMap->getName();
3992 return OutOfDate;
3993 }
3994 }
3995
3996 if (Listener)
3997 Listener->ReadModuleMapFile(F.ModuleMapPath);
3998 return Success;
3999}
4000
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00004001/// Move the given method to the back of the global list of methods.
Douglas Gregorc1489562013-02-12 23:36:21 +00004002static void moveMethodToBackOfGlobalList(Sema &S, ObjCMethodDecl *Method) {
4003 // Find the entry for this selector in the method pool.
4004 Sema::GlobalMethodPool::iterator Known
4005 = S.MethodPool.find(Method->getSelector());
4006 if (Known == S.MethodPool.end())
4007 return;
4008
4009 // Retrieve the appropriate method list.
4010 ObjCMethodList &Start = Method->isInstanceMethod()? Known->second.first
4011 : Known->second.second;
4012 bool Found = false;
Argyrios Kyrtzidisd3da6e02013-04-17 00:08:58 +00004013 for (ObjCMethodList *List = &Start; List; List = List->getNext()) {
Douglas Gregorc1489562013-02-12 23:36:21 +00004014 if (!Found) {
Nico Weber2e0c8f72014-12-27 03:58:08 +00004015 if (List->getMethod() == Method) {
Douglas Gregorc1489562013-02-12 23:36:21 +00004016 Found = true;
4017 } else {
4018 // Keep searching.
4019 continue;
4020 }
4021 }
4022
Argyrios Kyrtzidisd3da6e02013-04-17 00:08:58 +00004023 if (List->getNext())
Nico Weber2e0c8f72014-12-27 03:58:08 +00004024 List->setMethod(List->getNext()->getMethod());
Douglas Gregorc1489562013-02-12 23:36:21 +00004025 else
Nico Weber2e0c8f72014-12-27 03:58:08 +00004026 List->setMethod(Method);
Douglas Gregorc1489562013-02-12 23:36:21 +00004027 }
4028}
4029
Richard Smithde711422015-04-23 21:20:19 +00004030void ASTReader::makeNamesVisible(const HiddenNames &Names, Module *Owner) {
Richard Smith10434f32015-05-02 02:08:26 +00004031 assert(Owner->NameVisibility != Module::Hidden && "nothing to make visible?");
Vedant Kumar48b4f762018-04-14 01:40:48 +00004032 for (Decl *D : Names) {
Richard Smith90dc5252017-06-23 01:04:34 +00004033 bool wasHidden = D->isHidden();
4034 D->setVisibleDespiteOwningModule();
Guy Benyei11169dd2012-12-18 14:30:41 +00004035
Vedant Kumar48b4f762018-04-14 01:40:48 +00004036 if (wasHidden && SemaObj) {
4037 if (ObjCMethodDecl *Method = dyn_cast<ObjCMethodDecl>(D)) {
Richard Smith49f906a2014-03-01 00:08:04 +00004038 moveMethodToBackOfGlobalList(*SemaObj, Method);
Vedant Kumar48b4f762018-04-14 01:40:48 +00004039 }
4040 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004041 }
4042}
4043
Richard Smith49f906a2014-03-01 00:08:04 +00004044void ASTReader::makeModuleVisible(Module *Mod,
Argyrios Kyrtzidis125df052013-02-01 16:36:12 +00004045 Module::NameVisibilityKind NameVisibility,
Richard Smitha7e2cc62015-05-01 01:53:09 +00004046 SourceLocation ImportLoc) {
Guy Benyei11169dd2012-12-18 14:30:41 +00004047 llvm::SmallPtrSet<Module *, 4> Visited;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00004048 SmallVector<Module *, 4> Stack;
Robert Wilhelm25284cc2013-08-23 16:11:15 +00004049 Stack.push_back(Mod);
Guy Benyei11169dd2012-12-18 14:30:41 +00004050 while (!Stack.empty()) {
Robert Wilhelm25284cc2013-08-23 16:11:15 +00004051 Mod = Stack.pop_back_val();
Guy Benyei11169dd2012-12-18 14:30:41 +00004052
4053 if (NameVisibility <= Mod->NameVisibility) {
Robert Wilhelm25284cc2013-08-23 16:11:15 +00004054 // This module already has this level of visibility (or greater), so
Guy Benyei11169dd2012-12-18 14:30:41 +00004055 // there is nothing more to do.
4056 continue;
4057 }
Richard Smith49f906a2014-03-01 00:08:04 +00004058
Richard Smith6bc75022020-04-17 20:25:15 -07004059 if (Mod->isUnimportable()) {
4060 // Modules that aren't importable cannot be made visible.
Guy Benyei11169dd2012-12-18 14:30:41 +00004061 continue;
4062 }
4063
4064 // Update the module's name visibility.
4065 Mod->NameVisibility = NameVisibility;
Richard Smith49f906a2014-03-01 00:08:04 +00004066
Guy Benyei11169dd2012-12-18 14:30:41 +00004067 // If we've already deserialized any names from this module,
4068 // mark them as visible.
4069 HiddenNamesMapType::iterator Hidden = HiddenNamesMap.find(Mod);
4070 if (Hidden != HiddenNamesMap.end()) {
Richard Smith57721ac2014-07-21 04:10:40 +00004071 auto HiddenNames = std::move(*Hidden);
Guy Benyei11169dd2012-12-18 14:30:41 +00004072 HiddenNamesMap.erase(Hidden);
Richard Smithde711422015-04-23 21:20:19 +00004073 makeNamesVisible(HiddenNames.second, HiddenNames.first);
Richard Smith57721ac2014-07-21 04:10:40 +00004074 assert(HiddenNamesMap.find(Mod) == HiddenNamesMap.end() &&
4075 "making names visible added hidden names");
Guy Benyei11169dd2012-12-18 14:30:41 +00004076 }
Dmitri Gribenkoe9bcf5b2013-11-04 21:51:33 +00004077
Guy Benyei11169dd2012-12-18 14:30:41 +00004078 // Push any exported modules onto the stack to be marked as visible.
Argyrios Kyrtzidis8739f7b2013-02-19 19:34:40 +00004079 SmallVector<Module *, 16> Exports;
4080 Mod->getExportedModules(Exports);
Vedant Kumar48b4f762018-04-14 01:40:48 +00004081 for (SmallVectorImpl<Module *>::iterator
4082 I = Exports.begin(), E = Exports.end(); I != E; ++I) {
4083 Module *Exported = *I;
David Blaikie82e95a32014-11-19 07:49:47 +00004084 if (Visited.insert(Exported).second)
Argyrios Kyrtzidis8739f7b2013-02-19 19:34:40 +00004085 Stack.push_back(Exported);
Vedant Kumar48b4f762018-04-14 01:40:48 +00004086 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004087 }
4088}
4089
Richard Smith6561f922016-09-12 21:06:40 +00004090/// We've merged the definition \p MergedDef into the existing definition
4091/// \p Def. Ensure that \p Def is made visible whenever \p MergedDef is made
4092/// visible.
4093void ASTReader::mergeDefinitionVisibility(NamedDecl *Def,
4094 NamedDecl *MergedDef) {
Richard Smith6561f922016-09-12 21:06:40 +00004095 if (Def->isHidden()) {
4096 // If MergedDef is visible or becomes visible, make the definition visible.
Benjamin Kramera72a70a2016-10-17 13:00:44 +00004097 if (!MergedDef->isHidden())
Richard Smith90dc5252017-06-23 01:04:34 +00004098 Def->setVisibleDespiteOwningModule();
Richard Smith13897eb2018-09-12 23:37:00 +00004099 else {
Benjamin Kramera72a70a2016-10-17 13:00:44 +00004100 getContext().mergeDefinitionIntoModule(
4101 Def, MergedDef->getImportedOwningModule(),
4102 /*NotifyListeners*/ false);
4103 PendingMergedDefinitionsToDeduplicate.insert(Def);
Benjamin Kramera72a70a2016-10-17 13:00:44 +00004104 }
Richard Smith6561f922016-09-12 21:06:40 +00004105 }
4106}
4107
Douglas Gregore060e572013-01-25 01:03:03 +00004108bool ASTReader::loadGlobalIndex() {
4109 if (GlobalIndex)
4110 return false;
4111
4112 if (TriedLoadingGlobalIndex || !UseGlobalIndex ||
Richard Smithdbafb6c2017-06-29 23:23:46 +00004113 !PP.getLangOpts().Modules)
Douglas Gregore060e572013-01-25 01:03:03 +00004114 return true;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004115
Douglas Gregore060e572013-01-25 01:03:03 +00004116 // Try to load the global index.
4117 TriedLoadingGlobalIndex = true;
4118 StringRef ModuleCachePath
4119 = getPreprocessor().getHeaderSearchInfo().getModuleCachePath();
JF Bastien0e828952019-06-26 19:50:12 +00004120 std::pair<GlobalModuleIndex *, llvm::Error> Result =
4121 GlobalModuleIndex::readIndex(ModuleCachePath);
4122 if (llvm::Error Err = std::move(Result.second)) {
4123 assert(!Result.first);
4124 consumeError(std::move(Err)); // FIXME this drops errors on the floor.
Douglas Gregore060e572013-01-25 01:03:03 +00004125 return true;
JF Bastien0e828952019-06-26 19:50:12 +00004126 }
Douglas Gregore060e572013-01-25 01:03:03 +00004127
4128 GlobalIndex.reset(Result.first);
Douglas Gregor7211ac12013-01-25 23:32:03 +00004129 ModuleMgr.setGlobalIndex(GlobalIndex.get());
Douglas Gregore060e572013-01-25 01:03:03 +00004130 return false;
4131}
4132
4133bool ASTReader::isGlobalIndexUnavailable() const {
Richard Smithdbafb6c2017-06-29 23:23:46 +00004134 return PP.getLangOpts().Modules && UseGlobalIndex &&
Douglas Gregore060e572013-01-25 01:03:03 +00004135 !hasGlobalIndex() && TriedLoadingGlobalIndex;
4136}
4137
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004138static void updateModuleTimestamp(ModuleFile &MF) {
4139 // Overwrite the timestamp file contents so that file's mtime changes.
4140 std::string TimestampFilename = MF.getTimestampFilename();
Rafael Espindoladae941a2014-08-25 18:17:04 +00004141 std::error_code EC;
Fangrui Songd9b948b2019-08-05 05:43:48 +00004142 llvm::raw_fd_ostream OS(TimestampFilename, EC, llvm::sys::fs::OF_Text);
Rafael Espindoladae941a2014-08-25 18:17:04 +00004143 if (EC)
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004144 return;
4145 OS << "Timestamp file\n";
Alex Lorenz0bafa022017-06-02 10:36:56 +00004146 OS.close();
4147 OS.clear_error(); // Avoid triggering a fatal error.
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004148}
4149
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00004150/// Given a cursor at the start of an AST file, scan ahead and drop the
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004151/// cursor into the start of the given block ID, returning false on success and
4152/// true on failure.
4153static bool SkipCursorToBlock(BitstreamCursor &Cursor, unsigned BlockID) {
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00004154 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00004155 Expected<llvm::BitstreamEntry> MaybeEntry = Cursor.advance();
4156 if (!MaybeEntry) {
4157 // FIXME this drops errors on the floor.
4158 consumeError(MaybeEntry.takeError());
4159 return true;
4160 }
4161 llvm::BitstreamEntry Entry = MaybeEntry.get();
4162
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004163 switch (Entry.Kind) {
4164 case llvm::BitstreamEntry::Error:
4165 case llvm::BitstreamEntry::EndBlock:
4166 return true;
4167
4168 case llvm::BitstreamEntry::Record:
4169 // Ignore top-level records.
JF Bastien0e828952019-06-26 19:50:12 +00004170 if (Expected<unsigned> Skipped = Cursor.skipRecord(Entry.ID))
4171 break;
4172 else {
4173 // FIXME this drops errors on the floor.
4174 consumeError(Skipped.takeError());
4175 return true;
4176 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004177
4178 case llvm::BitstreamEntry::SubBlock:
4179 if (Entry.ID == BlockID) {
JF Bastien0e828952019-06-26 19:50:12 +00004180 if (llvm::Error Err = Cursor.EnterSubBlock(BlockID)) {
4181 // FIXME this drops the error on the floor.
4182 consumeError(std::move(Err));
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004183 return true;
JF Bastien0e828952019-06-26 19:50:12 +00004184 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004185 // Found it!
4186 return false;
4187 }
4188
JF Bastien0e828952019-06-26 19:50:12 +00004189 if (llvm::Error Err = Cursor.SkipBlock()) {
4190 // FIXME this drops the error on the floor.
4191 consumeError(std::move(Err));
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004192 return true;
JF Bastien0e828952019-06-26 19:50:12 +00004193 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004194 }
4195 }
4196}
4197
Benjamin Kramer0772c422016-02-13 13:42:54 +00004198ASTReader::ASTReadResult ASTReader::ReadAST(StringRef FileName,
Guy Benyei11169dd2012-12-18 14:30:41 +00004199 ModuleKind Type,
4200 SourceLocation ImportLoc,
Graydon Hoaree7196af2016-12-09 21:45:49 +00004201 unsigned ClientLoadCapabilities,
4202 SmallVectorImpl<ImportedSubmodule> *Imported) {
Argyrios Kyrtzidisdc9fdaf2013-05-24 05:44:08 +00004203 llvm::SaveAndRestore<SourceLocation>
4204 SetCurImportLocRAII(CurrentImportLoc, ImportLoc);
4205
Richard Smithd1c46742014-04-30 02:24:17 +00004206 // Defer any pending actions until we get to the end of reading the AST file.
4207 Deserializing AnASTFile(this);
4208
Guy Benyei11169dd2012-12-18 14:30:41 +00004209 // Bump the generation number.
Richard Smithdbafb6c2017-06-29 23:23:46 +00004210 unsigned PreviousGeneration = 0;
4211 if (ContextObj)
4212 PreviousGeneration = incrementGeneration(*ContextObj);
Guy Benyei11169dd2012-12-18 14:30:41 +00004213
4214 unsigned NumModules = ModuleMgr.size();
Duncan P. N. Exon Smithc46b3a22019-11-10 10:42:29 -08004215 auto removeModulesAndReturn = [&](ASTReadResult ReadResult) {
4216 assert(ReadResult && "expected to return error");
Duncan P. N. Exon Smith8e9e4332019-11-10 10:31:03 -08004217 ModuleMgr.removeModules(ModuleMgr.begin() + NumModules,
Richard Smithdbafb6c2017-06-29 23:23:46 +00004218 PP.getLangOpts().Modules
Duncan P. N. Exon Smith8e6bc1972017-01-28 23:02:12 +00004219 ? &PP.getHeaderSearchInfo().getModuleMap()
4220 : nullptr);
Douglas Gregore060e572013-01-25 01:03:03 +00004221
4222 // If we find that any modules are unusable, the global index is going
4223 // to be out-of-date. Just remove it.
4224 GlobalIndex.reset();
Craig Toppera13603a2014-05-22 05:54:18 +00004225 ModuleMgr.setGlobalIndex(nullptr);
Guy Benyei11169dd2012-12-18 14:30:41 +00004226 return ReadResult;
Duncan P. N. Exon Smithc46b3a22019-11-10 10:42:29 -08004227 };
4228
4229 SmallVector<ImportedModule, 4> Loaded;
4230 switch (ASTReadResult ReadResult =
4231 ReadASTCore(FileName, Type, ImportLoc,
4232 /*ImportedBy=*/nullptr, Loaded, 0, 0,
4233 ASTFileSignature(), ClientLoadCapabilities)) {
4234 case Failure:
4235 case Missing:
4236 case OutOfDate:
4237 case VersionMismatch:
4238 case ConfigurationMismatch:
4239 case HadErrors:
4240 return removeModulesAndReturn(ReadResult);
Guy Benyei11169dd2012-12-18 14:30:41 +00004241 case Success:
4242 break;
4243 }
4244
4245 // Here comes stuff that we only do once the entire chain is loaded.
4246
Duncan P. N. Exon Smith01782c32019-11-10 10:50:12 -08004247 // Load the AST blocks of all of the modules that we loaded. We can still
4248 // hit errors parsing the ASTs at this point.
Duncan P. N. Exon Smithbfd58fc2019-11-11 15:42:25 -08004249 for (ImportedModule &M : Loaded) {
4250 ModuleFile &F = *M.Mod;
Guy Benyei11169dd2012-12-18 14:30:41 +00004251
4252 // Read the AST block.
Ben Langmuir2c9af442014-04-10 17:57:43 +00004253 if (ASTReadResult Result = ReadASTBlock(F, ClientLoadCapabilities))
Duncan P. N. Exon Smithc46b3a22019-11-10 10:42:29 -08004254 return removeModulesAndReturn(Result);
Guy Benyei11169dd2012-12-18 14:30:41 +00004255
Duncan P. N. Exon Smith83dcb342019-11-10 13:14:52 -08004256 // The AST block should always have a definition for the main module.
4257 if (F.isModule() && !F.DidReadTopLevelSubmodule) {
4258 Error(diag::err_module_file_missing_top_level_submodule, F.FileName);
4259 return removeModulesAndReturn(Failure);
4260 }
4261
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004262 // Read the extension blocks.
4263 while (!SkipCursorToBlock(F.Stream, EXTENSION_BLOCK_ID)) {
4264 if (ASTReadResult Result = ReadExtensionBlock(F))
Duncan P. N. Exon Smithc46b3a22019-11-10 10:42:29 -08004265 return removeModulesAndReturn(Result);
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004266 }
4267
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004268 // Once read, set the ModuleFile bit base offset and update the size in
Guy Benyei11169dd2012-12-18 14:30:41 +00004269 // bits of all files we've seen.
4270 F.GlobalBitOffset = TotalModulesSizeInBits;
4271 TotalModulesSizeInBits += F.SizeInBits;
4272 GlobalBitOffsetsMap.insert(std::make_pair(F.GlobalBitOffset, &F));
Duncan P. N. Exon Smith01782c32019-11-10 10:50:12 -08004273 }
4274
4275 // Preload source locations and interesting indentifiers.
4276 for (ImportedModule &M : Loaded) {
4277 ModuleFile &F = *M.Mod;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004278
Guy Benyei11169dd2012-12-18 14:30:41 +00004279 // Preload SLocEntries.
Vedant Kumar48b4f762018-04-14 01:40:48 +00004280 for (unsigned I = 0, N = F.PreloadSLocEntries.size(); I != N; ++I) {
4281 int Index = int(F.PreloadSLocEntries[I] - 1) + F.SLocEntryBaseID;
Guy Benyei11169dd2012-12-18 14:30:41 +00004282 // Load it through the SourceManager and don't call ReadSLocEntry()
4283 // directly because the entry may have already been loaded in which case
4284 // calling ReadSLocEntry() directly would trigger an assertion in
4285 // SourceManager.
4286 SourceMgr.getLoadedSLocEntryByID(Index);
4287 }
Richard Smith33e0f7e2015-07-22 02:08:40 +00004288
Richard Smithea741482017-05-01 22:10:47 +00004289 // Map the original source file ID into the ID space of the current
4290 // compilation.
4291 if (F.OriginalSourceFileID.isValid()) {
4292 F.OriginalSourceFileID = FileID::get(
4293 F.SLocEntryBaseID + F.OriginalSourceFileID.getOpaqueValue() - 1);
4294 }
4295
Richard Smith33e0f7e2015-07-22 02:08:40 +00004296 // Preload all the pending interesting identifiers by marking them out of
4297 // date.
4298 for (auto Offset : F.PreloadIdentifierOffsets) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004299 const unsigned char *Data = reinterpret_cast<const unsigned char *>(
Richard Smith33e0f7e2015-07-22 02:08:40 +00004300 F.IdentifierTableData + Offset);
4301
4302 ASTIdentifierLookupTrait Trait(*this, F);
4303 auto KeyDataLen = Trait.ReadKeyDataLength(Data);
4304 auto Key = Trait.ReadKey(Data, KeyDataLen.first);
Richard Smith79bf9202015-08-24 03:33:22 +00004305 auto &II = PP.getIdentifierTable().getOwn(Key);
4306 II.setOutOfDate(true);
4307
4308 // Mark this identifier as being from an AST file so that we can track
4309 // whether we need to serialize it.
Richard Smitheb4b58f62016-02-05 01:40:54 +00004310 markIdentifierFromAST(*this, II);
Richard Smith79bf9202015-08-24 03:33:22 +00004311
4312 // Associate the ID with the identifier so that the writer can reuse it.
4313 auto ID = Trait.ReadIdentifierID(Data + KeyDataLen.first);
4314 SetIdentifierInfo(ID, &II);
Richard Smith33e0f7e2015-07-22 02:08:40 +00004315 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004316 }
4317
Douglas Gregor603cd862013-03-22 18:50:14 +00004318 // Setup the import locations and notify the module manager that we've
4319 // committed to these module files.
Duncan P. N. Exon Smithbfd58fc2019-11-11 15:42:25 -08004320 for (ImportedModule &M : Loaded) {
4321 ModuleFile &F = *M.Mod;
Douglas Gregor603cd862013-03-22 18:50:14 +00004322
4323 ModuleMgr.moduleFileAccepted(&F);
4324
4325 // Set the import location.
Argyrios Kyrtzidis71c1af82013-02-01 16:36:14 +00004326 F.DirectImportLoc = ImportLoc;
Richard Smithb22a1d12016-03-27 20:13:24 +00004327 // FIXME: We assume that locations from PCH / preamble do not need
4328 // any translation.
Duncan P. N. Exon Smithbfd58fc2019-11-11 15:42:25 -08004329 if (!M.ImportedBy)
4330 F.ImportLoc = M.ImportLoc;
Guy Benyei11169dd2012-12-18 14:30:41 +00004331 else
Duncan P. N. Exon Smithbfd58fc2019-11-11 15:42:25 -08004332 F.ImportLoc = TranslateSourceLocation(*M.ImportedBy, M.ImportLoc);
Guy Benyei11169dd2012-12-18 14:30:41 +00004333 }
4334
Richard Smithdbafb6c2017-06-29 23:23:46 +00004335 if (!PP.getLangOpts().CPlusPlus ||
Manman Ren11f2a472016-08-18 17:42:15 +00004336 (Type != MK_ImplicitModule && Type != MK_ExplicitModule &&
4337 Type != MK_PrebuiltModule)) {
Richard Smith33e0f7e2015-07-22 02:08:40 +00004338 // Mark all of the identifiers in the identifier table as being out of date,
4339 // so that various accessors know to check the loaded modules when the
4340 // identifier is used.
4341 //
4342 // For C++ modules, we don't need information on many identifiers (just
4343 // those that provide macros or are poisoned), so we mark all of
4344 // the interesting ones via PreloadIdentifierOffsets.
Vedant Kumar48b4f762018-04-14 01:40:48 +00004345 for (IdentifierTable::iterator Id = PP.getIdentifierTable().begin(),
4346 IdEnd = PP.getIdentifierTable().end();
4347 Id != IdEnd; ++Id)
4348 Id->second->setOutOfDate(true);
Richard Smith33e0f7e2015-07-22 02:08:40 +00004349 }
Manman Rena0f31a02016-04-29 19:04:05 +00004350 // Mark selectors as out of date.
4351 for (auto Sel : SelectorGeneration)
4352 SelectorOutOfDate[Sel.first] = true;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004353
Guy Benyei11169dd2012-12-18 14:30:41 +00004354 // Resolve any unresolved module exports.
Vedant Kumar48b4f762018-04-14 01:40:48 +00004355 for (unsigned I = 0, N = UnresolvedModuleRefs.size(); I != N; ++I) {
4356 UnresolvedModuleRef &Unresolved = UnresolvedModuleRefs[I];
Guy Benyei11169dd2012-12-18 14:30:41 +00004357 SubmoduleID GlobalID = getGlobalSubmoduleID(*Unresolved.File,Unresolved.ID);
4358 Module *ResolvedMod = getSubmodule(GlobalID);
Douglas Gregorfb912652013-03-20 21:10:35 +00004359
4360 switch (Unresolved.Kind) {
4361 case UnresolvedModuleRef::Conflict:
4362 if (ResolvedMod) {
4363 Module::Conflict Conflict;
4364 Conflict.Other = ResolvedMod;
4365 Conflict.Message = Unresolved.String.str();
4366 Unresolved.Mod->Conflicts.push_back(Conflict);
4367 }
4368 continue;
4369
4370 case UnresolvedModuleRef::Import:
Guy Benyei11169dd2012-12-18 14:30:41 +00004371 if (ResolvedMod)
Richard Smith38477db2015-05-02 00:45:56 +00004372 Unresolved.Mod->Imports.insert(ResolvedMod);
Guy Benyei11169dd2012-12-18 14:30:41 +00004373 continue;
Guy Benyei11169dd2012-12-18 14:30:41 +00004374
Douglas Gregorfb912652013-03-20 21:10:35 +00004375 case UnresolvedModuleRef::Export:
4376 if (ResolvedMod || Unresolved.IsWildcard)
4377 Unresolved.Mod->Exports.push_back(
4378 Module::ExportDecl(ResolvedMod, Unresolved.IsWildcard));
4379 continue;
4380 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004381 }
Douglas Gregorfb912652013-03-20 21:10:35 +00004382 UnresolvedModuleRefs.clear();
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004383
Graydon Hoaree7196af2016-12-09 21:45:49 +00004384 if (Imported)
4385 Imported->append(ImportedModules.begin(),
4386 ImportedModules.end());
4387
Daniel Jasperba7f2f72013-09-24 09:14:14 +00004388 // FIXME: How do we load the 'use'd modules? They may not be submodules.
4389 // Might be unnecessary as use declarations are only used to build the
4390 // module itself.
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004391
Richard Smithdbafb6c2017-06-29 23:23:46 +00004392 if (ContextObj)
4393 InitializeContext();
Guy Benyei11169dd2012-12-18 14:30:41 +00004394
Richard Smith3d8e97e2013-10-18 06:54:39 +00004395 if (SemaObj)
4396 UpdateSema();
4397
Guy Benyei11169dd2012-12-18 14:30:41 +00004398 if (DeserializationListener)
4399 DeserializationListener->ReaderInitialized(this);
4400
4401 ModuleFile &PrimaryModule = ModuleMgr.getPrimaryModule();
Yaron Keren8b563662015-10-03 10:46:20 +00004402 if (PrimaryModule.OriginalSourceFileID.isValid()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00004403 // If this AST file is a precompiled preamble, then set the
4404 // preamble file ID of the source manager to the file source file
4405 // from which the preamble was built.
4406 if (Type == MK_Preamble) {
4407 SourceMgr.setPreambleFileID(PrimaryModule.OriginalSourceFileID);
4408 } else if (Type == MK_MainFile) {
4409 SourceMgr.setMainFileID(PrimaryModule.OriginalSourceFileID);
4410 }
4411 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004412
Guy Benyei11169dd2012-12-18 14:30:41 +00004413 // For any Objective-C class definitions we have already loaded, make sure
4414 // that we load any additional categories.
Vedant Kumar48b4f762018-04-14 01:40:48 +00004415 if (ContextObj) {
4416 for (unsigned I = 0, N = ObjCClassesLoaded.size(); I != N; ++I) {
4417 loadObjCCategories(ObjCClassesLoaded[I]->getGlobalID(),
4418 ObjCClassesLoaded[I],
Richard Smithdbafb6c2017-06-29 23:23:46 +00004419 PreviousGeneration);
Vedant Kumar48b4f762018-04-14 01:40:48 +00004420 }
4421 }
Douglas Gregore060e572013-01-25 01:03:03 +00004422
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004423 if (PP.getHeaderSearchInfo()
4424 .getHeaderSearchOpts()
4425 .ModulesValidateOncePerBuildSession) {
4426 // Now we are certain that the module and all modules it depends on are
4427 // up to date. Create or update timestamp files for modules that are
4428 // located in the module cache (not for PCH files that could be anywhere
4429 // in the filesystem).
Vedant Kumar48b4f762018-04-14 01:40:48 +00004430 for (unsigned I = 0, N = Loaded.size(); I != N; ++I) {
4431 ImportedModule &M = Loaded[I];
4432 if (M.Mod->Kind == MK_ImplicitModule) {
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004433 updateModuleTimestamp(*M.Mod);
Vedant Kumar48b4f762018-04-14 01:40:48 +00004434 }
4435 }
Dmitri Gribenkof430da42014-02-12 10:33:14 +00004436 }
4437
Guy Benyei11169dd2012-12-18 14:30:41 +00004438 return Success;
4439}
4440
Peter Collingbourne77c89b62016-11-08 04:17:11 +00004441static ASTFileSignature readASTFileSignature(StringRef PCH);
Ben Langmuir487ea142014-10-23 18:05:36 +00004442
JF Bastien0e828952019-06-26 19:50:12 +00004443/// Whether \p Stream doesn't start with the AST/PCH file magic number 'CPCH'.
4444static llvm::Error doesntStartWithASTFileMagic(BitstreamCursor &Stream) {
4445 // FIXME checking magic headers is done in other places such as
4446 // SerializedDiagnosticReader and GlobalModuleIndex, but error handling isn't
4447 // always done the same. Unify it all with a helper.
4448 if (!Stream.canSkipToPos(4))
4449 return llvm::createStringError(std::errc::illegal_byte_sequence,
4450 "file too small to contain AST file magic");
4451 for (unsigned C : {'C', 'P', 'C', 'H'})
4452 if (Expected<llvm::SimpleBitstreamCursor::word_t> Res = Stream.Read(8)) {
4453 if (Res.get() != C)
4454 return llvm::createStringError(
4455 std::errc::illegal_byte_sequence,
4456 "file doesn't start with AST file magic");
4457 } else
4458 return Res.takeError();
4459 return llvm::Error::success();
Ben Langmuir70a1b812015-03-24 04:43:52 +00004460}
4461
Richard Smith0f99d6a2015-08-09 08:48:41 +00004462static unsigned moduleKindForDiagnostic(ModuleKind Kind) {
4463 switch (Kind) {
4464 case MK_PCH:
4465 return 0; // PCH
4466 case MK_ImplicitModule:
4467 case MK_ExplicitModule:
Manman Ren11f2a472016-08-18 17:42:15 +00004468 case MK_PrebuiltModule:
Richard Smith0f99d6a2015-08-09 08:48:41 +00004469 return 1; // module
4470 case MK_MainFile:
4471 case MK_Preamble:
4472 return 2; // main source file
4473 }
4474 llvm_unreachable("unknown module kind");
4475}
4476
Guy Benyei11169dd2012-12-18 14:30:41 +00004477ASTReader::ASTReadResult
4478ASTReader::ReadASTCore(StringRef FileName,
4479 ModuleKind Type,
4480 SourceLocation ImportLoc,
4481 ModuleFile *ImportedBy,
Dmitri Gribenkof8579502013-01-12 19:30:44 +00004482 SmallVectorImpl<ImportedModule> &Loaded,
Douglas Gregor7029ce12013-03-19 00:28:20 +00004483 off_t ExpectedSize, time_t ExpectedModTime,
Ben Langmuir487ea142014-10-23 18:05:36 +00004484 ASTFileSignature ExpectedSignature,
Guy Benyei11169dd2012-12-18 14:30:41 +00004485 unsigned ClientLoadCapabilities) {
4486 ModuleFile *M;
Guy Benyei11169dd2012-12-18 14:30:41 +00004487 std::string ErrorStr;
Douglas Gregor7029ce12013-03-19 00:28:20 +00004488 ModuleManager::AddModuleResult AddResult
4489 = ModuleMgr.addModule(FileName, Type, ImportLoc, ImportedBy,
Richard Smith053f6c62014-05-16 23:01:30 +00004490 getGeneration(), ExpectedSize, ExpectedModTime,
Ben Langmuir487ea142014-10-23 18:05:36 +00004491 ExpectedSignature, readASTFileSignature,
Douglas Gregor7029ce12013-03-19 00:28:20 +00004492 M, ErrorStr);
Guy Benyei11169dd2012-12-18 14:30:41 +00004493
Douglas Gregor7029ce12013-03-19 00:28:20 +00004494 switch (AddResult) {
4495 case ModuleManager::AlreadyLoaded:
Duncan P. N. Exon Smith9dda8f52019-03-06 02:50:46 +00004496 Diag(diag::remark_module_import)
4497 << M->ModuleName << M->FileName << (ImportedBy ? true : false)
4498 << (ImportedBy ? StringRef(ImportedBy->ModuleName) : StringRef());
Douglas Gregor7029ce12013-03-19 00:28:20 +00004499 return Success;
4500
4501 case ModuleManager::NewlyLoaded:
4502 // Load module file below.
4503 break;
4504
4505 case ModuleManager::Missing:
Richard Smithe842a472014-10-22 02:05:46 +00004506 // The module file was missing; if the client can handle that, return
Douglas Gregor7029ce12013-03-19 00:28:20 +00004507 // it.
4508 if (ClientLoadCapabilities & ARR_Missing)
4509 return Missing;
4510
4511 // Otherwise, return an error.
Richard Smith0f99d6a2015-08-09 08:48:41 +00004512 Diag(diag::err_module_file_not_found) << moduleKindForDiagnostic(Type)
Adrian Prantlb3b5a732016-08-29 20:46:59 +00004513 << FileName << !ErrorStr.empty()
Richard Smith0f99d6a2015-08-09 08:48:41 +00004514 << ErrorStr;
Douglas Gregor7029ce12013-03-19 00:28:20 +00004515 return Failure;
4516
4517 case ModuleManager::OutOfDate:
4518 // We couldn't load the module file because it is out-of-date. If the
4519 // client can handle out-of-date, return it.
4520 if (ClientLoadCapabilities & ARR_OutOfDate)
4521 return OutOfDate;
4522
4523 // Otherwise, return an error.
Richard Smith0f99d6a2015-08-09 08:48:41 +00004524 Diag(diag::err_module_file_out_of_date) << moduleKindForDiagnostic(Type)
Adrian Prantl9a06a882016-08-29 20:46:56 +00004525 << FileName << !ErrorStr.empty()
Richard Smith0f99d6a2015-08-09 08:48:41 +00004526 << ErrorStr;
Guy Benyei11169dd2012-12-18 14:30:41 +00004527 return Failure;
4528 }
4529
Douglas Gregor7029ce12013-03-19 00:28:20 +00004530 assert(M && "Missing module file");
Guy Benyei11169dd2012-12-18 14:30:41 +00004531
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00004532 bool ShouldFinalizePCM = false;
4533 auto FinalizeOrDropPCM = llvm::make_scope_exit([&]() {
4534 auto &MC = getModuleManager().getModuleCache();
4535 if (ShouldFinalizePCM)
4536 MC.finalizePCM(FileName);
4537 else
Rumeet Dhindsa57a2eaf2020-03-10 10:59:26 -07004538 MC.tryToDropPCM(FileName);
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00004539 });
Guy Benyei11169dd2012-12-18 14:30:41 +00004540 ModuleFile &F = *M;
Chris Lattner7fb3bef2013-01-20 00:56:42 +00004541 BitstreamCursor &Stream = F.Stream;
Peter Collingbourne77c89b62016-11-08 04:17:11 +00004542 Stream = BitstreamCursor(PCHContainerRdr.ExtractPCH(*F.Buffer));
Adrian Prantlcbc368c2015-02-25 02:44:04 +00004543 F.SizeInBits = F.Buffer->getBufferSize() * 8;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004544
Guy Benyei11169dd2012-12-18 14:30:41 +00004545 // Sniff for the signature.
JF Bastien0e828952019-06-26 19:50:12 +00004546 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
4547 Diag(diag::err_module_file_invalid)
4548 << moduleKindForDiagnostic(Type) << FileName << std::move(Err);
Guy Benyei11169dd2012-12-18 14:30:41 +00004549 return Failure;
4550 }
4551
4552 // This is used for compatibility with older PCH formats.
4553 bool HaveReadControlBlock = false;
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00004554 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00004555 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
4556 if (!MaybeEntry) {
4557 Error(MaybeEntry.takeError());
4558 return Failure;
4559 }
4560 llvm::BitstreamEntry Entry = MaybeEntry.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004561
Chris Lattnerefa77172013-01-20 00:00:22 +00004562 switch (Entry.Kind) {
4563 case llvm::BitstreamEntry::Error:
Chris Lattnerefa77172013-01-20 00:00:22 +00004564 case llvm::BitstreamEntry::Record:
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004565 case llvm::BitstreamEntry::EndBlock:
Guy Benyei11169dd2012-12-18 14:30:41 +00004566 Error("invalid record at top-level of AST file");
4567 return Failure;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004568
Chris Lattnerefa77172013-01-20 00:00:22 +00004569 case llvm::BitstreamEntry::SubBlock:
4570 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00004571 }
4572
Chris Lattnerefa77172013-01-20 00:00:22 +00004573 switch (Entry.ID) {
Guy Benyei11169dd2012-12-18 14:30:41 +00004574 case CONTROL_BLOCK_ID:
4575 HaveReadControlBlock = true;
Ben Langmuirbeee15e2014-04-14 18:00:01 +00004576 switch (ReadControlBlock(F, Loaded, ImportedBy, ClientLoadCapabilities)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00004577 case Success:
Richard Smith0f99d6a2015-08-09 08:48:41 +00004578 // Check that we didn't try to load a non-module AST file as a module.
4579 //
4580 // FIXME: Should we also perform the converse check? Loading a module as
4581 // a PCH file sort of works, but it's a bit wonky.
Manman Ren11f2a472016-08-18 17:42:15 +00004582 if ((Type == MK_ImplicitModule || Type == MK_ExplicitModule ||
4583 Type == MK_PrebuiltModule) &&
Richard Smith0f99d6a2015-08-09 08:48:41 +00004584 F.ModuleName.empty()) {
4585 auto Result = (Type == MK_ImplicitModule) ? OutOfDate : Failure;
4586 if (Result != OutOfDate ||
4587 (ClientLoadCapabilities & ARR_OutOfDate) == 0)
4588 Diag(diag::err_module_file_not_module) << FileName;
4589 return Result;
4590 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004591 break;
4592
4593 case Failure: return Failure;
Douglas Gregor7029ce12013-03-19 00:28:20 +00004594 case Missing: return Missing;
Guy Benyei11169dd2012-12-18 14:30:41 +00004595 case OutOfDate: return OutOfDate;
4596 case VersionMismatch: return VersionMismatch;
4597 case ConfigurationMismatch: return ConfigurationMismatch;
4598 case HadErrors: return HadErrors;
4599 }
4600 break;
Richard Smithf8c32552015-09-02 17:45:54 +00004601
Guy Benyei11169dd2012-12-18 14:30:41 +00004602 case AST_BLOCK_ID:
4603 if (!HaveReadControlBlock) {
4604 if ((ClientLoadCapabilities & ARR_VersionMismatch) == 0)
Dmitri Gribenko2228cd32014-02-11 15:40:09 +00004605 Diag(diag::err_pch_version_too_old);
Guy Benyei11169dd2012-12-18 14:30:41 +00004606 return VersionMismatch;
4607 }
4608
4609 // Record that we've loaded this module.
4610 Loaded.push_back(ImportedModule(M, ImportedBy, ImportLoc));
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00004611 ShouldFinalizePCM = true;
Guy Benyei11169dd2012-12-18 14:30:41 +00004612 return Success;
4613
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004614 case UNHASHED_CONTROL_BLOCK_ID:
4615 // This block is handled using look-ahead during ReadControlBlock. We
4616 // shouldn't get here!
4617 Error("malformed block record in AST file");
4618 return Failure;
4619
Guy Benyei11169dd2012-12-18 14:30:41 +00004620 default:
JF Bastien0e828952019-06-26 19:50:12 +00004621 if (llvm::Error Err = Stream.SkipBlock()) {
4622 Error(std::move(Err));
Guy Benyei11169dd2012-12-18 14:30:41 +00004623 return Failure;
4624 }
4625 break;
4626 }
4627 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004628
Duncan P. N. Exon Smithfae03d82019-03-03 20:17:53 +00004629 llvm_unreachable("unexpected break; expected return");
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004630}
4631
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004632ASTReader::ASTReadResult
4633ASTReader::readUnhashedControlBlock(ModuleFile &F, bool WasImportedBy,
4634 unsigned ClientLoadCapabilities) {
4635 const HeaderSearchOptions &HSOpts =
4636 PP.getHeaderSearchInfo().getHeaderSearchOpts();
4637 bool AllowCompatibleConfigurationMismatch =
4638 F.Kind == MK_ExplicitModule || F.Kind == MK_PrebuiltModule;
4639
4640 ASTReadResult Result = readUnhashedControlBlockImpl(
4641 &F, F.Data, ClientLoadCapabilities, AllowCompatibleConfigurationMismatch,
4642 Listener.get(),
4643 WasImportedBy ? false : HSOpts.ModulesValidateDiagnosticOptions);
4644
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +00004645 // If F was directly imported by another module, it's implicitly validated by
4646 // the importing module.
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004647 if (DisableValidation || WasImportedBy ||
4648 (AllowConfigurationMismatch && Result == ConfigurationMismatch))
4649 return Success;
4650
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +00004651 if (Result == Failure) {
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004652 Error("malformed block record in AST file");
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +00004653 return Failure;
4654 }
4655
4656 if (Result == OutOfDate && F.Kind == MK_ImplicitModule) {
Duncan P. N. Exon Smith8bef5cd2019-03-09 17:33:56 +00004657 // If this module has already been finalized in the ModuleCache, we're stuck
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +00004658 // with it; we can only load a single version of each module.
4659 //
4660 // This can happen when a module is imported in two contexts: in one, as a
4661 // user module; in another, as a system module (due to an import from
4662 // another module marked with the [system] flag). It usually indicates a
4663 // bug in the module map: this module should also be marked with [system].
4664 //
4665 // If -Wno-system-headers (the default), and the first import is as a
4666 // system module, then validation will fail during the as-user import,
4667 // since -Werror flags won't have been validated. However, it's reasonable
4668 // to treat this consistently as a system module.
4669 //
4670 // If -Wsystem-headers, the PCM on disk was built with
4671 // -Wno-system-headers, and the first import is as a user module, then
4672 // validation will fail during the as-system import since the PCM on disk
4673 // doesn't guarantee that -Werror was respected. However, the -Werror
4674 // flags were checked during the initial as-user import.
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00004675 if (getModuleManager().getModuleCache().isPCMFinal(F.FileName)) {
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +00004676 Diag(diag::warn_module_system_bit_conflict) << F.FileName;
4677 return Success;
4678 }
4679 }
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004680
4681 return Result;
4682}
4683
4684ASTReader::ASTReadResult ASTReader::readUnhashedControlBlockImpl(
4685 ModuleFile *F, llvm::StringRef StreamData, unsigned ClientLoadCapabilities,
4686 bool AllowCompatibleConfigurationMismatch, ASTReaderListener *Listener,
4687 bool ValidateDiagnosticOptions) {
4688 // Initialize a stream.
4689 BitstreamCursor Stream(StreamData);
4690
4691 // Sniff for the signature.
JF Bastien0e828952019-06-26 19:50:12 +00004692 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
4693 // FIXME this drops the error on the floor.
4694 consumeError(std::move(Err));
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004695 return Failure;
JF Bastien0e828952019-06-26 19:50:12 +00004696 }
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004697
4698 // Scan for the UNHASHED_CONTROL_BLOCK_ID block.
4699 if (SkipCursorToBlock(Stream, UNHASHED_CONTROL_BLOCK_ID))
4700 return Failure;
4701
4702 // Read all of the records in the options block.
4703 RecordData Record;
4704 ASTReadResult Result = Success;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00004705 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00004706 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
4707 if (!MaybeEntry) {
4708 // FIXME this drops the error on the floor.
4709 consumeError(MaybeEntry.takeError());
4710 return Failure;
4711 }
4712 llvm::BitstreamEntry Entry = MaybeEntry.get();
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004713
4714 switch (Entry.Kind) {
4715 case llvm::BitstreamEntry::Error:
4716 case llvm::BitstreamEntry::SubBlock:
4717 return Failure;
4718
4719 case llvm::BitstreamEntry::EndBlock:
4720 return Result;
4721
4722 case llvm::BitstreamEntry::Record:
4723 // The interesting case.
4724 break;
4725 }
4726
4727 // Read and process a record.
4728 Record.clear();
JF Bastien0e828952019-06-26 19:50:12 +00004729 Expected<unsigned> MaybeRecordType = Stream.readRecord(Entry.ID, Record);
4730 if (!MaybeRecordType) {
4731 // FIXME this drops the error.
4732 return Failure;
4733 }
4734 switch ((UnhashedControlBlockRecordTypes)MaybeRecordType.get()) {
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00004735 case SIGNATURE:
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004736 if (F)
4737 std::copy(Record.begin(), Record.end(), F->Signature.data());
4738 break;
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004739 case DIAGNOSTIC_OPTIONS: {
4740 bool Complain = (ClientLoadCapabilities & ARR_OutOfDate) == 0;
4741 if (Listener && ValidateDiagnosticOptions &&
4742 !AllowCompatibleConfigurationMismatch &&
4743 ParseDiagnosticOptions(Record, Complain, *Listener))
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +00004744 Result = OutOfDate; // Don't return early. Read the signature.
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004745 break;
4746 }
4747 case DIAG_PRAGMA_MAPPINGS:
4748 if (!F)
4749 break;
4750 if (F->PragmaDiagMappings.empty())
4751 F->PragmaDiagMappings.swap(Record);
4752 else
4753 F->PragmaDiagMappings.insert(F->PragmaDiagMappings.end(),
4754 Record.begin(), Record.end());
4755 break;
4756 }
4757 }
4758}
4759
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004760/// Parse a record and blob containing module file extension metadata.
4761static bool parseModuleFileExtensionMetadata(
4762 const SmallVectorImpl<uint64_t> &Record,
4763 StringRef Blob,
4764 ModuleFileExtensionMetadata &Metadata) {
4765 if (Record.size() < 4) return true;
4766
4767 Metadata.MajorVersion = Record[0];
4768 Metadata.MinorVersion = Record[1];
4769
4770 unsigned BlockNameLen = Record[2];
4771 unsigned UserInfoLen = Record[3];
4772
4773 if (BlockNameLen + UserInfoLen > Blob.size()) return true;
4774
4775 Metadata.BlockName = std::string(Blob.data(), Blob.data() + BlockNameLen);
4776 Metadata.UserInfo = std::string(Blob.data() + BlockNameLen,
4777 Blob.data() + BlockNameLen + UserInfoLen);
4778 return false;
4779}
4780
4781ASTReader::ASTReadResult ASTReader::ReadExtensionBlock(ModuleFile &F) {
4782 BitstreamCursor &Stream = F.Stream;
4783
4784 RecordData Record;
4785 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00004786 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
4787 if (!MaybeEntry) {
4788 Error(MaybeEntry.takeError());
4789 return Failure;
4790 }
4791 llvm::BitstreamEntry Entry = MaybeEntry.get();
4792
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004793 switch (Entry.Kind) {
4794 case llvm::BitstreamEntry::SubBlock:
JF Bastien0e828952019-06-26 19:50:12 +00004795 if (llvm::Error Err = Stream.SkipBlock()) {
4796 Error(std::move(Err));
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004797 return Failure;
JF Bastien0e828952019-06-26 19:50:12 +00004798 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004799 continue;
4800
4801 case llvm::BitstreamEntry::EndBlock:
4802 return Success;
4803
4804 case llvm::BitstreamEntry::Error:
4805 return HadErrors;
4806
4807 case llvm::BitstreamEntry::Record:
4808 break;
4809 }
4810
4811 Record.clear();
4812 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00004813 Expected<unsigned> MaybeRecCode =
4814 Stream.readRecord(Entry.ID, Record, &Blob);
4815 if (!MaybeRecCode) {
4816 Error(MaybeRecCode.takeError());
4817 return Failure;
4818 }
4819 switch (MaybeRecCode.get()) {
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004820 case EXTENSION_METADATA: {
4821 ModuleFileExtensionMetadata Metadata;
Duncan P. N. Exon Smith8e2c1922019-11-10 11:07:20 -08004822 if (parseModuleFileExtensionMetadata(Record, Blob, Metadata)) {
4823 Error("malformed EXTENSION_METADATA in AST file");
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004824 return Failure;
Duncan P. N. Exon Smith8e2c1922019-11-10 11:07:20 -08004825 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00004826
4827 // Find a module file extension with this block name.
4828 auto Known = ModuleFileExtensions.find(Metadata.BlockName);
4829 if (Known == ModuleFileExtensions.end()) break;
4830
4831 // Form a reader.
4832 if (auto Reader = Known->second->createExtensionReader(Metadata, *this,
4833 F, Stream)) {
4834 F.ExtensionReaders.push_back(std::move(Reader));
4835 }
4836
4837 break;
4838 }
4839 }
4840 }
4841
4842 return Success;
Guy Benyei11169dd2012-12-18 14:30:41 +00004843}
4844
Richard Smitha7e2cc62015-05-01 01:53:09 +00004845void ASTReader::InitializeContext() {
Richard Smithdbafb6c2017-06-29 23:23:46 +00004846 assert(ContextObj && "no context to initialize");
4847 ASTContext &Context = *ContextObj;
4848
Guy Benyei11169dd2012-12-18 14:30:41 +00004849 // If there's a listener, notify them that we "read" the translation unit.
4850 if (DeserializationListener)
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004851 DeserializationListener->DeclRead(PREDEF_DECL_TRANSLATION_UNIT_ID,
Guy Benyei11169dd2012-12-18 14:30:41 +00004852 Context.getTranslationUnitDecl());
4853
Guy Benyei11169dd2012-12-18 14:30:41 +00004854 // FIXME: Find a better way to deal with collisions between these
4855 // built-in types. Right now, we just ignore the problem.
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004856
Guy Benyei11169dd2012-12-18 14:30:41 +00004857 // Load the special types.
4858 if (SpecialTypes.size() >= NumSpecialTypeIDs) {
4859 if (unsigned String = SpecialTypes[SPECIAL_TYPE_CF_CONSTANT_STRING]) {
4860 if (!Context.CFConstantStringTypeDecl)
4861 Context.setCFConstantStringType(GetType(String));
4862 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004863
Guy Benyei11169dd2012-12-18 14:30:41 +00004864 if (unsigned File = SpecialTypes[SPECIAL_TYPE_FILE]) {
4865 QualType FileType = GetType(File);
4866 if (FileType.isNull()) {
4867 Error("FILE type is NULL");
4868 return;
4869 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004870
Guy Benyei11169dd2012-12-18 14:30:41 +00004871 if (!Context.FILEDecl) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004872 if (const TypedefType *Typedef = FileType->getAs<TypedefType>())
Guy Benyei11169dd2012-12-18 14:30:41 +00004873 Context.setFILEDecl(Typedef->getDecl());
4874 else {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004875 const TagType *Tag = FileType->getAs<TagType>();
Guy Benyei11169dd2012-12-18 14:30:41 +00004876 if (!Tag) {
4877 Error("Invalid FILE type in AST file");
4878 return;
4879 }
4880 Context.setFILEDecl(Tag->getDecl());
4881 }
4882 }
4883 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004884
Guy Benyei11169dd2012-12-18 14:30:41 +00004885 if (unsigned Jmp_buf = SpecialTypes[SPECIAL_TYPE_JMP_BUF]) {
4886 QualType Jmp_bufType = GetType(Jmp_buf);
4887 if (Jmp_bufType.isNull()) {
4888 Error("jmp_buf type is NULL");
4889 return;
4890 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004891
Guy Benyei11169dd2012-12-18 14:30:41 +00004892 if (!Context.jmp_bufDecl) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004893 if (const TypedefType *Typedef = Jmp_bufType->getAs<TypedefType>())
Guy Benyei11169dd2012-12-18 14:30:41 +00004894 Context.setjmp_bufDecl(Typedef->getDecl());
4895 else {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004896 const TagType *Tag = Jmp_bufType->getAs<TagType>();
Guy Benyei11169dd2012-12-18 14:30:41 +00004897 if (!Tag) {
4898 Error("Invalid jmp_buf type in AST file");
4899 return;
4900 }
4901 Context.setjmp_bufDecl(Tag->getDecl());
4902 }
4903 }
4904 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004905
Guy Benyei11169dd2012-12-18 14:30:41 +00004906 if (unsigned Sigjmp_buf = SpecialTypes[SPECIAL_TYPE_SIGJMP_BUF]) {
4907 QualType Sigjmp_bufType = GetType(Sigjmp_buf);
4908 if (Sigjmp_bufType.isNull()) {
4909 Error("sigjmp_buf type is NULL");
4910 return;
4911 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004912
Guy Benyei11169dd2012-12-18 14:30:41 +00004913 if (!Context.sigjmp_bufDecl) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004914 if (const TypedefType *Typedef = Sigjmp_bufType->getAs<TypedefType>())
Guy Benyei11169dd2012-12-18 14:30:41 +00004915 Context.setsigjmp_bufDecl(Typedef->getDecl());
4916 else {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004917 const TagType *Tag = Sigjmp_bufType->getAs<TagType>();
Guy Benyei11169dd2012-12-18 14:30:41 +00004918 assert(Tag && "Invalid sigjmp_buf type in AST file");
4919 Context.setsigjmp_bufDecl(Tag->getDecl());
4920 }
4921 }
4922 }
4923
4924 if (unsigned ObjCIdRedef
4925 = SpecialTypes[SPECIAL_TYPE_OBJC_ID_REDEFINITION]) {
4926 if (Context.ObjCIdRedefinitionType.isNull())
4927 Context.ObjCIdRedefinitionType = GetType(ObjCIdRedef);
4928 }
4929
4930 if (unsigned ObjCClassRedef
4931 = SpecialTypes[SPECIAL_TYPE_OBJC_CLASS_REDEFINITION]) {
4932 if (Context.ObjCClassRedefinitionType.isNull())
4933 Context.ObjCClassRedefinitionType = GetType(ObjCClassRedef);
4934 }
4935
4936 if (unsigned ObjCSelRedef
4937 = SpecialTypes[SPECIAL_TYPE_OBJC_SEL_REDEFINITION]) {
4938 if (Context.ObjCSelRedefinitionType.isNull())
4939 Context.ObjCSelRedefinitionType = GetType(ObjCSelRedef);
4940 }
4941
4942 if (unsigned Ucontext_t = SpecialTypes[SPECIAL_TYPE_UCONTEXT_T]) {
4943 QualType Ucontext_tType = GetType(Ucontext_t);
4944 if (Ucontext_tType.isNull()) {
4945 Error("ucontext_t type is NULL");
4946 return;
4947 }
4948
4949 if (!Context.ucontext_tDecl) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004950 if (const TypedefType *Typedef = Ucontext_tType->getAs<TypedefType>())
Guy Benyei11169dd2012-12-18 14:30:41 +00004951 Context.setucontext_tDecl(Typedef->getDecl());
4952 else {
Vedant Kumar48b4f762018-04-14 01:40:48 +00004953 const TagType *Tag = Ucontext_tType->getAs<TagType>();
Guy Benyei11169dd2012-12-18 14:30:41 +00004954 assert(Tag && "Invalid ucontext_t type in AST file");
4955 Context.setucontext_tDecl(Tag->getDecl());
4956 }
4957 }
4958 }
4959 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00004960
Guy Benyei11169dd2012-12-18 14:30:41 +00004961 ReadPragmaDiagnosticMappings(Context.getDiagnostics());
4962
4963 // If there were any CUDA special declarations, deserialize them.
4964 if (!CUDASpecialDeclRefs.empty()) {
4965 assert(CUDASpecialDeclRefs.size() == 1 && "More decl refs than expected!");
4966 Context.setcudaConfigureCallDecl(
4967 cast<FunctionDecl>(GetDecl(CUDASpecialDeclRefs[0])));
4968 }
Richard Smith56be7542014-03-21 00:33:59 +00004969
Guy Benyei11169dd2012-12-18 14:30:41 +00004970 // Re-export any modules that were imported by a non-module AST file.
Richard Smitha7e2cc62015-05-01 01:53:09 +00004971 // FIXME: This does not make macro-only imports visible again.
Richard Smith56be7542014-03-21 00:33:59 +00004972 for (auto &Import : ImportedModules) {
Richard Smitha7e2cc62015-05-01 01:53:09 +00004973 if (Module *Imported = getSubmodule(Import.ID)) {
Argyrios Kyrtzidis125df052013-02-01 16:36:12 +00004974 makeModuleVisible(Imported, Module::AllVisible,
Richard Smitha7e2cc62015-05-01 01:53:09 +00004975 /*ImportLoc=*/Import.ImportLoc);
Ben Langmuir6d25fdc2016-02-11 17:04:42 +00004976 if (Import.ImportLoc.isValid())
4977 PP.makeModuleVisible(Imported, Import.ImportLoc);
4978 // FIXME: should we tell Sema to make the module visible too?
Richard Smitha7e2cc62015-05-01 01:53:09 +00004979 }
Guy Benyei11169dd2012-12-18 14:30:41 +00004980 }
4981 ImportedModules.clear();
4982}
4983
4984void ASTReader::finalizeForWriting() {
Richard Smithde711422015-04-23 21:20:19 +00004985 // Nothing to do for now.
Guy Benyei11169dd2012-12-18 14:30:41 +00004986}
4987
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00004988/// Reads and return the signature record from \p PCH's control block, or
Peter Collingbourne77c89b62016-11-08 04:17:11 +00004989/// else returns 0.
4990static ASTFileSignature readASTFileSignature(StringRef PCH) {
4991 BitstreamCursor Stream(PCH);
JF Bastien0e828952019-06-26 19:50:12 +00004992 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
4993 // FIXME this drops the error on the floor.
4994 consumeError(std::move(Err));
Vedant Kumar48b4f762018-04-14 01:40:48 +00004995 return ASTFileSignature();
JF Bastien0e828952019-06-26 19:50:12 +00004996 }
Ben Langmuir487ea142014-10-23 18:05:36 +00004997
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00004998 // Scan for the UNHASHED_CONTROL_BLOCK_ID block.
4999 if (SkipCursorToBlock(Stream, UNHASHED_CONTROL_BLOCK_ID))
Vedant Kumar48b4f762018-04-14 01:40:48 +00005000 return ASTFileSignature();
Ben Langmuir487ea142014-10-23 18:05:36 +00005001
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00005002 // Scan for SIGNATURE inside the diagnostic options block.
Ben Langmuir487ea142014-10-23 18:05:36 +00005003 ASTReader::RecordData Record;
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00005004 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00005005 Expected<llvm::BitstreamEntry> MaybeEntry =
5006 Stream.advanceSkippingSubblocks();
5007 if (!MaybeEntry) {
5008 // FIXME this drops the error on the floor.
5009 consumeError(MaybeEntry.takeError());
5010 return ASTFileSignature();
5011 }
5012 llvm::BitstreamEntry Entry = MaybeEntry.get();
5013
Simon Pilgrim0b33f112016-11-16 16:11:08 +00005014 if (Entry.Kind != llvm::BitstreamEntry::Record)
Vedant Kumar48b4f762018-04-14 01:40:48 +00005015 return ASTFileSignature();
Ben Langmuir487ea142014-10-23 18:05:36 +00005016
5017 Record.clear();
5018 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00005019 Expected<unsigned> MaybeRecord = Stream.readRecord(Entry.ID, Record, &Blob);
5020 if (!MaybeRecord) {
5021 // FIXME this drops the error on the floor.
5022 consumeError(MaybeRecord.takeError());
5023 return ASTFileSignature();
5024 }
5025 if (SIGNATURE == MaybeRecord.get())
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00005026 return {{{(uint32_t)Record[0], (uint32_t)Record[1], (uint32_t)Record[2],
5027 (uint32_t)Record[3], (uint32_t)Record[4]}}};
Ben Langmuir487ea142014-10-23 18:05:36 +00005028 }
5029}
5030
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00005031/// Retrieve the name of the original source file name
Guy Benyei11169dd2012-12-18 14:30:41 +00005032/// directly from the AST file, without actually loading the AST
5033/// file.
Adrian Prantlbb165fb2015-06-20 18:53:08 +00005034std::string ASTReader::getOriginalSourceFile(
5035 const std::string &ASTFileName, FileManager &FileMgr,
Adrian Prantlfb2398d2015-07-17 01:19:54 +00005036 const PCHContainerReader &PCHContainerRdr, DiagnosticsEngine &Diags) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005037 // Open the AST file.
Benjamin Kramera8857962014-10-26 22:44:13 +00005038 auto Buffer = FileMgr.getBufferForFile(ASTFileName);
Guy Benyei11169dd2012-12-18 14:30:41 +00005039 if (!Buffer) {
Benjamin Kramera8857962014-10-26 22:44:13 +00005040 Diags.Report(diag::err_fe_unable_to_read_pch_file)
5041 << ASTFileName << Buffer.getError().message();
Vedant Kumar48b4f762018-04-14 01:40:48 +00005042 return std::string();
Guy Benyei11169dd2012-12-18 14:30:41 +00005043 }
5044
5045 // Initialize the stream
Peter Collingbourne77c89b62016-11-08 04:17:11 +00005046 BitstreamCursor Stream(PCHContainerRdr.ExtractPCH(**Buffer));
Guy Benyei11169dd2012-12-18 14:30:41 +00005047
5048 // Sniff for the signature.
JF Bastien0e828952019-06-26 19:50:12 +00005049 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
5050 Diags.Report(diag::err_fe_not_a_pch_file) << ASTFileName << std::move(Err);
Vedant Kumar48b4f762018-04-14 01:40:48 +00005051 return std::string();
Guy Benyei11169dd2012-12-18 14:30:41 +00005052 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005053
Chris Lattnere7b154b2013-01-19 21:39:22 +00005054 // Scan for the CONTROL_BLOCK_ID block.
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005055 if (SkipCursorToBlock(Stream, CONTROL_BLOCK_ID)) {
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005056 Diags.Report(diag::err_fe_pch_malformed_block) << ASTFileName;
Vedant Kumar48b4f762018-04-14 01:40:48 +00005057 return std::string();
Chris Lattnere7b154b2013-01-19 21:39:22 +00005058 }
Guy Benyei11169dd2012-12-18 14:30:41 +00005059
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005060 // Scan for ORIGINAL_FILE inside the control block.
5061 RecordData Record;
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00005062 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00005063 Expected<llvm::BitstreamEntry> MaybeEntry =
5064 Stream.advanceSkippingSubblocks();
5065 if (!MaybeEntry) {
5066 // FIXME this drops errors on the floor.
5067 consumeError(MaybeEntry.takeError());
5068 return std::string();
5069 }
5070 llvm::BitstreamEntry Entry = MaybeEntry.get();
5071
Chris Lattnere7b154b2013-01-19 21:39:22 +00005072 if (Entry.Kind == llvm::BitstreamEntry::EndBlock)
Vedant Kumar48b4f762018-04-14 01:40:48 +00005073 return std::string();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005074
Chris Lattnere7b154b2013-01-19 21:39:22 +00005075 if (Entry.Kind != llvm::BitstreamEntry::Record) {
5076 Diags.Report(diag::err_fe_pch_malformed_block) << ASTFileName;
Vedant Kumar48b4f762018-04-14 01:40:48 +00005077 return std::string();
Guy Benyei11169dd2012-12-18 14:30:41 +00005078 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005079
Guy Benyei11169dd2012-12-18 14:30:41 +00005080 Record.clear();
Chris Lattner0e6c9402013-01-20 02:38:54 +00005081 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00005082 Expected<unsigned> MaybeRecord = Stream.readRecord(Entry.ID, Record, &Blob);
5083 if (!MaybeRecord) {
5084 // FIXME this drops the errors on the floor.
5085 consumeError(MaybeRecord.takeError());
5086 return std::string();
5087 }
5088 if (ORIGINAL_FILE == MaybeRecord.get())
Chris Lattner0e6c9402013-01-20 02:38:54 +00005089 return Blob.str();
Guy Benyei11169dd2012-12-18 14:30:41 +00005090 }
Guy Benyei11169dd2012-12-18 14:30:41 +00005091}
5092
5093namespace {
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00005094
Guy Benyei11169dd2012-12-18 14:30:41 +00005095 class SimplePCHValidator : public ASTReaderListener {
5096 const LangOptions &ExistingLangOpts;
5097 const TargetOptions &ExistingTargetOpts;
5098 const PreprocessorOptions &ExistingPPOpts;
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +00005099 std::string ExistingModuleCachePath;
Guy Benyei11169dd2012-12-18 14:30:41 +00005100 FileManager &FileMgr;
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +00005101
Guy Benyei11169dd2012-12-18 14:30:41 +00005102 public:
5103 SimplePCHValidator(const LangOptions &ExistingLangOpts,
5104 const TargetOptions &ExistingTargetOpts,
5105 const PreprocessorOptions &ExistingPPOpts,
Benjamin Krameradcd0262020-01-28 20:23:46 +01005106 StringRef ExistingModuleCachePath, FileManager &FileMgr)
5107 : ExistingLangOpts(ExistingLangOpts),
5108 ExistingTargetOpts(ExistingTargetOpts),
5109 ExistingPPOpts(ExistingPPOpts),
5110 ExistingModuleCachePath(ExistingModuleCachePath), FileMgr(FileMgr) {}
Guy Benyei11169dd2012-12-18 14:30:41 +00005111
Richard Smith1e2cf0d2014-10-31 02:28:58 +00005112 bool ReadLanguageOptions(const LangOptions &LangOpts, bool Complain,
5113 bool AllowCompatibleDifferences) override {
5114 return checkLanguageOptions(ExistingLangOpts, LangOpts, nullptr,
5115 AllowCompatibleDifferences);
Guy Benyei11169dd2012-12-18 14:30:41 +00005116 }
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00005117
Chandler Carruth0d745bc2015-03-14 04:47:43 +00005118 bool ReadTargetOptions(const TargetOptions &TargetOpts, bool Complain,
5119 bool AllowCompatibleDifferences) override {
5120 return checkTargetOptions(ExistingTargetOpts, TargetOpts, nullptr,
5121 AllowCompatibleDifferences);
Guy Benyei11169dd2012-12-18 14:30:41 +00005122 }
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00005123
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +00005124 bool ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts,
5125 StringRef SpecificModuleCachePath,
5126 bool Complain) override {
5127 return checkHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
5128 ExistingModuleCachePath,
5129 nullptr, ExistingLangOpts);
5130 }
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00005131
Craig Topper3e89dfe2014-03-13 02:13:41 +00005132 bool ReadPreprocessorOptions(const PreprocessorOptions &PPOpts,
5133 bool Complain,
5134 std::string &SuggestedPredefines) override {
Craig Toppera13603a2014-05-22 05:54:18 +00005135 return checkPreprocessorOptions(ExistingPPOpts, PPOpts, nullptr, FileMgr,
Argyrios Kyrtzidisd3afa0c2013-04-26 21:33:40 +00005136 SuggestedPredefines, ExistingLangOpts);
Guy Benyei11169dd2012-12-18 14:30:41 +00005137 }
5138 };
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00005139
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00005140} // namespace
Guy Benyei11169dd2012-12-18 14:30:41 +00005141
Adrian Prantlbb165fb2015-06-20 18:53:08 +00005142bool ASTReader::readASTFileControlBlock(
5143 StringRef Filename, FileManager &FileMgr,
Adrian Prantlfb2398d2015-07-17 01:19:54 +00005144 const PCHContainerReader &PCHContainerRdr,
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005145 bool FindModuleFileExtensions,
Manman Ren47a44452016-07-26 17:12:17 +00005146 ASTReaderListener &Listener, bool ValidateDiagnosticOptions) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005147 // Open the AST file.
Richard Smith7f330cd2015-03-18 01:42:29 +00005148 // FIXME: This allows use of the VFS; we do not allow use of the
5149 // VFS when actually loading a module.
Benjamin Kramera8857962014-10-26 22:44:13 +00005150 auto Buffer = FileMgr.getBufferForFile(Filename);
Guy Benyei11169dd2012-12-18 14:30:41 +00005151 if (!Buffer) {
5152 return true;
5153 }
5154
5155 // Initialize the stream
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00005156 StringRef Bytes = PCHContainerRdr.ExtractPCH(**Buffer);
5157 BitstreamCursor Stream(Bytes);
Guy Benyei11169dd2012-12-18 14:30:41 +00005158
5159 // Sniff for the signature.
JF Bastien0e828952019-06-26 19:50:12 +00005160 if (llvm::Error Err = doesntStartWithASTFileMagic(Stream)) {
5161 consumeError(std::move(Err)); // FIXME this drops errors on the floor.
Guy Benyei11169dd2012-12-18 14:30:41 +00005162 return true;
JF Bastien0e828952019-06-26 19:50:12 +00005163 }
Guy Benyei11169dd2012-12-18 14:30:41 +00005164
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005165 // Scan for the CONTROL_BLOCK_ID block.
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005166 if (SkipCursorToBlock(Stream, CONTROL_BLOCK_ID))
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005167 return true;
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005168
5169 bool NeedsInputFiles = Listener.needsInputFileVisitation();
Ben Langmuircb69b572014-03-07 06:40:32 +00005170 bool NeedsSystemInputFiles = Listener.needsSystemInputFileVisitation();
Richard Smithd4b230b2014-10-27 23:01:16 +00005171 bool NeedsImports = Listener.needsImportVisitation();
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005172 BitstreamCursor InputFilesCursor;
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005173
Guy Benyei11169dd2012-12-18 14:30:41 +00005174 RecordData Record;
Richard Smith7ed1bc92014-12-05 22:42:13 +00005175 std::string ModuleDir;
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005176 bool DoneWithControlBlock = false;
5177 while (!DoneWithControlBlock) {
JF Bastien0e828952019-06-26 19:50:12 +00005178 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
5179 if (!MaybeEntry) {
5180 // FIXME this drops the error on the floor.
5181 consumeError(MaybeEntry.takeError());
5182 return true;
5183 }
5184 llvm::BitstreamEntry Entry = MaybeEntry.get();
Richard Smith0516b182015-09-08 19:40:14 +00005185
5186 switch (Entry.Kind) {
5187 case llvm::BitstreamEntry::SubBlock: {
5188 switch (Entry.ID) {
5189 case OPTIONS_BLOCK_ID: {
5190 std::string IgnoredSuggestedPredefines;
5191 if (ReadOptionsBlock(Stream, ARR_ConfigurationMismatch | ARR_OutOfDate,
5192 /*AllowCompatibleConfigurationMismatch*/ false,
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00005193 Listener, IgnoredSuggestedPredefines) != Success)
Richard Smith0516b182015-09-08 19:40:14 +00005194 return true;
5195 break;
5196 }
5197
5198 case INPUT_FILES_BLOCK_ID:
5199 InputFilesCursor = Stream;
JF Bastien0e828952019-06-26 19:50:12 +00005200 if (llvm::Error Err = Stream.SkipBlock()) {
5201 // FIXME this drops the error on the floor.
5202 consumeError(std::move(Err));
5203 return true;
5204 }
5205 if (NeedsInputFiles &&
5206 ReadBlockAbbrevs(InputFilesCursor, INPUT_FILES_BLOCK_ID))
Richard Smith0516b182015-09-08 19:40:14 +00005207 return true;
5208 break;
5209
5210 default:
JF Bastien0e828952019-06-26 19:50:12 +00005211 if (llvm::Error Err = Stream.SkipBlock()) {
5212 // FIXME this drops the error on the floor.
5213 consumeError(std::move(Err));
Richard Smith0516b182015-09-08 19:40:14 +00005214 return true;
JF Bastien0e828952019-06-26 19:50:12 +00005215 }
Richard Smith0516b182015-09-08 19:40:14 +00005216 break;
5217 }
5218
5219 continue;
5220 }
5221
5222 case llvm::BitstreamEntry::EndBlock:
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005223 DoneWithControlBlock = true;
5224 break;
Richard Smith0516b182015-09-08 19:40:14 +00005225
5226 case llvm::BitstreamEntry::Error:
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005227 return true;
Richard Smith0516b182015-09-08 19:40:14 +00005228
5229 case llvm::BitstreamEntry::Record:
5230 break;
5231 }
5232
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005233 if (DoneWithControlBlock) break;
5234
Guy Benyei11169dd2012-12-18 14:30:41 +00005235 Record.clear();
Chris Lattner0e6c9402013-01-20 02:38:54 +00005236 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00005237 Expected<unsigned> MaybeRecCode =
5238 Stream.readRecord(Entry.ID, Record, &Blob);
5239 if (!MaybeRecCode) {
5240 // FIXME this drops the error.
5241 return Failure;
5242 }
5243 switch ((ControlRecordTypes)MaybeRecCode.get()) {
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00005244 case METADATA:
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005245 if (Record[0] != VERSION_MAJOR)
5246 return true;
Douglas Gregorbf7fc9c2013-03-27 16:47:18 +00005247 if (Listener.ReadFullVersionInformation(Blob))
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005248 return true;
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005249 break;
Ben Langmuir4f5212a2014-04-14 22:12:44 +00005250 case MODULE_NAME:
5251 Listener.ReadModuleName(Blob);
5252 break;
Richard Smith7ed1bc92014-12-05 22:42:13 +00005253 case MODULE_DIRECTORY:
Benjamin Krameradcd0262020-01-28 20:23:46 +01005254 ModuleDir = std::string(Blob);
Richard Smith7ed1bc92014-12-05 22:42:13 +00005255 break;
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00005256 case MODULE_MAP_FILE: {
5257 unsigned Idx = 0;
Richard Smith7ed1bc92014-12-05 22:42:13 +00005258 auto Path = ReadString(Record, Idx);
5259 ResolveImportedPath(Path, ModuleDir);
5260 Listener.ReadModuleMapFile(Path);
Ben Langmuir4f5212a2014-04-14 22:12:44 +00005261 break;
Ben Langmuir4b8a9e92014-08-12 16:42:33 +00005262 }
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005263 case INPUT_FILE_OFFSETS: {
5264 if (!NeedsInputFiles)
5265 break;
5266
5267 unsigned NumInputFiles = Record[0];
5268 unsigned NumUserFiles = Record[1];
Raphael Isemanneb13d3d2018-05-23 09:02:40 +00005269 const llvm::support::unaligned_uint64_t *InputFileOffs =
5270 (const llvm::support::unaligned_uint64_t *)Blob.data();
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005271 for (unsigned I = 0; I != NumInputFiles; ++I) {
5272 // Go find this input file.
5273 bool isSystemFile = I >= NumUserFiles;
Ben Langmuircb69b572014-03-07 06:40:32 +00005274
5275 if (isSystemFile && !NeedsSystemInputFiles)
5276 break; // the rest are system input files
5277
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005278 BitstreamCursor &Cursor = InputFilesCursor;
5279 SavedStreamPosition SavedPosition(Cursor);
JF Bastien0e828952019-06-26 19:50:12 +00005280 if (llvm::Error Err = Cursor.JumpToBit(InputFileOffs[I])) {
5281 // FIXME this drops errors on the floor.
5282 consumeError(std::move(Err));
5283 }
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005284
JF Bastien0e828952019-06-26 19:50:12 +00005285 Expected<unsigned> MaybeCode = Cursor.ReadCode();
5286 if (!MaybeCode) {
5287 // FIXME this drops errors on the floor.
5288 consumeError(MaybeCode.takeError());
5289 }
5290 unsigned Code = MaybeCode.get();
5291
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005292 RecordData Record;
5293 StringRef Blob;
5294 bool shouldContinue = false;
JF Bastien0e828952019-06-26 19:50:12 +00005295 Expected<unsigned> MaybeRecordType =
5296 Cursor.readRecord(Code, Record, &Blob);
5297 if (!MaybeRecordType) {
5298 // FIXME this drops errors on the floor.
5299 consumeError(MaybeRecordType.takeError());
5300 }
5301 switch ((InputFileRecordTypes)MaybeRecordType.get()) {
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +00005302 case INPUT_FILE_HASH:
5303 break;
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005304 case INPUT_FILE:
Vedant Kumar48b4f762018-04-14 01:40:48 +00005305 bool Overridden = static_cast<bool>(Record[3]);
Benjamin Krameradcd0262020-01-28 20:23:46 +01005306 std::string Filename = std::string(Blob);
Richard Smith7ed1bc92014-12-05 22:42:13 +00005307 ResolveImportedPath(Filename, ModuleDir);
Richard Smith216a3bd2015-08-13 17:57:10 +00005308 shouldContinue = Listener.visitInputFile(
5309 Filename, isSystemFile, Overridden, /*IsExplicitModule*/false);
Argyrios Kyrtzidisc4cd2c42013-05-06 19:23:40 +00005310 break;
5311 }
5312 if (!shouldContinue)
5313 break;
5314 }
5315 break;
5316 }
5317
Richard Smithd4b230b2014-10-27 23:01:16 +00005318 case IMPORTS: {
5319 if (!NeedsImports)
5320 break;
5321
5322 unsigned Idx = 0, N = Record.size();
5323 while (Idx < N) {
5324 // Read information about the AST file.
Bruno Cardoso Lopes6fc8a562018-09-11 05:17:13 +00005325 Idx += 1+1+1+1+5; // Kind, ImportLoc, Size, ModTime, Signature
5326 std::string ModuleName = ReadString(Record, Idx);
Richard Smith7ed1bc92014-12-05 22:42:13 +00005327 std::string Filename = ReadString(Record, Idx);
5328 ResolveImportedPath(Filename, ModuleDir);
Bruno Cardoso Lopes6fc8a562018-09-11 05:17:13 +00005329 Listener.visitImport(ModuleName, Filename);
Richard Smithd4b230b2014-10-27 23:01:16 +00005330 }
5331 break;
5332 }
5333
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005334 default:
5335 // No other validation to perform.
5336 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00005337 }
5338 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005339
5340 // Look for module file extension blocks, if requested.
5341 if (FindModuleFileExtensions) {
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00005342 BitstreamCursor SavedStream = Stream;
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005343 while (!SkipCursorToBlock(Stream, EXTENSION_BLOCK_ID)) {
5344 bool DoneWithExtensionBlock = false;
5345 while (!DoneWithExtensionBlock) {
JF Bastien0e828952019-06-26 19:50:12 +00005346 Expected<llvm::BitstreamEntry> MaybeEntry = Stream.advance();
5347 if (!MaybeEntry) {
5348 // FIXME this drops the error.
5349 return true;
5350 }
5351 llvm::BitstreamEntry Entry = MaybeEntry.get();
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005352
JF Bastien0e828952019-06-26 19:50:12 +00005353 switch (Entry.Kind) {
5354 case llvm::BitstreamEntry::SubBlock:
5355 if (llvm::Error Err = Stream.SkipBlock()) {
5356 // FIXME this drops the error on the floor.
5357 consumeError(std::move(Err));
5358 return true;
5359 }
5360 continue;
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005361
JF Bastien0e828952019-06-26 19:50:12 +00005362 case llvm::BitstreamEntry::EndBlock:
5363 DoneWithExtensionBlock = true;
5364 continue;
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005365
JF Bastien0e828952019-06-26 19:50:12 +00005366 case llvm::BitstreamEntry::Error:
5367 return true;
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005368
JF Bastien0e828952019-06-26 19:50:12 +00005369 case llvm::BitstreamEntry::Record:
5370 break;
5371 }
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005372
5373 Record.clear();
5374 StringRef Blob;
JF Bastien0e828952019-06-26 19:50:12 +00005375 Expected<unsigned> MaybeRecCode =
5376 Stream.readRecord(Entry.ID, Record, &Blob);
5377 if (!MaybeRecCode) {
5378 // FIXME this drops the error.
5379 return true;
5380 }
5381 switch (MaybeRecCode.get()) {
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005382 case EXTENSION_METADATA: {
5383 ModuleFileExtensionMetadata Metadata;
5384 if (parseModuleFileExtensionMetadata(Record, Blob, Metadata))
5385 return true;
5386
5387 Listener.readModuleFileExtension(Metadata);
5388 break;
5389 }
5390 }
5391 }
5392 }
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00005393 Stream = SavedStream;
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005394 }
5395
Duncan P. N. Exon Smith60fa2882017-03-13 18:45:08 +00005396 // Scan for the UNHASHED_CONTROL_BLOCK_ID block.
5397 if (readUnhashedControlBlockImpl(
5398 nullptr, Bytes, ARR_ConfigurationMismatch | ARR_OutOfDate,
5399 /*AllowCompatibleConfigurationMismatch*/ false, &Listener,
5400 ValidateDiagnosticOptions) != Success)
5401 return true;
5402
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005403 return false;
Guy Benyei11169dd2012-12-18 14:30:41 +00005404}
5405
Benjamin Kramerf6021ec2017-03-21 21:35:04 +00005406bool ASTReader::isAcceptableASTFile(StringRef Filename, FileManager &FileMgr,
5407 const PCHContainerReader &PCHContainerRdr,
5408 const LangOptions &LangOpts,
5409 const TargetOptions &TargetOpts,
5410 const PreprocessorOptions &PPOpts,
5411 StringRef ExistingModuleCachePath) {
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +00005412 SimplePCHValidator validator(LangOpts, TargetOpts, PPOpts,
5413 ExistingModuleCachePath, FileMgr);
Adrian Prantlfb2398d2015-07-17 01:19:54 +00005414 return !readASTFileControlBlock(Filename, FileMgr, PCHContainerRdr,
Douglas Gregor6623e1f2015-11-03 18:33:07 +00005415 /*FindModuleFileExtensions=*/false,
Manman Ren47a44452016-07-26 17:12:17 +00005416 validator,
5417 /*ValidateDiagnosticOptions=*/true);
Guy Benyei11169dd2012-12-18 14:30:41 +00005418}
5419
Ben Langmuir2c9af442014-04-10 17:57:43 +00005420ASTReader::ASTReadResult
5421ASTReader::ReadSubmoduleBlock(ModuleFile &F, unsigned ClientLoadCapabilities) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005422 // Enter the submodule block.
JF Bastien0e828952019-06-26 19:50:12 +00005423 if (llvm::Error Err = F.Stream.EnterSubBlock(SUBMODULE_BLOCK_ID)) {
5424 Error(std::move(Err));
Ben Langmuir2c9af442014-04-10 17:57:43 +00005425 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00005426 }
5427
5428 ModuleMap &ModMap = PP.getHeaderSearchInfo().getModuleMap();
5429 bool First = true;
Craig Toppera13603a2014-05-22 05:54:18 +00005430 Module *CurrentModule = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00005431 RecordData Record;
5432 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00005433 Expected<llvm::BitstreamEntry> MaybeEntry =
5434 F.Stream.advanceSkippingSubblocks();
5435 if (!MaybeEntry) {
5436 Error(MaybeEntry.takeError());
5437 return Failure;
5438 }
5439 llvm::BitstreamEntry Entry = MaybeEntry.get();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005440
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005441 switch (Entry.Kind) {
5442 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
5443 case llvm::BitstreamEntry::Error:
5444 Error("malformed block record in AST file");
Ben Langmuir2c9af442014-04-10 17:57:43 +00005445 return Failure;
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005446 case llvm::BitstreamEntry::EndBlock:
Ben Langmuir2c9af442014-04-10 17:57:43 +00005447 return Success;
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005448 case llvm::BitstreamEntry::Record:
5449 // The interesting case.
5450 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00005451 }
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005452
Guy Benyei11169dd2012-12-18 14:30:41 +00005453 // Read a record.
Chris Lattner0e6c9402013-01-20 02:38:54 +00005454 StringRef Blob;
Guy Benyei11169dd2012-12-18 14:30:41 +00005455 Record.clear();
JF Bastien0e828952019-06-26 19:50:12 +00005456 Expected<unsigned> MaybeKind = F.Stream.readRecord(Entry.ID, Record, &Blob);
5457 if (!MaybeKind) {
5458 Error(MaybeKind.takeError());
5459 return Failure;
5460 }
5461 unsigned Kind = MaybeKind.get();
Richard Smith03478d92014-10-23 22:12:14 +00005462
5463 if ((Kind == SUBMODULE_METADATA) != First) {
5464 Error("submodule metadata record should be at beginning of block");
5465 return Failure;
5466 }
5467 First = false;
5468
5469 // Submodule information is only valid if we have a current module.
5470 // FIXME: Should we error on these cases?
5471 if (!CurrentModule && Kind != SUBMODULE_METADATA &&
5472 Kind != SUBMODULE_DEFINITION)
5473 continue;
5474
5475 switch (Kind) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005476 default: // Default behavior: ignore.
5477 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00005478
Richard Smith03478d92014-10-23 22:12:14 +00005479 case SUBMODULE_DEFINITION: {
Jordan Rose90b0a1f2018-04-20 17:16:04 +00005480 if (Record.size() < 12) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005481 Error("malformed module definition");
Ben Langmuir2c9af442014-04-10 17:57:43 +00005482 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00005483 }
Richard Smith03478d92014-10-23 22:12:14 +00005484
Chris Lattner0e6c9402013-01-20 02:38:54 +00005485 StringRef Name = Blob;
Richard Smith9bca2982014-03-08 00:03:56 +00005486 unsigned Idx = 0;
5487 SubmoduleID GlobalID = getGlobalSubmoduleID(F, Record[Idx++]);
5488 SubmoduleID Parent = getGlobalSubmoduleID(F, Record[Idx++]);
Vedant Kumar48b4f762018-04-14 01:40:48 +00005489 Module::ModuleKind Kind = (Module::ModuleKind)Record[Idx++];
Richard Smith9bca2982014-03-08 00:03:56 +00005490 bool IsFramework = Record[Idx++];
5491 bool IsExplicit = Record[Idx++];
5492 bool IsSystem = Record[Idx++];
5493 bool IsExternC = Record[Idx++];
5494 bool InferSubmodules = Record[Idx++];
5495 bool InferExplicitSubmodules = Record[Idx++];
5496 bool InferExportWildcard = Record[Idx++];
5497 bool ConfigMacrosExhaustive = Record[Idx++];
Jordan Rose90b0a1f2018-04-20 17:16:04 +00005498 bool ModuleMapIsPrivate = Record[Idx++];
Douglas Gregor8d932422013-03-20 03:59:18 +00005499
Ben Langmuirbeee15e2014-04-14 18:00:01 +00005500 Module *ParentModule = nullptr;
Ben Langmuir9d6448b2014-08-09 00:57:23 +00005501 if (Parent)
Guy Benyei11169dd2012-12-18 14:30:41 +00005502 ParentModule = getSubmodule(Parent);
Ben Langmuirbeee15e2014-04-14 18:00:01 +00005503
Guy Benyei11169dd2012-12-18 14:30:41 +00005504 // Retrieve this (sub)module from the module map, creating it if
5505 // necessary.
David Blaikie9ffe5a32017-01-30 05:00:26 +00005506 CurrentModule =
5507 ModMap.findOrCreateModule(Name, ParentModule, IsFramework, IsExplicit)
5508 .first;
Ben Langmuir9d6448b2014-08-09 00:57:23 +00005509
5510 // FIXME: set the definition loc for CurrentModule, or call
5511 // ModMap.setInferredModuleAllowedBy()
5512
Guy Benyei11169dd2012-12-18 14:30:41 +00005513 SubmoduleID GlobalIndex = GlobalID - NUM_PREDEF_SUBMODULE_IDS;
5514 if (GlobalIndex >= SubmodulesLoaded.size() ||
5515 SubmodulesLoaded[GlobalIndex]) {
5516 Error("too many submodules");
Ben Langmuir2c9af442014-04-10 17:57:43 +00005517 return Failure;
Guy Benyei11169dd2012-12-18 14:30:41 +00005518 }
Douglas Gregor8a114ab2013-02-06 22:40:31 +00005519
Douglas Gregor7029ce12013-03-19 00:28:20 +00005520 if (!ParentModule) {
5521 if (const FileEntry *CurFile = CurrentModule->getASTFile()) {
Yuka Takahashid8baec22018-08-01 09:50:02 +00005522 // Don't emit module relocation error if we have -fno-validate-pch
5523 if (!PP.getPreprocessorOpts().DisablePCHValidation &&
5524 CurFile != F.File) {
Duncan P. N. Exon Smitheef69022019-11-10 11:17:42 -08005525 Error(diag::err_module_file_conflict,
5526 CurrentModule->getTopLevelModuleName(), CurFile->getName(),
5527 F.File->getName());
Ben Langmuir2c9af442014-04-10 17:57:43 +00005528 return Failure;
Douglas Gregor8a114ab2013-02-06 22:40:31 +00005529 }
Douglas Gregor8a114ab2013-02-06 22:40:31 +00005530 }
Douglas Gregor7029ce12013-03-19 00:28:20 +00005531
Duncan P. N. Exon Smith83dcb342019-11-10 13:14:52 -08005532 F.DidReadTopLevelSubmodule = true;
Douglas Gregor7029ce12013-03-19 00:28:20 +00005533 CurrentModule->setASTFile(F.File);
Richard Smithab755972017-06-05 18:10:11 +00005534 CurrentModule->PresumedModuleMapFile = F.ModuleMapPath;
Douglas Gregor8a114ab2013-02-06 22:40:31 +00005535 }
Ben Langmuirbeee15e2014-04-14 18:00:01 +00005536
Richard Smithdd8b5332017-09-04 05:37:53 +00005537 CurrentModule->Kind = Kind;
Adrian Prantl15bcf702015-06-30 17:39:43 +00005538 CurrentModule->Signature = F.Signature;
Guy Benyei11169dd2012-12-18 14:30:41 +00005539 CurrentModule->IsFromModuleFile = true;
5540 CurrentModule->IsSystem = IsSystem || CurrentModule->IsSystem;
Richard Smith9bca2982014-03-08 00:03:56 +00005541 CurrentModule->IsExternC = IsExternC;
Guy Benyei11169dd2012-12-18 14:30:41 +00005542 CurrentModule->InferSubmodules = InferSubmodules;
5543 CurrentModule->InferExplicitSubmodules = InferExplicitSubmodules;
5544 CurrentModule->InferExportWildcard = InferExportWildcard;
Douglas Gregor8d932422013-03-20 03:59:18 +00005545 CurrentModule->ConfigMacrosExhaustive = ConfigMacrosExhaustive;
Jordan Rose90b0a1f2018-04-20 17:16:04 +00005546 CurrentModule->ModuleMapIsPrivate = ModuleMapIsPrivate;
Guy Benyei11169dd2012-12-18 14:30:41 +00005547 if (DeserializationListener)
5548 DeserializationListener->ModuleRead(GlobalID, CurrentModule);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005549
Guy Benyei11169dd2012-12-18 14:30:41 +00005550 SubmodulesLoaded[GlobalIndex] = CurrentModule;
Douglas Gregor6ddfca92013-01-14 17:21:00 +00005551
Richard Smith8a3e39a2016-03-28 21:31:09 +00005552 // Clear out data that will be replaced by what is in the module file.
Douglas Gregor6ddfca92013-01-14 17:21:00 +00005553 CurrentModule->LinkLibraries.clear();
Douglas Gregor8d932422013-03-20 03:59:18 +00005554 CurrentModule->ConfigMacros.clear();
Douglas Gregorfb912652013-03-20 21:10:35 +00005555 CurrentModule->UnresolvedConflicts.clear();
5556 CurrentModule->Conflicts.clear();
Richard Smith8a3e39a2016-03-28 21:31:09 +00005557
5558 // The module is available unless it's missing a requirement; relevant
5559 // requirements will be (re-)added by SUBMODULE_REQUIRES records.
5560 // Missing headers that were present when the module was built do not
5561 // make it unavailable -- if we got this far, this must be an explicitly
5562 // imported module file.
5563 CurrentModule->Requirements.clear();
5564 CurrentModule->MissingHeaders.clear();
Richard Smithfc76b4a2020-04-17 16:23:41 -07005565 CurrentModule->IsUnimportable =
5566 ParentModule && ParentModule->IsUnimportable;
5567 CurrentModule->IsAvailable = !CurrentModule->IsUnimportable;
Guy Benyei11169dd2012-12-18 14:30:41 +00005568 break;
5569 }
Richard Smith8a3e39a2016-03-28 21:31:09 +00005570
Guy Benyei11169dd2012-12-18 14:30:41 +00005571 case SUBMODULE_UMBRELLA_HEADER: {
Benjamin Krameradcd0262020-01-28 20:23:46 +01005572 std::string Filename = std::string(Blob);
Richard Smith2b63d152015-05-16 02:28:53 +00005573 ResolveImportedPath(F, Filename);
Harlan Haskins8d323d12019-08-01 21:31:56 +00005574 if (auto Umbrella = PP.getFileManager().getFile(Filename)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005575 if (!CurrentModule->getUmbrellaHeader())
Harlan Haskins8d323d12019-08-01 21:31:56 +00005576 ModMap.setUmbrellaHeader(CurrentModule, *Umbrella, Blob);
5577 else if (CurrentModule->getUmbrellaHeader().Entry != *Umbrella) {
Bruno Cardoso Lopes573b13f2017-03-22 00:11:21 +00005578 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
5579 Error("mismatched umbrella headers in submodule");
5580 return OutOfDate;
Guy Benyei11169dd2012-12-18 14:30:41 +00005581 }
5582 }
5583 break;
5584 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005585
Richard Smith202210b2014-10-24 20:23:01 +00005586 case SUBMODULE_HEADER:
5587 case SUBMODULE_EXCLUDED_HEADER:
5588 case SUBMODULE_PRIVATE_HEADER:
5589 // We lazily associate headers with their modules via the HeaderInfo table.
Argyrios Kyrtzidisb146baa2013-03-13 21:13:51 +00005590 // FIXME: Re-evaluate this section; maybe only store InputFile IDs instead
5591 // of complete filenames or remove it entirely.
Richard Smith202210b2014-10-24 20:23:01 +00005592 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00005593
Richard Smith202210b2014-10-24 20:23:01 +00005594 case SUBMODULE_TEXTUAL_HEADER:
5595 case SUBMODULE_PRIVATE_TEXTUAL_HEADER:
5596 // FIXME: Textual headers are not marked in the HeaderInfo table. Load
5597 // them here.
5598 break;
Lawrence Crowlb53e5482013-06-20 21:14:14 +00005599
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00005600 case SUBMODULE_TOPHEADER:
Argyrios Kyrtzidis3c5305c2013-03-13 21:13:43 +00005601 CurrentModule->addTopHeaderFilename(Blob);
Guy Benyei11169dd2012-12-18 14:30:41 +00005602 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00005603
5604 case SUBMODULE_UMBRELLA_DIR: {
Benjamin Krameradcd0262020-01-28 20:23:46 +01005605 std::string Dirname = std::string(Blob);
Richard Smith2b63d152015-05-16 02:28:53 +00005606 ResolveImportedPath(F, Dirname);
Harlan Haskins8d323d12019-08-01 21:31:56 +00005607 if (auto Umbrella = PP.getFileManager().getDirectory(Dirname)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005608 if (!CurrentModule->getUmbrellaDir())
Harlan Haskins8d323d12019-08-01 21:31:56 +00005609 ModMap.setUmbrellaDir(CurrentModule, *Umbrella, Blob);
5610 else if (CurrentModule->getUmbrellaDir().Entry != *Umbrella) {
Ben Langmuir2c9af442014-04-10 17:57:43 +00005611 if ((ClientLoadCapabilities & ARR_OutOfDate) == 0)
5612 Error("mismatched umbrella directories in submodule");
5613 return OutOfDate;
Guy Benyei11169dd2012-12-18 14:30:41 +00005614 }
5615 }
5616 break;
5617 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005618
Guy Benyei11169dd2012-12-18 14:30:41 +00005619 case SUBMODULE_METADATA: {
Guy Benyei11169dd2012-12-18 14:30:41 +00005620 F.BaseSubmoduleID = getTotalNumSubmodules();
5621 F.LocalNumSubmodules = Record[0];
5622 unsigned LocalBaseSubmoduleID = Record[1];
5623 if (F.LocalNumSubmodules > 0) {
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005624 // Introduce the global -> local mapping for submodules within this
Guy Benyei11169dd2012-12-18 14:30:41 +00005625 // module.
5626 GlobalSubmoduleMap.insert(std::make_pair(getTotalNumSubmodules()+1,&F));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005627
5628 // Introduce the local -> global mapping for submodules within this
Guy Benyei11169dd2012-12-18 14:30:41 +00005629 // module.
5630 F.SubmoduleRemap.insertOrReplace(
5631 std::make_pair(LocalBaseSubmoduleID,
5632 F.BaseSubmoduleID - LocalBaseSubmoduleID));
Ben Langmuirfe971d92014-08-16 04:54:18 +00005633
Ben Langmuir52ca6782014-10-20 16:27:32 +00005634 SubmodulesLoaded.resize(SubmodulesLoaded.size() + F.LocalNumSubmodules);
5635 }
Guy Benyei11169dd2012-12-18 14:30:41 +00005636 break;
5637 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005638
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00005639 case SUBMODULE_IMPORTS:
Guy Benyei11169dd2012-12-18 14:30:41 +00005640 for (unsigned Idx = 0; Idx != Record.size(); ++Idx) {
Douglas Gregorfb912652013-03-20 21:10:35 +00005641 UnresolvedModuleRef Unresolved;
Guy Benyei11169dd2012-12-18 14:30:41 +00005642 Unresolved.File = &F;
5643 Unresolved.Mod = CurrentModule;
5644 Unresolved.ID = Record[Idx];
Douglas Gregorfb912652013-03-20 21:10:35 +00005645 Unresolved.Kind = UnresolvedModuleRef::Import;
Guy Benyei11169dd2012-12-18 14:30:41 +00005646 Unresolved.IsWildcard = false;
Douglas Gregorfb912652013-03-20 21:10:35 +00005647 UnresolvedModuleRefs.push_back(Unresolved);
Guy Benyei11169dd2012-12-18 14:30:41 +00005648 }
5649 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00005650
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00005651 case SUBMODULE_EXPORTS:
Guy Benyei11169dd2012-12-18 14:30:41 +00005652 for (unsigned Idx = 0; Idx + 1 < Record.size(); Idx += 2) {
Douglas Gregorfb912652013-03-20 21:10:35 +00005653 UnresolvedModuleRef Unresolved;
Guy Benyei11169dd2012-12-18 14:30:41 +00005654 Unresolved.File = &F;
5655 Unresolved.Mod = CurrentModule;
5656 Unresolved.ID = Record[Idx];
Douglas Gregorfb912652013-03-20 21:10:35 +00005657 Unresolved.Kind = UnresolvedModuleRef::Export;
Guy Benyei11169dd2012-12-18 14:30:41 +00005658 Unresolved.IsWildcard = Record[Idx + 1];
Douglas Gregorfb912652013-03-20 21:10:35 +00005659 UnresolvedModuleRefs.push_back(Unresolved);
Guy Benyei11169dd2012-12-18 14:30:41 +00005660 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005661
5662 // Once we've loaded the set of exports, there's no reason to keep
Guy Benyei11169dd2012-12-18 14:30:41 +00005663 // the parsed, unresolved exports around.
5664 CurrentModule->UnresolvedExports.clear();
5665 break;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00005666
5667 case SUBMODULE_REQUIRES:
Richard Smithdbafb6c2017-06-29 23:23:46 +00005668 CurrentModule->addRequirement(Blob, Record[0], PP.getLangOpts(),
5669 PP.getTargetInfo());
Guy Benyei11169dd2012-12-18 14:30:41 +00005670 break;
Douglas Gregor6ddfca92013-01-14 17:21:00 +00005671
5672 case SUBMODULE_LINK_LIBRARY:
Bruno Cardoso Lopesa3b5f712018-04-16 19:42:32 +00005673 ModMap.resolveLinkAsDependencies(CurrentModule);
Douglas Gregor6ddfca92013-01-14 17:21:00 +00005674 CurrentModule->LinkLibraries.push_back(
Benjamin Krameradcd0262020-01-28 20:23:46 +01005675 Module::LinkLibrary(std::string(Blob), Record[0]));
Douglas Gregor6ddfca92013-01-14 17:21:00 +00005676 break;
Douglas Gregor35b13ec2013-03-20 00:22:05 +00005677
5678 case SUBMODULE_CONFIG_MACRO:
Douglas Gregor35b13ec2013-03-20 00:22:05 +00005679 CurrentModule->ConfigMacros.push_back(Blob.str());
5680 break;
Douglas Gregorfb912652013-03-20 21:10:35 +00005681
5682 case SUBMODULE_CONFLICT: {
Douglas Gregorfb912652013-03-20 21:10:35 +00005683 UnresolvedModuleRef Unresolved;
5684 Unresolved.File = &F;
5685 Unresolved.Mod = CurrentModule;
5686 Unresolved.ID = Record[0];
5687 Unresolved.Kind = UnresolvedModuleRef::Conflict;
5688 Unresolved.IsWildcard = false;
5689 Unresolved.String = Blob;
5690 UnresolvedModuleRefs.push_back(Unresolved);
5691 break;
5692 }
Richard Smithdc1f0422016-07-20 19:10:16 +00005693
Douglas Gregorf0b11de2017-09-14 23:38:44 +00005694 case SUBMODULE_INITIALIZERS: {
Richard Smithdbafb6c2017-06-29 23:23:46 +00005695 if (!ContextObj)
5696 break;
Richard Smithdc1f0422016-07-20 19:10:16 +00005697 SmallVector<uint32_t, 16> Inits;
5698 for (auto &ID : Record)
5699 Inits.push_back(getGlobalDeclID(F, ID));
Richard Smithdbafb6c2017-06-29 23:23:46 +00005700 ContextObj->addLazyModuleInitializers(CurrentModule, Inits);
Richard Smithdc1f0422016-07-20 19:10:16 +00005701 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00005702 }
Douglas Gregorf0b11de2017-09-14 23:38:44 +00005703
5704 case SUBMODULE_EXPORT_AS:
5705 CurrentModule->ExportAsModule = Blob.str();
Bruno Cardoso Lopesa3b5f712018-04-16 19:42:32 +00005706 ModMap.addLinkAsDependency(CurrentModule);
Douglas Gregorf0b11de2017-09-14 23:38:44 +00005707 break;
5708 }
Guy Benyei11169dd2012-12-18 14:30:41 +00005709 }
5710}
5711
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00005712/// Parse the record that corresponds to a LangOptions data
Guy Benyei11169dd2012-12-18 14:30:41 +00005713/// structure.
5714///
5715/// This routine parses the language options from the AST file and then gives
5716/// them to the AST listener if one is set.
5717///
5718/// \returns true if the listener deems the file unacceptable, false otherwise.
5719bool ASTReader::ParseLanguageOptions(const RecordData &Record,
5720 bool Complain,
Richard Smith1e2cf0d2014-10-31 02:28:58 +00005721 ASTReaderListener &Listener,
5722 bool AllowCompatibleDifferences) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005723 LangOptions LangOpts;
5724 unsigned Idx = 0;
5725#define LANGOPT(Name, Bits, Default, Description) \
5726 LangOpts.Name = Record[Idx++];
5727#define ENUM_LANGOPT(Name, Type, Bits, Default, Description) \
5728 LangOpts.set##Name(static_cast<LangOptions::Type>(Record[Idx++]));
5729#include "clang/Basic/LangOptions.def"
Alexey Samsonovedf99a92014-11-07 22:29:38 +00005730#define SANITIZER(NAME, ID) \
5731 LangOpts.Sanitize.set(SanitizerKind::ID, Record[Idx++]);
Will Dietzf54319c2013-01-18 11:30:38 +00005732#include "clang/Basic/Sanitizers.def"
Guy Benyei11169dd2012-12-18 14:30:41 +00005733
Ben Langmuircd98cb72015-06-23 18:20:18 +00005734 for (unsigned N = Record[Idx++]; N; --N)
5735 LangOpts.ModuleFeatures.push_back(ReadString(Record, Idx));
5736
Vedant Kumar48b4f762018-04-14 01:40:48 +00005737 ObjCRuntime::Kind runtimeKind = (ObjCRuntime::Kind) Record[Idx++];
Guy Benyei11169dd2012-12-18 14:30:41 +00005738 VersionTuple runtimeVersion = ReadVersionTuple(Record, Idx);
5739 LangOpts.ObjCRuntime = ObjCRuntime(runtimeKind, runtimeVersion);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005740
Ben Langmuird4a667a2015-06-23 18:20:23 +00005741 LangOpts.CurrentModule = ReadString(Record, Idx);
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005742
5743 // Comment options.
5744 for (unsigned N = Record[Idx++]; N; --N) {
5745 LangOpts.CommentOpts.BlockCommandNames.push_back(
5746 ReadString(Record, Idx));
5747 }
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00005748 LangOpts.CommentOpts.ParseAllComments = Record[Idx++];
Dmitri Gribenkoacf2e782013-02-22 14:21:27 +00005749
Samuel Antaoee8fb302016-01-06 13:42:12 +00005750 // OpenMP offloading options.
5751 for (unsigned N = Record[Idx++]; N; --N) {
5752 LangOpts.OMPTargetTriples.push_back(llvm::Triple(ReadString(Record, Idx)));
5753 }
5754
5755 LangOpts.OMPHostIRFile = ReadString(Record, Idx);
5756
Richard Smith1e2cf0d2014-10-31 02:28:58 +00005757 return Listener.ReadLanguageOptions(LangOpts, Complain,
5758 AllowCompatibleDifferences);
Guy Benyei11169dd2012-12-18 14:30:41 +00005759}
5760
Chandler Carruth0d745bc2015-03-14 04:47:43 +00005761bool ASTReader::ParseTargetOptions(const RecordData &Record, bool Complain,
5762 ASTReaderListener &Listener,
5763 bool AllowCompatibleDifferences) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005764 unsigned Idx = 0;
5765 TargetOptions TargetOpts;
5766 TargetOpts.Triple = ReadString(Record, Idx);
5767 TargetOpts.CPU = ReadString(Record, Idx);
5768 TargetOpts.ABI = ReadString(Record, Idx);
Guy Benyei11169dd2012-12-18 14:30:41 +00005769 for (unsigned N = Record[Idx++]; N; --N) {
5770 TargetOpts.FeaturesAsWritten.push_back(ReadString(Record, Idx));
5771 }
5772 for (unsigned N = Record[Idx++]; N; --N) {
5773 TargetOpts.Features.push_back(ReadString(Record, Idx));
5774 }
5775
Chandler Carruth0d745bc2015-03-14 04:47:43 +00005776 return Listener.ReadTargetOptions(TargetOpts, Complain,
5777 AllowCompatibleDifferences);
Guy Benyei11169dd2012-12-18 14:30:41 +00005778}
5779
5780bool ASTReader::ParseDiagnosticOptions(const RecordData &Record, bool Complain,
5781 ASTReaderListener &Listener) {
Ben Langmuirb92de022014-04-29 16:25:26 +00005782 IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts(new DiagnosticOptions);
Guy Benyei11169dd2012-12-18 14:30:41 +00005783 unsigned Idx = 0;
Ben Langmuirb92de022014-04-29 16:25:26 +00005784#define DIAGOPT(Name, Bits, Default) DiagOpts->Name = Record[Idx++];
Guy Benyei11169dd2012-12-18 14:30:41 +00005785#define ENUM_DIAGOPT(Name, Type, Bits, Default) \
Ben Langmuirb92de022014-04-29 16:25:26 +00005786 DiagOpts->set##Name(static_cast<Type>(Record[Idx++]));
Guy Benyei11169dd2012-12-18 14:30:41 +00005787#include "clang/Basic/DiagnosticOptions.def"
5788
Richard Smith3be1cb22014-08-07 00:24:21 +00005789 for (unsigned N = Record[Idx++]; N; --N)
Ben Langmuirb92de022014-04-29 16:25:26 +00005790 DiagOpts->Warnings.push_back(ReadString(Record, Idx));
Richard Smith3be1cb22014-08-07 00:24:21 +00005791 for (unsigned N = Record[Idx++]; N; --N)
5792 DiagOpts->Remarks.push_back(ReadString(Record, Idx));
Guy Benyei11169dd2012-12-18 14:30:41 +00005793
5794 return Listener.ReadDiagnosticOptions(DiagOpts, Complain);
5795}
5796
5797bool ASTReader::ParseFileSystemOptions(const RecordData &Record, bool Complain,
5798 ASTReaderListener &Listener) {
5799 FileSystemOptions FSOpts;
5800 unsigned Idx = 0;
5801 FSOpts.WorkingDir = ReadString(Record, Idx);
5802 return Listener.ReadFileSystemOptions(FSOpts, Complain);
5803}
5804
5805bool ASTReader::ParseHeaderSearchOptions(const RecordData &Record,
5806 bool Complain,
5807 ASTReaderListener &Listener) {
5808 HeaderSearchOptions HSOpts;
5809 unsigned Idx = 0;
5810 HSOpts.Sysroot = ReadString(Record, Idx);
5811
5812 // Include entries.
5813 for (unsigned N = Record[Idx++]; N; --N) {
5814 std::string Path = ReadString(Record, Idx);
Vedant Kumar48b4f762018-04-14 01:40:48 +00005815 frontend::IncludeDirGroup Group
5816 = static_cast<frontend::IncludeDirGroup>(Record[Idx++]);
Guy Benyei11169dd2012-12-18 14:30:41 +00005817 bool IsFramework = Record[Idx++];
5818 bool IgnoreSysRoot = Record[Idx++];
Benjamin Kramer3204b152015-05-29 19:42:19 +00005819 HSOpts.UserEntries.emplace_back(std::move(Path), Group, IsFramework,
5820 IgnoreSysRoot);
Guy Benyei11169dd2012-12-18 14:30:41 +00005821 }
5822
5823 // System header prefixes.
5824 for (unsigned N = Record[Idx++]; N; --N) {
5825 std::string Prefix = ReadString(Record, Idx);
5826 bool IsSystemHeader = Record[Idx++];
Benjamin Kramer3204b152015-05-29 19:42:19 +00005827 HSOpts.SystemHeaderPrefixes.emplace_back(std::move(Prefix), IsSystemHeader);
Guy Benyei11169dd2012-12-18 14:30:41 +00005828 }
5829
5830 HSOpts.ResourceDir = ReadString(Record, Idx);
5831 HSOpts.ModuleCachePath = ReadString(Record, Idx);
Argyrios Kyrtzidis1594c152014-03-03 08:12:05 +00005832 HSOpts.ModuleUserBuildPath = ReadString(Record, Idx);
Guy Benyei11169dd2012-12-18 14:30:41 +00005833 HSOpts.DisableModuleHash = Record[Idx++];
Richard Smith18934752017-06-06 00:32:01 +00005834 HSOpts.ImplicitModuleMaps = Record[Idx++];
5835 HSOpts.ModuleMapFileHomeIsCwd = Record[Idx++];
Guy Benyei11169dd2012-12-18 14:30:41 +00005836 HSOpts.UseBuiltinIncludes = Record[Idx++];
5837 HSOpts.UseStandardSystemIncludes = Record[Idx++];
5838 HSOpts.UseStandardCXXIncludes = Record[Idx++];
5839 HSOpts.UseLibcxx = Record[Idx++];
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +00005840 std::string SpecificModuleCachePath = ReadString(Record, Idx);
Guy Benyei11169dd2012-12-18 14:30:41 +00005841
Argyrios Kyrtzidisbd0b6512015-02-19 20:12:20 +00005842 return Listener.ReadHeaderSearchOptions(HSOpts, SpecificModuleCachePath,
5843 Complain);
Guy Benyei11169dd2012-12-18 14:30:41 +00005844}
5845
5846bool ASTReader::ParsePreprocessorOptions(const RecordData &Record,
5847 bool Complain,
5848 ASTReaderListener &Listener,
5849 std::string &SuggestedPredefines) {
5850 PreprocessorOptions PPOpts;
5851 unsigned Idx = 0;
5852
5853 // Macro definitions/undefs
5854 for (unsigned N = Record[Idx++]; N; --N) {
5855 std::string Macro = ReadString(Record, Idx);
5856 bool IsUndef = Record[Idx++];
5857 PPOpts.Macros.push_back(std::make_pair(Macro, IsUndef));
5858 }
5859
5860 // Includes
5861 for (unsigned N = Record[Idx++]; N; --N) {
5862 PPOpts.Includes.push_back(ReadString(Record, Idx));
5863 }
5864
5865 // Macro Includes
5866 for (unsigned N = Record[Idx++]; N; --N) {
5867 PPOpts.MacroIncludes.push_back(ReadString(Record, Idx));
5868 }
5869
5870 PPOpts.UsePredefines = Record[Idx++];
Argyrios Kyrtzidisd3afa0c2013-04-26 21:33:40 +00005871 PPOpts.DetailedRecord = Record[Idx++];
Guy Benyei11169dd2012-12-18 14:30:41 +00005872 PPOpts.ImplicitPCHInclude = ReadString(Record, Idx);
Guy Benyei11169dd2012-12-18 14:30:41 +00005873 PPOpts.ObjCXXARCStandardLibrary =
5874 static_cast<ObjCXXARCStandardLibraryKind>(Record[Idx++]);
5875 SuggestedPredefines.clear();
5876 return Listener.ReadPreprocessorOptions(PPOpts, Complain,
5877 SuggestedPredefines);
5878}
5879
5880std::pair<ModuleFile *, unsigned>
5881ASTReader::getModulePreprocessedEntity(unsigned GlobalIndex) {
5882 GlobalPreprocessedEntityMapType::iterator
5883 I = GlobalPreprocessedEntityMap.find(GlobalIndex);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005884 assert(I != GlobalPreprocessedEntityMap.end() &&
Guy Benyei11169dd2012-12-18 14:30:41 +00005885 "Corrupted global preprocessed entity map");
5886 ModuleFile *M = I->second;
5887 unsigned LocalIndex = GlobalIndex - M->BasePreprocessedEntityID;
5888 return std::make_pair(M, LocalIndex);
5889}
5890
Benjamin Kramerb4ef6682015-02-06 17:25:10 +00005891llvm::iterator_range<PreprocessingRecord::iterator>
Guy Benyei11169dd2012-12-18 14:30:41 +00005892ASTReader::getModulePreprocessedEntities(ModuleFile &Mod) const {
5893 if (PreprocessingRecord *PPRec = PP.getPreprocessingRecord())
5894 return PPRec->getIteratorsForLoadedRange(Mod.BasePreprocessedEntityID,
5895 Mod.NumPreprocessedEntities);
5896
Benjamin Kramerb4ef6682015-02-06 17:25:10 +00005897 return llvm::make_range(PreprocessingRecord::iterator(),
5898 PreprocessingRecord::iterator());
Guy Benyei11169dd2012-12-18 14:30:41 +00005899}
5900
Benjamin Kramerb4ef6682015-02-06 17:25:10 +00005901llvm::iterator_range<ASTReader::ModuleDeclIterator>
Guy Benyei11169dd2012-12-18 14:30:41 +00005902ASTReader::getModuleFileLevelDecls(ModuleFile &Mod) {
Benjamin Kramerb4ef6682015-02-06 17:25:10 +00005903 return llvm::make_range(
5904 ModuleDeclIterator(this, &Mod, Mod.FileSortedDecls),
5905 ModuleDeclIterator(this, &Mod,
5906 Mod.FileSortedDecls + Mod.NumFileSortedDecls));
Guy Benyei11169dd2012-12-18 14:30:41 +00005907}
5908
Cameron Desrochersb60f1b62018-01-15 19:14:16 +00005909SourceRange ASTReader::ReadSkippedRange(unsigned GlobalIndex) {
5910 auto I = GlobalSkippedRangeMap.find(GlobalIndex);
5911 assert(I != GlobalSkippedRangeMap.end() &&
5912 "Corrupted global skipped range map");
5913 ModuleFile *M = I->second;
5914 unsigned LocalIndex = GlobalIndex - M->BasePreprocessedSkippedRangeID;
5915 assert(LocalIndex < M->NumPreprocessedSkippedRanges);
5916 PPSkippedRange RawRange = M->PreprocessedSkippedRangeOffsets[LocalIndex];
5917 SourceRange Range(TranslateSourceLocation(*M, RawRange.getBegin()),
5918 TranslateSourceLocation(*M, RawRange.getEnd()));
5919 assert(Range.isValid());
5920 return Range;
5921}
5922
Guy Benyei11169dd2012-12-18 14:30:41 +00005923PreprocessedEntity *ASTReader::ReadPreprocessedEntity(unsigned Index) {
5924 PreprocessedEntityID PPID = Index+1;
5925 std::pair<ModuleFile *, unsigned> PPInfo = getModulePreprocessedEntity(Index);
5926 ModuleFile &M = *PPInfo.first;
5927 unsigned LocalIndex = PPInfo.second;
5928 const PPEntityOffset &PPOffs = M.PreprocessedEntityOffsets[LocalIndex];
5929
Guy Benyei11169dd2012-12-18 14:30:41 +00005930 if (!PP.getPreprocessingRecord()) {
5931 Error("no preprocessing record");
Craig Toppera13603a2014-05-22 05:54:18 +00005932 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00005933 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005934
5935 SavedStreamPosition SavedPosition(M.PreprocessorDetailCursor);
Dmitry Polukhina7afb212020-04-16 09:24:46 -07005936 if (llvm::Error Err = M.PreprocessorDetailCursor.JumpToBit(
5937 M.MacroOffsetsBase + PPOffs.BitOffset)) {
JF Bastien0e828952019-06-26 19:50:12 +00005938 Error(std::move(Err));
5939 return nullptr;
5940 }
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005941
JF Bastien0e828952019-06-26 19:50:12 +00005942 Expected<llvm::BitstreamEntry> MaybeEntry =
5943 M.PreprocessorDetailCursor.advance(BitstreamCursor::AF_DontPopBlockAtEnd);
5944 if (!MaybeEntry) {
5945 Error(MaybeEntry.takeError());
5946 return nullptr;
5947 }
5948 llvm::BitstreamEntry Entry = MaybeEntry.get();
5949
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005950 if (Entry.Kind != llvm::BitstreamEntry::Record)
Craig Toppera13603a2014-05-22 05:54:18 +00005951 return nullptr;
Chris Lattner7fb3bef2013-01-20 00:56:42 +00005952
Guy Benyei11169dd2012-12-18 14:30:41 +00005953 // Read the record.
Richard Smithcb34bd32016-03-27 07:28:06 +00005954 SourceRange Range(TranslateSourceLocation(M, PPOffs.getBegin()),
5955 TranslateSourceLocation(M, PPOffs.getEnd()));
Guy Benyei11169dd2012-12-18 14:30:41 +00005956 PreprocessingRecord &PPRec = *PP.getPreprocessingRecord();
Chris Lattner0e6c9402013-01-20 02:38:54 +00005957 StringRef Blob;
Guy Benyei11169dd2012-12-18 14:30:41 +00005958 RecordData Record;
JF Bastien0e828952019-06-26 19:50:12 +00005959 Expected<unsigned> MaybeRecType =
5960 M.PreprocessorDetailCursor.readRecord(Entry.ID, Record, &Blob);
5961 if (!MaybeRecType) {
5962 Error(MaybeRecType.takeError());
5963 return nullptr;
5964 }
5965 switch ((PreprocessorDetailRecordTypes)MaybeRecType.get()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00005966 case PPD_MACRO_EXPANSION: {
5967 bool isBuiltin = Record[0];
Craig Toppera13603a2014-05-22 05:54:18 +00005968 IdentifierInfo *Name = nullptr;
Richard Smith66a81862015-05-04 02:25:31 +00005969 MacroDefinitionRecord *Def = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00005970 if (isBuiltin)
5971 Name = getLocalIdentifier(M, Record[1]);
5972 else {
Richard Smith66a81862015-05-04 02:25:31 +00005973 PreprocessedEntityID GlobalID =
5974 getGlobalPreprocessedEntityID(M, Record[1]);
5975 Def = cast<MacroDefinitionRecord>(
5976 PPRec.getLoadedPreprocessedEntity(GlobalID - 1));
Guy Benyei11169dd2012-12-18 14:30:41 +00005977 }
5978
5979 MacroExpansion *ME;
5980 if (isBuiltin)
5981 ME = new (PPRec) MacroExpansion(Name, Range);
5982 else
5983 ME = new (PPRec) MacroExpansion(Def, Range);
5984
5985 return ME;
5986 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005987
Guy Benyei11169dd2012-12-18 14:30:41 +00005988 case PPD_MACRO_DEFINITION: {
5989 // Decode the identifier info and then check again; if the macro is
5990 // still defined and associated with the identifier,
5991 IdentifierInfo *II = getLocalIdentifier(M, Record[0]);
Vedant Kumar48b4f762018-04-14 01:40:48 +00005992 MacroDefinitionRecord *MD = new (PPRec) MacroDefinitionRecord(II, Range);
Guy Benyei11169dd2012-12-18 14:30:41 +00005993
5994 if (DeserializationListener)
5995 DeserializationListener->MacroDefinitionRead(PPID, MD);
5996
5997 return MD;
5998 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00005999
Guy Benyei11169dd2012-12-18 14:30:41 +00006000 case PPD_INCLUSION_DIRECTIVE: {
Chris Lattner0e6c9402013-01-20 02:38:54 +00006001 const char *FullFileNameStart = Blob.data() + Record[0];
6002 StringRef FullFileName(FullFileNameStart, Blob.size() - Record[0]);
Craig Toppera13603a2014-05-22 05:54:18 +00006003 const FileEntry *File = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00006004 if (!FullFileName.empty())
Harlan Haskins8d323d12019-08-01 21:31:56 +00006005 if (auto FE = PP.getFileManager().getFile(FullFileName))
6006 File = *FE;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00006007
Guy Benyei11169dd2012-12-18 14:30:41 +00006008 // FIXME: Stable encoding
Vedant Kumar48b4f762018-04-14 01:40:48 +00006009 InclusionDirective::InclusionKind Kind
6010 = static_cast<InclusionDirective::InclusionKind>(Record[2]);
6011 InclusionDirective *ID
6012 = new (PPRec) InclusionDirective(PPRec, Kind,
Chris Lattner0e6c9402013-01-20 02:38:54 +00006013 StringRef(Blob.data(), Record[0]),
Guy Benyei11169dd2012-12-18 14:30:41 +00006014 Record[1], Record[3],
6015 File,
6016 Range);
6017 return ID;
6018 }
6019 }
6020
6021 llvm_unreachable("Invalid PreprocessorDetailRecordTypes");
6022}
6023
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00006024/// Find the next module that contains entities and return the ID
Guy Benyei11169dd2012-12-18 14:30:41 +00006025/// of the first entry.
NAKAMURA Takumi12ab07e2017-10-12 09:42:14 +00006026///
6027/// \param SLocMapI points at a chunk of a module that contains no
6028/// preprocessed entities or the entities it contains are not the ones we are
6029/// looking for.
Guy Benyei11169dd2012-12-18 14:30:41 +00006030PreprocessedEntityID ASTReader::findNextPreprocessedEntity(
6031 GlobalSLocOffsetMapType::const_iterator SLocMapI) const {
6032 ++SLocMapI;
6033 for (GlobalSLocOffsetMapType::const_iterator
6034 EndI = GlobalSLocOffsetMap.end(); SLocMapI != EndI; ++SLocMapI) {
6035 ModuleFile &M = *SLocMapI->second;
6036 if (M.NumPreprocessedEntities)
6037 return M.BasePreprocessedEntityID;
6038 }
6039
6040 return getTotalNumPreprocessedEntities();
6041}
6042
6043namespace {
6044
Guy Benyei11169dd2012-12-18 14:30:41 +00006045struct PPEntityComp {
6046 const ASTReader &Reader;
6047 ModuleFile &M;
6048
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006049 PPEntityComp(const ASTReader &Reader, ModuleFile &M) : Reader(Reader), M(M) {}
Guy Benyei11169dd2012-12-18 14:30:41 +00006050
6051 bool operator()(const PPEntityOffset &L, const PPEntityOffset &R) const {
6052 SourceLocation LHS = getLoc(L);
6053 SourceLocation RHS = getLoc(R);
6054 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6055 }
6056
6057 bool operator()(const PPEntityOffset &L, SourceLocation RHS) const {
6058 SourceLocation LHS = getLoc(L);
6059 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6060 }
6061
6062 bool operator()(SourceLocation LHS, const PPEntityOffset &R) const {
6063 SourceLocation RHS = getLoc(R);
6064 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
6065 }
6066
6067 SourceLocation getLoc(const PPEntityOffset &PPE) const {
Richard Smithb22a1d12016-03-27 20:13:24 +00006068 return Reader.TranslateSourceLocation(M, PPE.getBegin());
Guy Benyei11169dd2012-12-18 14:30:41 +00006069 }
6070};
6071
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006072} // namespace
Guy Benyei11169dd2012-12-18 14:30:41 +00006073
Alp Toker2e9ce4c2014-05-16 18:59:21 +00006074PreprocessedEntityID ASTReader::findPreprocessedEntity(SourceLocation Loc,
6075 bool EndsAfter) const {
6076 if (SourceMgr.isLocalSourceLocation(Loc))
Guy Benyei11169dd2012-12-18 14:30:41 +00006077 return getTotalNumPreprocessedEntities();
6078
Alp Toker2e9ce4c2014-05-16 18:59:21 +00006079 GlobalSLocOffsetMapType::const_iterator SLocMapI = GlobalSLocOffsetMap.find(
6080 SourceManager::MaxLoadedOffset - Loc.getOffset() - 1);
Guy Benyei11169dd2012-12-18 14:30:41 +00006081 assert(SLocMapI != GlobalSLocOffsetMap.end() &&
6082 "Corrupted global sloc offset map");
6083
6084 if (SLocMapI->second->NumPreprocessedEntities == 0)
6085 return findNextPreprocessedEntity(SLocMapI);
6086
6087 ModuleFile &M = *SLocMapI->second;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006088
6089 using pp_iterator = const PPEntityOffset *;
6090
Guy Benyei11169dd2012-12-18 14:30:41 +00006091 pp_iterator pp_begin = M.PreprocessedEntityOffsets;
6092 pp_iterator pp_end = pp_begin + M.NumPreprocessedEntities;
6093
6094 size_t Count = M.NumPreprocessedEntities;
6095 size_t Half;
6096 pp_iterator First = pp_begin;
6097 pp_iterator PPI;
6098
Alp Toker2e9ce4c2014-05-16 18:59:21 +00006099 if (EndsAfter) {
6100 PPI = std::upper_bound(pp_begin, pp_end, Loc,
Richard Smithb22a1d12016-03-27 20:13:24 +00006101 PPEntityComp(*this, M));
Alp Toker2e9ce4c2014-05-16 18:59:21 +00006102 } else {
6103 // Do a binary search manually instead of using std::lower_bound because
6104 // The end locations of entities may be unordered (when a macro expansion
6105 // is inside another macro argument), but for this case it is not important
6106 // whether we get the first macro expansion or its containing macro.
6107 while (Count > 0) {
6108 Half = Count / 2;
6109 PPI = First;
6110 std::advance(PPI, Half);
Richard Smithb22a1d12016-03-27 20:13:24 +00006111 if (SourceMgr.isBeforeInTranslationUnit(
6112 TranslateSourceLocation(M, PPI->getEnd()), Loc)) {
Alp Toker2e9ce4c2014-05-16 18:59:21 +00006113 First = PPI;
6114 ++First;
6115 Count = Count - Half - 1;
6116 } else
6117 Count = Half;
6118 }
Guy Benyei11169dd2012-12-18 14:30:41 +00006119 }
6120
6121 if (PPI == pp_end)
6122 return findNextPreprocessedEntity(SLocMapI);
6123
6124 return M.BasePreprocessedEntityID + (PPI - pp_begin);
6125}
6126
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00006127/// Returns a pair of [Begin, End) indices of preallocated
Guy Benyei11169dd2012-12-18 14:30:41 +00006128/// preprocessed entities that \arg Range encompasses.
6129std::pair<unsigned, unsigned>
6130 ASTReader::findPreprocessedEntitiesInRange(SourceRange Range) {
6131 if (Range.isInvalid())
6132 return std::make_pair(0,0);
6133 assert(!SourceMgr.isBeforeInTranslationUnit(Range.getEnd(),Range.getBegin()));
6134
Alp Toker2e9ce4c2014-05-16 18:59:21 +00006135 PreprocessedEntityID BeginID =
6136 findPreprocessedEntity(Range.getBegin(), false);
6137 PreprocessedEntityID EndID = findPreprocessedEntity(Range.getEnd(), true);
Guy Benyei11169dd2012-12-18 14:30:41 +00006138 return std::make_pair(BeginID, EndID);
6139}
6140
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00006141/// Optionally returns true or false if the preallocated preprocessed
Guy Benyei11169dd2012-12-18 14:30:41 +00006142/// entity with index \arg Index came from file \arg FID.
David Blaikie05785d12013-02-20 22:23:23 +00006143Optional<bool> ASTReader::isPreprocessedEntityInFileID(unsigned Index,
Guy Benyei11169dd2012-12-18 14:30:41 +00006144 FileID FID) {
6145 if (FID.isInvalid())
6146 return false;
6147
6148 std::pair<ModuleFile *, unsigned> PPInfo = getModulePreprocessedEntity(Index);
6149 ModuleFile &M = *PPInfo.first;
6150 unsigned LocalIndex = PPInfo.second;
6151 const PPEntityOffset &PPOffs = M.PreprocessedEntityOffsets[LocalIndex];
David L. Jonesc4808b9e2016-12-15 20:53:26 +00006152
Richard Smithcb34bd32016-03-27 07:28:06 +00006153 SourceLocation Loc = TranslateSourceLocation(M, PPOffs.getBegin());
Guy Benyei11169dd2012-12-18 14:30:41 +00006154 if (Loc.isInvalid())
6155 return false;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00006156
Guy Benyei11169dd2012-12-18 14:30:41 +00006157 if (SourceMgr.isInFileID(SourceMgr.getFileLoc(Loc), FID))
6158 return true;
6159 else
6160 return false;
6161}
6162
6163namespace {
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006164
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00006165 /// Visitor used to search for information about a header file.
Guy Benyei11169dd2012-12-18 14:30:41 +00006166 class HeaderFileInfoVisitor {
Guy Benyei11169dd2012-12-18 14:30:41 +00006167 const FileEntry *FE;
David Blaikie05785d12013-02-20 22:23:23 +00006168 Optional<HeaderFileInfo> HFI;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00006169
Guy Benyei11169dd2012-12-18 14:30:41 +00006170 public:
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006171 explicit HeaderFileInfoVisitor(const FileEntry *FE) : FE(FE) {}
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00006172
6173 bool operator()(ModuleFile &M) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00006174 HeaderFileInfoLookupTable *Table
6175 = static_cast<HeaderFileInfoLookupTable *>(M.HeaderFileInfoTable);
Guy Benyei11169dd2012-12-18 14:30:41 +00006176 if (!Table)
6177 return false;
6178
6179 // Look in the on-disk hash table for an entry for this file name.
Richard Smithbdf2d932015-07-30 03:37:16 +00006180 HeaderFileInfoLookupTable::iterator Pos = Table->find(FE);
Guy Benyei11169dd2012-12-18 14:30:41 +00006181 if (Pos == Table->end())
6182 return false;
6183
Richard Smithbdf2d932015-07-30 03:37:16 +00006184 HFI = *Pos;
Guy Benyei11169dd2012-12-18 14:30:41 +00006185 return true;
6186 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00006187
David Blaikie05785d12013-02-20 22:23:23 +00006188 Optional<HeaderFileInfo> getHeaderFileInfo() const { return HFI; }
Guy Benyei11169dd2012-12-18 14:30:41 +00006189 };
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006190
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006191} // namespace
Guy Benyei11169dd2012-12-18 14:30:41 +00006192
6193HeaderFileInfo ASTReader::GetHeaderFileInfo(const FileEntry *FE) {
Argyrios Kyrtzidis61a38962013-03-06 18:12:44 +00006194 HeaderFileInfoVisitor Visitor(FE);
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00006195 ModuleMgr.visit(Visitor);
Argyrios Kyrtzidis1054bbf2013-05-08 23:46:55 +00006196 if (Optional<HeaderFileInfo> HFI = Visitor.getHeaderFileInfo())
Guy Benyei11169dd2012-12-18 14:30:41 +00006197 return *HFI;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00006198
Guy Benyei11169dd2012-12-18 14:30:41 +00006199 return HeaderFileInfo();
6200}
6201
6202void ASTReader::ReadPragmaDiagnosticMappings(DiagnosticsEngine &Diag) {
Richard Smithd230de22017-01-26 01:01:01 +00006203 using DiagState = DiagnosticsEngine::DiagState;
6204 SmallVector<DiagState *, 32> DiagStates;
6205
Vedant Kumar48b4f762018-04-14 01:40:48 +00006206 for (ModuleFile &F : ModuleMgr) {
Guy Benyei11169dd2012-12-18 14:30:41 +00006207 unsigned Idx = 0;
Richard Smithd230de22017-01-26 01:01:01 +00006208 auto &Record = F.PragmaDiagMappings;
6209 if (Record.empty())
6210 continue;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00006211
Richard Smithd230de22017-01-26 01:01:01 +00006212 DiagStates.clear();
6213
6214 auto ReadDiagState =
6215 [&](const DiagState &BasedOn, SourceLocation Loc,
6216 bool IncludeNonPragmaStates) -> DiagnosticsEngine::DiagState * {
6217 unsigned BackrefID = Record[Idx++];
6218 if (BackrefID != 0)
6219 return DiagStates[BackrefID - 1];
6220
Guy Benyei11169dd2012-12-18 14:30:41 +00006221 // A new DiagState was created here.
Richard Smithd230de22017-01-26 01:01:01 +00006222 Diag.DiagStates.push_back(BasedOn);
6223 DiagState *NewState = &Diag.DiagStates.back();
Guy Benyei11169dd2012-12-18 14:30:41 +00006224 DiagStates.push_back(NewState);
Duncan P. N. Exon Smith3cb183b2017-03-14 19:31:27 +00006225 unsigned Size = Record[Idx++];
6226 assert(Idx + Size * 2 <= Record.size() &&
6227 "Invalid data, not enough diag/map pairs");
6228 while (Size--) {
Richard Smithd230de22017-01-26 01:01:01 +00006229 unsigned DiagID = Record[Idx++];
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006230 DiagnosticMapping NewMapping =
Richard Smithe37391c2017-05-03 00:28:49 +00006231 DiagnosticMapping::deserialize(Record[Idx++]);
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006232 if (!NewMapping.isPragma() && !IncludeNonPragmaStates)
6233 continue;
6234
6235 DiagnosticMapping &Mapping = NewState->getOrAddMapping(DiagID);
6236
6237 // If this mapping was specified as a warning but the severity was
6238 // upgraded due to diagnostic settings, simulate the current diagnostic
6239 // settings (and use a warning).
Richard Smithe37391c2017-05-03 00:28:49 +00006240 if (NewMapping.wasUpgradedFromWarning() && !Mapping.isErrorOrFatal()) {
6241 NewMapping.setSeverity(diag::Severity::Warning);
6242 NewMapping.setUpgradedFromWarning(false);
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006243 }
6244
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006245 Mapping = NewMapping;
Richard Smithd230de22017-01-26 01:01:01 +00006246 }
Richard Smithd230de22017-01-26 01:01:01 +00006247 return NewState;
6248 };
6249
Duncan P. N. Exon Smitha351c102017-04-12 03:45:32 +00006250 // Read the first state.
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006251 DiagState *FirstState;
6252 if (F.Kind == MK_ImplicitModule) {
6253 // Implicitly-built modules are reused with different diagnostic
6254 // settings. Use the initial diagnostic state from Diag to simulate this
6255 // compilation's diagnostic settings.
6256 FirstState = Diag.DiagStatesByLoc.FirstDiagState;
6257 DiagStates.push_back(FirstState);
6258
6259 // Skip the initial diagnostic state from the serialized module.
Richard Smithe37391c2017-05-03 00:28:49 +00006260 assert(Record[1] == 0 &&
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006261 "Invalid data, unexpected backref in initial state");
Richard Smithe37391c2017-05-03 00:28:49 +00006262 Idx = 3 + Record[2] * 2;
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006263 assert(Idx < Record.size() &&
6264 "Invalid data, not enough state change pairs in initial state");
Richard Smithe37391c2017-05-03 00:28:49 +00006265 } else if (F.isModule()) {
6266 // For an explicit module, preserve the flags from the module build
6267 // command line (-w, -Weverything, -Werror, ...) along with any explicit
6268 // -Wblah flags.
6269 unsigned Flags = Record[Idx++];
6270 DiagState Initial;
6271 Initial.SuppressSystemWarnings = Flags & 1; Flags >>= 1;
6272 Initial.ErrorsAsFatal = Flags & 1; Flags >>= 1;
6273 Initial.WarningsAsErrors = Flags & 1; Flags >>= 1;
6274 Initial.EnableAllWarnings = Flags & 1; Flags >>= 1;
6275 Initial.IgnoreAllWarnings = Flags & 1; Flags >>= 1;
6276 Initial.ExtBehavior = (diag::Severity)Flags;
6277 FirstState = ReadDiagState(Initial, SourceLocation(), true);
Richard Smithea741482017-05-01 22:10:47 +00006278
Richard Smith6c2b5a82018-02-09 01:15:13 +00006279 assert(F.OriginalSourceFileID.isValid());
6280
Richard Smithe37391c2017-05-03 00:28:49 +00006281 // Set up the root buffer of the module to start with the initial
6282 // diagnostic state of the module itself, to cover files that contain no
6283 // explicit transitions (for which we did not serialize anything).
6284 Diag.DiagStatesByLoc.Files[F.OriginalSourceFileID]
6285 .StateTransitions.push_back({FirstState, 0});
6286 } else {
6287 // For prefix ASTs, start with whatever the user configured on the
6288 // command line.
6289 Idx++; // Skip flags.
6290 FirstState = ReadDiagState(*Diag.DiagStatesByLoc.CurDiagState,
6291 SourceLocation(), false);
Duncan P. N. Exon Smith900f8172017-04-12 03:58:58 +00006292 }
Richard Smithd230de22017-01-26 01:01:01 +00006293
Duncan P. N. Exon Smitha351c102017-04-12 03:45:32 +00006294 // Read the state transitions.
6295 unsigned NumLocations = Record[Idx++];
6296 while (NumLocations--) {
6297 assert(Idx < Record.size() &&
6298 "Invalid data, missing pragma diagnostic states");
Richard Smithd230de22017-01-26 01:01:01 +00006299 SourceLocation Loc = ReadSourceLocation(F, Record[Idx++]);
6300 auto IDAndOffset = SourceMgr.getDecomposedLoc(Loc);
Richard Smith6c2b5a82018-02-09 01:15:13 +00006301 assert(IDAndOffset.first.isValid() && "invalid FileID for transition");
Richard Smithd230de22017-01-26 01:01:01 +00006302 assert(IDAndOffset.second == 0 && "not a start location for a FileID");
6303 unsigned Transitions = Record[Idx++];
6304
6305 // Note that we don't need to set up Parent/ParentOffset here, because
6306 // we won't be changing the diagnostic state within imported FileIDs
6307 // (other than perhaps appending to the main source file, which has no
6308 // parent).
6309 auto &F = Diag.DiagStatesByLoc.Files[IDAndOffset.first];
6310 F.StateTransitions.reserve(F.StateTransitions.size() + Transitions);
6311 for (unsigned I = 0; I != Transitions; ++I) {
6312 unsigned Offset = Record[Idx++];
6313 auto *State =
6314 ReadDiagState(*FirstState, Loc.getLocWithOffset(Offset), false);
6315 F.StateTransitions.push_back({State, Offset});
Guy Benyei11169dd2012-12-18 14:30:41 +00006316 }
6317 }
Richard Smithd230de22017-01-26 01:01:01 +00006318
Duncan P. N. Exon Smitha351c102017-04-12 03:45:32 +00006319 // Read the final state.
6320 assert(Idx < Record.size() &&
6321 "Invalid data, missing final pragma diagnostic state");
6322 SourceLocation CurStateLoc =
6323 ReadSourceLocation(F, F.PragmaDiagMappings[Idx++]);
6324 auto *CurState = ReadDiagState(*FirstState, CurStateLoc, false);
6325
6326 if (!F.isModule()) {
6327 Diag.DiagStatesByLoc.CurDiagState = CurState;
6328 Diag.DiagStatesByLoc.CurDiagStateLoc = CurStateLoc;
6329
6330 // Preserve the property that the imaginary root file describes the
6331 // current state.
Simon Pilgrim22518632017-10-10 13:56:17 +00006332 FileID NullFile;
6333 auto &T = Diag.DiagStatesByLoc.Files[NullFile].StateTransitions;
Duncan P. N. Exon Smitha351c102017-04-12 03:45:32 +00006334 if (T.empty())
6335 T.push_back({CurState, 0});
6336 else
6337 T[0].State = CurState;
6338 }
6339
Richard Smithd230de22017-01-26 01:01:01 +00006340 // Don't try to read these mappings again.
6341 Record.clear();
Guy Benyei11169dd2012-12-18 14:30:41 +00006342 }
6343}
6344
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00006345/// Get the correct cursor and offset for loading a type.
Guy Benyei11169dd2012-12-18 14:30:41 +00006346ASTReader::RecordLocation ASTReader::TypeCursorForIndex(unsigned Index) {
6347 GlobalTypeMapType::iterator I = GlobalTypeMap.find(Index);
6348 assert(I != GlobalTypeMap.end() && "Corrupted global type map");
6349 ModuleFile *M = I->second;
Dmitry Polukhina7afb212020-04-16 09:24:46 -07006350 return RecordLocation(
6351 M, M->TypeOffsets[Index - M->BaseTypeIndex].getBitOffset());
Guy Benyei11169dd2012-12-18 14:30:41 +00006352}
6353
John McCalld505e572019-12-13 21:54:44 -05006354static llvm::Optional<Type::TypeClass> getTypeClassForCode(TypeCode code) {
6355 switch (code) {
6356#define TYPE_BIT_CODE(CLASS_ID, CODE_ID, CODE_VALUE) \
6357 case TYPE_##CODE_ID: return Type::CLASS_ID;
6358#include "clang/Serialization/TypeBitCodes.def"
6359 default: return llvm::None;
6360 }
John McCall3ce3d232019-12-13 03:37:23 -05006361}
6362
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00006363/// Read and return the type with the given index..
Guy Benyei11169dd2012-12-18 14:30:41 +00006364///
6365/// The index is the type ID, shifted and minus the number of predefs. This
6366/// routine actually reads the record corresponding to the type at the given
6367/// location. It is a helper routine for GetType, which deals with reading type
6368/// IDs.
6369QualType ASTReader::readTypeRecord(unsigned Index) {
Richard Smithdbafb6c2017-06-29 23:23:46 +00006370 assert(ContextObj && "reading type with no AST context");
6371 ASTContext &Context = *ContextObj;
Guy Benyei11169dd2012-12-18 14:30:41 +00006372 RecordLocation Loc = TypeCursorForIndex(Index);
Chris Lattner7fb3bef2013-01-20 00:56:42 +00006373 BitstreamCursor &DeclsCursor = Loc.F->DeclsCursor;
Guy Benyei11169dd2012-12-18 14:30:41 +00006374
6375 // Keep track of where we are in the stream, then jump back there
6376 // after reading this type.
6377 SavedStreamPosition SavedPosition(DeclsCursor);
6378
6379 ReadingKindTracker ReadingKind(Read_Type, *this);
6380
6381 // Note that we are loading a type record.
6382 Deserializing AType(this);
6383
JF Bastien0e828952019-06-26 19:50:12 +00006384 if (llvm::Error Err = DeclsCursor.JumpToBit(Loc.Offset)) {
6385 Error(std::move(Err));
6386 return QualType();
6387 }
John McCall3ce3d232019-12-13 03:37:23 -05006388 Expected<unsigned> RawCode = DeclsCursor.ReadCode();
6389 if (!RawCode) {
6390 Error(RawCode.takeError());
JF Bastien0e828952019-06-26 19:50:12 +00006391 return QualType();
6392 }
JF Bastien0e828952019-06-26 19:50:12 +00006393
John McCall3ce3d232019-12-13 03:37:23 -05006394 ASTRecordReader Record(*this, *Loc.F);
6395 Expected<unsigned> Code = Record.readRecord(DeclsCursor, RawCode.get());
6396 if (!Code) {
6397 Error(Code.takeError());
JF Bastien0e828952019-06-26 19:50:12 +00006398 return QualType();
6399 }
John McCalld505e572019-12-13 21:54:44 -05006400 if (Code.get() == TYPE_EXT_QUAL) {
6401 QualType baseType = Record.readQualType();
6402 Qualifiers quals = Record.readQualifiers();
6403 return Context.getQualifiedType(baseType, quals);
Guy Benyei11169dd2012-12-18 14:30:41 +00006404 }
6405
John McCalld505e572019-12-13 21:54:44 -05006406 auto maybeClass = getTypeClassForCode((TypeCode) Code.get());
6407 if (!maybeClass) {
6408 Error("Unexpected code for type");
6409 return QualType();
Guy Benyei11169dd2012-12-18 14:30:41 +00006410 }
6411
John McCalld505e572019-12-13 21:54:44 -05006412 serialization::AbstractTypeReader<ASTRecordReader> TypeReader(Record);
6413 return TypeReader.read(*maybeClass);
Richard Smith564417a2014-03-20 21:47:22 +00006414}
6415
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006416namespace clang {
6417
6418class TypeLocReader : public TypeLocVisitor<TypeLocReader> {
John McCall3ce3d232019-12-13 03:37:23 -05006419 ASTRecordReader &Reader;
Guy Benyei11169dd2012-12-18 14:30:41 +00006420
John McCall3ce3d232019-12-13 03:37:23 -05006421 SourceLocation readSourceLocation() {
6422 return Reader.readSourceLocation();
David L. Jonesbe1557a2016-12-21 00:17:49 +00006423 }
6424
6425 TypeSourceInfo *GetTypeSourceInfo() {
John McCall3ce3d232019-12-13 03:37:23 -05006426 return Reader.readTypeSourceInfo();
David L. Jonesbe1557a2016-12-21 00:17:49 +00006427 }
6428
6429 NestedNameSpecifierLoc ReadNestedNameSpecifierLoc() {
John McCall3ce3d232019-12-13 03:37:23 -05006430 return Reader.readNestedNameSpecifierLoc();
Guy Benyei11169dd2012-12-18 14:30:41 +00006431 }
6432
Richard Smithe43e2b32018-08-20 21:47:29 +00006433 Attr *ReadAttr() {
John McCall3ce3d232019-12-13 03:37:23 -05006434 return Reader.readAttr();
Richard Smithe43e2b32018-08-20 21:47:29 +00006435 }
6436
Guy Benyei11169dd2012-12-18 14:30:41 +00006437public:
John McCall3ce3d232019-12-13 03:37:23 -05006438 TypeLocReader(ASTRecordReader &Reader) : Reader(Reader) {}
Guy Benyei11169dd2012-12-18 14:30:41 +00006439
6440 // We want compile-time assurance that we've enumerated all of
6441 // these, so unfortunately we have to declare them first, then
6442 // define them out-of-line.
6443#define ABSTRACT_TYPELOC(CLASS, PARENT)
6444#define TYPELOC(CLASS, PARENT) \
6445 void Visit##CLASS##TypeLoc(CLASS##TypeLoc TyLoc);
6446#include "clang/AST/TypeLocNodes.def"
6447
6448 void VisitFunctionTypeLoc(FunctionTypeLoc);
6449 void VisitArrayTypeLoc(ArrayTypeLoc);
6450};
6451
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006452} // namespace clang
6453
Guy Benyei11169dd2012-12-18 14:30:41 +00006454void TypeLocReader::VisitQualifiedTypeLoc(QualifiedTypeLoc TL) {
6455 // nothing to do
6456}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006457
Guy Benyei11169dd2012-12-18 14:30:41 +00006458void TypeLocReader::VisitBuiltinTypeLoc(BuiltinTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006459 TL.setBuiltinLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006460 if (TL.needsExtraLocalData()) {
John McCall3ce3d232019-12-13 03:37:23 -05006461 TL.setWrittenTypeSpec(static_cast<DeclSpec::TST>(Reader.readInt()));
6462 TL.setWrittenSignSpec(static_cast<DeclSpec::TSS>(Reader.readInt()));
6463 TL.setWrittenWidthSpec(static_cast<DeclSpec::TSW>(Reader.readInt()));
6464 TL.setModeAttr(Reader.readInt());
Guy Benyei11169dd2012-12-18 14:30:41 +00006465 }
6466}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006467
Guy Benyei11169dd2012-12-18 14:30:41 +00006468void TypeLocReader::VisitComplexTypeLoc(ComplexTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006469 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006470}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006471
Guy Benyei11169dd2012-12-18 14:30:41 +00006472void TypeLocReader::VisitPointerTypeLoc(PointerTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006473 TL.setStarLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006474}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006475
Reid Kleckner8a365022013-06-24 17:51:48 +00006476void TypeLocReader::VisitDecayedTypeLoc(DecayedTypeLoc TL) {
6477 // nothing to do
6478}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006479
Reid Kleckner0503a872013-12-05 01:23:43 +00006480void TypeLocReader::VisitAdjustedTypeLoc(AdjustedTypeLoc TL) {
6481 // nothing to do
6482}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006483
Leonard Chanc72aaf62019-05-07 03:20:17 +00006484void TypeLocReader::VisitMacroQualifiedTypeLoc(MacroQualifiedTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006485 TL.setExpansionLoc(readSourceLocation());
Leonard Chanc72aaf62019-05-07 03:20:17 +00006486}
6487
Guy Benyei11169dd2012-12-18 14:30:41 +00006488void TypeLocReader::VisitBlockPointerTypeLoc(BlockPointerTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006489 TL.setCaretLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006490}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006491
Guy Benyei11169dd2012-12-18 14:30:41 +00006492void TypeLocReader::VisitLValueReferenceTypeLoc(LValueReferenceTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006493 TL.setAmpLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006494}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006495
Guy Benyei11169dd2012-12-18 14:30:41 +00006496void TypeLocReader::VisitRValueReferenceTypeLoc(RValueReferenceTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006497 TL.setAmpAmpLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006498}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006499
Guy Benyei11169dd2012-12-18 14:30:41 +00006500void TypeLocReader::VisitMemberPointerTypeLoc(MemberPointerTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006501 TL.setStarLoc(readSourceLocation());
David L. Jonesbe1557a2016-12-21 00:17:49 +00006502 TL.setClassTInfo(GetTypeSourceInfo());
Guy Benyei11169dd2012-12-18 14:30:41 +00006503}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006504
Guy Benyei11169dd2012-12-18 14:30:41 +00006505void TypeLocReader::VisitArrayTypeLoc(ArrayTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006506 TL.setLBracketLoc(readSourceLocation());
6507 TL.setRBracketLoc(readSourceLocation());
6508 if (Reader.readBool())
6509 TL.setSizeExpr(Reader.readExpr());
Guy Benyei11169dd2012-12-18 14:30:41 +00006510 else
Craig Toppera13603a2014-05-22 05:54:18 +00006511 TL.setSizeExpr(nullptr);
Guy Benyei11169dd2012-12-18 14:30:41 +00006512}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006513
Guy Benyei11169dd2012-12-18 14:30:41 +00006514void TypeLocReader::VisitConstantArrayTypeLoc(ConstantArrayTypeLoc TL) {
6515 VisitArrayTypeLoc(TL);
6516}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006517
Guy Benyei11169dd2012-12-18 14:30:41 +00006518void TypeLocReader::VisitIncompleteArrayTypeLoc(IncompleteArrayTypeLoc TL) {
6519 VisitArrayTypeLoc(TL);
6520}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006521
Guy Benyei11169dd2012-12-18 14:30:41 +00006522void TypeLocReader::VisitVariableArrayTypeLoc(VariableArrayTypeLoc TL) {
6523 VisitArrayTypeLoc(TL);
6524}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006525
Guy Benyei11169dd2012-12-18 14:30:41 +00006526void TypeLocReader::VisitDependentSizedArrayTypeLoc(
6527 DependentSizedArrayTypeLoc TL) {
6528 VisitArrayTypeLoc(TL);
6529}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006530
Andrew Gozillon572bbb02017-10-02 06:25:51 +00006531void TypeLocReader::VisitDependentAddressSpaceTypeLoc(
6532 DependentAddressSpaceTypeLoc TL) {
6533
John McCall3ce3d232019-12-13 03:37:23 -05006534 TL.setAttrNameLoc(readSourceLocation());
6535 TL.setAttrOperandParensRange(Reader.readSourceRange());
6536 TL.setAttrExprOperand(Reader.readExpr());
Andrew Gozillon572bbb02017-10-02 06:25:51 +00006537}
6538
Guy Benyei11169dd2012-12-18 14:30:41 +00006539void TypeLocReader::VisitDependentSizedExtVectorTypeLoc(
6540 DependentSizedExtVectorTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006541 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006542}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006543
Guy Benyei11169dd2012-12-18 14:30:41 +00006544void TypeLocReader::VisitVectorTypeLoc(VectorTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006545 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006546}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006547
Erich Keanef702b022018-07-13 19:46:04 +00006548void TypeLocReader::VisitDependentVectorTypeLoc(
6549 DependentVectorTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006550 TL.setNameLoc(readSourceLocation());
Erich Keanef702b022018-07-13 19:46:04 +00006551}
6552
Guy Benyei11169dd2012-12-18 14:30:41 +00006553void TypeLocReader::VisitExtVectorTypeLoc(ExtVectorTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006554 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006555}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006556
Guy Benyei11169dd2012-12-18 14:30:41 +00006557void TypeLocReader::VisitFunctionTypeLoc(FunctionTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006558 TL.setLocalRangeBegin(readSourceLocation());
6559 TL.setLParenLoc(readSourceLocation());
6560 TL.setRParenLoc(readSourceLocation());
6561 TL.setExceptionSpecRange(Reader.readSourceRange());
6562 TL.setLocalRangeEnd(readSourceLocation());
Alp Tokerb3fd5cf2014-01-21 00:32:38 +00006563 for (unsigned i = 0, e = TL.getNumParams(); i != e; ++i) {
John McCall3ce3d232019-12-13 03:37:23 -05006564 TL.setParam(i, Reader.readDeclAs<ParmVarDecl>());
Guy Benyei11169dd2012-12-18 14:30:41 +00006565 }
6566}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006567
Guy Benyei11169dd2012-12-18 14:30:41 +00006568void TypeLocReader::VisitFunctionProtoTypeLoc(FunctionProtoTypeLoc TL) {
6569 VisitFunctionTypeLoc(TL);
6570}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006571
Guy Benyei11169dd2012-12-18 14:30:41 +00006572void TypeLocReader::VisitFunctionNoProtoTypeLoc(FunctionNoProtoTypeLoc TL) {
6573 VisitFunctionTypeLoc(TL);
6574}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006575
Guy Benyei11169dd2012-12-18 14:30:41 +00006576void TypeLocReader::VisitUnresolvedUsingTypeLoc(UnresolvedUsingTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006577 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006578}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006579
Guy Benyei11169dd2012-12-18 14:30:41 +00006580void TypeLocReader::VisitTypedefTypeLoc(TypedefTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006581 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006582}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006583
Guy Benyei11169dd2012-12-18 14:30:41 +00006584void TypeLocReader::VisitTypeOfExprTypeLoc(TypeOfExprTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006585 TL.setTypeofLoc(readSourceLocation());
6586 TL.setLParenLoc(readSourceLocation());
6587 TL.setRParenLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006588}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006589
Guy Benyei11169dd2012-12-18 14:30:41 +00006590void TypeLocReader::VisitTypeOfTypeLoc(TypeOfTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006591 TL.setTypeofLoc(readSourceLocation());
6592 TL.setLParenLoc(readSourceLocation());
6593 TL.setRParenLoc(readSourceLocation());
David L. Jonesbe1557a2016-12-21 00:17:49 +00006594 TL.setUnderlyingTInfo(GetTypeSourceInfo());
Guy Benyei11169dd2012-12-18 14:30:41 +00006595}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006596
Guy Benyei11169dd2012-12-18 14:30:41 +00006597void TypeLocReader::VisitDecltypeTypeLoc(DecltypeTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006598 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006599}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006600
Guy Benyei11169dd2012-12-18 14:30:41 +00006601void TypeLocReader::VisitUnaryTransformTypeLoc(UnaryTransformTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006602 TL.setKWLoc(readSourceLocation());
6603 TL.setLParenLoc(readSourceLocation());
6604 TL.setRParenLoc(readSourceLocation());
David L. Jonesbe1557a2016-12-21 00:17:49 +00006605 TL.setUnderlyingTInfo(GetTypeSourceInfo());
Guy Benyei11169dd2012-12-18 14:30:41 +00006606}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006607
Guy Benyei11169dd2012-12-18 14:30:41 +00006608void TypeLocReader::VisitAutoTypeLoc(AutoTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006609 TL.setNameLoc(readSourceLocation());
Saar Razb481f022020-01-22 02:03:05 +02006610 if (Reader.readBool()) {
6611 TL.setNestedNameSpecifierLoc(ReadNestedNameSpecifierLoc());
6612 TL.setTemplateKWLoc(readSourceLocation());
6613 TL.setConceptNameLoc(readSourceLocation());
6614 TL.setFoundDecl(Reader.readDeclAs<NamedDecl>());
6615 TL.setLAngleLoc(readSourceLocation());
6616 TL.setRAngleLoc(readSourceLocation());
6617 for (unsigned i = 0, e = TL.getNumArgs(); i != e; ++i)
6618 TL.setArgLocInfo(i, Reader.readTemplateArgumentLocInfo(
6619 TL.getTypePtr()->getArg(i).getKind()));
6620 }
Guy Benyei11169dd2012-12-18 14:30:41 +00006621}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006622
Richard Smith600b5262017-01-26 20:40:47 +00006623void TypeLocReader::VisitDeducedTemplateSpecializationTypeLoc(
6624 DeducedTemplateSpecializationTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006625 TL.setTemplateNameLoc(readSourceLocation());
Richard Smith600b5262017-01-26 20:40:47 +00006626}
6627
Guy Benyei11169dd2012-12-18 14:30:41 +00006628void TypeLocReader::VisitRecordTypeLoc(RecordTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006629 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006630}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006631
Guy Benyei11169dd2012-12-18 14:30:41 +00006632void TypeLocReader::VisitEnumTypeLoc(EnumTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006633 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006634}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006635
Guy Benyei11169dd2012-12-18 14:30:41 +00006636void TypeLocReader::VisitAttributedTypeLoc(AttributedTypeLoc TL) {
Richard Smithe43e2b32018-08-20 21:47:29 +00006637 TL.setAttr(ReadAttr());
Guy Benyei11169dd2012-12-18 14:30:41 +00006638}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006639
Guy Benyei11169dd2012-12-18 14:30:41 +00006640void TypeLocReader::VisitTemplateTypeParmTypeLoc(TemplateTypeParmTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006641 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006642}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006643
Guy Benyei11169dd2012-12-18 14:30:41 +00006644void TypeLocReader::VisitSubstTemplateTypeParmTypeLoc(
6645 SubstTemplateTypeParmTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006646 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006647}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006648
Guy Benyei11169dd2012-12-18 14:30:41 +00006649void TypeLocReader::VisitSubstTemplateTypeParmPackTypeLoc(
6650 SubstTemplateTypeParmPackTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006651 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006652}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006653
Guy Benyei11169dd2012-12-18 14:30:41 +00006654void TypeLocReader::VisitTemplateSpecializationTypeLoc(
6655 TemplateSpecializationTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006656 TL.setTemplateKeywordLoc(readSourceLocation());
6657 TL.setTemplateNameLoc(readSourceLocation());
6658 TL.setLAngleLoc(readSourceLocation());
6659 TL.setRAngleLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006660 for (unsigned i = 0, e = TL.getNumArgs(); i != e; ++i)
David L. Jonesbe1557a2016-12-21 00:17:49 +00006661 TL.setArgLocInfo(
6662 i,
John McCall3ce3d232019-12-13 03:37:23 -05006663 Reader.readTemplateArgumentLocInfo(
6664 TL.getTypePtr()->getArg(i).getKind()));
Guy Benyei11169dd2012-12-18 14:30:41 +00006665}
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00006666
Guy Benyei11169dd2012-12-18 14:30:41 +00006667void TypeLocReader::VisitParenTypeLoc(ParenTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006668 TL.setLParenLoc(readSourceLocation());
6669 TL.setRParenLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006670}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006671
Guy Benyei11169dd2012-12-18 14:30:41 +00006672void TypeLocReader::VisitElaboratedTypeLoc(ElaboratedTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006673 TL.setElaboratedKeywordLoc(readSourceLocation());
David L. Jonesbe1557a2016-12-21 00:17:49 +00006674 TL.setQualifierLoc(ReadNestedNameSpecifierLoc());
Guy Benyei11169dd2012-12-18 14:30:41 +00006675}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006676
Guy Benyei11169dd2012-12-18 14:30:41 +00006677void TypeLocReader::VisitInjectedClassNameTypeLoc(InjectedClassNameTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006678 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006679}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006680
Guy Benyei11169dd2012-12-18 14:30:41 +00006681void TypeLocReader::VisitDependentNameTypeLoc(DependentNameTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006682 TL.setElaboratedKeywordLoc(readSourceLocation());
David L. Jonesbe1557a2016-12-21 00:17:49 +00006683 TL.setQualifierLoc(ReadNestedNameSpecifierLoc());
John McCall3ce3d232019-12-13 03:37:23 -05006684 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006685}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006686
Guy Benyei11169dd2012-12-18 14:30:41 +00006687void TypeLocReader::VisitDependentTemplateSpecializationTypeLoc(
6688 DependentTemplateSpecializationTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006689 TL.setElaboratedKeywordLoc(readSourceLocation());
David L. Jonesbe1557a2016-12-21 00:17:49 +00006690 TL.setQualifierLoc(ReadNestedNameSpecifierLoc());
John McCall3ce3d232019-12-13 03:37:23 -05006691 TL.setTemplateKeywordLoc(readSourceLocation());
6692 TL.setTemplateNameLoc(readSourceLocation());
6693 TL.setLAngleLoc(readSourceLocation());
6694 TL.setRAngleLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006695 for (unsigned I = 0, E = TL.getNumArgs(); I != E; ++I)
David L. Jonesbe1557a2016-12-21 00:17:49 +00006696 TL.setArgLocInfo(
6697 I,
John McCall3ce3d232019-12-13 03:37:23 -05006698 Reader.readTemplateArgumentLocInfo(
6699 TL.getTypePtr()->getArg(I).getKind()));
Guy Benyei11169dd2012-12-18 14:30:41 +00006700}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006701
Guy Benyei11169dd2012-12-18 14:30:41 +00006702void TypeLocReader::VisitPackExpansionTypeLoc(PackExpansionTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006703 TL.setEllipsisLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006704}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006705
Guy Benyei11169dd2012-12-18 14:30:41 +00006706void TypeLocReader::VisitObjCInterfaceTypeLoc(ObjCInterfaceTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006707 TL.setNameLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006708}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006709
Manman Rene6be26c2016-09-13 17:25:08 +00006710void TypeLocReader::VisitObjCTypeParamTypeLoc(ObjCTypeParamTypeLoc TL) {
6711 if (TL.getNumProtocols()) {
John McCall3ce3d232019-12-13 03:37:23 -05006712 TL.setProtocolLAngleLoc(readSourceLocation());
6713 TL.setProtocolRAngleLoc(readSourceLocation());
Manman Rene6be26c2016-09-13 17:25:08 +00006714 }
6715 for (unsigned i = 0, e = TL.getNumProtocols(); i != e; ++i)
John McCall3ce3d232019-12-13 03:37:23 -05006716 TL.setProtocolLoc(i, readSourceLocation());
Manman Rene6be26c2016-09-13 17:25:08 +00006717}
6718
Guy Benyei11169dd2012-12-18 14:30:41 +00006719void TypeLocReader::VisitObjCObjectTypeLoc(ObjCObjectTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006720 TL.setHasBaseTypeAsWritten(Reader.readBool());
6721 TL.setTypeArgsLAngleLoc(readSourceLocation());
6722 TL.setTypeArgsRAngleLoc(readSourceLocation());
Douglas Gregore9d95f12015-07-07 03:57:35 +00006723 for (unsigned i = 0, e = TL.getNumTypeArgs(); i != e; ++i)
David L. Jonesbe1557a2016-12-21 00:17:49 +00006724 TL.setTypeArgTInfo(i, GetTypeSourceInfo());
John McCall3ce3d232019-12-13 03:37:23 -05006725 TL.setProtocolLAngleLoc(readSourceLocation());
6726 TL.setProtocolRAngleLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006727 for (unsigned i = 0, e = TL.getNumProtocols(); i != e; ++i)
John McCall3ce3d232019-12-13 03:37:23 -05006728 TL.setProtocolLoc(i, readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006729}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006730
Guy Benyei11169dd2012-12-18 14:30:41 +00006731void TypeLocReader::VisitObjCObjectPointerTypeLoc(ObjCObjectPointerTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006732 TL.setStarLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006733}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006734
Guy Benyei11169dd2012-12-18 14:30:41 +00006735void TypeLocReader::VisitAtomicTypeLoc(AtomicTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006736 TL.setKWLoc(readSourceLocation());
6737 TL.setLParenLoc(readSourceLocation());
6738 TL.setRParenLoc(readSourceLocation());
Guy Benyei11169dd2012-12-18 14:30:41 +00006739}
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00006740
Xiuli Pan9c14e282016-01-09 12:53:17 +00006741void TypeLocReader::VisitPipeTypeLoc(PipeTypeLoc TL) {
John McCall3ce3d232019-12-13 03:37:23 -05006742 TL.setKWLoc(readSourceLocation());
Xiuli Pan9c14e282016-01-09 12:53:17 +00006743}
Guy Benyei11169dd2012-12-18 14:30:41 +00006744
Erich Keane5f0903e2020-04-17 10:44:19 -07006745void TypeLocReader::VisitExtIntTypeLoc(clang::ExtIntTypeLoc TL) {
6746 TL.setNameLoc(readSourceLocation());
6747}
6748void TypeLocReader::VisitDependentExtIntTypeLoc(
6749 clang::DependentExtIntTypeLoc TL) {
6750 TL.setNameLoc(readSourceLocation());
6751}
6752
6753
John McCall3ce3d232019-12-13 03:37:23 -05006754void ASTRecordReader::readTypeLoc(TypeLoc TL) {
6755 TypeLocReader TLR(*this);
Richard Smithc23d7342018-06-29 20:46:25 +00006756 for (; !TL.isNull(); TL = TL.getNextTypeLoc())
6757 TLR.Visit(TL);
6758}
6759
John McCall3ce3d232019-12-13 03:37:23 -05006760TypeSourceInfo *ASTRecordReader::readTypeSourceInfo() {
6761 QualType InfoTy = readType();
Guy Benyei11169dd2012-12-18 14:30:41 +00006762 if (InfoTy.isNull())
Craig Toppera13603a2014-05-22 05:54:18 +00006763 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00006764
6765 TypeSourceInfo *TInfo = getContext().CreateTypeSourceInfo(InfoTy);
John McCall3ce3d232019-12-13 03:37:23 -05006766 readTypeLoc(TInfo->getTypeLoc());
Guy Benyei11169dd2012-12-18 14:30:41 +00006767 return TInfo;
6768}
6769
6770QualType ASTReader::GetType(TypeID ID) {
Richard Smithdbafb6c2017-06-29 23:23:46 +00006771 assert(ContextObj && "reading type with no AST context");
6772 ASTContext &Context = *ContextObj;
6773
Guy Benyei11169dd2012-12-18 14:30:41 +00006774 unsigned FastQuals = ID & Qualifiers::FastMask;
6775 unsigned Index = ID >> Qualifiers::FastWidth;
6776
6777 if (Index < NUM_PREDEF_TYPE_IDS) {
6778 QualType T;
6779 switch ((PredefinedTypeIDs)Index) {
Alexey Baderbdf7c842015-09-15 12:18:29 +00006780 case PREDEF_TYPE_NULL_ID:
Vedant Kumar48b4f762018-04-14 01:40:48 +00006781 return QualType();
Alexey Baderbdf7c842015-09-15 12:18:29 +00006782 case PREDEF_TYPE_VOID_ID:
6783 T = Context.VoidTy;
6784 break;
6785 case PREDEF_TYPE_BOOL_ID:
6786 T = Context.BoolTy;
6787 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00006788 case PREDEF_TYPE_CHAR_U_ID:
6789 case PREDEF_TYPE_CHAR_S_ID:
6790 // FIXME: Check that the signedness of CharTy is correct!
6791 T = Context.CharTy;
6792 break;
Alexey Baderbdf7c842015-09-15 12:18:29 +00006793 case PREDEF_TYPE_UCHAR_ID:
6794 T = Context.UnsignedCharTy;
6795 break;
6796 case PREDEF_TYPE_USHORT_ID:
6797 T = Context.UnsignedShortTy;
6798 break;
6799 case PREDEF_TYPE_UINT_ID:
6800 T = Context.UnsignedIntTy;
6801 break;
6802 case PREDEF_TYPE_ULONG_ID:
6803 T = Context.UnsignedLongTy;
6804 break;
6805 case PREDEF_TYPE_ULONGLONG_ID:
6806 T = Context.UnsignedLongLongTy;
6807 break;
6808 case PREDEF_TYPE_UINT128_ID:
6809 T = Context.UnsignedInt128Ty;
6810 break;
6811 case PREDEF_TYPE_SCHAR_ID:
6812 T = Context.SignedCharTy;
6813 break;
6814 case PREDEF_TYPE_WCHAR_ID:
6815 T = Context.WCharTy;
6816 break;
6817 case PREDEF_TYPE_SHORT_ID:
6818 T = Context.ShortTy;
6819 break;
6820 case PREDEF_TYPE_INT_ID:
6821 T = Context.IntTy;
6822 break;
6823 case PREDEF_TYPE_LONG_ID:
6824 T = Context.LongTy;
6825 break;
6826 case PREDEF_TYPE_LONGLONG_ID:
6827 T = Context.LongLongTy;
6828 break;
6829 case PREDEF_TYPE_INT128_ID:
6830 T = Context.Int128Ty;
6831 break;
6832 case PREDEF_TYPE_HALF_ID:
6833 T = Context.HalfTy;
6834 break;
6835 case PREDEF_TYPE_FLOAT_ID:
6836 T = Context.FloatTy;
6837 break;
6838 case PREDEF_TYPE_DOUBLE_ID:
6839 T = Context.DoubleTy;
6840 break;
6841 case PREDEF_TYPE_LONGDOUBLE_ID:
6842 T = Context.LongDoubleTy;
6843 break;
Leonard Chanf921d852018-06-04 16:07:52 +00006844 case PREDEF_TYPE_SHORT_ACCUM_ID:
6845 T = Context.ShortAccumTy;
6846 break;
6847 case PREDEF_TYPE_ACCUM_ID:
6848 T = Context.AccumTy;
6849 break;
6850 case PREDEF_TYPE_LONG_ACCUM_ID:
6851 T = Context.LongAccumTy;
6852 break;
6853 case PREDEF_TYPE_USHORT_ACCUM_ID:
6854 T = Context.UnsignedShortAccumTy;
6855 break;
6856 case PREDEF_TYPE_UACCUM_ID:
6857 T = Context.UnsignedAccumTy;
6858 break;
6859 case PREDEF_TYPE_ULONG_ACCUM_ID:
6860 T = Context.UnsignedLongAccumTy;
6861 break;
Leonard Chanab80f3c2018-06-14 14:53:51 +00006862 case PREDEF_TYPE_SHORT_FRACT_ID:
6863 T = Context.ShortFractTy;
6864 break;
6865 case PREDEF_TYPE_FRACT_ID:
6866 T = Context.FractTy;
6867 break;
6868 case PREDEF_TYPE_LONG_FRACT_ID:
6869 T = Context.LongFractTy;
6870 break;
6871 case PREDEF_TYPE_USHORT_FRACT_ID:
6872 T = Context.UnsignedShortFractTy;
6873 break;
6874 case PREDEF_TYPE_UFRACT_ID:
6875 T = Context.UnsignedFractTy;
6876 break;
6877 case PREDEF_TYPE_ULONG_FRACT_ID:
6878 T = Context.UnsignedLongFractTy;
6879 break;
6880 case PREDEF_TYPE_SAT_SHORT_ACCUM_ID:
6881 T = Context.SatShortAccumTy;
6882 break;
6883 case PREDEF_TYPE_SAT_ACCUM_ID:
6884 T = Context.SatAccumTy;
6885 break;
6886 case PREDEF_TYPE_SAT_LONG_ACCUM_ID:
6887 T = Context.SatLongAccumTy;
6888 break;
6889 case PREDEF_TYPE_SAT_USHORT_ACCUM_ID:
6890 T = Context.SatUnsignedShortAccumTy;
6891 break;
6892 case PREDEF_TYPE_SAT_UACCUM_ID:
6893 T = Context.SatUnsignedAccumTy;
6894 break;
6895 case PREDEF_TYPE_SAT_ULONG_ACCUM_ID:
6896 T = Context.SatUnsignedLongAccumTy;
6897 break;
6898 case PREDEF_TYPE_SAT_SHORT_FRACT_ID:
6899 T = Context.SatShortFractTy;
6900 break;
6901 case PREDEF_TYPE_SAT_FRACT_ID:
6902 T = Context.SatFractTy;
6903 break;
6904 case PREDEF_TYPE_SAT_LONG_FRACT_ID:
6905 T = Context.SatLongFractTy;
6906 break;
6907 case PREDEF_TYPE_SAT_USHORT_FRACT_ID:
6908 T = Context.SatUnsignedShortFractTy;
6909 break;
6910 case PREDEF_TYPE_SAT_UFRACT_ID:
6911 T = Context.SatUnsignedFractTy;
6912 break;
6913 case PREDEF_TYPE_SAT_ULONG_FRACT_ID:
6914 T = Context.SatUnsignedLongFractTy;
6915 break;
Sjoerd Meijercc623ad2017-09-08 15:15:00 +00006916 case PREDEF_TYPE_FLOAT16_ID:
6917 T = Context.Float16Ty;
6918 break;
Nemanja Ivanovicbb1ea2d2016-05-09 08:52:33 +00006919 case PREDEF_TYPE_FLOAT128_ID:
6920 T = Context.Float128Ty;
6921 break;
Alexey Baderbdf7c842015-09-15 12:18:29 +00006922 case PREDEF_TYPE_OVERLOAD_ID:
6923 T = Context.OverloadTy;
6924 break;
6925 case PREDEF_TYPE_BOUND_MEMBER:
6926 T = Context.BoundMemberTy;
6927 break;
6928 case PREDEF_TYPE_PSEUDO_OBJECT:
6929 T = Context.PseudoObjectTy;
6930 break;
6931 case PREDEF_TYPE_DEPENDENT_ID:
6932 T = Context.DependentTy;
6933 break;
6934 case PREDEF_TYPE_UNKNOWN_ANY:
6935 T = Context.UnknownAnyTy;
6936 break;
6937 case PREDEF_TYPE_NULLPTR_ID:
6938 T = Context.NullPtrTy;
6939 break;
Richard Smith3a8244d2018-05-01 05:02:45 +00006940 case PREDEF_TYPE_CHAR8_ID:
6941 T = Context.Char8Ty;
6942 break;
Alexey Baderbdf7c842015-09-15 12:18:29 +00006943 case PREDEF_TYPE_CHAR16_ID:
6944 T = Context.Char16Ty;
6945 break;
6946 case PREDEF_TYPE_CHAR32_ID:
6947 T = Context.Char32Ty;
6948 break;
6949 case PREDEF_TYPE_OBJC_ID:
6950 T = Context.ObjCBuiltinIdTy;
6951 break;
6952 case PREDEF_TYPE_OBJC_CLASS:
6953 T = Context.ObjCBuiltinClassTy;
6954 break;
6955 case PREDEF_TYPE_OBJC_SEL:
6956 T = Context.ObjCBuiltinSelTy;
6957 break;
Alexey Bader954ba212016-04-08 13:40:33 +00006958#define IMAGE_TYPE(ImgType, Id, SingletonId, Access, Suffix) \
6959 case PREDEF_TYPE_##Id##_ID: \
6960 T = Context.SingletonId; \
Alexey Baderbdf7c842015-09-15 12:18:29 +00006961 break;
Alexey Baderb62f1442016-04-13 08:33:41 +00006962#include "clang/Basic/OpenCLImageTypes.def"
Andrew Savonichev3fee3512018-11-08 11:25:41 +00006963#define EXT_OPAQUE_TYPE(ExtType, Id, Ext) \
6964 case PREDEF_TYPE_##Id##_ID: \
6965 T = Context.Id##Ty; \
6966 break;
6967#include "clang/Basic/OpenCLExtensionTypes.def"
Alexey Baderbdf7c842015-09-15 12:18:29 +00006968 case PREDEF_TYPE_SAMPLER_ID:
6969 T = Context.OCLSamplerTy;
6970 break;
6971 case PREDEF_TYPE_EVENT_ID:
6972 T = Context.OCLEventTy;
6973 break;
Alexey Bader9c8453f2015-09-15 11:18:52 +00006974 case PREDEF_TYPE_CLK_EVENT_ID:
6975 T = Context.OCLClkEventTy;
6976 break;
6977 case PREDEF_TYPE_QUEUE_ID:
6978 T = Context.OCLQueueTy;
6979 break;
Alexey Bader9c8453f2015-09-15 11:18:52 +00006980 case PREDEF_TYPE_RESERVE_ID_ID:
6981 T = Context.OCLReserveIDTy;
6982 break;
Alexey Baderbdf7c842015-09-15 12:18:29 +00006983 case PREDEF_TYPE_AUTO_DEDUCT:
6984 T = Context.getAutoDeductType();
6985 break;
Alexey Baderbdf7c842015-09-15 12:18:29 +00006986 case PREDEF_TYPE_AUTO_RREF_DEDUCT:
6987 T = Context.getAutoRRefDeductType();
Guy Benyei11169dd2012-12-18 14:30:41 +00006988 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00006989 case PREDEF_TYPE_ARC_UNBRIDGED_CAST:
6990 T = Context.ARCUnbridgedCastTy;
6991 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00006992 case PREDEF_TYPE_BUILTIN_FN:
6993 T = Context.BuiltinFnTy;
6994 break;
Alexey Bataev1a3320e2015-08-25 14:24:04 +00006995 case PREDEF_TYPE_OMP_ARRAY_SECTION:
6996 T = Context.OMPArraySectionTy;
6997 break;
Alexey Bataev7ac9efb2020-02-05 09:33:05 -05006998 case PREDEF_TYPE_OMP_ARRAY_SHAPING:
6999 T = Context.OMPArraySectionTy;
7000 break;
Alexey Bataev13a15042020-04-01 15:06:38 -04007001 case PREDEF_TYPE_OMP_ITERATOR:
7002 T = Context.OMPIteratorTy;
7003 break;
Richard Sandifordeb485fb2019-08-09 08:52:54 +00007004#define SVE_TYPE(Name, Id, SingletonId) \
7005 case PREDEF_TYPE_##Id##_ID: \
7006 T = Context.SingletonId; \
7007 break;
7008#include "clang/Basic/AArch64SVEACLETypes.def"
Guy Benyei11169dd2012-12-18 14:30:41 +00007009 }
7010
7011 assert(!T.isNull() && "Unknown predefined type");
7012 return T.withFastQualifiers(FastQuals);
7013 }
7014
7015 Index -= NUM_PREDEF_TYPE_IDS;
7016 assert(Index < TypesLoaded.size() && "Type index out-of-range");
7017 if (TypesLoaded[Index].isNull()) {
7018 TypesLoaded[Index] = readTypeRecord(Index);
7019 if (TypesLoaded[Index].isNull())
Vedant Kumar48b4f762018-04-14 01:40:48 +00007020 return QualType();
Guy Benyei11169dd2012-12-18 14:30:41 +00007021
7022 TypesLoaded[Index]->setFromAST();
7023 if (DeserializationListener)
7024 DeserializationListener->TypeRead(TypeIdx::fromTypeID(ID),
7025 TypesLoaded[Index]);
7026 }
7027
7028 return TypesLoaded[Index].withFastQualifiers(FastQuals);
7029}
7030
7031QualType ASTReader::getLocalType(ModuleFile &F, unsigned LocalID) {
7032 return GetType(getGlobalTypeID(F, LocalID));
7033}
7034
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007035serialization::TypeID
Guy Benyei11169dd2012-12-18 14:30:41 +00007036ASTReader::getGlobalTypeID(ModuleFile &F, unsigned LocalID) const {
7037 unsigned FastQuals = LocalID & Qualifiers::FastMask;
7038 unsigned LocalIndex = LocalID >> Qualifiers::FastWidth;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007039
Guy Benyei11169dd2012-12-18 14:30:41 +00007040 if (LocalIndex < NUM_PREDEF_TYPE_IDS)
7041 return LocalID;
7042
Richard Smith37a93df2017-02-18 00:32:02 +00007043 if (!F.ModuleOffsetMap.empty())
7044 ReadModuleOffsetMap(F);
7045
Guy Benyei11169dd2012-12-18 14:30:41 +00007046 ContinuousRangeMap<uint32_t, int, 2>::iterator I
7047 = F.TypeRemap.find(LocalIndex - NUM_PREDEF_TYPE_IDS);
7048 assert(I != F.TypeRemap.end() && "Invalid index into type index remap");
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007049
Guy Benyei11169dd2012-12-18 14:30:41 +00007050 unsigned GlobalIndex = LocalIndex + I->second;
7051 return (GlobalIndex << Qualifiers::FastWidth) | FastQuals;
7052}
7053
7054TemplateArgumentLocInfo
John McCall3ce3d232019-12-13 03:37:23 -05007055ASTRecordReader::readTemplateArgumentLocInfo(TemplateArgument::ArgKind Kind) {
Guy Benyei11169dd2012-12-18 14:30:41 +00007056 switch (Kind) {
7057 case TemplateArgument::Expression:
John McCall3ce3d232019-12-13 03:37:23 -05007058 return readExpr();
Guy Benyei11169dd2012-12-18 14:30:41 +00007059 case TemplateArgument::Type:
John McCall3ce3d232019-12-13 03:37:23 -05007060 return readTypeSourceInfo();
Guy Benyei11169dd2012-12-18 14:30:41 +00007061 case TemplateArgument::Template: {
John McCall3ce3d232019-12-13 03:37:23 -05007062 NestedNameSpecifierLoc QualifierLoc =
7063 readNestedNameSpecifierLoc();
7064 SourceLocation TemplateNameLoc = readSourceLocation();
Guy Benyei11169dd2012-12-18 14:30:41 +00007065 return TemplateArgumentLocInfo(QualifierLoc, TemplateNameLoc,
7066 SourceLocation());
7067 }
7068 case TemplateArgument::TemplateExpansion: {
John McCall3ce3d232019-12-13 03:37:23 -05007069 NestedNameSpecifierLoc QualifierLoc = readNestedNameSpecifierLoc();
7070 SourceLocation TemplateNameLoc = readSourceLocation();
7071 SourceLocation EllipsisLoc = readSourceLocation();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007072 return TemplateArgumentLocInfo(QualifierLoc, TemplateNameLoc,
Guy Benyei11169dd2012-12-18 14:30:41 +00007073 EllipsisLoc);
7074 }
7075 case TemplateArgument::Null:
7076 case TemplateArgument::Integral:
7077 case TemplateArgument::Declaration:
7078 case TemplateArgument::NullPtr:
7079 case TemplateArgument::Pack:
7080 // FIXME: Is this right?
Vedant Kumar48b4f762018-04-14 01:40:48 +00007081 return TemplateArgumentLocInfo();
Guy Benyei11169dd2012-12-18 14:30:41 +00007082 }
7083 llvm_unreachable("unexpected template argument loc");
7084}
7085
John McCall3ce3d232019-12-13 03:37:23 -05007086TemplateArgumentLoc ASTRecordReader::readTemplateArgumentLoc() {
7087 TemplateArgument Arg = readTemplateArgument();
Guy Benyei11169dd2012-12-18 14:30:41 +00007088
7089 if (Arg.getKind() == TemplateArgument::Expression) {
John McCall3ce3d232019-12-13 03:37:23 -05007090 if (readBool()) // bool InfoHasSameExpr.
Guy Benyei11169dd2012-12-18 14:30:41 +00007091 return TemplateArgumentLoc(Arg, TemplateArgumentLocInfo(Arg.getAsExpr()));
7092 }
John McCall3ce3d232019-12-13 03:37:23 -05007093 return TemplateArgumentLoc(Arg, readTemplateArgumentLocInfo(Arg.getKind()));
Guy Benyei11169dd2012-12-18 14:30:41 +00007094}
7095
John McCall3ce3d232019-12-13 03:37:23 -05007096const ASTTemplateArgumentListInfo *
7097ASTRecordReader::readASTTemplateArgumentListInfo() {
7098 SourceLocation LAngleLoc = readSourceLocation();
7099 SourceLocation RAngleLoc = readSourceLocation();
7100 unsigned NumArgsAsWritten = readInt();
Enea Zaffanella6dbe1872013-08-10 07:24:53 +00007101 TemplateArgumentListInfo TemplArgsInfo(LAngleLoc, RAngleLoc);
7102 for (unsigned i = 0; i != NumArgsAsWritten; ++i)
John McCall3ce3d232019-12-13 03:37:23 -05007103 TemplArgsInfo.addArgument(readTemplateArgumentLoc());
Enea Zaffanella6dbe1872013-08-10 07:24:53 +00007104 return ASTTemplateArgumentListInfo::Create(getContext(), TemplArgsInfo);
7105}
7106
Guy Benyei11169dd2012-12-18 14:30:41 +00007107Decl *ASTReader::GetExternalDecl(uint32_t ID) {
7108 return GetDecl(ID);
7109}
7110
Richard Smith053f6c62014-05-16 23:01:30 +00007111void ASTReader::CompleteRedeclChain(const Decl *D) {
Richard Smith851072e2014-05-19 20:59:20 +00007112 if (NumCurrentElementsDeserializing) {
7113 // We arrange to not care about the complete redeclaration chain while we're
7114 // deserializing. Just remember that the AST has marked this one as complete
7115 // but that it's not actually complete yet, so we know we still need to
7116 // complete it later.
7117 PendingIncompleteDeclChains.push_back(const_cast<Decl*>(D));
7118 return;
7119 }
7120
Richard Smith053f6c62014-05-16 23:01:30 +00007121 const DeclContext *DC = D->getDeclContext()->getRedeclContext();
7122
Richard Smith053f6c62014-05-16 23:01:30 +00007123 // If this is a named declaration, complete it by looking it up
7124 // within its context.
7125 //
Richard Smith01bdb7a2014-08-28 05:44:07 +00007126 // FIXME: Merging a function definition should merge
Richard Smith053f6c62014-05-16 23:01:30 +00007127 // all mergeable entities within it.
7128 if (isa<TranslationUnitDecl>(DC) || isa<NamespaceDecl>(DC) ||
7129 isa<CXXRecordDecl>(DC) || isa<EnumDecl>(DC)) {
7130 if (DeclarationName Name = cast<NamedDecl>(D)->getDeclName()) {
Richard Smitha534a312015-07-21 23:54:07 +00007131 if (!getContext().getLangOpts().CPlusPlus &&
7132 isa<TranslationUnitDecl>(DC)) {
Richard Smith053f6c62014-05-16 23:01:30 +00007133 // Outside of C++, we don't have a lookup table for the TU, so update
Richard Smitha534a312015-07-21 23:54:07 +00007134 // the identifier instead. (For C++ modules, we don't store decls
7135 // in the serialized identifier table, so we do the lookup in the TU.)
7136 auto *II = Name.getAsIdentifierInfo();
7137 assert(II && "non-identifier name in C?");
Richard Smith053f6c62014-05-16 23:01:30 +00007138 if (II->isOutOfDate())
7139 updateOutOfDateIdentifier(*II);
7140 } else
7141 DC->lookup(Name);
Richard Smith01bdb7a2014-08-28 05:44:07 +00007142 } else if (needsAnonymousDeclarationNumber(cast<NamedDecl>(D))) {
Richard Smith3cb15722015-08-05 22:41:45 +00007143 // Find all declarations of this kind from the relevant context.
7144 for (auto *DCDecl : cast<Decl>(D->getLexicalDeclContext())->redecls()) {
7145 auto *DC = cast<DeclContext>(DCDecl);
7146 SmallVector<Decl*, 8> Decls;
7147 FindExternalLexicalDecls(
7148 DC, [&](Decl::Kind K) { return K == D->getKind(); }, Decls);
7149 }
Richard Smith053f6c62014-05-16 23:01:30 +00007150 }
7151 }
Richard Smith50895422015-01-31 03:04:55 +00007152
7153 if (auto *CTSD = dyn_cast<ClassTemplateSpecializationDecl>(D))
7154 CTSD->getSpecializedTemplate()->LoadLazySpecializations();
7155 if (auto *VTSD = dyn_cast<VarTemplateSpecializationDecl>(D))
7156 VTSD->getSpecializedTemplate()->LoadLazySpecializations();
7157 if (auto *FD = dyn_cast<FunctionDecl>(D)) {
7158 if (auto *Template = FD->getPrimaryTemplate())
7159 Template->LoadLazySpecializations();
7160 }
Richard Smith053f6c62014-05-16 23:01:30 +00007161}
7162
Richard Smithc2bb8182015-03-24 06:36:48 +00007163CXXCtorInitializer **
7164ASTReader::GetExternalCXXCtorInitializers(uint64_t Offset) {
7165 RecordLocation Loc = getLocalBitOffset(Offset);
7166 BitstreamCursor &Cursor = Loc.F->DeclsCursor;
7167 SavedStreamPosition SavedPosition(Cursor);
JF Bastien0e828952019-06-26 19:50:12 +00007168 if (llvm::Error Err = Cursor.JumpToBit(Loc.Offset)) {
7169 Error(std::move(Err));
7170 return nullptr;
7171 }
Richard Smithc2bb8182015-03-24 06:36:48 +00007172 ReadingKindTracker ReadingKind(Read_Decl, *this);
7173
JF Bastien0e828952019-06-26 19:50:12 +00007174 Expected<unsigned> MaybeCode = Cursor.ReadCode();
7175 if (!MaybeCode) {
7176 Error(MaybeCode.takeError());
7177 return nullptr;
7178 }
7179 unsigned Code = MaybeCode.get();
7180
John McCall3ce3d232019-12-13 03:37:23 -05007181 ASTRecordReader Record(*this, *Loc.F);
7182 Expected<unsigned> MaybeRecCode = Record.readRecord(Cursor, Code);
JF Bastien0e828952019-06-26 19:50:12 +00007183 if (!MaybeRecCode) {
7184 Error(MaybeRecCode.takeError());
7185 return nullptr;
7186 }
7187 if (MaybeRecCode.get() != DECL_CXX_CTOR_INITIALIZERS) {
Richard Smithc2bb8182015-03-24 06:36:48 +00007188 Error("malformed AST file: missing C++ ctor initializers");
7189 return nullptr;
7190 }
7191
John McCall3ce3d232019-12-13 03:37:23 -05007192 return Record.readCXXCtorInitializers();
Richard Smithc2bb8182015-03-24 06:36:48 +00007193}
7194
Guy Benyei11169dd2012-12-18 14:30:41 +00007195CXXBaseSpecifier *ASTReader::GetExternalCXXBaseSpecifiers(uint64_t Offset) {
Richard Smithdbafb6c2017-06-29 23:23:46 +00007196 assert(ContextObj && "reading base specifiers with no AST context");
7197 ASTContext &Context = *ContextObj;
7198
Guy Benyei11169dd2012-12-18 14:30:41 +00007199 RecordLocation Loc = getLocalBitOffset(Offset);
Chris Lattner7fb3bef2013-01-20 00:56:42 +00007200 BitstreamCursor &Cursor = Loc.F->DeclsCursor;
Guy Benyei11169dd2012-12-18 14:30:41 +00007201 SavedStreamPosition SavedPosition(Cursor);
JF Bastien0e828952019-06-26 19:50:12 +00007202 if (llvm::Error Err = Cursor.JumpToBit(Loc.Offset)) {
7203 Error(std::move(Err));
7204 return nullptr;
7205 }
Guy Benyei11169dd2012-12-18 14:30:41 +00007206 ReadingKindTracker ReadingKind(Read_Decl, *this);
JF Bastien0e828952019-06-26 19:50:12 +00007207
7208 Expected<unsigned> MaybeCode = Cursor.ReadCode();
7209 if (!MaybeCode) {
7210 Error(MaybeCode.takeError());
7211 return nullptr;
7212 }
7213 unsigned Code = MaybeCode.get();
7214
John McCall3ce3d232019-12-13 03:37:23 -05007215 ASTRecordReader Record(*this, *Loc.F);
7216 Expected<unsigned> MaybeRecCode = Record.readRecord(Cursor, Code);
JF Bastien0e828952019-06-26 19:50:12 +00007217 if (!MaybeRecCode) {
7218 Error(MaybeCode.takeError());
7219 return nullptr;
7220 }
7221 unsigned RecCode = MaybeRecCode.get();
7222
Guy Benyei11169dd2012-12-18 14:30:41 +00007223 if (RecCode != DECL_CXX_BASE_SPECIFIERS) {
Richard Smithcd45dbc2014-04-19 03:48:30 +00007224 Error("malformed AST file: missing C++ base specifiers");
Craig Toppera13603a2014-05-22 05:54:18 +00007225 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00007226 }
7227
John McCall3ce3d232019-12-13 03:37:23 -05007228 unsigned NumBases = Record.readInt();
Guy Benyei11169dd2012-12-18 14:30:41 +00007229 void *Mem = Context.Allocate(sizeof(CXXBaseSpecifier) * NumBases);
Vedant Kumar48b4f762018-04-14 01:40:48 +00007230 CXXBaseSpecifier *Bases = new (Mem) CXXBaseSpecifier [NumBases];
Guy Benyei11169dd2012-12-18 14:30:41 +00007231 for (unsigned I = 0; I != NumBases; ++I)
John McCall3ce3d232019-12-13 03:37:23 -05007232 Bases[I] = Record.readCXXBaseSpecifier();
Guy Benyei11169dd2012-12-18 14:30:41 +00007233 return Bases;
7234}
7235
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007236serialization::DeclID
Guy Benyei11169dd2012-12-18 14:30:41 +00007237ASTReader::getGlobalDeclID(ModuleFile &F, LocalDeclID LocalID) const {
7238 if (LocalID < NUM_PREDEF_DECL_IDS)
7239 return LocalID;
7240
Richard Smith37a93df2017-02-18 00:32:02 +00007241 if (!F.ModuleOffsetMap.empty())
7242 ReadModuleOffsetMap(F);
7243
Guy Benyei11169dd2012-12-18 14:30:41 +00007244 ContinuousRangeMap<uint32_t, int, 2>::iterator I
7245 = F.DeclRemap.find(LocalID - NUM_PREDEF_DECL_IDS);
7246 assert(I != F.DeclRemap.end() && "Invalid index into decl index remap");
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007247
Guy Benyei11169dd2012-12-18 14:30:41 +00007248 return LocalID + I->second;
7249}
7250
7251bool ASTReader::isDeclIDFromModule(serialization::GlobalDeclID ID,
7252 ModuleFile &M) const {
Richard Smithfe620d22015-03-05 23:24:12 +00007253 // Predefined decls aren't from any module.
7254 if (ID < NUM_PREDEF_DECL_IDS)
7255 return false;
7256
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007257 return ID - NUM_PREDEF_DECL_IDS >= M.BaseDeclID &&
Richard Smithbcda1a92015-07-12 23:51:20 +00007258 ID - NUM_PREDEF_DECL_IDS < M.BaseDeclID + M.LocalNumDecls;
Guy Benyei11169dd2012-12-18 14:30:41 +00007259}
7260
Douglas Gregor9f782892013-01-21 15:25:38 +00007261ModuleFile *ASTReader::getOwningModuleFile(const Decl *D) {
Guy Benyei11169dd2012-12-18 14:30:41 +00007262 if (!D->isFromASTFile())
Craig Toppera13603a2014-05-22 05:54:18 +00007263 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00007264 GlobalDeclMapType::const_iterator I = GlobalDeclMap.find(D->getGlobalID());
7265 assert(I != GlobalDeclMap.end() && "Corrupted global declaration map");
7266 return I->second;
7267}
7268
7269SourceLocation ASTReader::getSourceLocationForDeclID(GlobalDeclID ID) {
7270 if (ID < NUM_PREDEF_DECL_IDS)
Vedant Kumar48b4f762018-04-14 01:40:48 +00007271 return SourceLocation();
Richard Smithcd45dbc2014-04-19 03:48:30 +00007272
Guy Benyei11169dd2012-12-18 14:30:41 +00007273 unsigned Index = ID - NUM_PREDEF_DECL_IDS;
7274
7275 if (Index > DeclsLoaded.size()) {
7276 Error("declaration ID out-of-range for AST file");
Vedant Kumar48b4f762018-04-14 01:40:48 +00007277 return SourceLocation();
Guy Benyei11169dd2012-12-18 14:30:41 +00007278 }
Richard Smithcd45dbc2014-04-19 03:48:30 +00007279
Guy Benyei11169dd2012-12-18 14:30:41 +00007280 if (Decl *D = DeclsLoaded[Index])
7281 return D->getLocation();
7282
Richard Smithcb34bd32016-03-27 07:28:06 +00007283 SourceLocation Loc;
7284 DeclCursorForID(ID, Loc);
7285 return Loc;
Guy Benyei11169dd2012-12-18 14:30:41 +00007286}
7287
Richard Smithfe620d22015-03-05 23:24:12 +00007288static Decl *getPredefinedDecl(ASTContext &Context, PredefinedDeclIDs ID) {
7289 switch (ID) {
7290 case PREDEF_DECL_NULL_ID:
7291 return nullptr;
7292
7293 case PREDEF_DECL_TRANSLATION_UNIT_ID:
7294 return Context.getTranslationUnitDecl();
7295
7296 case PREDEF_DECL_OBJC_ID_ID:
7297 return Context.getObjCIdDecl();
7298
7299 case PREDEF_DECL_OBJC_SEL_ID:
7300 return Context.getObjCSelDecl();
7301
7302 case PREDEF_DECL_OBJC_CLASS_ID:
7303 return Context.getObjCClassDecl();
7304
7305 case PREDEF_DECL_OBJC_PROTOCOL_ID:
7306 return Context.getObjCProtocolDecl();
7307
7308 case PREDEF_DECL_INT_128_ID:
7309 return Context.getInt128Decl();
7310
7311 case PREDEF_DECL_UNSIGNED_INT_128_ID:
7312 return Context.getUInt128Decl();
7313
7314 case PREDEF_DECL_OBJC_INSTANCETYPE_ID:
7315 return Context.getObjCInstanceTypeDecl();
7316
7317 case PREDEF_DECL_BUILTIN_VA_LIST_ID:
7318 return Context.getBuiltinVaListDecl();
Richard Smithf19e1272015-03-07 00:04:49 +00007319
Richard Smith9b88a4c2015-07-27 05:40:23 +00007320 case PREDEF_DECL_VA_LIST_TAG:
7321 return Context.getVaListTagDecl();
7322
Charles Davisc7d5c942015-09-17 20:55:33 +00007323 case PREDEF_DECL_BUILTIN_MS_VA_LIST_ID:
7324 return Context.getBuiltinMSVaListDecl();
7325
Richard Smithbab6df82020-04-11 22:15:29 -07007326 case PREDEF_DECL_BUILTIN_MS_GUID_ID:
7327 return Context.getMSGuidTagDecl();
7328
Richard Smithf19e1272015-03-07 00:04:49 +00007329 case PREDEF_DECL_EXTERN_C_CONTEXT_ID:
7330 return Context.getExternCContextDecl();
David Majnemerd9b1a4f2015-11-04 03:40:30 +00007331
7332 case PREDEF_DECL_MAKE_INTEGER_SEQ_ID:
7333 return Context.getMakeIntegerSeqDecl();
Quentin Colombet043406b2016-02-03 22:41:00 +00007334
7335 case PREDEF_DECL_CF_CONSTANT_STRING_ID:
7336 return Context.getCFConstantStringDecl();
Ben Langmuirf5416742016-02-04 00:55:24 +00007337
7338 case PREDEF_DECL_CF_CONSTANT_STRING_TAG_ID:
7339 return Context.getCFConstantStringTagDecl();
Eric Fiselier6ad68552016-07-01 01:24:09 +00007340
7341 case PREDEF_DECL_TYPE_PACK_ELEMENT_ID:
7342 return Context.getTypePackElementDecl();
Richard Smithfe620d22015-03-05 23:24:12 +00007343 }
Yaron Keren322bdad2015-03-06 07:49:14 +00007344 llvm_unreachable("PredefinedDeclIDs unknown enum value");
Richard Smithfe620d22015-03-05 23:24:12 +00007345}
7346
Richard Smithcd45dbc2014-04-19 03:48:30 +00007347Decl *ASTReader::GetExistingDecl(DeclID ID) {
Richard Smithdbafb6c2017-06-29 23:23:46 +00007348 assert(ContextObj && "reading decl with no AST context");
Richard Smithcd45dbc2014-04-19 03:48:30 +00007349 if (ID < NUM_PREDEF_DECL_IDS) {
Richard Smithdbafb6c2017-06-29 23:23:46 +00007350 Decl *D = getPredefinedDecl(*ContextObj, (PredefinedDeclIDs)ID);
Richard Smithfe620d22015-03-05 23:24:12 +00007351 if (D) {
7352 // Track that we have merged the declaration with ID \p ID into the
7353 // pre-existing predefined declaration \p D.
Richard Smith5fc18a92015-07-12 23:43:21 +00007354 auto &Merged = KeyDecls[D->getCanonicalDecl()];
Richard Smithfe620d22015-03-05 23:24:12 +00007355 if (Merged.empty())
7356 Merged.push_back(ID);
Guy Benyei11169dd2012-12-18 14:30:41 +00007357 }
Richard Smithfe620d22015-03-05 23:24:12 +00007358 return D;
Guy Benyei11169dd2012-12-18 14:30:41 +00007359 }
Richard Smithcd45dbc2014-04-19 03:48:30 +00007360
Guy Benyei11169dd2012-12-18 14:30:41 +00007361 unsigned Index = ID - NUM_PREDEF_DECL_IDS;
7362
7363 if (Index >= DeclsLoaded.size()) {
7364 assert(0 && "declaration ID out-of-range for AST file");
7365 Error("declaration ID out-of-range for AST file");
Craig Toppera13603a2014-05-22 05:54:18 +00007366 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00007367 }
Richard Smithcd45dbc2014-04-19 03:48:30 +00007368
7369 return DeclsLoaded[Index];
7370}
7371
7372Decl *ASTReader::GetDecl(DeclID ID) {
7373 if (ID < NUM_PREDEF_DECL_IDS)
7374 return GetExistingDecl(ID);
7375
7376 unsigned Index = ID - NUM_PREDEF_DECL_IDS;
7377
7378 if (Index >= DeclsLoaded.size()) {
7379 assert(0 && "declaration ID out-of-range for AST file");
7380 Error("declaration ID out-of-range for AST file");
Craig Toppera13603a2014-05-22 05:54:18 +00007381 return nullptr;
Richard Smithcd45dbc2014-04-19 03:48:30 +00007382 }
7383
Guy Benyei11169dd2012-12-18 14:30:41 +00007384 if (!DeclsLoaded[Index]) {
7385 ReadDeclRecord(ID);
7386 if (DeserializationListener)
7387 DeserializationListener->DeclRead(ID, DeclsLoaded[Index]);
7388 }
7389
7390 return DeclsLoaded[Index];
7391}
7392
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007393DeclID ASTReader::mapGlobalIDToModuleFileGlobalID(ModuleFile &M,
Guy Benyei11169dd2012-12-18 14:30:41 +00007394 DeclID GlobalID) {
7395 if (GlobalID < NUM_PREDEF_DECL_IDS)
7396 return GlobalID;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007397
Guy Benyei11169dd2012-12-18 14:30:41 +00007398 GlobalDeclMapType::const_iterator I = GlobalDeclMap.find(GlobalID);
7399 assert(I != GlobalDeclMap.end() && "Corrupted global declaration map");
7400 ModuleFile *Owner = I->second;
7401
7402 llvm::DenseMap<ModuleFile *, serialization::DeclID>::iterator Pos
7403 = M.GlobalToLocalDeclIDs.find(Owner);
7404 if (Pos == M.GlobalToLocalDeclIDs.end())
7405 return 0;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007406
Guy Benyei11169dd2012-12-18 14:30:41 +00007407 return GlobalID - Owner->BaseDeclID + Pos->second;
7408}
7409
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007410serialization::DeclID ASTReader::ReadDeclID(ModuleFile &F,
Guy Benyei11169dd2012-12-18 14:30:41 +00007411 const RecordData &Record,
7412 unsigned &Idx) {
7413 if (Idx >= Record.size()) {
7414 Error("Corrupted AST file");
7415 return 0;
7416 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007417
Guy Benyei11169dd2012-12-18 14:30:41 +00007418 return getGlobalDeclID(F, Record[Idx++]);
7419}
7420
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007421/// Resolve the offset of a statement into a statement.
Guy Benyei11169dd2012-12-18 14:30:41 +00007422///
7423/// This operation will read a new statement from the external
7424/// source each time it is called, and is meant to be used via a
7425/// LazyOffsetPtr (which is used by Decls for the body of functions, etc).
7426Stmt *ASTReader::GetExternalDeclStmt(uint64_t Offset) {
7427 // Switch case IDs are per Decl.
7428 ClearSwitchCaseIDs();
7429
7430 // Offset here is a global offset across the entire chain.
7431 RecordLocation Loc = getLocalBitOffset(Offset);
JF Bastien0e828952019-06-26 19:50:12 +00007432 if (llvm::Error Err = Loc.F->DeclsCursor.JumpToBit(Loc.Offset)) {
7433 Error(std::move(Err));
7434 return nullptr;
7435 }
David Blaikie9fd16f82017-03-08 23:57:08 +00007436 assert(NumCurrentElementsDeserializing == 0 &&
7437 "should not be called while already deserializing");
7438 Deserializing D(this);
Guy Benyei11169dd2012-12-18 14:30:41 +00007439 return ReadStmtFromStream(*Loc.F);
7440}
7441
Richard Smith3cb15722015-08-05 22:41:45 +00007442void ASTReader::FindExternalLexicalDecls(
7443 const DeclContext *DC, llvm::function_ref<bool(Decl::Kind)> IsKindWeWant,
7444 SmallVectorImpl<Decl *> &Decls) {
Richard Smith82f8fcd2015-08-06 22:07:25 +00007445 bool PredefsVisited[NUM_PREDEF_DECL_IDS] = {};
7446
Richard Smith9ccdd932015-08-06 22:14:12 +00007447 auto Visit = [&] (ModuleFile *M, LexicalContents LexicalDecls) {
Richard Smith82f8fcd2015-08-06 22:07:25 +00007448 assert(LexicalDecls.size() % 2 == 0 && "expected an even number of entries");
7449 for (int I = 0, N = LexicalDecls.size(); I != N; I += 2) {
7450 auto K = (Decl::Kind)+LexicalDecls[I];
7451 if (!IsKindWeWant(K))
7452 continue;
7453
7454 auto ID = (serialization::DeclID)+LexicalDecls[I + 1];
7455
7456 // Don't add predefined declarations to the lexical context more
7457 // than once.
7458 if (ID < NUM_PREDEF_DECL_IDS) {
7459 if (PredefsVisited[ID])
7460 continue;
7461
7462 PredefsVisited[ID] = true;
7463 }
7464
7465 if (Decl *D = GetLocalDecl(*M, ID)) {
Richard Smith2317a3e2015-08-11 21:21:20 +00007466 assert(D->getKind() == K && "wrong kind for lexical decl");
Richard Smith82f8fcd2015-08-06 22:07:25 +00007467 if (!DC->isDeclInLexicalTraversal(D))
7468 Decls.push_back(D);
7469 }
7470 }
7471 };
7472
7473 if (isa<TranslationUnitDecl>(DC)) {
7474 for (auto Lexical : TULexicalDecls)
7475 Visit(Lexical.first, Lexical.second);
7476 } else {
7477 auto I = LexicalDecls.find(DC);
7478 if (I != LexicalDecls.end())
Richard Smith9c9173d2015-08-11 22:00:24 +00007479 Visit(I->second.first, I->second.second);
Richard Smith82f8fcd2015-08-06 22:07:25 +00007480 }
7481
Guy Benyei11169dd2012-12-18 14:30:41 +00007482 ++NumLexicalDeclContextsRead;
Guy Benyei11169dd2012-12-18 14:30:41 +00007483}
7484
7485namespace {
7486
7487class DeclIDComp {
7488 ASTReader &Reader;
7489 ModuleFile &Mod;
7490
7491public:
7492 DeclIDComp(ASTReader &Reader, ModuleFile &M) : Reader(Reader), Mod(M) {}
7493
7494 bool operator()(LocalDeclID L, LocalDeclID R) const {
7495 SourceLocation LHS = getLocation(L);
7496 SourceLocation RHS = getLocation(R);
7497 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
7498 }
7499
7500 bool operator()(SourceLocation LHS, LocalDeclID R) const {
7501 SourceLocation RHS = getLocation(R);
7502 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
7503 }
7504
7505 bool operator()(LocalDeclID L, SourceLocation RHS) const {
7506 SourceLocation LHS = getLocation(L);
7507 return Reader.getSourceManager().isBeforeInTranslationUnit(LHS, RHS);
7508 }
7509
7510 SourceLocation getLocation(LocalDeclID ID) const {
7511 return Reader.getSourceManager().getFileLoc(
7512 Reader.getSourceLocationForDeclID(Reader.getGlobalDeclID(Mod, ID)));
7513 }
7514};
7515
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00007516} // namespace
Guy Benyei11169dd2012-12-18 14:30:41 +00007517
7518void ASTReader::FindFileRegionDecls(FileID File,
7519 unsigned Offset, unsigned Length,
7520 SmallVectorImpl<Decl *> &Decls) {
7521 SourceManager &SM = getSourceManager();
7522
7523 llvm::DenseMap<FileID, FileDeclsInfo>::iterator I = FileDeclIDs.find(File);
7524 if (I == FileDeclIDs.end())
7525 return;
7526
7527 FileDeclsInfo &DInfo = I->second;
7528 if (DInfo.Decls.empty())
7529 return;
7530
7531 SourceLocation
7532 BeginLoc = SM.getLocForStartOfFile(File).getLocWithOffset(Offset);
7533 SourceLocation EndLoc = BeginLoc.getLocWithOffset(Length);
7534
7535 DeclIDComp DIDComp(*this, *DInfo.Mod);
Fangrui Song7264a472019-07-03 08:13:17 +00007536 ArrayRef<serialization::LocalDeclID>::iterator BeginIt =
7537 llvm::lower_bound(DInfo.Decls, BeginLoc, DIDComp);
Guy Benyei11169dd2012-12-18 14:30:41 +00007538 if (BeginIt != DInfo.Decls.begin())
7539 --BeginIt;
7540
7541 // If we are pointing at a top-level decl inside an objc container, we need
7542 // to backtrack until we find it otherwise we will fail to report that the
7543 // region overlaps with an objc container.
7544 while (BeginIt != DInfo.Decls.begin() &&
7545 GetDecl(getGlobalDeclID(*DInfo.Mod, *BeginIt))
7546 ->isTopLevelDeclInObjCContainer())
7547 --BeginIt;
7548
Fangrui Song7264a472019-07-03 08:13:17 +00007549 ArrayRef<serialization::LocalDeclID>::iterator EndIt =
7550 llvm::upper_bound(DInfo.Decls, EndLoc, DIDComp);
Guy Benyei11169dd2012-12-18 14:30:41 +00007551 if (EndIt != DInfo.Decls.end())
7552 ++EndIt;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007553
Guy Benyei11169dd2012-12-18 14:30:41 +00007554 for (ArrayRef<serialization::LocalDeclID>::iterator
7555 DIt = BeginIt; DIt != EndIt; ++DIt)
7556 Decls.push_back(GetDecl(getGlobalDeclID(*DInfo.Mod, *DIt)));
7557}
7558
Richard Smith9ce12e32013-02-07 03:30:24 +00007559bool
Guy Benyei11169dd2012-12-18 14:30:41 +00007560ASTReader::FindExternalVisibleDeclsByName(const DeclContext *DC,
7561 DeclarationName Name) {
Richard Smithd88a7f12015-09-01 20:35:42 +00007562 assert(DC->hasExternalVisibleStorage() && DC == DC->getPrimaryContext() &&
Guy Benyei11169dd2012-12-18 14:30:41 +00007563 "DeclContext has no visible decls in storage");
7564 if (!Name)
Richard Smith9ce12e32013-02-07 03:30:24 +00007565 return false;
Guy Benyei11169dd2012-12-18 14:30:41 +00007566
Richard Smithd88a7f12015-09-01 20:35:42 +00007567 auto It = Lookups.find(DC);
7568 if (It == Lookups.end())
7569 return false;
7570
Richard Smith8c913ec2014-08-14 02:21:01 +00007571 Deserializing LookupResults(this);
7572
Richard Smithd88a7f12015-09-01 20:35:42 +00007573 // Load the list of declarations.
Guy Benyei11169dd2012-12-18 14:30:41 +00007574 SmallVector<NamedDecl *, 64> Decls;
Vedant Kumar48b4f762018-04-14 01:40:48 +00007575 for (DeclID ID : It->second.Table.find(Name)) {
7576 NamedDecl *ND = cast<NamedDecl>(GetDecl(ID));
Richard Smithd88a7f12015-09-01 20:35:42 +00007577 if (ND->getDeclName() == Name)
7578 Decls.push_back(ND);
7579 }
Richard Smithcd45dbc2014-04-19 03:48:30 +00007580
Guy Benyei11169dd2012-12-18 14:30:41 +00007581 ++NumVisibleDeclContextsRead;
7582 SetExternalVisibleDeclsForName(DC, Name, Decls);
Richard Smith9ce12e32013-02-07 03:30:24 +00007583 return !Decls.empty();
Guy Benyei11169dd2012-12-18 14:30:41 +00007584}
7585
Guy Benyei11169dd2012-12-18 14:30:41 +00007586void ASTReader::completeVisibleDeclsMap(const DeclContext *DC) {
7587 if (!DC->hasExternalVisibleStorage())
7588 return;
Richard Smithd88a7f12015-09-01 20:35:42 +00007589
7590 auto It = Lookups.find(DC);
7591 assert(It != Lookups.end() &&
7592 "have external visible storage but no lookup tables");
7593
Craig Topper79be4cd2013-07-05 04:33:53 +00007594 DeclsMap Decls;
Guy Benyei11169dd2012-12-18 14:30:41 +00007595
Vedant Kumar48b4f762018-04-14 01:40:48 +00007596 for (DeclID ID : It->second.Table.findAll()) {
7597 NamedDecl *ND = cast<NamedDecl>(GetDecl(ID));
Richard Smithd88a7f12015-09-01 20:35:42 +00007598 Decls[ND->getDeclName()].push_back(ND);
Guy Benyei11169dd2012-12-18 14:30:41 +00007599 }
7600
Guy Benyei11169dd2012-12-18 14:30:41 +00007601 ++NumVisibleDeclContextsRead;
7602
Vedant Kumar48b4f762018-04-14 01:40:48 +00007603 for (DeclsMap::iterator I = Decls.begin(), E = Decls.end(); I != E; ++I) {
7604 SetExternalVisibleDeclsForName(DC, I->first, I->second);
7605 }
Guy Benyei11169dd2012-12-18 14:30:41 +00007606 const_cast<DeclContext *>(DC)->setHasExternalVisibleStorage(false);
7607}
7608
Richard Smithd88a7f12015-09-01 20:35:42 +00007609const serialization::reader::DeclContextLookupTable *
7610ASTReader::getLoadedLookupTables(DeclContext *Primary) const {
7611 auto I = Lookups.find(Primary);
7612 return I == Lookups.end() ? nullptr : &I->second;
7613}
7614
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007615/// Under non-PCH compilation the consumer receives the objc methods
Guy Benyei11169dd2012-12-18 14:30:41 +00007616/// before receiving the implementation, and codegen depends on this.
7617/// We simulate this by deserializing and passing to consumer the methods of the
7618/// implementation before passing the deserialized implementation decl.
7619static void PassObjCImplDeclToConsumer(ObjCImplDecl *ImplD,
7620 ASTConsumer *Consumer) {
7621 assert(ImplD && Consumer);
7622
Aaron Ballmanaff18c02014-03-13 19:03:34 +00007623 for (auto *I : ImplD->methods())
7624 Consumer->HandleInterestingDecl(DeclGroupRef(I));
Guy Benyei11169dd2012-12-18 14:30:41 +00007625
7626 Consumer->HandleInterestingDecl(DeclGroupRef(ImplD));
7627}
7628
Guy Benyei11169dd2012-12-18 14:30:41 +00007629void ASTReader::PassInterestingDeclToConsumer(Decl *D) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00007630 if (ObjCImplDecl *ImplD = dyn_cast<ObjCImplDecl>(D))
Guy Benyei11169dd2012-12-18 14:30:41 +00007631 PassObjCImplDeclToConsumer(ImplD, Consumer);
7632 else
7633 Consumer->HandleInterestingDecl(DeclGroupRef(D));
7634}
7635
7636void ASTReader::StartTranslationUnit(ASTConsumer *Consumer) {
7637 this->Consumer = Consumer;
7638
Richard Smith9e2341d2015-03-23 03:25:59 +00007639 if (Consumer)
7640 PassInterestingDeclsToConsumer();
Richard Smith7f330cd2015-03-18 01:42:29 +00007641
7642 if (DeserializationListener)
7643 DeserializationListener->ReaderInitialized(this);
Guy Benyei11169dd2012-12-18 14:30:41 +00007644}
7645
7646void ASTReader::PrintStats() {
7647 std::fprintf(stderr, "*** AST File Statistics:\n");
7648
7649 unsigned NumTypesLoaded
7650 = TypesLoaded.size() - std::count(TypesLoaded.begin(), TypesLoaded.end(),
7651 QualType());
7652 unsigned NumDeclsLoaded
7653 = DeclsLoaded.size() - std::count(DeclsLoaded.begin(), DeclsLoaded.end(),
Craig Toppera13603a2014-05-22 05:54:18 +00007654 (Decl *)nullptr);
Guy Benyei11169dd2012-12-18 14:30:41 +00007655 unsigned NumIdentifiersLoaded
7656 = IdentifiersLoaded.size() - std::count(IdentifiersLoaded.begin(),
7657 IdentifiersLoaded.end(),
Craig Toppera13603a2014-05-22 05:54:18 +00007658 (IdentifierInfo *)nullptr);
Guy Benyei11169dd2012-12-18 14:30:41 +00007659 unsigned NumMacrosLoaded
7660 = MacrosLoaded.size() - std::count(MacrosLoaded.begin(),
7661 MacrosLoaded.end(),
Craig Toppera13603a2014-05-22 05:54:18 +00007662 (MacroInfo *)nullptr);
Guy Benyei11169dd2012-12-18 14:30:41 +00007663 unsigned NumSelectorsLoaded
7664 = SelectorsLoaded.size() - std::count(SelectorsLoaded.begin(),
7665 SelectorsLoaded.end(),
7666 Selector());
7667
7668 if (unsigned TotalNumSLocEntries = getTotalNumSLocs())
7669 std::fprintf(stderr, " %u/%u source location entries read (%f%%)\n",
7670 NumSLocEntriesRead, TotalNumSLocEntries,
7671 ((float)NumSLocEntriesRead/TotalNumSLocEntries * 100));
7672 if (!TypesLoaded.empty())
7673 std::fprintf(stderr, " %u/%u types read (%f%%)\n",
7674 NumTypesLoaded, (unsigned)TypesLoaded.size(),
7675 ((float)NumTypesLoaded/TypesLoaded.size() * 100));
7676 if (!DeclsLoaded.empty())
7677 std::fprintf(stderr, " %u/%u declarations read (%f%%)\n",
7678 NumDeclsLoaded, (unsigned)DeclsLoaded.size(),
7679 ((float)NumDeclsLoaded/DeclsLoaded.size() * 100));
7680 if (!IdentifiersLoaded.empty())
7681 std::fprintf(stderr, " %u/%u identifiers read (%f%%)\n",
7682 NumIdentifiersLoaded, (unsigned)IdentifiersLoaded.size(),
7683 ((float)NumIdentifiersLoaded/IdentifiersLoaded.size() * 100));
7684 if (!MacrosLoaded.empty())
7685 std::fprintf(stderr, " %u/%u macros read (%f%%)\n",
7686 NumMacrosLoaded, (unsigned)MacrosLoaded.size(),
7687 ((float)NumMacrosLoaded/MacrosLoaded.size() * 100));
7688 if (!SelectorsLoaded.empty())
7689 std::fprintf(stderr, " %u/%u selectors read (%f%%)\n",
7690 NumSelectorsLoaded, (unsigned)SelectorsLoaded.size(),
7691 ((float)NumSelectorsLoaded/SelectorsLoaded.size() * 100));
7692 if (TotalNumStatements)
7693 std::fprintf(stderr, " %u/%u statements read (%f%%)\n",
7694 NumStatementsRead, TotalNumStatements,
7695 ((float)NumStatementsRead/TotalNumStatements * 100));
7696 if (TotalNumMacros)
7697 std::fprintf(stderr, " %u/%u macros read (%f%%)\n",
7698 NumMacrosRead, TotalNumMacros,
7699 ((float)NumMacrosRead/TotalNumMacros * 100));
7700 if (TotalLexicalDeclContexts)
7701 std::fprintf(stderr, " %u/%u lexical declcontexts read (%f%%)\n",
7702 NumLexicalDeclContextsRead, TotalLexicalDeclContexts,
7703 ((float)NumLexicalDeclContextsRead/TotalLexicalDeclContexts
7704 * 100));
7705 if (TotalVisibleDeclContexts)
7706 std::fprintf(stderr, " %u/%u visible declcontexts read (%f%%)\n",
7707 NumVisibleDeclContextsRead, TotalVisibleDeclContexts,
7708 ((float)NumVisibleDeclContextsRead/TotalVisibleDeclContexts
7709 * 100));
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00007710 if (TotalNumMethodPoolEntries)
Guy Benyei11169dd2012-12-18 14:30:41 +00007711 std::fprintf(stderr, " %u/%u method pool entries read (%f%%)\n",
7712 NumMethodPoolEntriesRead, TotalNumMethodPoolEntries,
7713 ((float)NumMethodPoolEntriesRead/TotalNumMethodPoolEntries
7714 * 100));
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00007715 if (NumMethodPoolLookups)
Douglas Gregorad2f7a52013-01-28 17:54:36 +00007716 std::fprintf(stderr, " %u/%u method pool lookups succeeded (%f%%)\n",
7717 NumMethodPoolHits, NumMethodPoolLookups,
7718 ((float)NumMethodPoolHits/NumMethodPoolLookups * 100.0));
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00007719 if (NumMethodPoolTableLookups)
Douglas Gregorad2f7a52013-01-28 17:54:36 +00007720 std::fprintf(stderr, " %u/%u method pool table lookups succeeded (%f%%)\n",
7721 NumMethodPoolTableHits, NumMethodPoolTableLookups,
7722 ((float)NumMethodPoolTableHits/NumMethodPoolTableLookups
7723 * 100.0));
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00007724 if (NumIdentifierLookupHits)
Douglas Gregor00a50f72013-01-25 00:38:33 +00007725 std::fprintf(stderr,
7726 " %u / %u identifier table lookups succeeded (%f%%)\n",
7727 NumIdentifierLookupHits, NumIdentifierLookups,
7728 (double)NumIdentifierLookupHits*100.0/NumIdentifierLookups);
Douglas Gregor00a50f72013-01-25 00:38:33 +00007729
Douglas Gregore060e572013-01-25 01:03:03 +00007730 if (GlobalIndex) {
7731 std::fprintf(stderr, "\n");
7732 GlobalIndex->printStats();
7733 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007734
Guy Benyei11169dd2012-12-18 14:30:41 +00007735 std::fprintf(stderr, "\n");
7736 dump();
7737 std::fprintf(stderr, "\n");
7738}
7739
7740template<typename Key, typename ModuleFile, unsigned InitialCapacity>
Vassil Vassilevb2710682017-03-02 18:13:19 +00007741LLVM_DUMP_METHOD static void
Guy Benyei11169dd2012-12-18 14:30:41 +00007742dumpModuleIDMap(StringRef Name,
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007743 const ContinuousRangeMap<Key, ModuleFile *,
Guy Benyei11169dd2012-12-18 14:30:41 +00007744 InitialCapacity> &Map) {
7745 if (Map.begin() == Map.end())
7746 return;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007747
Vedant Kumar48b4f762018-04-14 01:40:48 +00007748 using MapType = ContinuousRangeMap<Key, ModuleFile *, InitialCapacity>;
7749
Guy Benyei11169dd2012-12-18 14:30:41 +00007750 llvm::errs() << Name << ":\n";
Vedant Kumar48b4f762018-04-14 01:40:48 +00007751 for (typename MapType::const_iterator I = Map.begin(), IEnd = Map.end();
7752 I != IEnd; ++I) {
7753 llvm::errs() << " " << I->first << " -> " << I->second->FileName
7754 << "\n";
7755 }
Guy Benyei11169dd2012-12-18 14:30:41 +00007756}
7757
Yaron Kerencdae9412016-01-29 19:38:18 +00007758LLVM_DUMP_METHOD void ASTReader::dump() {
Guy Benyei11169dd2012-12-18 14:30:41 +00007759 llvm::errs() << "*** PCH/ModuleFile Remappings:\n";
7760 dumpModuleIDMap("Global bit offset map", GlobalBitOffsetsMap);
7761 dumpModuleIDMap("Global source location entry map", GlobalSLocEntryMap);
7762 dumpModuleIDMap("Global type map", GlobalTypeMap);
7763 dumpModuleIDMap("Global declaration map", GlobalDeclMap);
7764 dumpModuleIDMap("Global identifier map", GlobalIdentifierMap);
7765 dumpModuleIDMap("Global macro map", GlobalMacroMap);
7766 dumpModuleIDMap("Global submodule map", GlobalSubmoduleMap);
7767 dumpModuleIDMap("Global selector map", GlobalSelectorMap);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007768 dumpModuleIDMap("Global preprocessed entity map",
Guy Benyei11169dd2012-12-18 14:30:41 +00007769 GlobalPreprocessedEntityMap);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00007770
Guy Benyei11169dd2012-12-18 14:30:41 +00007771 llvm::errs() << "\n*** PCH/Modules Loaded:";
Vedant Kumar48b4f762018-04-14 01:40:48 +00007772 for (ModuleFile &M : ModuleMgr)
Duncan P. N. Exon Smith96a06e02017-01-28 22:15:22 +00007773 M.dump();
Guy Benyei11169dd2012-12-18 14:30:41 +00007774}
7775
7776/// Return the amount of memory used by memory buffers, breaking down
7777/// by heap-backed versus mmap'ed memory.
7778void ASTReader::getMemoryBufferSizes(MemoryBufferSizes &sizes) const {
Vedant Kumar48b4f762018-04-14 01:40:48 +00007779 for (ModuleFile &I : ModuleMgr) {
Duncan P. N. Exon Smith030d7d62017-03-20 17:58:26 +00007780 if (llvm::MemoryBuffer *buf = I.Buffer) {
Guy Benyei11169dd2012-12-18 14:30:41 +00007781 size_t bytes = buf->getBufferSize();
7782 switch (buf->getBufferKind()) {
7783 case llvm::MemoryBuffer::MemoryBuffer_Malloc:
7784 sizes.malloc_bytes += bytes;
7785 break;
7786 case llvm::MemoryBuffer::MemoryBuffer_MMap:
7787 sizes.mmap_bytes += bytes;
7788 break;
7789 }
7790 }
7791 }
7792}
7793
7794void ASTReader::InitializeSema(Sema &S) {
7795 SemaObj = &S;
7796 S.addExternalSource(this);
7797
7798 // Makes sure any declarations that were deserialized "too early"
7799 // still get added to the identifier's declaration chains.
Vedant Kumar48b4f762018-04-14 01:40:48 +00007800 for (uint64_t ID : PreloadedDeclIDs) {
7801 NamedDecl *D = cast<NamedDecl>(GetDecl(ID));
Ben Langmuir5418f402014-09-10 21:29:41 +00007802 pushExternalDeclIntoScope(D, D->getDeclName());
Guy Benyei11169dd2012-12-18 14:30:41 +00007803 }
Ben Langmuir5418f402014-09-10 21:29:41 +00007804 PreloadedDeclIDs.clear();
Guy Benyei11169dd2012-12-18 14:30:41 +00007805
Richard Smith3d8e97e2013-10-18 06:54:39 +00007806 // FIXME: What happens if these are changed by a module import?
Guy Benyei11169dd2012-12-18 14:30:41 +00007807 if (!FPPragmaOptions.empty()) {
7808 assert(FPPragmaOptions.size() == 1 && "Wrong number of FP_PRAGMA_OPTIONS");
Melanie Blower8812b0c2020-04-16 08:45:26 -07007809 SemaObj->CurFPFeatures = FPOptions(FPPragmaOptions[0]);
Guy Benyei11169dd2012-12-18 14:30:41 +00007810 }
7811
Yaxun Liu5b746652016-12-18 05:18:55 +00007812 SemaObj->OpenCLFeatures.copy(OpenCLExtensions);
7813 SemaObj->OpenCLTypeExtMap = OpenCLTypeExtMap;
7814 SemaObj->OpenCLDeclExtMap = OpenCLDeclExtMap;
Richard Smith3d8e97e2013-10-18 06:54:39 +00007815
7816 UpdateSema();
7817}
7818
7819void ASTReader::UpdateSema() {
7820 assert(SemaObj && "no Sema to update");
7821
7822 // Load the offsets of the declarations that Sema references.
7823 // They will be lazily deserialized when needed.
7824 if (!SemaDeclRefs.empty()) {
Richard Smith96269c52016-09-29 22:49:46 +00007825 assert(SemaDeclRefs.size() % 3 == 0);
7826 for (unsigned I = 0; I != SemaDeclRefs.size(); I += 3) {
Richard Smith3d8e97e2013-10-18 06:54:39 +00007827 if (!SemaObj->StdNamespace)
7828 SemaObj->StdNamespace = SemaDeclRefs[I];
7829 if (!SemaObj->StdBadAlloc)
7830 SemaObj->StdBadAlloc = SemaDeclRefs[I+1];
Richard Smith96269c52016-09-29 22:49:46 +00007831 if (!SemaObj->StdAlignValT)
7832 SemaObj->StdAlignValT = SemaDeclRefs[I+2];
Richard Smith3d8e97e2013-10-18 06:54:39 +00007833 }
7834 SemaDeclRefs.clear();
7835 }
Dario Domizioli13a0a382014-05-23 12:13:25 +00007836
Nico Weber779355f2016-03-02 23:22:00 +00007837 // Update the state of pragmas. Use the same API as if we had encountered the
7838 // pragma in the source.
Dario Domizioli13a0a382014-05-23 12:13:25 +00007839 if(OptimizeOffPragmaLocation.isValid())
Rui Ueyama49a3ad22019-07-16 04:46:31 +00007840 SemaObj->ActOnPragmaOptimize(/* On = */ false, OptimizeOffPragmaLocation);
Nico Weber779355f2016-03-02 23:22:00 +00007841 if (PragmaMSStructState != -1)
7842 SemaObj->ActOnPragmaMSStruct((PragmaMSStructKind)PragmaMSStructState);
Nico Weber42932312016-03-03 00:17:35 +00007843 if (PointersToMembersPragmaLocation.isValid()) {
7844 SemaObj->ActOnPragmaMSPointersToMembers(
7845 (LangOptions::PragmaMSPointersToMembersKind)
7846 PragmaMSPointersToMembersState,
7847 PointersToMembersPragmaLocation);
7848 }
Justin Lebar67a78a62016-10-08 22:15:58 +00007849 SemaObj->ForceCUDAHostDeviceDepth = ForceCUDAHostDeviceDepth;
Alex Lorenz7d7e1e02017-03-31 15:36:21 +00007850
7851 if (PragmaPackCurrentValue) {
7852 // The bottom of the stack might have a default value. It must be adjusted
7853 // to the current value to ensure that the packing state is preserved after
7854 // popping entries that were included/imported from a PCH/module.
7855 bool DropFirst = false;
7856 if (!PragmaPackStack.empty() &&
7857 PragmaPackStack.front().Location.isInvalid()) {
7858 assert(PragmaPackStack.front().Value == SemaObj->PackStack.DefaultValue &&
7859 "Expected a default alignment value");
7860 SemaObj->PackStack.Stack.emplace_back(
7861 PragmaPackStack.front().SlotLabel, SemaObj->PackStack.CurrentValue,
Alex Lorenz45b40142017-07-28 14:41:21 +00007862 SemaObj->PackStack.CurrentPragmaLocation,
7863 PragmaPackStack.front().PushLocation);
Alex Lorenz7d7e1e02017-03-31 15:36:21 +00007864 DropFirst = true;
7865 }
7866 for (const auto &Entry :
7867 llvm::makeArrayRef(PragmaPackStack).drop_front(DropFirst ? 1 : 0))
7868 SemaObj->PackStack.Stack.emplace_back(Entry.SlotLabel, Entry.Value,
Alex Lorenz45b40142017-07-28 14:41:21 +00007869 Entry.Location, Entry.PushLocation);
Alex Lorenz7d7e1e02017-03-31 15:36:21 +00007870 if (PragmaPackCurrentLocation.isInvalid()) {
7871 assert(*PragmaPackCurrentValue == SemaObj->PackStack.DefaultValue &&
7872 "Expected a default alignment value");
7873 // Keep the current values.
7874 } else {
7875 SemaObj->PackStack.CurrentValue = *PragmaPackCurrentValue;
7876 SemaObj->PackStack.CurrentPragmaLocation = PragmaPackCurrentLocation;
7877 }
7878 }
Melanie Blowerf5360d42020-05-01 10:32:06 -07007879 if (FpPragmaCurrentValue) {
7880 // The bottom of the stack might have a default value. It must be adjusted
7881 // to the current value to ensure that fp-pragma state is preserved after
7882 // popping entries that were included/imported from a PCH/module.
7883 bool DropFirst = false;
7884 if (!FpPragmaStack.empty() && FpPragmaStack.front().Location.isInvalid()) {
7885 assert(FpPragmaStack.front().Value ==
7886 SemaObj->FpPragmaStack.DefaultValue &&
7887 "Expected a default pragma float_control value");
7888 SemaObj->FpPragmaStack.Stack.emplace_back(
7889 FpPragmaStack.front().SlotLabel, SemaObj->FpPragmaStack.CurrentValue,
7890 SemaObj->FpPragmaStack.CurrentPragmaLocation,
7891 FpPragmaStack.front().PushLocation);
7892 DropFirst = true;
7893 }
7894 for (const auto &Entry :
7895 llvm::makeArrayRef(FpPragmaStack).drop_front(DropFirst ? 1 : 0))
7896 SemaObj->FpPragmaStack.Stack.emplace_back(
7897 Entry.SlotLabel, Entry.Value, Entry.Location, Entry.PushLocation);
7898 if (FpPragmaCurrentLocation.isInvalid()) {
7899 assert(*FpPragmaCurrentValue == SemaObj->FpPragmaStack.DefaultValue &&
7900 "Expected a default pragma float_control value");
7901 // Keep the current values.
7902 } else {
7903 SemaObj->FpPragmaStack.CurrentValue = *FpPragmaCurrentValue;
7904 SemaObj->FpPragmaStack.CurrentPragmaLocation = FpPragmaCurrentLocation;
7905 }
7906 }
Guy Benyei11169dd2012-12-18 14:30:41 +00007907}
7908
Richard Smitha8d5b6a2015-07-17 19:51:03 +00007909IdentifierInfo *ASTReader::get(StringRef Name) {
Guy Benyei11169dd2012-12-18 14:30:41 +00007910 // Note that we are loading an identifier.
7911 Deserializing AnIdentifier(this);
Douglas Gregore060e572013-01-25 01:03:03 +00007912
Douglas Gregor7211ac12013-01-25 23:32:03 +00007913 IdentifierLookupVisitor Visitor(Name, /*PriorGeneration=*/0,
Douglas Gregor00a50f72013-01-25 00:38:33 +00007914 NumIdentifierLookups,
7915 NumIdentifierLookupHits);
Richard Smith33e0f7e2015-07-22 02:08:40 +00007916
7917 // We don't need to do identifier table lookups in C++ modules (we preload
7918 // all interesting declarations, and don't need to use the scope for name
7919 // lookups). Perform the lookup in PCH files, though, since we don't build
7920 // a complete initial identifier table if we're carrying on from a PCH.
Richard Smithdbafb6c2017-06-29 23:23:46 +00007921 if (PP.getLangOpts().CPlusPlus) {
Richard Smith33e0f7e2015-07-22 02:08:40 +00007922 for (auto F : ModuleMgr.pch_modules())
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00007923 if (Visitor(*F))
Richard Smith33e0f7e2015-07-22 02:08:40 +00007924 break;
7925 } else {
7926 // If there is a global index, look there first to determine which modules
7927 // provably do not have any results for this identifier.
7928 GlobalModuleIndex::HitSet Hits;
7929 GlobalModuleIndex::HitSet *HitsPtr = nullptr;
7930 if (!loadGlobalIndex()) {
7931 if (GlobalIndex->lookupIdentifier(Name, Hits)) {
7932 HitsPtr = &Hits;
7933 }
7934 }
7935
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00007936 ModuleMgr.visit(Visitor, HitsPtr);
Richard Smith33e0f7e2015-07-22 02:08:40 +00007937 }
7938
Guy Benyei11169dd2012-12-18 14:30:41 +00007939 IdentifierInfo *II = Visitor.getIdentifierInfo();
7940 markIdentifierUpToDate(II);
7941 return II;
7942}
7943
7944namespace clang {
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00007945
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007946 /// An identifier-lookup iterator that enumerates all of the
Guy Benyei11169dd2012-12-18 14:30:41 +00007947 /// identifiers stored within a set of AST files.
7948 class ASTIdentifierIterator : public IdentifierIterator {
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007949 /// The AST reader whose identifiers are being enumerated.
Guy Benyei11169dd2012-12-18 14:30:41 +00007950 const ASTReader &Reader;
7951
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007952 /// The current index into the chain of AST files stored in
Guy Benyei11169dd2012-12-18 14:30:41 +00007953 /// the AST reader.
7954 unsigned Index;
7955
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007956 /// The current position within the identifier lookup table
Guy Benyei11169dd2012-12-18 14:30:41 +00007957 /// of the current AST file.
7958 ASTIdentifierLookupTable::key_iterator Current;
7959
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007960 /// The end position within the identifier lookup table of
Guy Benyei11169dd2012-12-18 14:30:41 +00007961 /// the current AST file.
7962 ASTIdentifierLookupTable::key_iterator End;
7963
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00007964 /// Whether to skip any modules in the ASTReader.
Ben Langmuir537c5b52016-05-04 00:53:13 +00007965 bool SkipModules;
7966
Guy Benyei11169dd2012-12-18 14:30:41 +00007967 public:
Ben Langmuir537c5b52016-05-04 00:53:13 +00007968 explicit ASTIdentifierIterator(const ASTReader &Reader,
7969 bool SkipModules = false);
Guy Benyei11169dd2012-12-18 14:30:41 +00007970
Craig Topper3e89dfe2014-03-13 02:13:41 +00007971 StringRef Next() override;
Guy Benyei11169dd2012-12-18 14:30:41 +00007972 };
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00007973
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00007974} // namespace clang
Guy Benyei11169dd2012-12-18 14:30:41 +00007975
Ben Langmuir537c5b52016-05-04 00:53:13 +00007976ASTIdentifierIterator::ASTIdentifierIterator(const ASTReader &Reader,
7977 bool SkipModules)
7978 : Reader(Reader), Index(Reader.ModuleMgr.size()), SkipModules(SkipModules) {
Guy Benyei11169dd2012-12-18 14:30:41 +00007979}
7980
7981StringRef ASTIdentifierIterator::Next() {
7982 while (Current == End) {
7983 // If we have exhausted all of our AST files, we're done.
7984 if (Index == 0)
Vedant Kumar48b4f762018-04-14 01:40:48 +00007985 return StringRef();
Guy Benyei11169dd2012-12-18 14:30:41 +00007986
7987 --Index;
Ben Langmuir537c5b52016-05-04 00:53:13 +00007988 ModuleFile &F = Reader.ModuleMgr[Index];
7989 if (SkipModules && F.isModule())
7990 continue;
7991
Vedant Kumar48b4f762018-04-14 01:40:48 +00007992 ASTIdentifierLookupTable *IdTable =
7993 (ASTIdentifierLookupTable *)F.IdentifierLookupTable;
Guy Benyei11169dd2012-12-18 14:30:41 +00007994 Current = IdTable->key_begin();
7995 End = IdTable->key_end();
7996 }
7997
7998 // We have any identifiers remaining in the current AST file; return
7999 // the next one.
Douglas Gregorbfd73d72013-01-23 18:53:14 +00008000 StringRef Result = *Current;
Guy Benyei11169dd2012-12-18 14:30:41 +00008001 ++Current;
Douglas Gregorbfd73d72013-01-23 18:53:14 +00008002 return Result;
Guy Benyei11169dd2012-12-18 14:30:41 +00008003}
8004
Ben Langmuir537c5b52016-05-04 00:53:13 +00008005namespace {
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00008006
Ben Langmuir537c5b52016-05-04 00:53:13 +00008007/// A utility for appending two IdentifierIterators.
8008class ChainedIdentifierIterator : public IdentifierIterator {
8009 std::unique_ptr<IdentifierIterator> Current;
8010 std::unique_ptr<IdentifierIterator> Queued;
8011
8012public:
8013 ChainedIdentifierIterator(std::unique_ptr<IdentifierIterator> First,
8014 std::unique_ptr<IdentifierIterator> Second)
8015 : Current(std::move(First)), Queued(std::move(Second)) {}
8016
8017 StringRef Next() override {
8018 if (!Current)
Vedant Kumar48b4f762018-04-14 01:40:48 +00008019 return StringRef();
Ben Langmuir537c5b52016-05-04 00:53:13 +00008020
8021 StringRef result = Current->Next();
8022 if (!result.empty())
8023 return result;
8024
8025 // Try the queued iterator, which may itself be empty.
8026 Current.reset();
8027 std::swap(Current, Queued);
8028 return Next();
8029 }
8030};
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00008031
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008032} // namespace
Ben Langmuir537c5b52016-05-04 00:53:13 +00008033
Argyrios Kyrtzidis9aca3c62013-04-17 22:10:55 +00008034IdentifierIterator *ASTReader::getIdentifiers() {
Ben Langmuir537c5b52016-05-04 00:53:13 +00008035 if (!loadGlobalIndex()) {
8036 std::unique_ptr<IdentifierIterator> ReaderIter(
8037 new ASTIdentifierIterator(*this, /*SkipModules=*/true));
8038 std::unique_ptr<IdentifierIterator> ModulesIter(
8039 GlobalIndex->createIdentifierIterator());
8040 return new ChainedIdentifierIterator(std::move(ReaderIter),
8041 std::move(ModulesIter));
8042 }
Argyrios Kyrtzidis9aca3c62013-04-17 22:10:55 +00008043
Guy Benyei11169dd2012-12-18 14:30:41 +00008044 return new ASTIdentifierIterator(*this);
8045}
8046
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00008047namespace clang {
8048namespace serialization {
8049
Guy Benyei11169dd2012-12-18 14:30:41 +00008050 class ReadMethodPoolVisitor {
8051 ASTReader &Reader;
8052 Selector Sel;
8053 unsigned PriorGeneration;
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008054 unsigned InstanceBits = 0;
8055 unsigned FactoryBits = 0;
8056 bool InstanceHasMoreThanOneDecl = false;
8057 bool FactoryHasMoreThanOneDecl = false;
Dmitri Gribenkof8579502013-01-12 19:30:44 +00008058 SmallVector<ObjCMethodDecl *, 4> InstanceMethods;
8059 SmallVector<ObjCMethodDecl *, 4> FactoryMethods;
Guy Benyei11169dd2012-12-18 14:30:41 +00008060
8061 public:
Nico Weber2e0c8f72014-12-27 03:58:08 +00008062 ReadMethodPoolVisitor(ASTReader &Reader, Selector Sel,
Guy Benyei11169dd2012-12-18 14:30:41 +00008063 unsigned PriorGeneration)
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008064 : Reader(Reader), Sel(Sel), PriorGeneration(PriorGeneration) {}
Nico Weber2e0c8f72014-12-27 03:58:08 +00008065
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00008066 bool operator()(ModuleFile &M) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008067 if (!M.SelectorLookupTable)
8068 return false;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008069
Guy Benyei11169dd2012-12-18 14:30:41 +00008070 // If we've already searched this module file, skip it now.
Richard Smithbdf2d932015-07-30 03:37:16 +00008071 if (M.Generation <= PriorGeneration)
Guy Benyei11169dd2012-12-18 14:30:41 +00008072 return true;
8073
Richard Smithbdf2d932015-07-30 03:37:16 +00008074 ++Reader.NumMethodPoolTableLookups;
Vedant Kumar48b4f762018-04-14 01:40:48 +00008075 ASTSelectorLookupTable *PoolTable
8076 = (ASTSelectorLookupTable*)M.SelectorLookupTable;
Richard Smithbdf2d932015-07-30 03:37:16 +00008077 ASTSelectorLookupTable::iterator Pos = PoolTable->find(Sel);
Guy Benyei11169dd2012-12-18 14:30:41 +00008078 if (Pos == PoolTable->end())
8079 return false;
Douglas Gregorad2f7a52013-01-28 17:54:36 +00008080
Richard Smithbdf2d932015-07-30 03:37:16 +00008081 ++Reader.NumMethodPoolTableHits;
8082 ++Reader.NumSelectorsRead;
Guy Benyei11169dd2012-12-18 14:30:41 +00008083 // FIXME: Not quite happy with the statistics here. We probably should
8084 // disable this tracking when called via LoadSelector.
8085 // Also, should entries without methods count as misses?
Richard Smithbdf2d932015-07-30 03:37:16 +00008086 ++Reader.NumMethodPoolEntriesRead;
Guy Benyei11169dd2012-12-18 14:30:41 +00008087 ASTSelectorLookupTrait::data_type Data = *Pos;
Richard Smithbdf2d932015-07-30 03:37:16 +00008088 if (Reader.DeserializationListener)
8089 Reader.DeserializationListener->SelectorRead(Data.ID, Sel);
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00008090
Richard Smithbdf2d932015-07-30 03:37:16 +00008091 InstanceMethods.append(Data.Instance.begin(), Data.Instance.end());
8092 FactoryMethods.append(Data.Factory.begin(), Data.Factory.end());
8093 InstanceBits = Data.InstanceBits;
8094 FactoryBits = Data.FactoryBits;
8095 InstanceHasMoreThanOneDecl = Data.InstanceHasMoreThanOneDecl;
8096 FactoryHasMoreThanOneDecl = Data.FactoryHasMoreThanOneDecl;
Guy Benyei11169dd2012-12-18 14:30:41 +00008097 return true;
8098 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008099
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00008100 /// Retrieve the instance methods found by this visitor.
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008101 ArrayRef<ObjCMethodDecl *> getInstanceMethods() const {
8102 return InstanceMethods;
Guy Benyei11169dd2012-12-18 14:30:41 +00008103 }
8104
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00008105 /// Retrieve the instance methods found by this visitor.
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008106 ArrayRef<ObjCMethodDecl *> getFactoryMethods() const {
Guy Benyei11169dd2012-12-18 14:30:41 +00008107 return FactoryMethods;
8108 }
Argyrios Kyrtzidisd3da6e02013-04-17 00:08:58 +00008109
8110 unsigned getInstanceBits() const { return InstanceBits; }
8111 unsigned getFactoryBits() const { return FactoryBits; }
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008112
Nico Weberff4b35e2014-12-27 22:14:15 +00008113 bool instanceHasMoreThanOneDecl() const {
8114 return InstanceHasMoreThanOneDecl;
8115 }
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008116
Nico Weberff4b35e2014-12-27 22:14:15 +00008117 bool factoryHasMoreThanOneDecl() const { return FactoryHasMoreThanOneDecl; }
Guy Benyei11169dd2012-12-18 14:30:41 +00008118 };
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00008119
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008120} // namespace serialization
8121} // namespace clang
Guy Benyei11169dd2012-12-18 14:30:41 +00008122
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00008123/// Add the given set of methods to the method list.
Guy Benyei11169dd2012-12-18 14:30:41 +00008124static void addMethodsToPool(Sema &S, ArrayRef<ObjCMethodDecl *> Methods,
8125 ObjCMethodList &List) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008126 for (unsigned I = 0, N = Methods.size(); I != N; ++I) {
8127 S.addMethodToGlobalList(&List, Methods[I]);
8128 }
Guy Benyei11169dd2012-12-18 14:30:41 +00008129}
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008130
Guy Benyei11169dd2012-12-18 14:30:41 +00008131void ASTReader::ReadMethodPool(Selector Sel) {
8132 // Get the selector generation and update it to the current generation.
8133 unsigned &Generation = SelectorGeneration[Sel];
8134 unsigned PriorGeneration = Generation;
Richard Smith053f6c62014-05-16 23:01:30 +00008135 Generation = getGeneration();
Manman Rena0f31a02016-04-29 19:04:05 +00008136 SelectorOutOfDate[Sel] = false;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008137
Guy Benyei11169dd2012-12-18 14:30:41 +00008138 // Search for methods defined with this selector.
Douglas Gregorad2f7a52013-01-28 17:54:36 +00008139 ++NumMethodPoolLookups;
Guy Benyei11169dd2012-12-18 14:30:41 +00008140 ReadMethodPoolVisitor Visitor(*this, Sel, PriorGeneration);
Benjamin Kramer9a9efba2015-07-25 12:14:04 +00008141 ModuleMgr.visit(Visitor);
8142
Guy Benyei11169dd2012-12-18 14:30:41 +00008143 if (Visitor.getInstanceMethods().empty() &&
Douglas Gregorad2f7a52013-01-28 17:54:36 +00008144 Visitor.getFactoryMethods().empty())
Guy Benyei11169dd2012-12-18 14:30:41 +00008145 return;
Douglas Gregorad2f7a52013-01-28 17:54:36 +00008146
8147 ++NumMethodPoolHits;
8148
Guy Benyei11169dd2012-12-18 14:30:41 +00008149 if (!getSema())
8150 return;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008151
Guy Benyei11169dd2012-12-18 14:30:41 +00008152 Sema &S = *getSema();
8153 Sema::GlobalMethodPool::iterator Pos
8154 = S.MethodPool.insert(std::make_pair(Sel, Sema::GlobalMethods())).first;
Ben Langmuira0c32e92015-01-12 19:27:00 +00008155
Argyrios Kyrtzidisd3da6e02013-04-17 00:08:58 +00008156 Pos->second.first.setBits(Visitor.getInstanceBits());
Nico Weberff4b35e2014-12-27 22:14:15 +00008157 Pos->second.first.setHasMoreThanOneDecl(Visitor.instanceHasMoreThanOneDecl());
Argyrios Kyrtzidisd3da6e02013-04-17 00:08:58 +00008158 Pos->second.second.setBits(Visitor.getFactoryBits());
Nico Weberff4b35e2014-12-27 22:14:15 +00008159 Pos->second.second.setHasMoreThanOneDecl(Visitor.factoryHasMoreThanOneDecl());
Ben Langmuira0c32e92015-01-12 19:27:00 +00008160
8161 // Add methods to the global pool *after* setting hasMoreThanOneDecl, since
8162 // when building a module we keep every method individually and may need to
8163 // update hasMoreThanOneDecl as we add the methods.
8164 addMethodsToPool(S, Visitor.getInstanceMethods(), Pos->second.first);
8165 addMethodsToPool(S, Visitor.getFactoryMethods(), Pos->second.second);
Guy Benyei11169dd2012-12-18 14:30:41 +00008166}
8167
Manman Rena0f31a02016-04-29 19:04:05 +00008168void ASTReader::updateOutOfDateSelector(Selector Sel) {
8169 if (SelectorOutOfDate[Sel])
8170 ReadMethodPool(Sel);
8171}
8172
Guy Benyei11169dd2012-12-18 14:30:41 +00008173void ASTReader::ReadKnownNamespaces(
8174 SmallVectorImpl<NamespaceDecl *> &Namespaces) {
8175 Namespaces.clear();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008176
Vedant Kumar48b4f762018-04-14 01:40:48 +00008177 for (unsigned I = 0, N = KnownNamespaces.size(); I != N; ++I) {
8178 if (NamespaceDecl *Namespace
8179 = dyn_cast_or_null<NamespaceDecl>(GetDecl(KnownNamespaces[I])))
Guy Benyei11169dd2012-12-18 14:30:41 +00008180 Namespaces.push_back(Namespace);
Vedant Kumar48b4f762018-04-14 01:40:48 +00008181 }
Guy Benyei11169dd2012-12-18 14:30:41 +00008182}
8183
Nick Lewycky9c7eb1d2013-02-01 08:13:20 +00008184void ASTReader::ReadUndefinedButUsed(
Richard Smithd6a04d72016-03-25 21:49:43 +00008185 llvm::MapVector<NamedDecl *, SourceLocation> &Undefined) {
Nick Lewycky9c7eb1d2013-02-01 08:13:20 +00008186 for (unsigned Idx = 0, N = UndefinedButUsed.size(); Idx != N;) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008187 NamedDecl *D = cast<NamedDecl>(GetDecl(UndefinedButUsed[Idx++]));
Nick Lewycky8334af82013-01-26 00:35:08 +00008188 SourceLocation Loc =
Nick Lewycky9c7eb1d2013-02-01 08:13:20 +00008189 SourceLocation::getFromRawEncoding(UndefinedButUsed[Idx++]);
Nick Lewycky8334af82013-01-26 00:35:08 +00008190 Undefined.insert(std::make_pair(D, Loc));
8191 }
8192}
Nick Lewycky8334af82013-01-26 00:35:08 +00008193
Ismail Pazarbasie5768d12015-05-18 19:59:11 +00008194void ASTReader::ReadMismatchingDeleteExpressions(llvm::MapVector<
8195 FieldDecl *, llvm::SmallVector<std::pair<SourceLocation, bool>, 4>> &
8196 Exprs) {
8197 for (unsigned Idx = 0, N = DelayedDeleteExprs.size(); Idx != N;) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008198 FieldDecl *FD = cast<FieldDecl>(GetDecl(DelayedDeleteExprs[Idx++]));
Ismail Pazarbasie5768d12015-05-18 19:59:11 +00008199 uint64_t Count = DelayedDeleteExprs[Idx++];
8200 for (uint64_t C = 0; C < Count; ++C) {
8201 SourceLocation DeleteLoc =
8202 SourceLocation::getFromRawEncoding(DelayedDeleteExprs[Idx++]);
8203 const bool IsArrayForm = DelayedDeleteExprs[Idx++];
8204 Exprs[FD].push_back(std::make_pair(DeleteLoc, IsArrayForm));
8205 }
8206 }
8207}
8208
Guy Benyei11169dd2012-12-18 14:30:41 +00008209void ASTReader::ReadTentativeDefinitions(
8210 SmallVectorImpl<VarDecl *> &TentativeDefs) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008211 for (unsigned I = 0, N = TentativeDefinitions.size(); I != N; ++I) {
8212 VarDecl *Var = dyn_cast_or_null<VarDecl>(GetDecl(TentativeDefinitions[I]));
Guy Benyei11169dd2012-12-18 14:30:41 +00008213 if (Var)
8214 TentativeDefs.push_back(Var);
8215 }
8216 TentativeDefinitions.clear();
8217}
8218
8219void ASTReader::ReadUnusedFileScopedDecls(
8220 SmallVectorImpl<const DeclaratorDecl *> &Decls) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008221 for (unsigned I = 0, N = UnusedFileScopedDecls.size(); I != N; ++I) {
8222 DeclaratorDecl *D
8223 = dyn_cast_or_null<DeclaratorDecl>(GetDecl(UnusedFileScopedDecls[I]));
Guy Benyei11169dd2012-12-18 14:30:41 +00008224 if (D)
8225 Decls.push_back(D);
8226 }
8227 UnusedFileScopedDecls.clear();
8228}
8229
8230void ASTReader::ReadDelegatingConstructors(
8231 SmallVectorImpl<CXXConstructorDecl *> &Decls) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008232 for (unsigned I = 0, N = DelegatingCtorDecls.size(); I != N; ++I) {
8233 CXXConstructorDecl *D
8234 = dyn_cast_or_null<CXXConstructorDecl>(GetDecl(DelegatingCtorDecls[I]));
Guy Benyei11169dd2012-12-18 14:30:41 +00008235 if (D)
8236 Decls.push_back(D);
8237 }
8238 DelegatingCtorDecls.clear();
8239}
8240
8241void ASTReader::ReadExtVectorDecls(SmallVectorImpl<TypedefNameDecl *> &Decls) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008242 for (unsigned I = 0, N = ExtVectorDecls.size(); I != N; ++I) {
8243 TypedefNameDecl *D
8244 = dyn_cast_or_null<TypedefNameDecl>(GetDecl(ExtVectorDecls[I]));
Guy Benyei11169dd2012-12-18 14:30:41 +00008245 if (D)
8246 Decls.push_back(D);
8247 }
8248 ExtVectorDecls.clear();
8249}
8250
Nico Weber72889432014-09-06 01:25:55 +00008251void ASTReader::ReadUnusedLocalTypedefNameCandidates(
8252 llvm::SmallSetVector<const TypedefNameDecl *, 4> &Decls) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008253 for (unsigned I = 0, N = UnusedLocalTypedefNameCandidates.size(); I != N;
8254 ++I) {
8255 TypedefNameDecl *D = dyn_cast_or_null<TypedefNameDecl>(
8256 GetDecl(UnusedLocalTypedefNameCandidates[I]));
Nico Weber72889432014-09-06 01:25:55 +00008257 if (D)
8258 Decls.insert(D);
8259 }
8260 UnusedLocalTypedefNameCandidates.clear();
8261}
8262
Yaxun (Sam) Liub670ab72020-02-26 10:57:39 -05008263void ASTReader::ReadDeclsToCheckForDeferredDiags(
8264 llvm::SmallVector<Decl *, 4> &Decls) {
8265 for (unsigned I = 0, N = DeclsToCheckForDeferredDiags.size(); I != N;
8266 ++I) {
8267 auto *D = dyn_cast_or_null<Decl>(
8268 GetDecl(DeclsToCheckForDeferredDiags[I]));
8269 if (D)
8270 Decls.push_back(D);
8271 }
8272 DeclsToCheckForDeferredDiags.clear();
8273}
8274
8275
Guy Benyei11169dd2012-12-18 14:30:41 +00008276void ASTReader::ReadReferencedSelectors(
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008277 SmallVectorImpl<std::pair<Selector, SourceLocation>> &Sels) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008278 if (ReferencedSelectorsData.empty())
8279 return;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008280
Guy Benyei11169dd2012-12-18 14:30:41 +00008281 // If there are @selector references added them to its pool. This is for
8282 // implementation of -Wselector.
8283 unsigned int DataSize = ReferencedSelectorsData.size()-1;
8284 unsigned I = 0;
8285 while (I < DataSize) {
8286 Selector Sel = DecodeSelector(ReferencedSelectorsData[I++]);
8287 SourceLocation SelLoc
8288 = SourceLocation::getFromRawEncoding(ReferencedSelectorsData[I++]);
8289 Sels.push_back(std::make_pair(Sel, SelLoc));
8290 }
8291 ReferencedSelectorsData.clear();
8292}
8293
8294void ASTReader::ReadWeakUndeclaredIdentifiers(
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008295 SmallVectorImpl<std::pair<IdentifierInfo *, WeakInfo>> &WeakIDs) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008296 if (WeakUndeclaredIdentifiers.empty())
8297 return;
8298
8299 for (unsigned I = 0, N = WeakUndeclaredIdentifiers.size(); I < N; /*none*/) {
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008300 IdentifierInfo *WeakId
Guy Benyei11169dd2012-12-18 14:30:41 +00008301 = DecodeIdentifierInfo(WeakUndeclaredIdentifiers[I++]);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008302 IdentifierInfo *AliasId
Guy Benyei11169dd2012-12-18 14:30:41 +00008303 = DecodeIdentifierInfo(WeakUndeclaredIdentifiers[I++]);
8304 SourceLocation Loc
8305 = SourceLocation::getFromRawEncoding(WeakUndeclaredIdentifiers[I++]);
8306 bool Used = WeakUndeclaredIdentifiers[I++];
8307 WeakInfo WI(AliasId, Loc);
8308 WI.setUsed(Used);
8309 WeakIDs.push_back(std::make_pair(WeakId, WI));
8310 }
8311 WeakUndeclaredIdentifiers.clear();
8312}
8313
8314void ASTReader::ReadUsedVTables(SmallVectorImpl<ExternalVTableUse> &VTables) {
8315 for (unsigned Idx = 0, N = VTableUses.size(); Idx < N; /* In loop */) {
8316 ExternalVTableUse VT;
8317 VT.Record = dyn_cast_or_null<CXXRecordDecl>(GetDecl(VTableUses[Idx++]));
8318 VT.Location = SourceLocation::getFromRawEncoding(VTableUses[Idx++]);
8319 VT.DefinitionRequired = VTableUses[Idx++];
8320 VTables.push_back(VT);
8321 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008322
Guy Benyei11169dd2012-12-18 14:30:41 +00008323 VTableUses.clear();
8324}
8325
8326void ASTReader::ReadPendingInstantiations(
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00008327 SmallVectorImpl<std::pair<ValueDecl *, SourceLocation>> &Pending) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008328 for (unsigned Idx = 0, N = PendingInstantiations.size(); Idx < N;) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008329 ValueDecl *D = cast<ValueDecl>(GetDecl(PendingInstantiations[Idx++]));
Guy Benyei11169dd2012-12-18 14:30:41 +00008330 SourceLocation Loc
8331 = SourceLocation::getFromRawEncoding(PendingInstantiations[Idx++]);
8332
8333 Pending.push_back(std::make_pair(D, Loc));
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008334 }
Guy Benyei11169dd2012-12-18 14:30:41 +00008335 PendingInstantiations.clear();
8336}
8337
Richard Smithe40f2ba2013-08-07 21:41:30 +00008338void ASTReader::ReadLateParsedTemplates(
Justin Lebar28f09c52016-10-10 16:26:08 +00008339 llvm::MapVector<const FunctionDecl *, std::unique_ptr<LateParsedTemplate>>
8340 &LPTMap) {
Richard Smithe40f2ba2013-08-07 21:41:30 +00008341 for (unsigned Idx = 0, N = LateParsedTemplates.size(); Idx < N;
8342 /* In loop */) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00008343 FunctionDecl *FD = cast<FunctionDecl>(GetDecl(LateParsedTemplates[Idx++]));
Richard Smithe40f2ba2013-08-07 21:41:30 +00008344
Jonas Devlieghere2b3d49b2019-08-14 23:04:18 +00008345 auto LT = std::make_unique<LateParsedTemplate>();
Richard Smithe40f2ba2013-08-07 21:41:30 +00008346 LT->D = GetDecl(LateParsedTemplates[Idx++]);
8347
8348 ModuleFile *F = getOwningModuleFile(LT->D);
8349 assert(F && "No module");
8350
8351 unsigned TokN = LateParsedTemplates[Idx++];
8352 LT->Toks.reserve(TokN);
8353 for (unsigned T = 0; T < TokN; ++T)
8354 LT->Toks.push_back(ReadToken(*F, LateParsedTemplates, Idx));
8355
Justin Lebar28f09c52016-10-10 16:26:08 +00008356 LPTMap.insert(std::make_pair(FD, std::move(LT)));
Richard Smithe40f2ba2013-08-07 21:41:30 +00008357 }
8358
8359 LateParsedTemplates.clear();
8360}
8361
Guy Benyei11169dd2012-12-18 14:30:41 +00008362void ASTReader::LoadSelector(Selector Sel) {
8363 // It would be complicated to avoid reading the methods anyway. So don't.
8364 ReadMethodPool(Sel);
8365}
8366
8367void ASTReader::SetIdentifierInfo(IdentifierID ID, IdentifierInfo *II) {
8368 assert(ID && "Non-zero identifier ID required");
8369 assert(ID <= IdentifiersLoaded.size() && "identifier ID out of range");
8370 IdentifiersLoaded[ID - 1] = II;
8371 if (DeserializationListener)
8372 DeserializationListener->IdentifierRead(ID, II);
8373}
8374
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00008375/// Set the globally-visible declarations associated with the given
Guy Benyei11169dd2012-12-18 14:30:41 +00008376/// identifier.
8377///
8378/// If the AST reader is currently in a state where the given declaration IDs
8379/// cannot safely be resolved, they are queued until it is safe to resolve
8380/// them.
8381///
8382/// \param II an IdentifierInfo that refers to one or more globally-visible
8383/// declarations.
8384///
8385/// \param DeclIDs the set of declaration IDs with the name @p II that are
8386/// visible at global scope.
8387///
Douglas Gregor6168bd22013-02-18 15:53:43 +00008388/// \param Decls if non-null, this vector will be populated with the set of
8389/// deserialized declarations. These declarations will not be pushed into
8390/// scope.
Guy Benyei11169dd2012-12-18 14:30:41 +00008391void
8392ASTReader::SetGloballyVisibleDecls(IdentifierInfo *II,
8393 const SmallVectorImpl<uint32_t> &DeclIDs,
Douglas Gregor6168bd22013-02-18 15:53:43 +00008394 SmallVectorImpl<Decl *> *Decls) {
8395 if (NumCurrentElementsDeserializing && !Decls) {
8396 PendingIdentifierInfos[II].append(DeclIDs.begin(), DeclIDs.end());
Guy Benyei11169dd2012-12-18 14:30:41 +00008397 return;
8398 }
8399
Vedant Kumar48b4f762018-04-14 01:40:48 +00008400 for (unsigned I = 0, N = DeclIDs.size(); I != N; ++I) {
Ben Langmuir5418f402014-09-10 21:29:41 +00008401 if (!SemaObj) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008402 // Queue this declaration so that it will be added to the
8403 // translation unit scope and identifier's declaration chain
8404 // once a Sema object is known.
Vedant Kumar48b4f762018-04-14 01:40:48 +00008405 PreloadedDeclIDs.push_back(DeclIDs[I]);
Ben Langmuir5418f402014-09-10 21:29:41 +00008406 continue;
Guy Benyei11169dd2012-12-18 14:30:41 +00008407 }
Ben Langmuir5418f402014-09-10 21:29:41 +00008408
Vedant Kumar48b4f762018-04-14 01:40:48 +00008409 NamedDecl *D = cast<NamedDecl>(GetDecl(DeclIDs[I]));
Ben Langmuir5418f402014-09-10 21:29:41 +00008410
8411 // If we're simply supposed to record the declarations, do so now.
8412 if (Decls) {
8413 Decls->push_back(D);
8414 continue;
8415 }
8416
8417 // Introduce this declaration into the translation-unit scope
8418 // and add it to the declaration chain for this identifier, so
8419 // that (unqualified) name lookup will find it.
8420 pushExternalDeclIntoScope(D, II);
Guy Benyei11169dd2012-12-18 14:30:41 +00008421 }
8422}
8423
Douglas Gregorc8a992f2013-01-21 16:52:34 +00008424IdentifierInfo *ASTReader::DecodeIdentifierInfo(IdentifierID ID) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008425 if (ID == 0)
Craig Toppera13603a2014-05-22 05:54:18 +00008426 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00008427
8428 if (IdentifiersLoaded.empty()) {
8429 Error("no identifier table in AST file");
Craig Toppera13603a2014-05-22 05:54:18 +00008430 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00008431 }
8432
8433 ID -= 1;
8434 if (!IdentifiersLoaded[ID]) {
8435 GlobalIdentifierMapType::iterator I = GlobalIdentifierMap.find(ID + 1);
8436 assert(I != GlobalIdentifierMap.end() && "Corrupted global identifier map");
8437 ModuleFile *M = I->second;
8438 unsigned Index = ID - M->BaseIdentifierID;
8439 const char *Str = M->IdentifierTableData + M->IdentifierOffsets[Index];
8440
8441 // All of the strings in the AST file are preceded by a 16-bit length.
8442 // Extract that 16-bit length to avoid having to execute strlen().
8443 // NOTE: 'StrLenPtr' is an 'unsigned char*' so that we load bytes as
8444 // unsigned integers. This is important to avoid integer overflow when
8445 // we cast them to 'unsigned'.
8446 const unsigned char *StrLenPtr = (const unsigned char*) Str - 2;
8447 unsigned StrLen = (((unsigned) StrLenPtr[0])
8448 | (((unsigned) StrLenPtr[1]) << 8)) - 1;
Richard Smitheb4b58f62016-02-05 01:40:54 +00008449 auto &II = PP.getIdentifierTable().get(StringRef(Str, StrLen));
8450 IdentifiersLoaded[ID] = &II;
8451 markIdentifierFromAST(*this, II);
Guy Benyei11169dd2012-12-18 14:30:41 +00008452 if (DeserializationListener)
Richard Smitheb4b58f62016-02-05 01:40:54 +00008453 DeserializationListener->IdentifierRead(ID + 1, &II);
Guy Benyei11169dd2012-12-18 14:30:41 +00008454 }
8455
8456 return IdentifiersLoaded[ID];
8457}
8458
Douglas Gregorc8a992f2013-01-21 16:52:34 +00008459IdentifierInfo *ASTReader::getLocalIdentifier(ModuleFile &M, unsigned LocalID) {
8460 return DecodeIdentifierInfo(getGlobalIdentifierID(M, LocalID));
Guy Benyei11169dd2012-12-18 14:30:41 +00008461}
8462
8463IdentifierID ASTReader::getGlobalIdentifierID(ModuleFile &M, unsigned LocalID) {
8464 if (LocalID < NUM_PREDEF_IDENT_IDS)
8465 return LocalID;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008466
Richard Smith37a93df2017-02-18 00:32:02 +00008467 if (!M.ModuleOffsetMap.empty())
8468 ReadModuleOffsetMap(M);
8469
Guy Benyei11169dd2012-12-18 14:30:41 +00008470 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8471 = M.IdentifierRemap.find(LocalID - NUM_PREDEF_IDENT_IDS);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008472 assert(I != M.IdentifierRemap.end()
Guy Benyei11169dd2012-12-18 14:30:41 +00008473 && "Invalid index into identifier index remap");
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008474
Guy Benyei11169dd2012-12-18 14:30:41 +00008475 return LocalID + I->second;
8476}
8477
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00008478MacroInfo *ASTReader::getMacro(MacroID ID) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008479 if (ID == 0)
Craig Toppera13603a2014-05-22 05:54:18 +00008480 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00008481
8482 if (MacrosLoaded.empty()) {
8483 Error("no macro table in AST file");
Craig Toppera13603a2014-05-22 05:54:18 +00008484 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00008485 }
8486
8487 ID -= NUM_PREDEF_MACRO_IDS;
8488 if (!MacrosLoaded[ID]) {
8489 GlobalMacroMapType::iterator I
8490 = GlobalMacroMap.find(ID + NUM_PREDEF_MACRO_IDS);
8491 assert(I != GlobalMacroMap.end() && "Corrupted global macro map");
8492 ModuleFile *M = I->second;
8493 unsigned Index = ID - M->BaseMacroID;
Dmitry Polukhina7afb212020-04-16 09:24:46 -07008494 MacrosLoaded[ID] =
8495 ReadMacroRecord(*M, M->MacroOffsetsBase + M->MacroOffsets[Index]);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008496
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00008497 if (DeserializationListener)
8498 DeserializationListener->MacroRead(ID + NUM_PREDEF_MACRO_IDS,
8499 MacrosLoaded[ID]);
Guy Benyei11169dd2012-12-18 14:30:41 +00008500 }
8501
8502 return MacrosLoaded[ID];
8503}
8504
8505MacroID ASTReader::getGlobalMacroID(ModuleFile &M, unsigned LocalID) {
8506 if (LocalID < NUM_PREDEF_MACRO_IDS)
8507 return LocalID;
8508
Richard Smith37a93df2017-02-18 00:32:02 +00008509 if (!M.ModuleOffsetMap.empty())
8510 ReadModuleOffsetMap(M);
8511
Guy Benyei11169dd2012-12-18 14:30:41 +00008512 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8513 = M.MacroRemap.find(LocalID - NUM_PREDEF_MACRO_IDS);
8514 assert(I != M.MacroRemap.end() && "Invalid index into macro index remap");
8515
8516 return LocalID + I->second;
8517}
8518
8519serialization::SubmoduleID
8520ASTReader::getGlobalSubmoduleID(ModuleFile &M, unsigned LocalID) {
8521 if (LocalID < NUM_PREDEF_SUBMODULE_IDS)
8522 return LocalID;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008523
Richard Smith37a93df2017-02-18 00:32:02 +00008524 if (!M.ModuleOffsetMap.empty())
8525 ReadModuleOffsetMap(M);
8526
Guy Benyei11169dd2012-12-18 14:30:41 +00008527 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8528 = M.SubmoduleRemap.find(LocalID - NUM_PREDEF_SUBMODULE_IDS);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008529 assert(I != M.SubmoduleRemap.end()
Guy Benyei11169dd2012-12-18 14:30:41 +00008530 && "Invalid index into submodule index remap");
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008531
Guy Benyei11169dd2012-12-18 14:30:41 +00008532 return LocalID + I->second;
8533}
8534
8535Module *ASTReader::getSubmodule(SubmoduleID GlobalID) {
8536 if (GlobalID < NUM_PREDEF_SUBMODULE_IDS) {
8537 assert(GlobalID == 0 && "Unhandled global submodule ID");
Craig Toppera13603a2014-05-22 05:54:18 +00008538 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00008539 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008540
Guy Benyei11169dd2012-12-18 14:30:41 +00008541 if (GlobalID > SubmodulesLoaded.size()) {
8542 Error("submodule ID out of range in AST file");
Craig Toppera13603a2014-05-22 05:54:18 +00008543 return nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00008544 }
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008545
Guy Benyei11169dd2012-12-18 14:30:41 +00008546 return SubmodulesLoaded[GlobalID - NUM_PREDEF_SUBMODULE_IDS];
8547}
Douglas Gregorc147b0b2013-01-12 01:29:50 +00008548
8549Module *ASTReader::getModule(unsigned ID) {
8550 return getSubmodule(ID);
8551}
8552
Hans Wennborg08c5a7b2018-06-25 13:23:49 +00008553bool ASTReader::DeclIsFromPCHWithObjectFile(const Decl *D) {
8554 ModuleFile *MF = getOwningModuleFile(D);
8555 return MF && MF->PCHHasObjectFile;
8556}
8557
Richard Smithd88a7f12015-09-01 20:35:42 +00008558ModuleFile *ASTReader::getLocalModuleFile(ModuleFile &F, unsigned ID) {
8559 if (ID & 1) {
8560 // It's a module, look it up by submodule ID.
8561 auto I = GlobalSubmoduleMap.find(getGlobalSubmoduleID(F, ID >> 1));
8562 return I == GlobalSubmoduleMap.end() ? nullptr : I->second;
8563 } else {
8564 // It's a prefix (preamble, PCH, ...). Look it up by index.
8565 unsigned IndexFromEnd = ID >> 1;
8566 assert(IndexFromEnd && "got reference to unknown module file");
8567 return getModuleManager().pch_modules().end()[-IndexFromEnd];
8568 }
8569}
8570
8571unsigned ASTReader::getModuleFileID(ModuleFile *F) {
8572 if (!F)
8573 return 1;
8574
8575 // For a file representing a module, use the submodule ID of the top-level
8576 // module as the file ID. For any other kind of file, the number of such
8577 // files loaded beforehand will be the same on reload.
8578 // FIXME: Is this true even if we have an explicit module file and a PCH?
8579 if (F->isModule())
8580 return ((F->BaseSubmoduleID + NUM_PREDEF_SUBMODULE_IDS) << 1) | 1;
8581
8582 auto PCHModules = getModuleManager().pch_modules();
Fangrui Song75e74e02019-03-31 08:48:19 +00008583 auto I = llvm::find(PCHModules, F);
Richard Smithd88a7f12015-09-01 20:35:42 +00008584 assert(I != PCHModules.end() && "emitting reference to unknown file");
8585 return (I - PCHModules.end()) << 1;
8586}
8587
Reid Klecknerc915cb92020-02-27 18:13:54 -08008588llvm::Optional<ASTSourceDescriptor>
Adrian Prantl15bcf702015-06-30 17:39:43 +00008589ASTReader::getSourceDescriptor(unsigned ID) {
Adrian Prantlf4754ea2020-03-17 12:51:58 -07008590 if (Module *M = getSubmodule(ID))
Reid Klecknerc915cb92020-02-27 18:13:54 -08008591 return ASTSourceDescriptor(*M);
Adrian Prantl15bcf702015-06-30 17:39:43 +00008592
8593 // If there is only a single PCH, return it instead.
Hiroshi Inoue3170de02017-07-01 08:46:43 +00008594 // Chained PCH are not supported.
Saleem Abdulrasool97d25552017-03-02 17:37:11 +00008595 const auto &PCHChain = ModuleMgr.pch_modules();
8596 if (std::distance(std::begin(PCHChain), std::end(PCHChain))) {
Adrian Prantl15bcf702015-06-30 17:39:43 +00008597 ModuleFile &MF = ModuleMgr.getPrimaryModule();
Adrian Prantl3a2d4942016-01-22 23:30:56 +00008598 StringRef ModuleName = llvm::sys::path::filename(MF.OriginalSourceFileName);
Adrian Prantl9bc3c4f2016-04-27 17:06:22 +00008599 StringRef FileName = llvm::sys::path::filename(MF.FileName);
Reid Klecknerc915cb92020-02-27 18:13:54 -08008600 return ASTSourceDescriptor(ModuleName, MF.OriginalDir, FileName,
8601 MF.Signature);
Adrian Prantl15bcf702015-06-30 17:39:43 +00008602 }
8603 return None;
8604}
8605
David Blaikie1ac9c982017-04-11 21:13:37 +00008606ExternalASTSource::ExtKind ASTReader::hasExternalDefinitions(const Decl *FD) {
Richard Smitha4653622017-09-06 20:01:14 +00008607 auto I = DefinitionSource.find(FD);
8608 if (I == DefinitionSource.end())
David Blaikie9ffe5a32017-01-30 05:00:26 +00008609 return EK_ReplyHazy;
David Blaikiee6b7c282017-04-11 20:46:34 +00008610 return I->second ? EK_Never : EK_Always;
David Blaikie9ffe5a32017-01-30 05:00:26 +00008611}
8612
Guy Benyei11169dd2012-12-18 14:30:41 +00008613Selector ASTReader::getLocalSelector(ModuleFile &M, unsigned LocalID) {
8614 return DecodeSelector(getGlobalSelectorID(M, LocalID));
8615}
8616
8617Selector ASTReader::DecodeSelector(serialization::SelectorID ID) {
8618 if (ID == 0)
Vedant Kumar48b4f762018-04-14 01:40:48 +00008619 return Selector();
Guy Benyei11169dd2012-12-18 14:30:41 +00008620
8621 if (ID > SelectorsLoaded.size()) {
8622 Error("selector ID out of range in AST file");
Vedant Kumar48b4f762018-04-14 01:40:48 +00008623 return Selector();
Guy Benyei11169dd2012-12-18 14:30:41 +00008624 }
8625
Craig Toppera13603a2014-05-22 05:54:18 +00008626 if (SelectorsLoaded[ID - 1].getAsOpaquePtr() == nullptr) {
Guy Benyei11169dd2012-12-18 14:30:41 +00008627 // Load this selector from the selector table.
8628 GlobalSelectorMapType::iterator I = GlobalSelectorMap.find(ID);
8629 assert(I != GlobalSelectorMap.end() && "Corrupted global selector map");
8630 ModuleFile &M = *I->second;
8631 ASTSelectorLookupTrait Trait(*this, M);
8632 unsigned Idx = ID - M.BaseSelectorID - NUM_PREDEF_SELECTOR_IDS;
8633 SelectorsLoaded[ID - 1] =
8634 Trait.ReadKey(M.SelectorLookupTableData + M.SelectorOffsets[Idx], 0);
8635 if (DeserializationListener)
8636 DeserializationListener->SelectorRead(ID, SelectorsLoaded[ID - 1]);
8637 }
8638
8639 return SelectorsLoaded[ID - 1];
8640}
8641
8642Selector ASTReader::GetExternalSelector(serialization::SelectorID ID) {
8643 return DecodeSelector(ID);
8644}
8645
8646uint32_t ASTReader::GetNumExternalSelectors() {
8647 // ID 0 (the null selector) is considered an external selector.
8648 return getTotalNumSelectors() + 1;
8649}
8650
8651serialization::SelectorID
8652ASTReader::getGlobalSelectorID(ModuleFile &M, unsigned LocalID) const {
8653 if (LocalID < NUM_PREDEF_SELECTOR_IDS)
8654 return LocalID;
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008655
Richard Smith37a93df2017-02-18 00:32:02 +00008656 if (!M.ModuleOffsetMap.empty())
8657 ReadModuleOffsetMap(M);
8658
Guy Benyei11169dd2012-12-18 14:30:41 +00008659 ContinuousRangeMap<uint32_t, int, 2>::iterator I
8660 = M.SelectorRemap.find(LocalID - NUM_PREDEF_SELECTOR_IDS);
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008661 assert(I != M.SelectorRemap.end()
Guy Benyei11169dd2012-12-18 14:30:41 +00008662 && "Invalid index into selector index remap");
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008663
Guy Benyei11169dd2012-12-18 14:30:41 +00008664 return LocalID + I->second;
8665}
8666
John McCall3ce3d232019-12-13 03:37:23 -05008667DeclarationNameLoc
8668ASTRecordReader::readDeclarationNameLoc(DeclarationName Name) {
8669 DeclarationNameLoc DNLoc;
Guy Benyei11169dd2012-12-18 14:30:41 +00008670 switch (Name.getNameKind()) {
8671 case DeclarationName::CXXConstructorName:
8672 case DeclarationName::CXXDestructorName:
8673 case DeclarationName::CXXConversionFunctionName:
John McCall3ce3d232019-12-13 03:37:23 -05008674 DNLoc.NamedType.TInfo = readTypeSourceInfo();
Guy Benyei11169dd2012-12-18 14:30:41 +00008675 break;
8676
8677 case DeclarationName::CXXOperatorName:
8678 DNLoc.CXXOperatorName.BeginOpNameLoc
John McCall3ce3d232019-12-13 03:37:23 -05008679 = readSourceLocation().getRawEncoding();
Guy Benyei11169dd2012-12-18 14:30:41 +00008680 DNLoc.CXXOperatorName.EndOpNameLoc
John McCall3ce3d232019-12-13 03:37:23 -05008681 = readSourceLocation().getRawEncoding();
Guy Benyei11169dd2012-12-18 14:30:41 +00008682 break;
8683
8684 case DeclarationName::CXXLiteralOperatorName:
8685 DNLoc.CXXLiteralOperatorName.OpNameLoc
John McCall3ce3d232019-12-13 03:37:23 -05008686 = readSourceLocation().getRawEncoding();
Guy Benyei11169dd2012-12-18 14:30:41 +00008687 break;
8688
8689 case DeclarationName::Identifier:
8690 case DeclarationName::ObjCZeroArgSelector:
8691 case DeclarationName::ObjCOneArgSelector:
8692 case DeclarationName::ObjCMultiArgSelector:
8693 case DeclarationName::CXXUsingDirective:
Richard Smith35845152017-02-07 01:37:30 +00008694 case DeclarationName::CXXDeductionGuideName:
Guy Benyei11169dd2012-12-18 14:30:41 +00008695 break;
8696 }
John McCall3ce3d232019-12-13 03:37:23 -05008697 return DNLoc;
Guy Benyei11169dd2012-12-18 14:30:41 +00008698}
8699
John McCall3ce3d232019-12-13 03:37:23 -05008700DeclarationNameInfo ASTRecordReader::readDeclarationNameInfo() {
8701 DeclarationNameInfo NameInfo;
8702 NameInfo.setName(readDeclarationName());
8703 NameInfo.setLoc(readSourceLocation());
8704 NameInfo.setInfo(readDeclarationNameLoc(NameInfo.getName()));
8705 return NameInfo;
Guy Benyei11169dd2012-12-18 14:30:41 +00008706}
8707
John McCall3ce3d232019-12-13 03:37:23 -05008708void ASTRecordReader::readQualifierInfo(QualifierInfo &Info) {
8709 Info.QualifierLoc = readNestedNameSpecifierLoc();
8710 unsigned NumTPLists = readInt();
Guy Benyei11169dd2012-12-18 14:30:41 +00008711 Info.NumTemplParamLists = NumTPLists;
8712 if (NumTPLists) {
Richard Smithdbafb6c2017-06-29 23:23:46 +00008713 Info.TemplParamLists =
8714 new (getContext()) TemplateParameterList *[NumTPLists];
Eugene Zelenkoe95e7d52016-09-07 21:53:17 +00008715 for (unsigned i = 0; i != NumTPLists; ++i)
John McCall3ce3d232019-12-13 03:37:23 -05008716 Info.TemplParamLists[i] = readTemplateParameterList();
Guy Benyei11169dd2012-12-18 14:30:41 +00008717 }
8718}
8719
Guy Benyei11169dd2012-12-18 14:30:41 +00008720TemplateParameterList *
John McCall3ce3d232019-12-13 03:37:23 -05008721ASTRecordReader::readTemplateParameterList() {
8722 SourceLocation TemplateLoc = readSourceLocation();
8723 SourceLocation LAngleLoc = readSourceLocation();
8724 SourceLocation RAngleLoc = readSourceLocation();
Guy Benyei11169dd2012-12-18 14:30:41 +00008725
John McCall3ce3d232019-12-13 03:37:23 -05008726 unsigned NumParams = readInt();
Guy Benyei11169dd2012-12-18 14:30:41 +00008727 SmallVector<NamedDecl *, 16> Params;
8728 Params.reserve(NumParams);
8729 while (NumParams--)
John McCall3ce3d232019-12-13 03:37:23 -05008730 Params.push_back(readDeclAs<NamedDecl>());
Guy Benyei11169dd2012-12-18 14:30:41 +00008731
John McCall3ce3d232019-12-13 03:37:23 -05008732 bool HasRequiresClause = readBool();
8733 Expr *RequiresClause = HasRequiresClause ? readExpr() : nullptr;
Saar Raz0330fba2019-10-15 18:44:06 +00008734
Richard Smithdbafb6c2017-06-29 23:23:46 +00008735 TemplateParameterList *TemplateParams = TemplateParameterList::Create(
Saar Raz0330fba2019-10-15 18:44:06 +00008736 getContext(), TemplateLoc, LAngleLoc, Params, RAngleLoc, RequiresClause);
Guy Benyei11169dd2012-12-18 14:30:41 +00008737 return TemplateParams;
8738}
8739
John McCall3ce3d232019-12-13 03:37:23 -05008740void ASTRecordReader::readTemplateArgumentList(
8741 SmallVectorImpl<TemplateArgument> &TemplArgs,
8742 bool Canonicalize) {
8743 unsigned NumTemplateArgs = readInt();
Guy Benyei11169dd2012-12-18 14:30:41 +00008744 TemplArgs.reserve(NumTemplateArgs);
8745 while (NumTemplateArgs--)
John McCall3ce3d232019-12-13 03:37:23 -05008746 TemplArgs.push_back(readTemplateArgument(Canonicalize));
Guy Benyei11169dd2012-12-18 14:30:41 +00008747}
8748
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00008749/// Read a UnresolvedSet structure.
John McCall3ce3d232019-12-13 03:37:23 -05008750void ASTRecordReader::readUnresolvedSet(LazyASTUnresolvedSet &Set) {
8751 unsigned NumDecls = readInt();
Richard Smithdbafb6c2017-06-29 23:23:46 +00008752 Set.reserve(getContext(), NumDecls);
Guy Benyei11169dd2012-12-18 14:30:41 +00008753 while (NumDecls--) {
John McCall3ce3d232019-12-13 03:37:23 -05008754 DeclID ID = readDeclID();
8755 AccessSpecifier AS = (AccessSpecifier) readInt();
Richard Smithdbafb6c2017-06-29 23:23:46 +00008756 Set.addLazyDecl(getContext(), ID, AS);
Guy Benyei11169dd2012-12-18 14:30:41 +00008757 }
8758}
8759
8760CXXBaseSpecifier
John McCall3ce3d232019-12-13 03:37:23 -05008761ASTRecordReader::readCXXBaseSpecifier() {
8762 bool isVirtual = readBool();
8763 bool isBaseOfClass = readBool();
8764 AccessSpecifier AS = static_cast<AccessSpecifier>(readInt());
8765 bool inheritConstructors = readBool();
8766 TypeSourceInfo *TInfo = readTypeSourceInfo();
8767 SourceRange Range = readSourceRange();
8768 SourceLocation EllipsisLoc = readSourceLocation();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008769 CXXBaseSpecifier Result(Range, isVirtual, isBaseOfClass, AS, TInfo,
Guy Benyei11169dd2012-12-18 14:30:41 +00008770 EllipsisLoc);
8771 Result.setInheritConstructors(inheritConstructors);
8772 return Result;
8773}
8774
Richard Smithc2bb8182015-03-24 06:36:48 +00008775CXXCtorInitializer **
John McCall3ce3d232019-12-13 03:37:23 -05008776ASTRecordReader::readCXXCtorInitializers() {
Richard Smithdbafb6c2017-06-29 23:23:46 +00008777 ASTContext &Context = getContext();
John McCall3ce3d232019-12-13 03:37:23 -05008778 unsigned NumInitializers = readInt();
Richard Smithc2bb8182015-03-24 06:36:48 +00008779 assert(NumInitializers && "wrote ctor initializers but have no inits");
Vedant Kumar48b4f762018-04-14 01:40:48 +00008780 auto **CtorInitializers = new (Context) CXXCtorInitializer*[NumInitializers];
Richard Smithc2bb8182015-03-24 06:36:48 +00008781 for (unsigned i = 0; i != NumInitializers; ++i) {
8782 TypeSourceInfo *TInfo = nullptr;
8783 bool IsBaseVirtual = false;
8784 FieldDecl *Member = nullptr;
8785 IndirectFieldDecl *IndirectMember = nullptr;
Guy Benyei11169dd2012-12-18 14:30:41 +00008786
John McCall3ce3d232019-12-13 03:37:23 -05008787 CtorInitializerType Type = (CtorInitializerType) readInt();
Richard Smithc2bb8182015-03-24 06:36:48 +00008788 switch (Type) {
8789 case CTOR_INITIALIZER_BASE:
John McCall3ce3d232019-12-13 03:37:23 -05008790 TInfo = readTypeSourceInfo();
8791 IsBaseVirtual = readBool();
Richard Smithc2bb8182015-03-24 06:36:48 +00008792 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00008793
Richard Smithc2bb8182015-03-24 06:36:48 +00008794 case CTOR_INITIALIZER_DELEGATING:
John McCall3ce3d232019-12-13 03:37:23 -05008795 TInfo = readTypeSourceInfo();
Richard Smithc2bb8182015-03-24 06:36:48 +00008796 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00008797
Richard Smithc2bb8182015-03-24 06:36:48 +00008798 case CTOR_INITIALIZER_MEMBER:
John McCall3ce3d232019-12-13 03:37:23 -05008799 Member = readDeclAs<FieldDecl>();
Richard Smithc2bb8182015-03-24 06:36:48 +00008800 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00008801
Richard Smithc2bb8182015-03-24 06:36:48 +00008802 case CTOR_INITIALIZER_INDIRECT_MEMBER:
John McCall3ce3d232019-12-13 03:37:23 -05008803 IndirectMember = readDeclAs<IndirectFieldDecl>();
Richard Smithc2bb8182015-03-24 06:36:48 +00008804 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00008805 }
Richard Smithc2bb8182015-03-24 06:36:48 +00008806
John McCall3ce3d232019-12-13 03:37:23 -05008807 SourceLocation MemberOrEllipsisLoc = readSourceLocation();
8808 Expr *Init = readExpr();
8809 SourceLocation LParenLoc = readSourceLocation();
8810 SourceLocation RParenLoc = readSourceLocation();
Richard Smithc2bb8182015-03-24 06:36:48 +00008811
8812 CXXCtorInitializer *BOMInit;
Richard Smith30e304e2016-12-14 00:03:17 +00008813 if (Type == CTOR_INITIALIZER_BASE)
Richard Smithc2bb8182015-03-24 06:36:48 +00008814 BOMInit = new (Context)
8815 CXXCtorInitializer(Context, TInfo, IsBaseVirtual, LParenLoc, Init,
8816 RParenLoc, MemberOrEllipsisLoc);
Richard Smith30e304e2016-12-14 00:03:17 +00008817 else if (Type == CTOR_INITIALIZER_DELEGATING)
Richard Smithc2bb8182015-03-24 06:36:48 +00008818 BOMInit = new (Context)
8819 CXXCtorInitializer(Context, TInfo, LParenLoc, Init, RParenLoc);
Richard Smith30e304e2016-12-14 00:03:17 +00008820 else if (Member)
8821 BOMInit = new (Context)
8822 CXXCtorInitializer(Context, Member, MemberOrEllipsisLoc, LParenLoc,
8823 Init, RParenLoc);
8824 else
8825 BOMInit = new (Context)
8826 CXXCtorInitializer(Context, IndirectMember, MemberOrEllipsisLoc,
8827 LParenLoc, Init, RParenLoc);
8828
John McCall3ce3d232019-12-13 03:37:23 -05008829 if (/*IsWritten*/readBool()) {
8830 unsigned SourceOrder = readInt();
Richard Smith30e304e2016-12-14 00:03:17 +00008831 BOMInit->setSourceOrder(SourceOrder);
Richard Smithc2bb8182015-03-24 06:36:48 +00008832 }
8833
Richard Smithc2bb8182015-03-24 06:36:48 +00008834 CtorInitializers[i] = BOMInit;
Guy Benyei11169dd2012-12-18 14:30:41 +00008835 }
8836
Richard Smithc2bb8182015-03-24 06:36:48 +00008837 return CtorInitializers;
Guy Benyei11169dd2012-12-18 14:30:41 +00008838}
8839
Guy Benyei11169dd2012-12-18 14:30:41 +00008840NestedNameSpecifierLoc
John McCall3ce3d232019-12-13 03:37:23 -05008841ASTRecordReader::readNestedNameSpecifierLoc() {
Richard Smithdbafb6c2017-06-29 23:23:46 +00008842 ASTContext &Context = getContext();
John McCall3ce3d232019-12-13 03:37:23 -05008843 unsigned N = readInt();
Guy Benyei11169dd2012-12-18 14:30:41 +00008844 NestedNameSpecifierLocBuilder Builder;
8845 for (unsigned I = 0; I != N; ++I) {
John McCalld505e572019-12-13 21:54:44 -05008846 auto Kind = readNestedNameSpecifierKind();
Guy Benyei11169dd2012-12-18 14:30:41 +00008847 switch (Kind) {
8848 case NestedNameSpecifier::Identifier: {
John McCall3ce3d232019-12-13 03:37:23 -05008849 IdentifierInfo *II = readIdentifier();
8850 SourceRange Range = readSourceRange();
Guy Benyei11169dd2012-12-18 14:30:41 +00008851 Builder.Extend(Context, II, Range.getBegin(), Range.getEnd());
8852 break;
8853 }
8854
8855 case NestedNameSpecifier::Namespace: {
John McCall3ce3d232019-12-13 03:37:23 -05008856 NamespaceDecl *NS = readDeclAs<NamespaceDecl>();
8857 SourceRange Range = readSourceRange();
Guy Benyei11169dd2012-12-18 14:30:41 +00008858 Builder.Extend(Context, NS, Range.getBegin(), Range.getEnd());
8859 break;
8860 }
8861
8862 case NestedNameSpecifier::NamespaceAlias: {
John McCall3ce3d232019-12-13 03:37:23 -05008863 NamespaceAliasDecl *Alias = readDeclAs<NamespaceAliasDecl>();
8864 SourceRange Range = readSourceRange();
Guy Benyei11169dd2012-12-18 14:30:41 +00008865 Builder.Extend(Context, Alias, Range.getBegin(), Range.getEnd());
8866 break;
8867 }
8868
8869 case NestedNameSpecifier::TypeSpec:
8870 case NestedNameSpecifier::TypeSpecWithTemplate: {
John McCall3ce3d232019-12-13 03:37:23 -05008871 bool Template = readBool();
8872 TypeSourceInfo *T = readTypeSourceInfo();
Guy Benyei11169dd2012-12-18 14:30:41 +00008873 if (!T)
Vedant Kumar48b4f762018-04-14 01:40:48 +00008874 return NestedNameSpecifierLoc();
John McCall3ce3d232019-12-13 03:37:23 -05008875 SourceLocation ColonColonLoc = readSourceLocation();
Guy Benyei11169dd2012-12-18 14:30:41 +00008876
8877 // FIXME: 'template' keyword location not saved anywhere, so we fake it.
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008878 Builder.Extend(Context,
Guy Benyei11169dd2012-12-18 14:30:41 +00008879 Template? T->getTypeLoc().getBeginLoc() : SourceLocation(),
8880 T->getTypeLoc(), ColonColonLoc);
8881 break;
8882 }
8883
8884 case NestedNameSpecifier::Global: {
John McCall3ce3d232019-12-13 03:37:23 -05008885 SourceLocation ColonColonLoc = readSourceLocation();
Guy Benyei11169dd2012-12-18 14:30:41 +00008886 Builder.MakeGlobal(Context, ColonColonLoc);
8887 break;
8888 }
Nikola Smiljanic67860242014-09-26 00:28:20 +00008889
8890 case NestedNameSpecifier::Super: {
John McCall3ce3d232019-12-13 03:37:23 -05008891 CXXRecordDecl *RD = readDeclAs<CXXRecordDecl>();
8892 SourceRange Range = readSourceRange();
Nikola Smiljanic67860242014-09-26 00:28:20 +00008893 Builder.MakeSuper(Context, RD, Range.getBegin(), Range.getEnd());
8894 break;
8895 }
Guy Benyei11169dd2012-12-18 14:30:41 +00008896 }
8897 }
Nikola Smiljanic67860242014-09-26 00:28:20 +00008898
Guy Benyei11169dd2012-12-18 14:30:41 +00008899 return Builder.getWithLocInContext(Context);
8900}
8901
8902SourceRange
8903ASTReader::ReadSourceRange(ModuleFile &F, const RecordData &Record,
8904 unsigned &Idx) {
8905 SourceLocation beg = ReadSourceLocation(F, Record, Idx);
8906 SourceLocation end = ReadSourceLocation(F, Record, Idx);
8907 return SourceRange(beg, end);
8908}
8909
Gauthier Harnisch83c7b612019-06-15 10:24:47 +00008910static FixedPointSemantics
8911ReadFixedPointSemantics(const SmallVectorImpl<uint64_t> &Record,
8912 unsigned &Idx) {
8913 unsigned Width = Record[Idx++];
8914 unsigned Scale = Record[Idx++];
8915 uint64_t Tmp = Record[Idx++];
8916 bool IsSigned = Tmp & 0x1;
8917 bool IsSaturated = Tmp & 0x2;
8918 bool HasUnsignedPadding = Tmp & 0x4;
8919 return FixedPointSemantics(Width, Scale, IsSigned, IsSaturated,
8920 HasUnsignedPadding);
8921}
8922
John McCall3ce3d232019-12-13 03:37:23 -05008923static const llvm::fltSemantics &
8924readAPFloatSemantics(ASTRecordReader &reader) {
8925 return llvm::APFloatBase::EnumToSemantics(
8926 static_cast<llvm::APFloatBase::Semantics>(reader.readInt()));
8927}
8928
8929APValue ASTRecordReader::readAPValue() {
8930 unsigned Kind = readInt();
John McCalld505e572019-12-13 21:54:44 -05008931 switch ((APValue::ValueKind) Kind) {
Gauthier Harnisch83c7b612019-06-15 10:24:47 +00008932 case APValue::None:
8933 return APValue();
8934 case APValue::Indeterminate:
8935 return APValue::IndeterminateValue();
8936 case APValue::Int:
John McCall3ce3d232019-12-13 03:37:23 -05008937 return APValue(readAPSInt());
Gauthier Harnisch83c7b612019-06-15 10:24:47 +00008938 case APValue::Float: {
John McCall3ce3d232019-12-13 03:37:23 -05008939 const llvm::fltSemantics &FloatSema = readAPFloatSemantics(*this);
8940 return APValue(readAPFloat(FloatSema));
Gauthier Harnisch83c7b612019-06-15 10:24:47 +00008941 }
8942 case APValue::FixedPoint: {
8943 FixedPointSemantics FPSema = ReadFixedPointSemantics(Record, Idx);
John McCall3ce3d232019-12-13 03:37:23 -05008944 return APValue(APFixedPoint(readAPInt(), FPSema));
Gauthier Harnisch83c7b612019-06-15 10:24:47 +00008945 }
8946 case APValue::ComplexInt: {
John McCall3ce3d232019-12-13 03:37:23 -05008947 llvm::APSInt First = readAPSInt();
8948 return APValue(std::move(First), readAPSInt());
Gauthier Harnisch83c7b612019-06-15 10:24:47 +00008949 }
8950 case APValue::ComplexFloat: {
John McCall3ce3d232019-12-13 03:37:23 -05008951 const llvm::fltSemantics &FloatSema1 = readAPFloatSemantics(*this);
8952 llvm::APFloat First = readAPFloat(FloatSema1);
8953 const llvm::fltSemantics &FloatSema2 = readAPFloatSemantics(*this);
8954 return APValue(std::move(First), readAPFloat(FloatSema2));
Gauthier Harnisch83c7b612019-06-15 10:24:47 +00008955 }
8956 case APValue::LValue:
8957 case APValue::Vector:
8958 case APValue::Array:
8959 case APValue::Struct:
8960 case APValue::Union:
8961 case APValue::MemberPointer:
8962 case APValue::AddrLabelDiff:
8963 // TODO : Handle all these APValue::ValueKind.
8964 return APValue();
8965 }
8966 llvm_unreachable("Invalid APValue::ValueKind");
8967}
8968
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00008969/// Read a floating-point value
John McCall3ce3d232019-12-13 03:37:23 -05008970llvm::APFloat ASTRecordReader::readAPFloat(const llvm::fltSemantics &Sem) {
8971 return llvm::APFloat(Sem, readAPInt());
Guy Benyei11169dd2012-12-18 14:30:41 +00008972}
8973
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00008974// Read a string
Guy Benyei11169dd2012-12-18 14:30:41 +00008975std::string ASTReader::ReadString(const RecordData &Record, unsigned &Idx) {
8976 unsigned Len = Record[Idx++];
8977 std::string Result(Record.data() + Idx, Record.data() + Idx + Len);
8978 Idx += Len;
8979 return Result;
8980}
8981
Richard Smith7ed1bc92014-12-05 22:42:13 +00008982std::string ASTReader::ReadPath(ModuleFile &F, const RecordData &Record,
8983 unsigned &Idx) {
8984 std::string Filename = ReadString(Record, Idx);
8985 ResolveImportedPath(F, Filename);
8986 return Filename;
8987}
8988
Duncan P. N. Exon Smith0a2be462019-03-09 17:44:01 +00008989std::string ASTReader::ReadPath(StringRef BaseDirectory,
8990 const RecordData &Record, unsigned &Idx) {
8991 std::string Filename = ReadString(Record, Idx);
8992 if (!BaseDirectory.empty())
8993 ResolveImportedPath(Filename, BaseDirectory);
8994 return Filename;
8995}
8996
David L. Jonesc4808b9e2016-12-15 20:53:26 +00008997VersionTuple ASTReader::ReadVersionTuple(const RecordData &Record,
Guy Benyei11169dd2012-12-18 14:30:41 +00008998 unsigned &Idx) {
8999 unsigned Major = Record[Idx++];
9000 unsigned Minor = Record[Idx++];
9001 unsigned Subminor = Record[Idx++];
9002 if (Minor == 0)
9003 return VersionTuple(Major);
9004 if (Subminor == 0)
9005 return VersionTuple(Major, Minor - 1);
9006 return VersionTuple(Major, Minor - 1, Subminor - 1);
9007}
9008
David L. Jonesc4808b9e2016-12-15 20:53:26 +00009009CXXTemporary *ASTReader::ReadCXXTemporary(ModuleFile &F,
Guy Benyei11169dd2012-12-18 14:30:41 +00009010 const RecordData &Record,
9011 unsigned &Idx) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00009012 CXXDestructorDecl *Decl = ReadDeclAs<CXXDestructorDecl>(F, Record, Idx);
Richard Smithdbafb6c2017-06-29 23:23:46 +00009013 return CXXTemporary::Create(getContext(), Decl);
Guy Benyei11169dd2012-12-18 14:30:41 +00009014}
9015
Richard Smith37a93df2017-02-18 00:32:02 +00009016DiagnosticBuilder ASTReader::Diag(unsigned DiagID) const {
Argyrios Kyrtzidisdc9fdaf2013-05-24 05:44:08 +00009017 return Diag(CurrentImportLoc, DiagID);
Guy Benyei11169dd2012-12-18 14:30:41 +00009018}
9019
Richard Smith37a93df2017-02-18 00:32:02 +00009020DiagnosticBuilder ASTReader::Diag(SourceLocation Loc, unsigned DiagID) const {
Guy Benyei11169dd2012-12-18 14:30:41 +00009021 return Diags.Report(Loc, DiagID);
9022}
9023
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00009024/// Retrieve the identifier table associated with the
Guy Benyei11169dd2012-12-18 14:30:41 +00009025/// preprocessor.
9026IdentifierTable &ASTReader::getIdentifierTable() {
9027 return PP.getIdentifierTable();
9028}
9029
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00009030/// Record that the given ID maps to the given switch-case
Guy Benyei11169dd2012-12-18 14:30:41 +00009031/// statement.
9032void ASTReader::RecordSwitchCaseID(SwitchCase *SC, unsigned ID) {
Craig Toppera13603a2014-05-22 05:54:18 +00009033 assert((*CurrSwitchCaseStmts)[ID] == nullptr &&
Guy Benyei11169dd2012-12-18 14:30:41 +00009034 "Already have a SwitchCase with this ID");
9035 (*CurrSwitchCaseStmts)[ID] = SC;
9036}
9037
Adrian Prantl9fc8faf2018-05-09 01:00:01 +00009038/// Retrieve the switch-case statement with the given ID.
Guy Benyei11169dd2012-12-18 14:30:41 +00009039SwitchCase *ASTReader::getSwitchCaseWithID(unsigned ID) {
Craig Toppera13603a2014-05-22 05:54:18 +00009040 assert((*CurrSwitchCaseStmts)[ID] != nullptr && "No SwitchCase with this ID");
Guy Benyei11169dd2012-12-18 14:30:41 +00009041 return (*CurrSwitchCaseStmts)[ID];
9042}
9043
9044void ASTReader::ClearSwitchCaseIDs() {
9045 CurrSwitchCaseStmts->clear();
9046}
9047
9048void ASTReader::ReadComments() {
Richard Smithdbafb6c2017-06-29 23:23:46 +00009049 ASTContext &Context = getContext();
Guy Benyei11169dd2012-12-18 14:30:41 +00009050 std::vector<RawComment *> Comments;
Vedant Kumar48b4f762018-04-14 01:40:48 +00009051 for (SmallVectorImpl<std::pair<BitstreamCursor,
9052 serialization::ModuleFile *>>::iterator
9053 I = CommentsCursors.begin(),
9054 E = CommentsCursors.end();
9055 I != E; ++I) {
Dmitri Gribenko9ee0e302014-03-27 15:40:39 +00009056 Comments.clear();
Vedant Kumar48b4f762018-04-14 01:40:48 +00009057 BitstreamCursor &Cursor = I->first;
9058 serialization::ModuleFile &F = *I->second;
Guy Benyei11169dd2012-12-18 14:30:41 +00009059 SavedStreamPosition SavedPosition(Cursor);
9060
9061 RecordData Record;
9062 while (true) {
JF Bastien0e828952019-06-26 19:50:12 +00009063 Expected<llvm::BitstreamEntry> MaybeEntry =
9064 Cursor.advanceSkippingSubblocks(
9065 BitstreamCursor::AF_DontPopBlockAtEnd);
9066 if (!MaybeEntry) {
9067 Error(MaybeEntry.takeError());
9068 return;
9069 }
9070 llvm::BitstreamEntry Entry = MaybeEntry.get();
Dmitri Gribenko9ee0e302014-03-27 15:40:39 +00009071
Chris Lattner7fb3bef2013-01-20 00:56:42 +00009072 switch (Entry.Kind) {
9073 case llvm::BitstreamEntry::SubBlock: // Handled for us already.
9074 case llvm::BitstreamEntry::Error:
9075 Error("malformed block record in AST file");
9076 return;
9077 case llvm::BitstreamEntry::EndBlock:
9078 goto NextCursor;
9079 case llvm::BitstreamEntry::Record:
9080 // The interesting case.
Guy Benyei11169dd2012-12-18 14:30:41 +00009081 break;
Guy Benyei11169dd2012-12-18 14:30:41 +00009082 }
9083
9084 // Read a record.
9085 Record.clear();
JF Bastien0e828952019-06-26 19:50:12 +00009086 Expected<unsigned> MaybeComment = Cursor.readRecord(Entry.ID, Record);
9087 if (!MaybeComment) {
9088 Error(MaybeComment.takeError());
9089 return;
9090 }
9091 switch ((CommentRecordTypes)MaybeComment.get()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00009092 case COMMENTS_RAW_COMMENT: {
9093 unsigned Idx = 0;
9094 SourceRange SR = ReadSourceRange(F, Record, Idx);
Vedant Kumar48b4f762018-04-14 01:40:48 +00009095 RawComment::CommentKind Kind =
9096 (RawComment::CommentKind) Record[Idx++];
Guy Benyei11169dd2012-12-18 14:30:41 +00009097 bool IsTrailingComment = Record[Idx++];
9098 bool IsAlmostTrailingComment = Record[Idx++];
Dmitri Gribenkoa7d16ce2013-04-10 15:35:17 +00009099 Comments.push_back(new (Context) RawComment(
David L. Jones13d5a872018-03-02 00:07:45 +00009100 SR, Kind, IsTrailingComment, IsAlmostTrailingComment));
Guy Benyei11169dd2012-12-18 14:30:41 +00009101 break;
9102 }
9103 }
9104 }
Dmitri Gribenko9ee0e302014-03-27 15:40:39 +00009105 NextCursor:
Jan Korousf31d8df2019-08-13 18:11:44 +00009106 llvm::DenseMap<FileID, std::map<unsigned, RawComment *>>
9107 FileToOffsetToComment;
9108 for (RawComment *C : Comments) {
9109 SourceLocation CommentLoc = C->getBeginLoc();
9110 if (CommentLoc.isValid()) {
9111 std::pair<FileID, unsigned> Loc =
9112 SourceMgr.getDecomposedLoc(CommentLoc);
9113 if (Loc.first.isValid())
9114 Context.Comments.OrderedComments[Loc.first].emplace(Loc.second, C);
9115 }
9116 }
Guy Benyei11169dd2012-12-18 14:30:41 +00009117 }
Guy Benyei11169dd2012-12-18 14:30:41 +00009118}
9119
Argyrios Kyrtzidisa38cb202017-01-30 06:05:58 +00009120void ASTReader::visitInputFiles(serialization::ModuleFile &MF,
9121 bool IncludeSystem, bool Complain,
9122 llvm::function_ref<void(const serialization::InputFile &IF,
9123 bool isSystem)> Visitor) {
9124 unsigned NumUserInputs = MF.NumUserInputFiles;
9125 unsigned NumInputs = MF.InputFilesLoaded.size();
9126 assert(NumUserInputs <= NumInputs);
9127 unsigned N = IncludeSystem ? NumInputs : NumUserInputs;
9128 for (unsigned I = 0; I < N; ++I) {
9129 bool IsSystem = I >= NumUserInputs;
9130 InputFile IF = getInputFile(MF, I+1, Complain);
9131 Visitor(IF, IsSystem);
9132 }
9133}
9134
Richard Smithf3f84612017-06-29 02:19:42 +00009135void ASTReader::visitTopLevelModuleMaps(
9136 serialization::ModuleFile &MF,
9137 llvm::function_ref<void(const FileEntry *FE)> Visitor) {
9138 unsigned NumInputs = MF.InputFilesLoaded.size();
9139 for (unsigned I = 0; I < NumInputs; ++I) {
9140 InputFileInfo IFI = readInputFileInfo(MF, I + 1);
9141 if (IFI.TopLevelModuleMap)
9142 // FIXME: This unnecessarily re-reads the InputFileInfo.
9143 if (auto *FE = getInputFile(MF, I + 1).getFile())
9144 Visitor(FE);
9145 }
9146}
9147
Richard Smithcd45dbc2014-04-19 03:48:30 +00009148std::string ASTReader::getOwningModuleNameForDiagnostic(const Decl *D) {
9149 // If we know the owning module, use it.
Richard Smith42413142015-05-15 20:05:43 +00009150 if (Module *M = D->getImportedOwningModule())
Richard Smithcd45dbc2014-04-19 03:48:30 +00009151 return M->getFullModuleName();
9152
9153 // Otherwise, use the name of the top-level module the decl is within.
9154 if (ModuleFile *M = getOwningModuleFile(D))
9155 return M->ModuleName;
9156
9157 // Not from a module.
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00009158 return {};
Richard Smithcd45dbc2014-04-19 03:48:30 +00009159}
9160
Guy Benyei11169dd2012-12-18 14:30:41 +00009161void ASTReader::finishPendingActions() {
Richard Smitha62d1982018-08-03 01:00:01 +00009162 while (!PendingIdentifierInfos.empty() || !PendingFunctionTypes.empty() ||
Richard Smith851072e2014-05-19 20:59:20 +00009163 !PendingIncompleteDeclChains.empty() || !PendingDeclChains.empty() ||
Richard Smith2b9e3e32013-10-18 06:05:18 +00009164 !PendingMacroIDs.empty() || !PendingDeclContextInfos.empty() ||
Richard Smitha0ce9c42014-07-29 23:23:27 +00009165 !PendingUpdateRecords.empty()) {
Guy Benyei11169dd2012-12-18 14:30:41 +00009166 // If any identifiers with corresponding top-level declarations have
9167 // been loaded, load those declarations now.
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +00009168 using TopLevelDeclsMap =
9169 llvm::DenseMap<IdentifierInfo *, SmallVector<Decl *, 2>>;
Craig Topper79be4cd2013-07-05 04:33:53 +00009170 TopLevelDeclsMap TopLevelDecls;
9171
Guy Benyei11169dd2012-12-18 14:30:41 +00009172 while (!PendingIdentifierInfos.empty()) {
Douglas Gregor6168bd22013-02-18 15:53:43 +00009173 IdentifierInfo *II = PendingIdentifierInfos.back().first;
Richard Smithf0ae3c2d2014-03-28 17:31:23 +00009174 SmallVector<uint32_t, 4> DeclIDs =
9175 std::move(PendingIdentifierInfos.back().second);
Douglas Gregorcb15f082013-02-19 18:26:28 +00009176 PendingIdentifierInfos.pop_back();
Douglas Gregor6168bd22013-02-18 15:53:43 +00009177
9178 SetGloballyVisibleDecls(II, DeclIDs, &TopLevelDecls[II]);
Guy Benyei11169dd2012-12-18 14:30:41 +00009179 }
Richard Smithf0ae3c2d2014-03-28 17:31:23 +00009180
Richard Smitha62d1982018-08-03 01:00:01 +00009181 // Load each function type that we deferred loading because it was a
9182 // deduced type that might refer to a local type declared within itself.
9183 for (unsigned I = 0; I != PendingFunctionTypes.size(); ++I) {
9184 auto *FD = PendingFunctionTypes[I].first;
9185 FD->setType(GetType(PendingFunctionTypes[I].second));
9186
9187 // If we gave a function a deduced return type, remember that we need to
9188 // propagate that along the redeclaration chain.
9189 auto *DT = FD->getReturnType()->getContainedDeducedType();
9190 if (DT && DT->isDeduced())
9191 PendingDeducedTypeUpdates.insert(
9192 {FD->getCanonicalDecl(), FD->getReturnType()});
9193 }
9194 PendingFunctionTypes.clear();
9195
Richard Smith851072e2014-05-19 20:59:20 +00009196 // For each decl chain that we wanted to complete while deserializing, mark
9197 // it as "still needs to be completed".
Vedant Kumar48b4f762018-04-14 01:40:48 +00009198 for (unsigned I = 0; I != PendingIncompleteDeclChains.size(); ++I) {
9199 markIncompleteDeclChain(PendingIncompleteDeclChains[I]);
9200 }
Richard Smith851072e2014-05-19 20:59:20 +00009201 PendingIncompleteDeclChains.clear();
9202
Guy Benyei11169dd2012-12-18 14:30:41 +00009203 // Load pending declaration chains.
Vedant Kumar48b4f762018-04-14 01:40:48 +00009204 for (unsigned I = 0; I != PendingDeclChains.size(); ++I)
Richard Smitha62d1982018-08-03 01:00:01 +00009205 loadPendingDeclChain(PendingDeclChains[I].first,
9206 PendingDeclChains[I].second);
Guy Benyei11169dd2012-12-18 14:30:41 +00009207 PendingDeclChains.clear();
9208
Douglas Gregor6168bd22013-02-18 15:53:43 +00009209 // Make the most recent of the top-level declarations visible.
Vedant Kumar48b4f762018-04-14 01:40:48 +00009210 for (TopLevelDeclsMap::iterator TLD = TopLevelDecls.begin(),
9211 TLDEnd = TopLevelDecls.end(); TLD != TLDEnd; ++TLD) {
9212 IdentifierInfo *II = TLD->first;
9213 for (unsigned I = 0, N = TLD->second.size(); I != N; ++I) {
9214 pushExternalDeclIntoScope(cast<NamedDecl>(TLD->second[I]), II);
Douglas Gregor6168bd22013-02-18 15:53:43 +00009215 }
9216 }
9217
Guy Benyei11169dd2012-12-18 14:30:41 +00009218 // Load any pending macro definitions.
9219 for (unsigned I = 0; I != PendingMacroIDs.size(); ++I) {
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00009220 IdentifierInfo *II = PendingMacroIDs.begin()[I].first;
9221 SmallVector<PendingMacroInfo, 2> GlobalIDs;
9222 GlobalIDs.swap(PendingMacroIDs.begin()[I].second);
9223 // Initialize the macro history from chained-PCHs ahead of module imports.
Richard Smith49f906a2014-03-01 00:08:04 +00009224 for (unsigned IDIdx = 0, NumIDs = GlobalIDs.size(); IDIdx != NumIDs;
Argyrios Kyrtzidis719736c2013-01-19 03:14:56 +00009225 ++IDIdx) {
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00009226 const PendingMacroInfo &Info = GlobalIDs[IDIdx];
Manman Ren11f2a472016-08-18 17:42:15 +00009227 if (!Info.M->isModule())
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00009228 resolvePendingMacro(II, Info);
9229 }
9230 // Handle module imports.
Richard Smith49f906a2014-03-01 00:08:04 +00009231 for (unsigned IDIdx = 0, NumIDs = GlobalIDs.size(); IDIdx != NumIDs;
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00009232 ++IDIdx) {
9233 const PendingMacroInfo &Info = GlobalIDs[IDIdx];
Manman Ren11f2a472016-08-18 17:42:15 +00009234 if (Info.M->isModule())
Argyrios Kyrtzidiseb663da2013-03-22 21:12:57 +00009235 resolvePendingMacro(II, Info);
Guy Benyei11169dd2012-12-18 14:30:41 +00009236 }
9237 }
9238 PendingMacroIDs.clear();
Argyrios Kyrtzidis83a6e3b2013-02-16 00:48:59 +00009239
9240 // Wire up the DeclContexts for Decls that we delayed setting until
9241 // recursive loading is completed.
9242 while (!PendingDeclContextInfos.empty()) {
9243 PendingDeclContextInfo Info = PendingDeclContextInfos.front();
9244 PendingDeclContextInfos.pop_front();
Vedant Kumar48b4f762018-04-14 01:40:48 +00009245 DeclContext *SemaDC = cast<DeclContext>(GetDecl(Info.SemaDC));
9246 DeclContext *LexicalDC = cast<DeclContext>(GetDecl(Info.LexicalDC));
Argyrios Kyrtzidis83a6e3b2013-02-16 00:48:59 +00009247 Info.D->setDeclContextsImpl(SemaDC, LexicalDC, getContext());
9248 }
Richard Smith2b9e3e32013-10-18 06:05:18 +00009249
Richard Smithd1c46742014-04-30 02:24:17 +00009250 // Perform any pending declaration updates.
Richard Smithd6db68c2014-08-07 20:58:41 +00009251 while (!PendingUpdateRecords.empty()) {
Richard Smithd1c46742014-04-30 02:24:17 +00009252 auto Update = PendingUpdateRecords.pop_back_val();
9253 ReadingKindTracker ReadingKind(Read_Decl, *this);
Vassil Vassilev74c3e8c2017-05-19 16:46:06 +00009254 loadDeclUpdateRecords(Update);
Richard Smithd1c46742014-04-30 02:24:17 +00009255 }
Guy Benyei11169dd2012-12-18 14:30:41 +00009256 }
Richard Smith8a639892015-01-24 01:07:20 +00009257
9258 // At this point, all update records for loaded decls are in place, so any
9259 // fake class definitions should have become real.
9260 assert(PendingFakeDefinitionData.empty() &&
9261 "faked up a class definition but never saw the real one");
9262
Guy Benyei11169dd2012-12-18 14:30:41 +00009263 // If we deserialized any C++ or Objective-C class definitions, any
9264 // Objective-C protocol definitions, or any redeclarable templates, make sure
David L. Jonesc4808b9e2016-12-15 20:53:26 +00009265 // that all redeclarations point to the definitions. Note that this can only
Guy Benyei11169dd2012-12-18 14:30:41 +00009266 // happen now, after the redeclaration chains have been fully wired.
Vedant Kumar48b4f762018-04-14 01:40:48 +00009267 for (Decl *D : PendingDefinitions) {
9268 if (TagDecl *TD = dyn_cast<TagDecl>(D)) {
9269 if (const TagType *TagT = dyn_cast<TagType>(TD->getTypeForDecl())) {
Guy Benyei11169dd2012-12-18 14:30:41 +00009270 // Make sure that the TagType points at the definition.
9271 const_cast<TagType*>(TagT)->decl = TD;
9272 }
Richard Smith8ce51082015-03-11 01:44:51 +00009273
Vedant Kumar48b4f762018-04-14 01:40:48 +00009274 if (auto RD = dyn_cast<CXXRecordDecl>(D)) {
Richard Smith8ce51082015-03-11 01:44:51 +00009275 for (auto *R = getMostRecentExistingDecl(RD); R;
9276 R = R->getPreviousDecl()) {
9277 assert((R == D) ==
9278 cast<CXXRecordDecl>(R)->isThisDeclarationADefinition() &&
Richard Smith2c381642014-08-27 23:11:59 +00009279 "declaration thinks it's the definition but it isn't");
Aaron Ballman86c93902014-03-06 23:45:36 +00009280 cast<CXXRecordDecl>(R)->DefinitionData = RD->DefinitionData;
Richard Smith2c381642014-08-27 23:11:59 +00009281 }
Guy Benyei11169dd2012-12-18 14:30:41 +00009282 }
9283
9284 continue;
9285 }
Richard Smith8ce51082015-03-11 01:44:51 +00009286
Vedant Kumar48b4f762018-04-14 01:40:48 +00009287 if (auto ID = dyn_cast<ObjCInterfaceDecl>(D)) {
Guy Benyei11169dd2012-12-18 14:30:41 +00009288 // Make sure that the ObjCInterfaceType points at the definition.
9289 const_cast<ObjCInterfaceType *>(cast<ObjCInterfaceType>(ID->TypeForDecl))
9290 ->Decl = ID;
Richard Smith8ce51082015-03-11 01:44:51 +00009291
9292 for (auto *R = getMostRecentExistingDecl(ID); R; R = R->getPreviousDecl())
9293 cast<ObjCInterfaceDecl>(R)->Data = ID->Data;
9294
Guy Benyei11169dd2012-12-18 14:30:41 +00009295 continue;
9296 }
Richard Smith8ce51082015-03-11 01:44:51 +00009297
Vedant Kumar48b4f762018-04-14 01:40:48 +00009298 if (auto PD = dyn_cast<ObjCProtocolDecl>(D)) {
Richard Smith8ce51082015-03-11 01:44:51 +00009299 for (auto *R = getMostRecentExistingDecl(PD); R; R = R->getPreviousDecl())
9300 cast<ObjCProtocolDecl>(R)->Data = PD->Data;
9301
Guy Benyei11169dd2012-12-18 14:30:41 +00009302 continue;
9303 }
Richard Smith8ce51082015-03-11 01:44:51 +00009304
Vedant Kumar48b4f762018-04-14 01:40:48 +00009305 auto RTD = cast<RedeclarableTemplateDecl>(D)->getCanonicalDecl();
Richard Smith8ce51082015-03-11 01:44:51 +00009306 for (auto *R = getMostRecentExistingDecl(RTD); R; R = R->getPreviousDecl())
9307 cast<RedeclarableTemplateDecl>(R)->Common = RTD->Common;
Guy Benyei11169dd2012-12-18 14:30:41 +00009308 }
9309 PendingDefinitions.clear();
9310
Daniel Jasper4a6d5b72017-10-11 07:47:54 +00009311 // Load the bodies of any functions or methods we've encountered. We do
9312 // this now (delayed) so that we can be sure that the declaration chains
9313 // have been fully wired up (hasBody relies on this).
9314 // FIXME: We shouldn't require complete redeclaration chains here.
Vedant Kumar48b4f762018-04-14 01:40:48 +00009315 for (PendingBodiesMap::iterator PB = PendingBodies.begin(),
9316 PBEnd = PendingBodies.end();
9317 PB != PBEnd; ++PB) {
9318 if (FunctionDecl *FD = dyn_cast<FunctionDecl>(PB->first)) {
Richard Smith0b70de12018-06-28 01:07:28 +00009319 // For a function defined inline within a class template, force the
9320 // canonical definition to be the one inside the canonical definition of
9321 // the template. This ensures that we instantiate from a correct view
9322 // of the template.
9323 //
9324 // Sadly we can't do this more generally: we can't be sure that all
9325 // copies of an arbitrary class definition will have the same members
9326 // defined (eg, some member functions may not be instantiated, and some
9327 // special members may or may not have been implicitly defined).
9328 if (auto *RD = dyn_cast<CXXRecordDecl>(FD->getLexicalParent()))
9329 if (RD->isDependentContext() && !RD->isThisDeclarationADefinition())
9330 continue;
9331
Daniel Jasper4a6d5b72017-10-11 07:47:54 +00009332 // FIXME: Check for =delete/=default?
9333 // FIXME: Complain about ODR violations here?
9334 const FunctionDecl *Defn = nullptr;
9335 if (!getContext().getLangOpts().Modules || !FD->hasBody(Defn)) {
Vedant Kumar48b4f762018-04-14 01:40:48 +00009336 FD->setLazyBody(PB->second);
Richard Trieue6caa262017-12-23 00:41:01 +00009337 } else {
Vedant Kumar48b4f762018-04-14 01:40:48 +00009338 auto *NonConstDefn = const_cast<FunctionDecl*>(Defn);
Richard Trieue6caa262017-12-23 00:41:01 +00009339 mergeDefinitionVisibility(NonConstDefn, FD);
9340
9341 if (!FD->isLateTemplateParsed() &&
9342 !NonConstDefn->isLateTemplateParsed() &&
9343 FD->getODRHash() != NonConstDefn->getODRHash()) {
Richard Trieu27c1b1a2018-07-10 01:40:50 +00009344 if (!isa<CXXMethodDecl>(FD)) {
9345 PendingFunctionOdrMergeFailures[FD].push_back(NonConstDefn);
9346 } else if (FD->getLexicalParent()->isFileContext() &&
9347 NonConstDefn->getLexicalParent()->isFileContext()) {
9348 // Only diagnose out-of-line method definitions. If they are
9349 // in class definitions, then an error will be generated when
9350 // processing the class bodies.
9351 PendingFunctionOdrMergeFailures[FD].push_back(NonConstDefn);
9352 }
Richard Trieue6caa262017-12-23 00:41:01 +00009353 }
9354 }
Daniel Jasper4a6d5b72017-10-11 07:47:54 +00009355 continue;
9356 }
9357
Vedant Kumar48b4f762018-04-14 01:40:48 +00009358 ObjCMethodDecl *MD = cast<ObjCMethodDecl>(PB->first);
Daniel Jasper4a6d5b72017-10-11 07:47:54 +00009359 if (!getContext().getLangOpts().Modules || !MD->hasBody())
Vedant Kumar48b4f762018-04-14 01:40:48 +00009360 MD->setLazyBody(PB->second);
Daniel Jasper4a6d5b72017-10-11 07:47:54 +00009361 }
9362 PendingBodies.clear();
9363
Richard Smith42413142015-05-15 20:05:43 +00009364 // Do some cleanup.
9365 for (auto *ND : PendingMergedDefinitionsToDeduplicate)
9366 getContext().deduplicateMergedDefinitonsFor(ND);
9367 PendingMergedDefinitionsToDeduplicate.clear();
Richard Smitha0ce9c42014-07-29 23:23:27 +00009368}
9369
9370void ASTReader::diagnoseOdrViolations() {
Richard Trieue6caa262017-12-23 00:41:01 +00009371 if (PendingOdrMergeFailures.empty() && PendingOdrMergeChecks.empty() &&
Richard Trieuab4d7302018-07-25 22:52:05 +00009372 PendingFunctionOdrMergeFailures.empty() &&
9373 PendingEnumOdrMergeFailures.empty())
Richard Smithbb853c72014-08-13 01:23:33 +00009374 return;
9375
Richard Smitha0ce9c42014-07-29 23:23:27 +00009376 // Trigger the import of the full definition of each class that had any
9377 // odr-merging problems, so we can produce better diagnostics for them.
Richard Smithbb853c72014-08-13 01:23:33 +00009378 // These updates may in turn find and diagnose some ODR failures, so take
9379 // ownership of the set first.
9380 auto OdrMergeFailures = std::move(PendingOdrMergeFailures);
9381 PendingOdrMergeFailures.clear();
9382 for (auto &Merge : OdrMergeFailures) {
Richard Smitha0ce9c42014-07-29 23:23:27 +00009383 Merge.first->buildLookup();
9384 Merge.first->decls_begin();
9385 Merge.first->bases_begin();
9386 Merge.first->vbases_begin();
Richard Trieue13eabe2017-09-30 02:19:17 +00009387 for (auto &RecordPair : Merge.second) {
9388 auto *RD = RecordPair.first;
Richard Smitha0ce9c42014-07-29 23:23:27 +00009389 RD->decls_begin();
9390 RD->bases_begin();
9391 RD->vbases_begin();
9392 }
9393 }
9394
Richard Trieue6caa262017-12-23 00:41:01 +00009395 // Trigger the import of functions.
9396 auto FunctionOdrMergeFailures = std::move(PendingFunctionOdrMergeFailures);
9397 PendingFunctionOdrMergeFailures.clear();
9398 for (auto &Merge : FunctionOdrMergeFailures) {
9399 Merge.first->buildLookup();
9400 Merge.first->decls_begin();
9401 Merge.first->getBody();
9402 for (auto &FD : Merge.second) {
9403 FD->buildLookup();
9404 FD->decls_begin();
9405 FD->getBody();
9406 }
9407 }
9408
Richard Trieuab4d7302018-07-25 22:52:05 +00009409 // Trigger the import of enums.
9410 auto EnumOdrMergeFailures = std::move(PendingEnumOdrMergeFailures);
9411 PendingEnumOdrMergeFailures.clear();
9412 for (auto &Merge : EnumOdrMergeFailures) {
9413 Merge.first->decls_begin();
9414 for (auto &Enum : Merge.second) {
9415 Enum->decls_begin();
9416 }
9417 }
9418
Richard Smitha0ce9c42014-07-29 23:23:27 +00009419 // For each declaration from a merged context, check that the canonical
9420 // definition of that context also contains a declaration of the same
9421 // entity.
9422 //
9423 // Caution: this loop does things that might invalidate iterators into
9424 // PendingOdrMergeChecks. Don't turn this into a range-based for loop!
9425 while (!PendingOdrMergeChecks.empty()) {
9426 NamedDecl *D = PendingOdrMergeChecks.pop_back_val();
9427
9428 // FIXME: Skip over implicit declarations for now. This matters for things
9429 // like implicitly-declared special member functions. This isn't entirely
9430 // correct; we can end up with multiple unmerged declarations of the same
9431 // implicit entity.
9432 if (D->isImplicit())
9433 continue;
9434
9435 DeclContext *CanonDef = D->getDeclContext();
Richard Smitha0ce9c42014-07-29 23:23:27 +00009436
9437 bool Found = false;
9438 const Decl *DCanon = D->getCanonicalDecl();
9439
Richard Smith01bdb7a2014-08-28 05:44:07 +00009440 for (auto RI : D->redecls()) {
9441 if (RI->getLexicalDeclContext() == CanonDef) {
9442 Found = true;
9443 break;
9444 }
9445 }
9446 if (Found)
9447 continue;
9448
Richard Smith0f4e2c42015-08-06 04:23:48 +00009449 // Quick check failed, time to do the slow thing. Note, we can't just
9450 // look up the name of D in CanonDef here, because the member that is
9451 // in CanonDef might not be found by name lookup (it might have been
9452 // replaced by a more recent declaration in the lookup table), and we
9453 // can't necessarily find it in the redeclaration chain because it might
9454 // be merely mergeable, not redeclarable.
Richard Smitha0ce9c42014-07-29 23:23:27 +00009455 llvm::SmallVector<const NamedDecl*, 4> Candidates;
Richard Smith0f4e2c42015-08-06 04:23:48 +00009456 for (auto *CanonMember : CanonDef->decls()) {
9457 if (CanonMember->getCanonicalDecl() == DCanon) {
9458 // This can happen if the declaration is merely mergeable and not
9459 // actually redeclarable (we looked for redeclarations earlier).
9460 //
9461 // FIXME: We should be able to detect this more efficiently, without
9462 // pulling in all of the members of CanonDef.
9463 Found = true;
9464 break;
Richard Smitha0ce9c42014-07-29 23:23:27 +00009465 }
Richard Smith0f4e2c42015-08-06 04:23:48 +00009466 if (auto *ND = dyn_cast<NamedDecl>(CanonMember))
9467 if (ND->getDeclName() == D->getDeclName())
9468 Candidates.push_back(ND);
Richard Smitha0ce9c42014-07-29 23:23:27 +00009469 }
9470
9471 if (!Found) {
Richard Smithd08aeb62014-08-28 01:33:39 +00009472 // The AST doesn't like TagDecls becoming invalid after they've been
9473 // completed. We only really need to mark FieldDecls as invalid here.
9474 if (!isa<TagDecl>(D))
9475 D->setInvalidDecl();
David L. Jonesc4808b9e2016-12-15 20:53:26 +00009476
Richard Smith4ab3dbd2015-02-13 22:43:51 +00009477 // Ensure we don't accidentally recursively enter deserialization while
9478 // we're producing our diagnostic.
9479 Deserializing RecursionGuard(this);
Richard Smitha0ce9c42014-07-29 23:23:27 +00009480
9481 std::string CanonDefModule =
9482 getOwningModuleNameForDiagnostic(cast<Decl>(CanonDef));
9483 Diag(D->getLocation(), diag::err_module_odr_violation_missing_decl)
9484 << D << getOwningModuleNameForDiagnostic(D)
9485 << CanonDef << CanonDefModule.empty() << CanonDefModule;
9486
9487 if (Candidates.empty())
9488 Diag(cast<Decl>(CanonDef)->getLocation(),
9489 diag::note_module_odr_violation_no_possible_decls) << D;
9490 else {
Vedant Kumar48b4f762018-04-14 01:40:48 +00009491 for (unsigned I = 0, N = Candidates.size(); I != N; ++I)
9492 Diag(Candidates[I]->getLocation(),
Richard Smitha0ce9c42014-07-29 23:23:27 +00009493 diag::note_module_odr_violation_possible_decl)
Vedant Kumar48b4f762018-04-14 01:40:48 +00009494 << Candidates[I];
Richard Smitha0ce9c42014-07-29 23:23:27 +00009495 }
9496
9497 DiagnosedOdrMergeFailures.insert(CanonDef);
9498 }
9499 }
Richard Smithcd45dbc2014-04-19 03:48:30 +00009500
Richard Trieuab4d7302018-07-25 22:52:05 +00009501 if (OdrMergeFailures.empty() && FunctionOdrMergeFailures.empty() &&
9502 EnumOdrMergeFailures.empty())
Richard Smith4ab3dbd2015-02-13 22:43:51 +00009503 return;
9504
9505 // Ensure we don't accidentally recursively enter deserialization while
9506 // we're producing our diagnostics.
9507 Deserializing RecursionGuard(this);
9508
Richard Trieue6caa262017-12-23 00:41:01 +00009509 // Common code for hashing helpers.
9510 ODRHash Hash;
9511 auto ComputeQualTypeODRHash = [&Hash](QualType Ty) {
9512 Hash.clear();
9513 Hash.AddQualType(Ty);
9514 return Hash.CalculateHash();
9515 };
9516
9517 auto ComputeODRHash = [&Hash](const Stmt *S) {
9518 assert(S);
9519 Hash.clear();
9520 Hash.AddStmt(S);
9521 return Hash.CalculateHash();
9522 };
9523
9524 auto ComputeSubDeclODRHash = [&Hash](const Decl *D) {
9525 assert(D);
9526 Hash.clear();
9527 Hash.AddSubDecl(D);
9528 return Hash.CalculateHash();
9529 };
9530
Richard Trieu7282d322018-04-25 00:31:15 +00009531 auto ComputeTemplateArgumentODRHash = [&Hash](const TemplateArgument &TA) {
9532 Hash.clear();
9533 Hash.AddTemplateArgument(TA);
9534 return Hash.CalculateHash();
9535 };
9536
Richard Trieu9359e8f2018-05-30 01:12:26 +00009537 auto ComputeTemplateParameterListODRHash =
9538 [&Hash](const TemplateParameterList *TPL) {
9539 assert(TPL);
9540 Hash.clear();
9541 Hash.AddTemplateParameterList(TPL);
9542 return Hash.CalculateHash();
9543 };
9544
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -08009545 // Used with err_module_odr_violation_mismatch_decl and
9546 // note_module_odr_violation_mismatch_decl
9547 // This list should be the same Decl's as in ODRHash::isWhiteListedDecl
9548 enum ODRMismatchDecl {
9549 EndOfClass,
9550 PublicSpecifer,
9551 PrivateSpecifer,
9552 ProtectedSpecifer,
9553 StaticAssert,
9554 Field,
9555 CXXMethod,
9556 TypeAlias,
9557 TypeDef,
9558 Var,
9559 Friend,
9560 FunctionTemplate,
9561 Other
9562 };
9563
9564 // Used with err_module_odr_violation_mismatch_decl_diff and
9565 // note_module_odr_violation_mismatch_decl_diff
9566 enum ODRMismatchDeclDifference {
9567 StaticAssertCondition,
9568 StaticAssertMessage,
9569 StaticAssertOnlyMessage,
9570 FieldName,
9571 FieldTypeName,
9572 FieldSingleBitField,
9573 FieldDifferentWidthBitField,
9574 FieldSingleMutable,
9575 FieldSingleInitializer,
9576 FieldDifferentInitializers,
9577 MethodName,
9578 MethodDeleted,
9579 MethodDefaulted,
9580 MethodVirtual,
9581 MethodStatic,
9582 MethodVolatile,
9583 MethodConst,
9584 MethodInline,
9585 MethodNumberParameters,
9586 MethodParameterType,
9587 MethodParameterName,
9588 MethodParameterSingleDefaultArgument,
9589 MethodParameterDifferentDefaultArgument,
9590 MethodNoTemplateArguments,
9591 MethodDifferentNumberTemplateArguments,
9592 MethodDifferentTemplateArgument,
9593 MethodSingleBody,
9594 MethodDifferentBody,
9595 TypedefName,
9596 TypedefType,
9597 VarName,
9598 VarType,
9599 VarSingleInitializer,
9600 VarDifferentInitializer,
9601 VarConstexpr,
9602 FriendTypeFunction,
9603 FriendType,
9604 FriendFunction,
9605 FunctionTemplateDifferentNumberParameters,
9606 FunctionTemplateParameterDifferentKind,
9607 FunctionTemplateParameterName,
9608 FunctionTemplateParameterSingleDefaultArgument,
9609 FunctionTemplateParameterDifferentDefaultArgument,
9610 FunctionTemplateParameterDifferentType,
9611 FunctionTemplatePackParameter,
9612 };
9613
9614 // These lambdas have the common portions of the ODR diagnostics. This
9615 // has the same return as Diag(), so addition parameters can be passed
9616 // in with operator<<
9617 auto ODRDiagDeclError = [this](NamedDecl *FirstRecord, StringRef FirstModule,
9618 SourceLocation Loc, SourceRange Range,
9619 ODRMismatchDeclDifference DiffType) {
9620 return Diag(Loc, diag::err_module_odr_violation_mismatch_decl_diff)
9621 << FirstRecord << FirstModule.empty() << FirstModule << Range
9622 << DiffType;
9623 };
9624 auto ODRDiagDeclNote = [this](StringRef SecondModule, SourceLocation Loc,
9625 SourceRange Range, ODRMismatchDeclDifference DiffType) {
9626 return Diag(Loc, diag::note_module_odr_violation_mismatch_decl_diff)
9627 << SecondModule << Range << DiffType;
9628 };
9629
9630 auto ODRDiagField = [this, &ODRDiagDeclError, &ODRDiagDeclNote,
9631 &ComputeQualTypeODRHash, &ComputeODRHash](
9632 NamedDecl *FirstRecord, StringRef FirstModule,
9633 StringRef SecondModule, FieldDecl *FirstField,
9634 FieldDecl *SecondField) {
9635 IdentifierInfo *FirstII = FirstField->getIdentifier();
9636 IdentifierInfo *SecondII = SecondField->getIdentifier();
9637 if (FirstII->getName() != SecondII->getName()) {
9638 ODRDiagDeclError(FirstRecord, FirstModule, FirstField->getLocation(),
9639 FirstField->getSourceRange(), FieldName)
9640 << FirstII;
9641 ODRDiagDeclNote(SecondModule, SecondField->getLocation(),
9642 SecondField->getSourceRange(), FieldName)
9643 << SecondII;
9644
9645 return true;
9646 }
9647
9648 assert(getContext().hasSameType(FirstField->getType(),
9649 SecondField->getType()));
9650
9651 QualType FirstType = FirstField->getType();
9652 QualType SecondType = SecondField->getType();
9653 if (ComputeQualTypeODRHash(FirstType) !=
9654 ComputeQualTypeODRHash(SecondType)) {
9655 ODRDiagDeclError(FirstRecord, FirstModule, FirstField->getLocation(),
9656 FirstField->getSourceRange(), FieldTypeName)
9657 << FirstII << FirstType;
9658 ODRDiagDeclNote(SecondModule, SecondField->getLocation(),
9659 SecondField->getSourceRange(), FieldTypeName)
9660 << SecondII << SecondType;
9661
9662 return true;
9663 }
9664
9665 const bool IsFirstBitField = FirstField->isBitField();
9666 const bool IsSecondBitField = SecondField->isBitField();
9667 if (IsFirstBitField != IsSecondBitField) {
9668 ODRDiagDeclError(FirstRecord, FirstModule, FirstField->getLocation(),
9669 FirstField->getSourceRange(), FieldSingleBitField)
9670 << FirstII << IsFirstBitField;
9671 ODRDiagDeclNote(SecondModule, SecondField->getLocation(),
9672 SecondField->getSourceRange(), FieldSingleBitField)
9673 << SecondII << IsSecondBitField;
9674 return true;
9675 }
9676
9677 if (IsFirstBitField && IsSecondBitField) {
9678 unsigned FirstBitWidthHash =
9679 ComputeODRHash(FirstField->getBitWidth());
9680 unsigned SecondBitWidthHash =
9681 ComputeODRHash(SecondField->getBitWidth());
9682 if (FirstBitWidthHash != SecondBitWidthHash) {
9683 ODRDiagDeclError(FirstRecord, FirstModule, FirstField->getLocation(),
9684 FirstField->getSourceRange(),
9685 FieldDifferentWidthBitField)
9686 << FirstII << FirstField->getBitWidth()->getSourceRange();
9687 ODRDiagDeclNote(SecondModule, SecondField->getLocation(),
9688 SecondField->getSourceRange(),
9689 FieldDifferentWidthBitField)
9690 << SecondII << SecondField->getBitWidth()->getSourceRange();
9691 return true;
9692 }
9693 }
9694
9695 if (!PP.getLangOpts().CPlusPlus)
9696 return false;
9697
9698 const bool IsFirstMutable = FirstField->isMutable();
9699 const bool IsSecondMutable = SecondField->isMutable();
9700 if (IsFirstMutable != IsSecondMutable) {
9701 ODRDiagDeclError(FirstRecord, FirstModule, FirstField->getLocation(),
9702 FirstField->getSourceRange(), FieldSingleMutable)
9703 << FirstII << IsFirstMutable;
9704 ODRDiagDeclNote(SecondModule, SecondField->getLocation(),
9705 SecondField->getSourceRange(), FieldSingleMutable)
9706 << SecondII << IsSecondMutable;
9707 return true;
9708 }
9709
9710 const Expr *FirstInitializer = FirstField->getInClassInitializer();
9711 const Expr *SecondInitializer = SecondField->getInClassInitializer();
9712 if ((!FirstInitializer && SecondInitializer) ||
9713 (FirstInitializer && !SecondInitializer)) {
9714 ODRDiagDeclError(FirstRecord, FirstModule, FirstField->getLocation(),
9715 FirstField->getSourceRange(), FieldSingleInitializer)
9716 << FirstII << (FirstInitializer != nullptr);
9717 ODRDiagDeclNote(SecondModule, SecondField->getLocation(),
9718 SecondField->getSourceRange(), FieldSingleInitializer)
9719 << SecondII << (SecondInitializer != nullptr);
9720 return true;
9721 }
9722
9723 if (FirstInitializer && SecondInitializer) {
9724 unsigned FirstInitHash = ComputeODRHash(FirstInitializer);
9725 unsigned SecondInitHash = ComputeODRHash(SecondInitializer);
9726 if (FirstInitHash != SecondInitHash) {
9727 ODRDiagDeclError(FirstRecord, FirstModule, FirstField->getLocation(),
9728 FirstField->getSourceRange(),
9729 FieldDifferentInitializers)
9730 << FirstII << FirstInitializer->getSourceRange();
9731 ODRDiagDeclNote(SecondModule, SecondField->getLocation(),
9732 SecondField->getSourceRange(),
9733 FieldDifferentInitializers)
9734 << SecondII << SecondInitializer->getSourceRange();
9735 return true;
9736 }
9737 }
9738
9739 return false;
9740 };
9741
9742 auto ODRDiagTypeDefOrAlias =
9743 [&ODRDiagDeclError, &ODRDiagDeclNote, &ComputeQualTypeODRHash](
9744 NamedDecl *FirstRecord, StringRef FirstModule, StringRef SecondModule,
9745 TypedefNameDecl *FirstTD, TypedefNameDecl *SecondTD,
9746 bool IsTypeAlias) {
9747 auto FirstName = FirstTD->getDeclName();
9748 auto SecondName = SecondTD->getDeclName();
9749 if (FirstName != SecondName) {
9750 ODRDiagDeclError(FirstRecord, FirstModule, FirstTD->getLocation(),
9751 FirstTD->getSourceRange(), TypedefName)
9752 << IsTypeAlias << FirstName;
9753 ODRDiagDeclNote(SecondModule, SecondTD->getLocation(),
9754 SecondTD->getSourceRange(), TypedefName)
9755 << IsTypeAlias << SecondName;
9756 return true;
9757 }
9758
9759 QualType FirstType = FirstTD->getUnderlyingType();
9760 QualType SecondType = SecondTD->getUnderlyingType();
9761 if (ComputeQualTypeODRHash(FirstType) !=
9762 ComputeQualTypeODRHash(SecondType)) {
9763 ODRDiagDeclError(FirstRecord, FirstModule, FirstTD->getLocation(),
9764 FirstTD->getSourceRange(), TypedefType)
9765 << IsTypeAlias << FirstName << FirstType;
9766 ODRDiagDeclNote(SecondModule, SecondTD->getLocation(),
9767 SecondTD->getSourceRange(), TypedefType)
9768 << IsTypeAlias << SecondName << SecondType;
9769 return true;
9770 }
9771
9772 return false;
9773 };
9774
9775 auto ODRDiagVar = [&ODRDiagDeclError, &ODRDiagDeclNote,
9776 &ComputeQualTypeODRHash, &ComputeODRHash,
9777 this](NamedDecl *FirstRecord, StringRef FirstModule,
9778 StringRef SecondModule, VarDecl *FirstVD,
9779 VarDecl *SecondVD) {
9780 auto FirstName = FirstVD->getDeclName();
9781 auto SecondName = SecondVD->getDeclName();
9782 if (FirstName != SecondName) {
9783 ODRDiagDeclError(FirstRecord, FirstModule, FirstVD->getLocation(),
9784 FirstVD->getSourceRange(), VarName)
9785 << FirstName;
9786 ODRDiagDeclNote(SecondModule, SecondVD->getLocation(),
9787 SecondVD->getSourceRange(), VarName)
9788 << SecondName;
9789 return true;
9790 }
9791
9792 QualType FirstType = FirstVD->getType();
9793 QualType SecondType = SecondVD->getType();
9794 if (ComputeQualTypeODRHash(FirstType) !=
9795 ComputeQualTypeODRHash(SecondType)) {
9796 ODRDiagDeclError(FirstRecord, FirstModule, FirstVD->getLocation(),
9797 FirstVD->getSourceRange(), VarType)
9798 << FirstName << FirstType;
9799 ODRDiagDeclNote(SecondModule, SecondVD->getLocation(),
9800 SecondVD->getSourceRange(), VarType)
9801 << SecondName << SecondType;
9802 return true;
9803 }
9804
9805 if (!PP.getLangOpts().CPlusPlus)
9806 return false;
9807
9808 const Expr *FirstInit = FirstVD->getInit();
9809 const Expr *SecondInit = SecondVD->getInit();
9810 if ((FirstInit == nullptr) != (SecondInit == nullptr)) {
9811 ODRDiagDeclError(FirstRecord, FirstModule, FirstVD->getLocation(),
9812 FirstVD->getSourceRange(), VarSingleInitializer)
9813 << FirstName << (FirstInit == nullptr)
9814 << (FirstInit ? FirstInit->getSourceRange() : SourceRange());
9815 ODRDiagDeclNote(SecondModule, SecondVD->getLocation(),
9816 SecondVD->getSourceRange(), VarSingleInitializer)
9817 << SecondName << (SecondInit == nullptr)
9818 << (SecondInit ? SecondInit->getSourceRange() : SourceRange());
9819 return true;
9820 }
9821
9822 if (FirstInit && SecondInit &&
9823 ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
9824 ODRDiagDeclError(FirstRecord, FirstModule, FirstVD->getLocation(),
9825 FirstVD->getSourceRange(), VarDifferentInitializer)
9826 << FirstName << FirstInit->getSourceRange();
9827 ODRDiagDeclNote(SecondModule, SecondVD->getLocation(),
9828 SecondVD->getSourceRange(), VarDifferentInitializer)
9829 << SecondName << SecondInit->getSourceRange();
9830 return true;
9831 }
9832
9833 const bool FirstIsConstexpr = FirstVD->isConstexpr();
9834 const bool SecondIsConstexpr = SecondVD->isConstexpr();
9835 if (FirstIsConstexpr != SecondIsConstexpr) {
9836 ODRDiagDeclError(FirstRecord, FirstModule, FirstVD->getLocation(),
9837 FirstVD->getSourceRange(), VarConstexpr)
9838 << FirstName << FirstIsConstexpr;
9839 ODRDiagDeclNote(SecondModule, SecondVD->getLocation(),
9840 SecondVD->getSourceRange(), VarConstexpr)
9841 << SecondName << SecondIsConstexpr;
9842 return true;
9843 }
9844 return false;
9845 };
9846
9847 auto DifferenceSelector = [](Decl *D) {
9848 assert(D && "valid Decl required");
9849 switch (D->getKind()) {
9850 default:
9851 return Other;
9852 case Decl::AccessSpec:
9853 switch (D->getAccess()) {
9854 case AS_public:
9855 return PublicSpecifer;
9856 case AS_private:
9857 return PrivateSpecifer;
9858 case AS_protected:
9859 return ProtectedSpecifer;
9860 case AS_none:
9861 break;
9862 }
9863 llvm_unreachable("Invalid access specifier");
9864 case Decl::StaticAssert:
9865 return StaticAssert;
9866 case Decl::Field:
9867 return Field;
9868 case Decl::CXXMethod:
9869 case Decl::CXXConstructor:
9870 case Decl::CXXDestructor:
9871 return CXXMethod;
9872 case Decl::TypeAlias:
9873 return TypeAlias;
9874 case Decl::Typedef:
9875 return TypeDef;
9876 case Decl::Var:
9877 return Var;
9878 case Decl::Friend:
9879 return Friend;
9880 case Decl::FunctionTemplate:
9881 return FunctionTemplate;
9882 }
9883 };
9884
9885 using DeclHashes = llvm::SmallVector<std::pair<Decl *, unsigned>, 4>;
9886 auto PopulateHashes = [&ComputeSubDeclODRHash](DeclHashes &Hashes,
9887 RecordDecl *Record,
9888 const DeclContext *DC) {
9889 for (auto *D : Record->decls()) {
9890 if (!ODRHash::isWhitelistedDecl(D, DC))
9891 continue;
9892 Hashes.emplace_back(D, ComputeSubDeclODRHash(D));
9893 }
9894 };
9895
9896 struct DiffResult {
9897 Decl *FirstDecl = nullptr, *SecondDecl = nullptr;
9898 ODRMismatchDecl FirstDiffType = Other, SecondDiffType = Other;
9899 };
9900
9901 // If there is a diagnoseable difference, FirstDiffType and
9902 // SecondDiffType will not be Other and FirstDecl and SecondDecl will be
9903 // filled in if not EndOfClass.
9904 auto FindTypeDiffs = [&DifferenceSelector](DeclHashes &FirstHashes,
9905 DeclHashes &SecondHashes) {
9906 DiffResult DR;
9907 auto FirstIt = FirstHashes.begin();
9908 auto SecondIt = SecondHashes.begin();
9909 while (FirstIt != FirstHashes.end() || SecondIt != SecondHashes.end()) {
9910 if (FirstIt != FirstHashes.end() && SecondIt != SecondHashes.end() &&
9911 FirstIt->second == SecondIt->second) {
9912 ++FirstIt;
9913 ++SecondIt;
9914 continue;
9915 }
9916
9917 DR.FirstDecl = FirstIt == FirstHashes.end() ? nullptr : FirstIt->first;
9918 DR.SecondDecl =
9919 SecondIt == SecondHashes.end() ? nullptr : SecondIt->first;
9920
9921 DR.FirstDiffType =
9922 DR.FirstDecl ? DifferenceSelector(DR.FirstDecl) : EndOfClass;
9923 DR.SecondDiffType =
9924 DR.SecondDecl ? DifferenceSelector(DR.SecondDecl) : EndOfClass;
9925 return DR;
9926 }
9927 return DR;
9928 };
9929
9930 // Use this to diagnose that an unexpected Decl was encountered
9931 // or no difference was detected. This causes a generic error
9932 // message to be emitted.
9933 auto DiagnoseODRUnexpected = [this](DiffResult &DR, NamedDecl *FirstRecord,
9934 StringRef FirstModule,
9935 NamedDecl *SecondRecord,
9936 StringRef SecondModule) {
9937 Diag(FirstRecord->getLocation(),
9938 diag::err_module_odr_violation_different_definitions)
9939 << FirstRecord << FirstModule.empty() << FirstModule;
9940
9941 if (DR.FirstDecl) {
9942 Diag(DR.FirstDecl->getLocation(), diag::note_first_module_difference)
9943 << FirstRecord << DR.FirstDecl->getSourceRange();
9944 }
9945
9946 Diag(SecondRecord->getLocation(),
9947 diag::note_module_odr_violation_different_definitions)
9948 << SecondModule;
9949
9950 if (DR.SecondDecl) {
9951 Diag(DR.SecondDecl->getLocation(), diag::note_second_module_difference)
9952 << DR.SecondDecl->getSourceRange();
9953 }
9954 };
9955
9956 auto DiagnoseODRMismatch =
9957 [this](DiffResult &DR, NamedDecl *FirstRecord, StringRef FirstModule,
9958 NamedDecl *SecondRecord, StringRef SecondModule) {
9959 SourceLocation FirstLoc;
9960 SourceRange FirstRange;
9961 auto *FirstTag = dyn_cast<TagDecl>(FirstRecord);
9962 if (DR.FirstDiffType == EndOfClass && FirstTag) {
9963 FirstLoc = FirstTag->getBraceRange().getEnd();
9964 } else {
9965 FirstLoc = DR.FirstDecl->getLocation();
9966 FirstRange = DR.FirstDecl->getSourceRange();
9967 }
9968 Diag(FirstLoc, diag::err_module_odr_violation_mismatch_decl)
9969 << FirstRecord << FirstModule.empty() << FirstModule << FirstRange
9970 << DR.FirstDiffType;
9971
9972 SourceLocation SecondLoc;
9973 SourceRange SecondRange;
9974 auto *SecondTag = dyn_cast<TagDecl>(SecondRecord);
9975 if (DR.SecondDiffType == EndOfClass && SecondTag) {
9976 SecondLoc = SecondTag->getBraceRange().getEnd();
9977 } else {
9978 SecondLoc = DR.SecondDecl->getLocation();
9979 SecondRange = DR.SecondDecl->getSourceRange();
9980 }
9981 Diag(SecondLoc, diag::note_module_odr_violation_mismatch_decl)
9982 << SecondModule << SecondRange << DR.SecondDiffType;
9983 };
9984
Richard Smithcd45dbc2014-04-19 03:48:30 +00009985 // Issue any pending ODR-failure diagnostics.
Richard Smithbb853c72014-08-13 01:23:33 +00009986 for (auto &Merge : OdrMergeFailures) {
Richard Smitha0ce9c42014-07-29 23:23:27 +00009987 // If we've already pointed out a specific problem with this class, don't
9988 // bother issuing a general "something's different" diagnostic.
David Blaikie82e95a32014-11-19 07:49:47 +00009989 if (!DiagnosedOdrMergeFailures.insert(Merge.first).second)
Richard Smithcd45dbc2014-04-19 03:48:30 +00009990 continue;
9991
9992 bool Diagnosed = false;
Richard Trieue7f7ed22017-02-22 01:11:25 +00009993 CXXRecordDecl *FirstRecord = Merge.first;
9994 std::string FirstModule = getOwningModuleNameForDiagnostic(FirstRecord);
Richard Trieue13eabe2017-09-30 02:19:17 +00009995 for (auto &RecordPair : Merge.second) {
9996 CXXRecordDecl *SecondRecord = RecordPair.first;
Richard Smithcd45dbc2014-04-19 03:48:30 +00009997 // Multiple different declarations got merged together; tell the user
9998 // where they came from.
Richard Trieue7f7ed22017-02-22 01:11:25 +00009999 if (FirstRecord == SecondRecord)
10000 continue;
10001
10002 std::string SecondModule = getOwningModuleNameForDiagnostic(SecondRecord);
Richard Trieue13eabe2017-09-30 02:19:17 +000010003
10004 auto *FirstDD = FirstRecord->DefinitionData;
10005 auto *SecondDD = RecordPair.second;
10006
10007 assert(FirstDD && SecondDD && "Definitions without DefinitionData");
10008
10009 // Diagnostics from DefinitionData are emitted here.
10010 if (FirstDD != SecondDD) {
10011 enum ODRDefinitionDataDifference {
10012 NumBases,
10013 NumVBases,
10014 BaseType,
10015 BaseVirtual,
10016 BaseAccess,
10017 };
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010018 auto ODRDiagBaseError = [FirstRecord, &FirstModule,
10019 this](SourceLocation Loc, SourceRange Range,
10020 ODRDefinitionDataDifference DiffType) {
Richard Trieue13eabe2017-09-30 02:19:17 +000010021 return Diag(Loc, diag::err_module_odr_violation_definition_data)
10022 << FirstRecord << FirstModule.empty() << FirstModule << Range
10023 << DiffType;
10024 };
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010025 auto ODRDiagBaseNote = [&SecondModule,
10026 this](SourceLocation Loc, SourceRange Range,
10027 ODRDefinitionDataDifference DiffType) {
Richard Trieue13eabe2017-09-30 02:19:17 +000010028 return Diag(Loc, diag::note_module_odr_violation_definition_data)
10029 << SecondModule << Range << DiffType;
10030 };
10031
Richard Trieue13eabe2017-09-30 02:19:17 +000010032 unsigned FirstNumBases = FirstDD->NumBases;
10033 unsigned FirstNumVBases = FirstDD->NumVBases;
10034 unsigned SecondNumBases = SecondDD->NumBases;
10035 unsigned SecondNumVBases = SecondDD->NumVBases;
10036
10037 auto GetSourceRange = [](struct CXXRecordDecl::DefinitionData *DD) {
10038 unsigned NumBases = DD->NumBases;
10039 if (NumBases == 0) return SourceRange();
10040 auto bases = DD->bases();
Stephen Kellyf2ceec42018-08-09 21:08:08 +000010041 return SourceRange(bases[0].getBeginLoc(),
Stephen Kelly1c301dc2018-08-09 21:09:38 +000010042 bases[NumBases - 1].getEndLoc());
Richard Trieue13eabe2017-09-30 02:19:17 +000010043 };
10044
10045 if (FirstNumBases != SecondNumBases) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010046 ODRDiagBaseError(FirstRecord->getLocation(), GetSourceRange(FirstDD),
10047 NumBases)
Richard Trieue13eabe2017-09-30 02:19:17 +000010048 << FirstNumBases;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010049 ODRDiagBaseNote(SecondRecord->getLocation(), GetSourceRange(SecondDD),
10050 NumBases)
Richard Trieue13eabe2017-09-30 02:19:17 +000010051 << SecondNumBases;
10052 Diagnosed = true;
10053 break;
10054 }
10055
10056 if (FirstNumVBases != SecondNumVBases) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010057 ODRDiagBaseError(FirstRecord->getLocation(), GetSourceRange(FirstDD),
10058 NumVBases)
Richard Trieue13eabe2017-09-30 02:19:17 +000010059 << FirstNumVBases;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010060 ODRDiagBaseNote(SecondRecord->getLocation(), GetSourceRange(SecondDD),
10061 NumVBases)
Richard Trieue13eabe2017-09-30 02:19:17 +000010062 << SecondNumVBases;
10063 Diagnosed = true;
10064 break;
10065 }
10066
10067 auto FirstBases = FirstDD->bases();
10068 auto SecondBases = SecondDD->bases();
10069 unsigned i = 0;
10070 for (i = 0; i < FirstNumBases; ++i) {
10071 auto FirstBase = FirstBases[i];
10072 auto SecondBase = SecondBases[i];
10073 if (ComputeQualTypeODRHash(FirstBase.getType()) !=
10074 ComputeQualTypeODRHash(SecondBase.getType())) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010075 ODRDiagBaseError(FirstRecord->getLocation(),
10076 FirstBase.getSourceRange(), BaseType)
Richard Trieue13eabe2017-09-30 02:19:17 +000010077 << (i + 1) << FirstBase.getType();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010078 ODRDiagBaseNote(SecondRecord->getLocation(),
10079 SecondBase.getSourceRange(), BaseType)
Richard Trieue13eabe2017-09-30 02:19:17 +000010080 << (i + 1) << SecondBase.getType();
10081 break;
10082 }
10083
10084 if (FirstBase.isVirtual() != SecondBase.isVirtual()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010085 ODRDiagBaseError(FirstRecord->getLocation(),
10086 FirstBase.getSourceRange(), BaseVirtual)
Richard Trieue13eabe2017-09-30 02:19:17 +000010087 << (i + 1) << FirstBase.isVirtual() << FirstBase.getType();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010088 ODRDiagBaseNote(SecondRecord->getLocation(),
10089 SecondBase.getSourceRange(), BaseVirtual)
Richard Trieue13eabe2017-09-30 02:19:17 +000010090 << (i + 1) << SecondBase.isVirtual() << SecondBase.getType();
10091 break;
10092 }
10093
10094 if (FirstBase.getAccessSpecifierAsWritten() !=
10095 SecondBase.getAccessSpecifierAsWritten()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010096 ODRDiagBaseError(FirstRecord->getLocation(),
10097 FirstBase.getSourceRange(), BaseAccess)
Richard Trieue13eabe2017-09-30 02:19:17 +000010098 << (i + 1) << FirstBase.getType()
10099 << (int)FirstBase.getAccessSpecifierAsWritten();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010100 ODRDiagBaseNote(SecondRecord->getLocation(),
10101 SecondBase.getSourceRange(), BaseAccess)
Richard Trieue13eabe2017-09-30 02:19:17 +000010102 << (i + 1) << SecondBase.getType()
10103 << (int)SecondBase.getAccessSpecifierAsWritten();
10104 break;
10105 }
10106 }
10107
10108 if (i != FirstNumBases) {
10109 Diagnosed = true;
10110 break;
10111 }
10112 }
10113
Richard Trieu498117b2017-08-23 02:43:59 +000010114 const ClassTemplateDecl *FirstTemplate =
10115 FirstRecord->getDescribedClassTemplate();
10116 const ClassTemplateDecl *SecondTemplate =
10117 SecondRecord->getDescribedClassTemplate();
10118
10119 assert(!FirstTemplate == !SecondTemplate &&
10120 "Both pointers should be null or non-null");
10121
10122 enum ODRTemplateDifference {
10123 ParamEmptyName,
10124 ParamName,
10125 ParamSingleDefaultArgument,
10126 ParamDifferentDefaultArgument,
10127 };
10128
10129 if (FirstTemplate && SecondTemplate) {
10130 DeclHashes FirstTemplateHashes;
10131 DeclHashes SecondTemplateHashes;
Richard Trieu498117b2017-08-23 02:43:59 +000010132
10133 auto PopulateTemplateParameterHashs =
Richard Trieue6caa262017-12-23 00:41:01 +000010134 [&ComputeSubDeclODRHash](DeclHashes &Hashes,
10135 const ClassTemplateDecl *TD) {
Richard Trieu498117b2017-08-23 02:43:59 +000010136 for (auto *D : TD->getTemplateParameters()->asArray()) {
Richard Trieue6caa262017-12-23 00:41:01 +000010137 Hashes.emplace_back(D, ComputeSubDeclODRHash(D));
Richard Trieu498117b2017-08-23 02:43:59 +000010138 }
10139 };
10140
10141 PopulateTemplateParameterHashs(FirstTemplateHashes, FirstTemplate);
10142 PopulateTemplateParameterHashs(SecondTemplateHashes, SecondTemplate);
10143
10144 assert(FirstTemplateHashes.size() == SecondTemplateHashes.size() &&
10145 "Number of template parameters should be equal.");
10146
10147 auto FirstIt = FirstTemplateHashes.begin();
10148 auto FirstEnd = FirstTemplateHashes.end();
10149 auto SecondIt = SecondTemplateHashes.begin();
10150 for (; FirstIt != FirstEnd; ++FirstIt, ++SecondIt) {
10151 if (FirstIt->second == SecondIt->second)
10152 continue;
10153
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010154 auto ODRDiagTemplateError = [FirstRecord, &FirstModule, this](
10155 SourceLocation Loc, SourceRange Range,
10156 ODRTemplateDifference DiffType) {
Richard Trieu498117b2017-08-23 02:43:59 +000010157 return Diag(Loc, diag::err_module_odr_violation_template_parameter)
10158 << FirstRecord << FirstModule.empty() << FirstModule << Range
10159 << DiffType;
10160 };
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010161 auto ODRDiagTemplateNote = [&SecondModule, this](
10162 SourceLocation Loc, SourceRange Range,
10163 ODRTemplateDifference DiffType) {
Richard Trieu498117b2017-08-23 02:43:59 +000010164 return Diag(Loc, diag::note_module_odr_violation_template_parameter)
10165 << SecondModule << Range << DiffType;
10166 };
10167
Vedant Kumar48b4f762018-04-14 01:40:48 +000010168 const NamedDecl* FirstDecl = cast<NamedDecl>(FirstIt->first);
10169 const NamedDecl* SecondDecl = cast<NamedDecl>(SecondIt->first);
Richard Trieu498117b2017-08-23 02:43:59 +000010170
10171 assert(FirstDecl->getKind() == SecondDecl->getKind() &&
10172 "Parameter Decl's should be the same kind.");
10173
10174 DeclarationName FirstName = FirstDecl->getDeclName();
10175 DeclarationName SecondName = SecondDecl->getDeclName();
10176
10177 if (FirstName != SecondName) {
10178 const bool FirstNameEmpty =
10179 FirstName.isIdentifier() && !FirstName.getAsIdentifierInfo();
10180 const bool SecondNameEmpty =
10181 SecondName.isIdentifier() && !SecondName.getAsIdentifierInfo();
10182 assert((!FirstNameEmpty || !SecondNameEmpty) &&
10183 "Both template parameters cannot be unnamed.");
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010184 ODRDiagTemplateError(FirstDecl->getLocation(),
10185 FirstDecl->getSourceRange(),
10186 FirstNameEmpty ? ParamEmptyName : ParamName)
Richard Trieu498117b2017-08-23 02:43:59 +000010187 << FirstName;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010188 ODRDiagTemplateNote(SecondDecl->getLocation(),
10189 SecondDecl->getSourceRange(),
10190 SecondNameEmpty ? ParamEmptyName : ParamName)
Richard Trieu498117b2017-08-23 02:43:59 +000010191 << SecondName;
10192 break;
10193 }
10194
10195 switch (FirstDecl->getKind()) {
10196 default:
10197 llvm_unreachable("Invalid template parameter type.");
10198 case Decl::TemplateTypeParm: {
10199 const auto *FirstParam = cast<TemplateTypeParmDecl>(FirstDecl);
10200 const auto *SecondParam = cast<TemplateTypeParmDecl>(SecondDecl);
10201 const bool HasFirstDefaultArgument =
10202 FirstParam->hasDefaultArgument() &&
10203 !FirstParam->defaultArgumentWasInherited();
10204 const bool HasSecondDefaultArgument =
10205 SecondParam->hasDefaultArgument() &&
10206 !SecondParam->defaultArgumentWasInherited();
10207
10208 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010209 ODRDiagTemplateError(FirstDecl->getLocation(),
10210 FirstDecl->getSourceRange(),
10211 ParamSingleDefaultArgument)
Richard Trieu498117b2017-08-23 02:43:59 +000010212 << HasFirstDefaultArgument;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010213 ODRDiagTemplateNote(SecondDecl->getLocation(),
10214 SecondDecl->getSourceRange(),
10215 ParamSingleDefaultArgument)
Richard Trieu498117b2017-08-23 02:43:59 +000010216 << HasSecondDefaultArgument;
10217 break;
10218 }
10219
10220 assert(HasFirstDefaultArgument && HasSecondDefaultArgument &&
10221 "Expecting default arguments.");
10222
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010223 ODRDiagTemplateError(FirstDecl->getLocation(),
10224 FirstDecl->getSourceRange(),
10225 ParamDifferentDefaultArgument);
10226 ODRDiagTemplateNote(SecondDecl->getLocation(),
10227 SecondDecl->getSourceRange(),
10228 ParamDifferentDefaultArgument);
Richard Trieu498117b2017-08-23 02:43:59 +000010229
10230 break;
10231 }
10232 case Decl::NonTypeTemplateParm: {
10233 const auto *FirstParam = cast<NonTypeTemplateParmDecl>(FirstDecl);
10234 const auto *SecondParam = cast<NonTypeTemplateParmDecl>(SecondDecl);
10235 const bool HasFirstDefaultArgument =
10236 FirstParam->hasDefaultArgument() &&
10237 !FirstParam->defaultArgumentWasInherited();
10238 const bool HasSecondDefaultArgument =
10239 SecondParam->hasDefaultArgument() &&
10240 !SecondParam->defaultArgumentWasInherited();
10241
10242 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010243 ODRDiagTemplateError(FirstDecl->getLocation(),
10244 FirstDecl->getSourceRange(),
10245 ParamSingleDefaultArgument)
Richard Trieu498117b2017-08-23 02:43:59 +000010246 << HasFirstDefaultArgument;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010247 ODRDiagTemplateNote(SecondDecl->getLocation(),
10248 SecondDecl->getSourceRange(),
10249 ParamSingleDefaultArgument)
Richard Trieu498117b2017-08-23 02:43:59 +000010250 << HasSecondDefaultArgument;
10251 break;
10252 }
10253
10254 assert(HasFirstDefaultArgument && HasSecondDefaultArgument &&
10255 "Expecting default arguments.");
10256
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010257 ODRDiagTemplateError(FirstDecl->getLocation(),
10258 FirstDecl->getSourceRange(),
10259 ParamDifferentDefaultArgument);
10260 ODRDiagTemplateNote(SecondDecl->getLocation(),
10261 SecondDecl->getSourceRange(),
10262 ParamDifferentDefaultArgument);
Richard Trieu498117b2017-08-23 02:43:59 +000010263
10264 break;
10265 }
10266 case Decl::TemplateTemplateParm: {
10267 const auto *FirstParam = cast<TemplateTemplateParmDecl>(FirstDecl);
10268 const auto *SecondParam =
10269 cast<TemplateTemplateParmDecl>(SecondDecl);
10270 const bool HasFirstDefaultArgument =
10271 FirstParam->hasDefaultArgument() &&
10272 !FirstParam->defaultArgumentWasInherited();
10273 const bool HasSecondDefaultArgument =
10274 SecondParam->hasDefaultArgument() &&
10275 !SecondParam->defaultArgumentWasInherited();
10276
10277 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010278 ODRDiagTemplateError(FirstDecl->getLocation(),
10279 FirstDecl->getSourceRange(),
10280 ParamSingleDefaultArgument)
Richard Trieu498117b2017-08-23 02:43:59 +000010281 << HasFirstDefaultArgument;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010282 ODRDiagTemplateNote(SecondDecl->getLocation(),
10283 SecondDecl->getSourceRange(),
10284 ParamSingleDefaultArgument)
Richard Trieu498117b2017-08-23 02:43:59 +000010285 << HasSecondDefaultArgument;
10286 break;
10287 }
10288
10289 assert(HasFirstDefaultArgument && HasSecondDefaultArgument &&
10290 "Expecting default arguments.");
10291
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010292 ODRDiagTemplateError(FirstDecl->getLocation(),
10293 FirstDecl->getSourceRange(),
10294 ParamDifferentDefaultArgument);
10295 ODRDiagTemplateNote(SecondDecl->getLocation(),
10296 SecondDecl->getSourceRange(),
10297 ParamDifferentDefaultArgument);
Richard Trieu498117b2017-08-23 02:43:59 +000010298
10299 break;
10300 }
10301 }
10302
10303 break;
10304 }
10305
10306 if (FirstIt != FirstEnd) {
10307 Diagnosed = true;
10308 break;
10309 }
10310 }
10311
Richard Trieue7f7ed22017-02-22 01:11:25 +000010312 DeclHashes FirstHashes;
10313 DeclHashes SecondHashes;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010314 const DeclContext *DC = FirstRecord;
10315 PopulateHashes(FirstHashes, FirstRecord, DC);
10316 PopulateHashes(SecondHashes, SecondRecord, DC);
Richard Trieue7f7ed22017-02-22 01:11:25 +000010317
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010318 auto DR = FindTypeDiffs(FirstHashes, SecondHashes);
10319 ODRMismatchDecl FirstDiffType = DR.FirstDiffType;
10320 ODRMismatchDecl SecondDiffType = DR.SecondDiffType;
10321 Decl *FirstDecl = DR.FirstDecl;
10322 Decl *SecondDecl = DR.SecondDecl;
Richard Trieue7f7ed22017-02-22 01:11:25 +000010323
10324 if (FirstDiffType == Other || SecondDiffType == Other) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010325 DiagnoseODRUnexpected(DR, FirstRecord, FirstModule, SecondRecord,
10326 SecondModule);
Richard Trieue7f7ed22017-02-22 01:11:25 +000010327 Diagnosed = true;
10328 break;
10329 }
10330
10331 if (FirstDiffType != SecondDiffType) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010332 DiagnoseODRMismatch(DR, FirstRecord, FirstModule, SecondRecord,
10333 SecondModule);
Richard Trieue7f7ed22017-02-22 01:11:25 +000010334 Diagnosed = true;
10335 break;
10336 }
10337
Richard Trieu639d7b62017-02-22 22:22:42 +000010338 assert(FirstDiffType == SecondDiffType);
10339
Richard Trieu639d7b62017-02-22 22:22:42 +000010340 switch (FirstDiffType) {
10341 case Other:
10342 case EndOfClass:
10343 case PublicSpecifer:
10344 case PrivateSpecifer:
10345 case ProtectedSpecifer:
10346 llvm_unreachable("Invalid diff type");
10347
10348 case StaticAssert: {
Vedant Kumar48b4f762018-04-14 01:40:48 +000010349 StaticAssertDecl *FirstSA = cast<StaticAssertDecl>(FirstDecl);
10350 StaticAssertDecl *SecondSA = cast<StaticAssertDecl>(SecondDecl);
Richard Trieu639d7b62017-02-22 22:22:42 +000010351
10352 Expr *FirstExpr = FirstSA->getAssertExpr();
10353 Expr *SecondExpr = SecondSA->getAssertExpr();
10354 unsigned FirstODRHash = ComputeODRHash(FirstExpr);
10355 unsigned SecondODRHash = ComputeODRHash(SecondExpr);
10356 if (FirstODRHash != SecondODRHash) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010357 ODRDiagDeclError(FirstRecord, FirstModule, FirstExpr->getBeginLoc(),
10358 FirstExpr->getSourceRange(), StaticAssertCondition);
10359 ODRDiagDeclNote(SecondModule, SecondExpr->getBeginLoc(),
10360 SecondExpr->getSourceRange(), StaticAssertCondition);
Richard Trieu639d7b62017-02-22 22:22:42 +000010361 Diagnosed = true;
10362 break;
10363 }
10364
10365 StringLiteral *FirstStr = FirstSA->getMessage();
10366 StringLiteral *SecondStr = SecondSA->getMessage();
10367 assert((FirstStr || SecondStr) && "Both messages cannot be empty");
10368 if ((FirstStr && !SecondStr) || (!FirstStr && SecondStr)) {
10369 SourceLocation FirstLoc, SecondLoc;
10370 SourceRange FirstRange, SecondRange;
10371 if (FirstStr) {
Stephen Kellyf2ceec42018-08-09 21:08:08 +000010372 FirstLoc = FirstStr->getBeginLoc();
Richard Trieu639d7b62017-02-22 22:22:42 +000010373 FirstRange = FirstStr->getSourceRange();
10374 } else {
Stephen Kellyf2ceec42018-08-09 21:08:08 +000010375 FirstLoc = FirstSA->getBeginLoc();
Richard Trieu639d7b62017-02-22 22:22:42 +000010376 FirstRange = FirstSA->getSourceRange();
10377 }
10378 if (SecondStr) {
Stephen Kellyf2ceec42018-08-09 21:08:08 +000010379 SecondLoc = SecondStr->getBeginLoc();
Richard Trieu639d7b62017-02-22 22:22:42 +000010380 SecondRange = SecondStr->getSourceRange();
10381 } else {
Stephen Kellyf2ceec42018-08-09 21:08:08 +000010382 SecondLoc = SecondSA->getBeginLoc();
Richard Trieu639d7b62017-02-22 22:22:42 +000010383 SecondRange = SecondSA->getSourceRange();
10384 }
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010385 ODRDiagDeclError(FirstRecord, FirstModule, FirstLoc, FirstRange,
10386 StaticAssertOnlyMessage)
Richard Trieu639d7b62017-02-22 22:22:42 +000010387 << (FirstStr == nullptr);
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010388 ODRDiagDeclNote(SecondModule, SecondLoc, SecondRange,
10389 StaticAssertOnlyMessage)
Richard Trieu639d7b62017-02-22 22:22:42 +000010390 << (SecondStr == nullptr);
10391 Diagnosed = true;
10392 break;
10393 }
10394
10395 if (FirstStr && SecondStr &&
10396 FirstStr->getString() != SecondStr->getString()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010397 ODRDiagDeclError(FirstRecord, FirstModule, FirstStr->getBeginLoc(),
10398 FirstStr->getSourceRange(), StaticAssertMessage);
10399 ODRDiagDeclNote(SecondModule, SecondStr->getBeginLoc(),
10400 SecondStr->getSourceRange(), StaticAssertMessage);
Richard Trieu639d7b62017-02-22 22:22:42 +000010401 Diagnosed = true;
10402 break;
10403 }
10404 break;
10405 }
Richard Trieud0786092017-02-23 00:23:01 +000010406 case Field: {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010407 Diagnosed = ODRDiagField(FirstRecord, FirstModule, SecondModule,
10408 cast<FieldDecl>(FirstDecl),
10409 cast<FieldDecl>(SecondDecl));
Richard Trieud0786092017-02-23 00:23:01 +000010410 break;
10411 }
Richard Trieu48143742017-02-28 21:24:38 +000010412 case CXXMethod: {
Richard Trieu1c71d512017-07-15 02:55:13 +000010413 enum {
10414 DiagMethod,
10415 DiagConstructor,
10416 DiagDestructor,
10417 } FirstMethodType,
10418 SecondMethodType;
10419 auto GetMethodTypeForDiagnostics = [](const CXXMethodDecl* D) {
10420 if (isa<CXXConstructorDecl>(D)) return DiagConstructor;
10421 if (isa<CXXDestructorDecl>(D)) return DiagDestructor;
10422 return DiagMethod;
10423 };
Vedant Kumar48b4f762018-04-14 01:40:48 +000010424 const CXXMethodDecl *FirstMethod = cast<CXXMethodDecl>(FirstDecl);
10425 const CXXMethodDecl *SecondMethod = cast<CXXMethodDecl>(SecondDecl);
Richard Trieu1c71d512017-07-15 02:55:13 +000010426 FirstMethodType = GetMethodTypeForDiagnostics(FirstMethod);
10427 SecondMethodType = GetMethodTypeForDiagnostics(SecondMethod);
Richard Trieu583e2c12017-03-04 00:08:58 +000010428 auto FirstName = FirstMethod->getDeclName();
10429 auto SecondName = SecondMethod->getDeclName();
Richard Trieu1c71d512017-07-15 02:55:13 +000010430 if (FirstMethodType != SecondMethodType || FirstName != SecondName) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010431 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10432 FirstMethod->getSourceRange(), MethodName)
Richard Trieu1c71d512017-07-15 02:55:13 +000010433 << FirstMethodType << FirstName;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010434 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10435 SecondMethod->getSourceRange(), MethodName)
Richard Trieu1c71d512017-07-15 02:55:13 +000010436 << SecondMethodType << SecondName;
Richard Trieu48143742017-02-28 21:24:38 +000010437
10438 Diagnosed = true;
10439 break;
10440 }
10441
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010442 const bool FirstDeleted = FirstMethod->isDeletedAsWritten();
10443 const bool SecondDeleted = SecondMethod->isDeletedAsWritten();
Richard Trieu583e2c12017-03-04 00:08:58 +000010444 if (FirstDeleted != SecondDeleted) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010445 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10446 FirstMethod->getSourceRange(), MethodDeleted)
Richard Trieu1c71d512017-07-15 02:55:13 +000010447 << FirstMethodType << FirstName << FirstDeleted;
Richard Trieu583e2c12017-03-04 00:08:58 +000010448
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010449 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10450 SecondMethod->getSourceRange(), MethodDeleted)
Richard Trieu1c71d512017-07-15 02:55:13 +000010451 << SecondMethodType << SecondName << SecondDeleted;
Richard Trieu583e2c12017-03-04 00:08:58 +000010452 Diagnosed = true;
10453 break;
10454 }
10455
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010456 const bool FirstDefaulted = FirstMethod->isExplicitlyDefaulted();
10457 const bool SecondDefaulted = SecondMethod->isExplicitlyDefaulted();
10458 if (FirstDefaulted != SecondDefaulted) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010459 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10460 FirstMethod->getSourceRange(), MethodDefaulted)
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010461 << FirstMethodType << FirstName << FirstDefaulted;
10462
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010463 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10464 SecondMethod->getSourceRange(), MethodDefaulted)
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010465 << SecondMethodType << SecondName << SecondDefaulted;
10466 Diagnosed = true;
10467 break;
10468 }
10469
Richard Trieu583e2c12017-03-04 00:08:58 +000010470 const bool FirstVirtual = FirstMethod->isVirtualAsWritten();
10471 const bool SecondVirtual = SecondMethod->isVirtualAsWritten();
10472 const bool FirstPure = FirstMethod->isPure();
10473 const bool SecondPure = SecondMethod->isPure();
10474 if ((FirstVirtual || SecondVirtual) &&
10475 (FirstVirtual != SecondVirtual || FirstPure != SecondPure)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010476 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10477 FirstMethod->getSourceRange(), MethodVirtual)
Richard Trieu1c71d512017-07-15 02:55:13 +000010478 << FirstMethodType << FirstName << FirstPure << FirstVirtual;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010479 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10480 SecondMethod->getSourceRange(), MethodVirtual)
Richard Trieu1c71d512017-07-15 02:55:13 +000010481 << SecondMethodType << SecondName << SecondPure << SecondVirtual;
Richard Trieu583e2c12017-03-04 00:08:58 +000010482 Diagnosed = true;
10483 break;
10484 }
10485
10486 // CXXMethodDecl::isStatic uses the canonical Decl. With Decl merging,
10487 // FirstDecl is the canonical Decl of SecondDecl, so the storage
10488 // class needs to be checked instead.
10489 const auto FirstStorage = FirstMethod->getStorageClass();
10490 const auto SecondStorage = SecondMethod->getStorageClass();
10491 const bool FirstStatic = FirstStorage == SC_Static;
10492 const bool SecondStatic = SecondStorage == SC_Static;
10493 if (FirstStatic != SecondStatic) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010494 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10495 FirstMethod->getSourceRange(), MethodStatic)
Richard Trieu1c71d512017-07-15 02:55:13 +000010496 << FirstMethodType << FirstName << FirstStatic;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010497 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10498 SecondMethod->getSourceRange(), MethodStatic)
Richard Trieu1c71d512017-07-15 02:55:13 +000010499 << SecondMethodType << SecondName << SecondStatic;
Richard Trieu583e2c12017-03-04 00:08:58 +000010500 Diagnosed = true;
10501 break;
10502 }
10503
10504 const bool FirstVolatile = FirstMethod->isVolatile();
10505 const bool SecondVolatile = SecondMethod->isVolatile();
10506 if (FirstVolatile != SecondVolatile) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010507 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10508 FirstMethod->getSourceRange(), MethodVolatile)
Richard Trieu1c71d512017-07-15 02:55:13 +000010509 << FirstMethodType << FirstName << FirstVolatile;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010510 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10511 SecondMethod->getSourceRange(), MethodVolatile)
Richard Trieu1c71d512017-07-15 02:55:13 +000010512 << SecondMethodType << SecondName << SecondVolatile;
Richard Trieu583e2c12017-03-04 00:08:58 +000010513 Diagnosed = true;
10514 break;
10515 }
10516
10517 const bool FirstConst = FirstMethod->isConst();
10518 const bool SecondConst = SecondMethod->isConst();
10519 if (FirstConst != SecondConst) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010520 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10521 FirstMethod->getSourceRange(), MethodConst)
Richard Trieu1c71d512017-07-15 02:55:13 +000010522 << FirstMethodType << FirstName << FirstConst;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010523 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10524 SecondMethod->getSourceRange(), MethodConst)
Richard Trieu1c71d512017-07-15 02:55:13 +000010525 << SecondMethodType << SecondName << SecondConst;
Richard Trieu583e2c12017-03-04 00:08:58 +000010526 Diagnosed = true;
10527 break;
10528 }
10529
10530 const bool FirstInline = FirstMethod->isInlineSpecified();
10531 const bool SecondInline = SecondMethod->isInlineSpecified();
10532 if (FirstInline != SecondInline) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010533 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10534 FirstMethod->getSourceRange(), MethodInline)
Richard Trieu1c71d512017-07-15 02:55:13 +000010535 << FirstMethodType << FirstName << FirstInline;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010536 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10537 SecondMethod->getSourceRange(), MethodInline)
Richard Trieu1c71d512017-07-15 02:55:13 +000010538 << SecondMethodType << SecondName << SecondInline;
Richard Trieu583e2c12017-03-04 00:08:58 +000010539 Diagnosed = true;
10540 break;
10541 }
10542
Richard Trieu02552272017-05-02 23:58:52 +000010543 const unsigned FirstNumParameters = FirstMethod->param_size();
10544 const unsigned SecondNumParameters = SecondMethod->param_size();
10545 if (FirstNumParameters != SecondNumParameters) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010546 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10547 FirstMethod->getSourceRange(),
10548 MethodNumberParameters)
Richard Trieu1c71d512017-07-15 02:55:13 +000010549 << FirstMethodType << FirstName << FirstNumParameters;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010550 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10551 SecondMethod->getSourceRange(),
10552 MethodNumberParameters)
Richard Trieu1c71d512017-07-15 02:55:13 +000010553 << SecondMethodType << SecondName << SecondNumParameters;
Richard Trieu02552272017-05-02 23:58:52 +000010554 Diagnosed = true;
10555 break;
10556 }
10557
10558 // Need this status boolean to know when break out of the switch.
10559 bool ParameterMismatch = false;
10560 for (unsigned I = 0; I < FirstNumParameters; ++I) {
10561 const ParmVarDecl *FirstParam = FirstMethod->getParamDecl(I);
10562 const ParmVarDecl *SecondParam = SecondMethod->getParamDecl(I);
10563
10564 QualType FirstParamType = FirstParam->getType();
10565 QualType SecondParamType = SecondParam->getType();
10566 if (FirstParamType != SecondParamType &&
10567 ComputeQualTypeODRHash(FirstParamType) !=
10568 ComputeQualTypeODRHash(SecondParamType)) {
Vedant Kumar48b4f762018-04-14 01:40:48 +000010569 if (const DecayedType *ParamDecayedType =
Richard Trieu02552272017-05-02 23:58:52 +000010570 FirstParamType->getAs<DecayedType>()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010571 ODRDiagDeclError(
10572 FirstRecord, FirstModule, FirstMethod->getLocation(),
10573 FirstMethod->getSourceRange(), MethodParameterType)
Richard Trieu1c71d512017-07-15 02:55:13 +000010574 << FirstMethodType << FirstName << (I + 1) << FirstParamType
10575 << true << ParamDecayedType->getOriginalType();
Richard Trieu02552272017-05-02 23:58:52 +000010576 } else {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010577 ODRDiagDeclError(
10578 FirstRecord, FirstModule, FirstMethod->getLocation(),
10579 FirstMethod->getSourceRange(), MethodParameterType)
Richard Trieu1c71d512017-07-15 02:55:13 +000010580 << FirstMethodType << FirstName << (I + 1) << FirstParamType
10581 << false;
Richard Trieu02552272017-05-02 23:58:52 +000010582 }
10583
Vedant Kumar48b4f762018-04-14 01:40:48 +000010584 if (const DecayedType *ParamDecayedType =
Richard Trieu02552272017-05-02 23:58:52 +000010585 SecondParamType->getAs<DecayedType>()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010586 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10587 SecondMethod->getSourceRange(),
10588 MethodParameterType)
Richard Trieu1c71d512017-07-15 02:55:13 +000010589 << SecondMethodType << SecondName << (I + 1)
10590 << SecondParamType << true
Richard Trieu02552272017-05-02 23:58:52 +000010591 << ParamDecayedType->getOriginalType();
10592 } else {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010593 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10594 SecondMethod->getSourceRange(),
10595 MethodParameterType)
Richard Trieu1c71d512017-07-15 02:55:13 +000010596 << SecondMethodType << SecondName << (I + 1)
10597 << SecondParamType << false;
Richard Trieu02552272017-05-02 23:58:52 +000010598 }
10599 ParameterMismatch = true;
10600 break;
10601 }
10602
10603 DeclarationName FirstParamName = FirstParam->getDeclName();
10604 DeclarationName SecondParamName = SecondParam->getDeclName();
10605 if (FirstParamName != SecondParamName) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010606 ODRDiagDeclError(FirstRecord, FirstModule,
10607 FirstMethod->getLocation(),
10608 FirstMethod->getSourceRange(), MethodParameterName)
Richard Trieu1c71d512017-07-15 02:55:13 +000010609 << FirstMethodType << FirstName << (I + 1) << FirstParamName;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010610 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10611 SecondMethod->getSourceRange(), MethodParameterName)
Richard Trieu1c71d512017-07-15 02:55:13 +000010612 << SecondMethodType << SecondName << (I + 1) << SecondParamName;
Richard Trieu02552272017-05-02 23:58:52 +000010613 ParameterMismatch = true;
10614 break;
10615 }
Richard Trieu6e13ff32017-06-16 02:44:29 +000010616
10617 const Expr *FirstInit = FirstParam->getInit();
10618 const Expr *SecondInit = SecondParam->getInit();
10619 if ((FirstInit == nullptr) != (SecondInit == nullptr)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010620 ODRDiagDeclError(FirstRecord, FirstModule,
10621 FirstMethod->getLocation(),
10622 FirstMethod->getSourceRange(),
10623 MethodParameterSingleDefaultArgument)
Richard Trieu1c71d512017-07-15 02:55:13 +000010624 << FirstMethodType << FirstName << (I + 1)
10625 << (FirstInit == nullptr)
Richard Trieu6e13ff32017-06-16 02:44:29 +000010626 << (FirstInit ? FirstInit->getSourceRange() : SourceRange());
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010627 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10628 SecondMethod->getSourceRange(),
10629 MethodParameterSingleDefaultArgument)
Richard Trieu1c71d512017-07-15 02:55:13 +000010630 << SecondMethodType << SecondName << (I + 1)
10631 << (SecondInit == nullptr)
Richard Trieu6e13ff32017-06-16 02:44:29 +000010632 << (SecondInit ? SecondInit->getSourceRange() : SourceRange());
10633 ParameterMismatch = true;
10634 break;
10635 }
10636
10637 if (FirstInit && SecondInit &&
10638 ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010639 ODRDiagDeclError(FirstRecord, FirstModule,
10640 FirstMethod->getLocation(),
10641 FirstMethod->getSourceRange(),
10642 MethodParameterDifferentDefaultArgument)
Richard Trieu1c71d512017-07-15 02:55:13 +000010643 << FirstMethodType << FirstName << (I + 1)
10644 << FirstInit->getSourceRange();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010645 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10646 SecondMethod->getSourceRange(),
10647 MethodParameterDifferentDefaultArgument)
Richard Trieu1c71d512017-07-15 02:55:13 +000010648 << SecondMethodType << SecondName << (I + 1)
10649 << SecondInit->getSourceRange();
Richard Trieu6e13ff32017-06-16 02:44:29 +000010650 ParameterMismatch = true;
10651 break;
10652
10653 }
Richard Trieu02552272017-05-02 23:58:52 +000010654 }
10655
10656 if (ParameterMismatch) {
10657 Diagnosed = true;
10658 break;
10659 }
10660
Richard Trieu7282d322018-04-25 00:31:15 +000010661 const auto *FirstTemplateArgs =
10662 FirstMethod->getTemplateSpecializationArgs();
10663 const auto *SecondTemplateArgs =
10664 SecondMethod->getTemplateSpecializationArgs();
10665
10666 if ((FirstTemplateArgs && !SecondTemplateArgs) ||
10667 (!FirstTemplateArgs && SecondTemplateArgs)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010668 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10669 FirstMethod->getSourceRange(),
10670 MethodNoTemplateArguments)
Richard Trieu7282d322018-04-25 00:31:15 +000010671 << FirstMethodType << FirstName << (FirstTemplateArgs != nullptr);
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010672 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10673 SecondMethod->getSourceRange(),
10674 MethodNoTemplateArguments)
Richard Trieu7282d322018-04-25 00:31:15 +000010675 << SecondMethodType << SecondName
10676 << (SecondTemplateArgs != nullptr);
10677
10678 Diagnosed = true;
10679 break;
10680 }
10681
10682 if (FirstTemplateArgs && SecondTemplateArgs) {
10683 // Remove pack expansions from argument list.
10684 auto ExpandTemplateArgumentList =
10685 [](const TemplateArgumentList *TAL) {
10686 llvm::SmallVector<const TemplateArgument *, 8> ExpandedList;
10687 for (const TemplateArgument &TA : TAL->asArray()) {
10688 if (TA.getKind() != TemplateArgument::Pack) {
10689 ExpandedList.push_back(&TA);
10690 continue;
10691 }
10692 for (const TemplateArgument &PackTA : TA.getPackAsArray()) {
10693 ExpandedList.push_back(&PackTA);
10694 }
10695 }
10696 return ExpandedList;
10697 };
10698 llvm::SmallVector<const TemplateArgument *, 8> FirstExpandedList =
10699 ExpandTemplateArgumentList(FirstTemplateArgs);
10700 llvm::SmallVector<const TemplateArgument *, 8> SecondExpandedList =
10701 ExpandTemplateArgumentList(SecondTemplateArgs);
10702
10703 if (FirstExpandedList.size() != SecondExpandedList.size()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010704 ODRDiagDeclError(FirstRecord, FirstModule,
10705 FirstMethod->getLocation(),
10706 FirstMethod->getSourceRange(),
10707 MethodDifferentNumberTemplateArguments)
Richard Trieu7282d322018-04-25 00:31:15 +000010708 << FirstMethodType << FirstName
10709 << (unsigned)FirstExpandedList.size();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010710 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10711 SecondMethod->getSourceRange(),
10712 MethodDifferentNumberTemplateArguments)
Richard Trieu7282d322018-04-25 00:31:15 +000010713 << SecondMethodType << SecondName
10714 << (unsigned)SecondExpandedList.size();
10715
10716 Diagnosed = true;
10717 break;
10718 }
10719
10720 bool TemplateArgumentMismatch = false;
10721 for (unsigned i = 0, e = FirstExpandedList.size(); i != e; ++i) {
10722 const TemplateArgument &FirstTA = *FirstExpandedList[i],
10723 &SecondTA = *SecondExpandedList[i];
10724 if (ComputeTemplateArgumentODRHash(FirstTA) ==
10725 ComputeTemplateArgumentODRHash(SecondTA)) {
10726 continue;
10727 }
10728
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010729 ODRDiagDeclError(
10730 FirstRecord, FirstModule, FirstMethod->getLocation(),
10731 FirstMethod->getSourceRange(), MethodDifferentTemplateArgument)
Richard Trieu7282d322018-04-25 00:31:15 +000010732 << FirstMethodType << FirstName << FirstTA << i + 1;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010733 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10734 SecondMethod->getSourceRange(),
10735 MethodDifferentTemplateArgument)
Richard Trieu7282d322018-04-25 00:31:15 +000010736 << SecondMethodType << SecondName << SecondTA << i + 1;
10737
10738 TemplateArgumentMismatch = true;
10739 break;
10740 }
10741
10742 if (TemplateArgumentMismatch) {
10743 Diagnosed = true;
10744 break;
10745 }
10746 }
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010747
10748 // Compute the hash of the method as if it has no body.
10749 auto ComputeCXXMethodODRHash = [&Hash](const CXXMethodDecl *D) {
10750 Hash.clear();
10751 Hash.AddFunctionDecl(D, true /*SkipBody*/);
10752 return Hash.CalculateHash();
10753 };
10754
10755 // Compare the hash generated to the hash stored. A difference means
10756 // that a body was present in the original source. Due to merging,
10757 // the stardard way of detecting a body will not work.
10758 const bool HasFirstBody =
10759 ComputeCXXMethodODRHash(FirstMethod) != FirstMethod->getODRHash();
10760 const bool HasSecondBody =
10761 ComputeCXXMethodODRHash(SecondMethod) != SecondMethod->getODRHash();
10762
10763 if (HasFirstBody != HasSecondBody) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010764 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10765 FirstMethod->getSourceRange(), MethodSingleBody)
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010766 << FirstMethodType << FirstName << HasFirstBody;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010767 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10768 SecondMethod->getSourceRange(), MethodSingleBody)
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010769 << SecondMethodType << SecondName << HasSecondBody;
10770 Diagnosed = true;
10771 break;
10772 }
10773
10774 if (HasFirstBody && HasSecondBody) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010775 ODRDiagDeclError(FirstRecord, FirstModule, FirstMethod->getLocation(),
10776 FirstMethod->getSourceRange(), MethodDifferentBody)
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010777 << FirstMethodType << FirstName;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010778 ODRDiagDeclNote(SecondModule, SecondMethod->getLocation(),
10779 SecondMethod->getSourceRange(), MethodDifferentBody)
Richard Trieu27c1b1a2018-07-10 01:40:50 +000010780 << SecondMethodType << SecondName;
10781 Diagnosed = true;
10782 break;
10783 }
10784
Richard Trieu48143742017-02-28 21:24:38 +000010785 break;
10786 }
Richard Trieu11d566a2017-06-12 21:58:22 +000010787 case TypeAlias:
10788 case TypeDef: {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010789 Diagnosed = ODRDiagTypeDefOrAlias(
10790 FirstRecord, FirstModule, SecondModule,
10791 cast<TypedefNameDecl>(FirstDecl), cast<TypedefNameDecl>(SecondDecl),
10792 FirstDiffType == TypeAlias);
Richard Trieu11d566a2017-06-12 21:58:22 +000010793 break;
10794 }
Richard Trieu6e13ff32017-06-16 02:44:29 +000010795 case Var: {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010796 Diagnosed =
10797 ODRDiagVar(FirstRecord, FirstModule, SecondModule,
10798 cast<VarDecl>(FirstDecl), cast<VarDecl>(SecondDecl));
Richard Trieu6e13ff32017-06-16 02:44:29 +000010799 break;
10800 }
Richard Trieuac6a1b62017-07-08 02:04:42 +000010801 case Friend: {
Vedant Kumar48b4f762018-04-14 01:40:48 +000010802 FriendDecl *FirstFriend = cast<FriendDecl>(FirstDecl);
10803 FriendDecl *SecondFriend = cast<FriendDecl>(SecondDecl);
Richard Trieuac6a1b62017-07-08 02:04:42 +000010804
10805 NamedDecl *FirstND = FirstFriend->getFriendDecl();
10806 NamedDecl *SecondND = SecondFriend->getFriendDecl();
10807
10808 TypeSourceInfo *FirstTSI = FirstFriend->getFriendType();
10809 TypeSourceInfo *SecondTSI = SecondFriend->getFriendType();
10810
10811 if (FirstND && SecondND) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010812 ODRDiagDeclError(FirstRecord, FirstModule,
10813 FirstFriend->getFriendLoc(),
10814 FirstFriend->getSourceRange(), FriendFunction)
Richard Trieuac6a1b62017-07-08 02:04:42 +000010815 << FirstND;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010816 ODRDiagDeclNote(SecondModule, SecondFriend->getFriendLoc(),
10817 SecondFriend->getSourceRange(), FriendFunction)
Richard Trieuac6a1b62017-07-08 02:04:42 +000010818 << SecondND;
10819
10820 Diagnosed = true;
10821 break;
10822 }
10823
10824 if (FirstTSI && SecondTSI) {
10825 QualType FirstFriendType = FirstTSI->getType();
10826 QualType SecondFriendType = SecondTSI->getType();
10827 assert(ComputeQualTypeODRHash(FirstFriendType) !=
10828 ComputeQualTypeODRHash(SecondFriendType));
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010829 ODRDiagDeclError(FirstRecord, FirstModule,
10830 FirstFriend->getFriendLoc(),
10831 FirstFriend->getSourceRange(), FriendType)
Richard Trieuac6a1b62017-07-08 02:04:42 +000010832 << FirstFriendType;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010833 ODRDiagDeclNote(SecondModule, SecondFriend->getFriendLoc(),
10834 SecondFriend->getSourceRange(), FriendType)
Richard Trieuac6a1b62017-07-08 02:04:42 +000010835 << SecondFriendType;
10836 Diagnosed = true;
10837 break;
10838 }
10839
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010840 ODRDiagDeclError(FirstRecord, FirstModule, FirstFriend->getFriendLoc(),
10841 FirstFriend->getSourceRange(), FriendTypeFunction)
Richard Trieuac6a1b62017-07-08 02:04:42 +000010842 << (FirstTSI == nullptr);
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010843 ODRDiagDeclNote(SecondModule, SecondFriend->getFriendLoc(),
10844 SecondFriend->getSourceRange(), FriendTypeFunction)
Richard Trieuac6a1b62017-07-08 02:04:42 +000010845 << (SecondTSI == nullptr);
10846
10847 Diagnosed = true;
10848 break;
10849 }
Richard Trieu9359e8f2018-05-30 01:12:26 +000010850 case FunctionTemplate: {
10851 FunctionTemplateDecl *FirstTemplate =
10852 cast<FunctionTemplateDecl>(FirstDecl);
10853 FunctionTemplateDecl *SecondTemplate =
10854 cast<FunctionTemplateDecl>(SecondDecl);
10855
10856 TemplateParameterList *FirstTPL =
10857 FirstTemplate->getTemplateParameters();
10858 TemplateParameterList *SecondTPL =
10859 SecondTemplate->getTemplateParameters();
10860
10861 if (FirstTPL->size() != SecondTPL->size()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010862 ODRDiagDeclError(FirstRecord, FirstModule,
10863 FirstTemplate->getLocation(),
10864 FirstTemplate->getSourceRange(),
10865 FunctionTemplateDifferentNumberParameters)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010866 << FirstTemplate << FirstTPL->size();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010867 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
10868 SecondTemplate->getSourceRange(),
10869 FunctionTemplateDifferentNumberParameters)
10870 << SecondTemplate << SecondTPL->size();
Richard Trieu9359e8f2018-05-30 01:12:26 +000010871
10872 Diagnosed = true;
10873 break;
10874 }
10875
10876 bool ParameterMismatch = false;
10877 for (unsigned i = 0, e = FirstTPL->size(); i != e; ++i) {
10878 NamedDecl *FirstParam = FirstTPL->getParam(i);
10879 NamedDecl *SecondParam = SecondTPL->getParam(i);
10880
10881 if (FirstParam->getKind() != SecondParam->getKind()) {
10882 enum {
10883 TemplateTypeParameter,
10884 NonTypeTemplateParameter,
10885 TemplateTemplateParameter,
10886 };
10887 auto GetParamType = [](NamedDecl *D) {
10888 switch (D->getKind()) {
10889 default:
10890 llvm_unreachable("Unexpected template parameter type");
10891 case Decl::TemplateTypeParm:
10892 return TemplateTypeParameter;
10893 case Decl::NonTypeTemplateParm:
10894 return NonTypeTemplateParameter;
10895 case Decl::TemplateTemplateParm:
10896 return TemplateTemplateParameter;
10897 }
10898 };
10899
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010900 ODRDiagDeclError(FirstRecord, FirstModule,
10901 FirstTemplate->getLocation(),
10902 FirstTemplate->getSourceRange(),
10903 FunctionTemplateParameterDifferentKind)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010904 << FirstTemplate << (i + 1) << GetParamType(FirstParam);
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010905 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
10906 SecondTemplate->getSourceRange(),
10907 FunctionTemplateParameterDifferentKind)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010908 << SecondTemplate << (i + 1) << GetParamType(SecondParam);
10909
10910 ParameterMismatch = true;
10911 break;
10912 }
10913
10914 if (FirstParam->getName() != SecondParam->getName()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010915 ODRDiagDeclError(
10916 FirstRecord, FirstModule, FirstTemplate->getLocation(),
10917 FirstTemplate->getSourceRange(), FunctionTemplateParameterName)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010918 << FirstTemplate << (i + 1) << (bool)FirstParam->getIdentifier()
10919 << FirstParam;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010920 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
10921 SecondTemplate->getSourceRange(),
10922 FunctionTemplateParameterName)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010923 << SecondTemplate << (i + 1)
10924 << (bool)SecondParam->getIdentifier() << SecondParam;
10925 ParameterMismatch = true;
10926 break;
10927 }
10928
10929 if (isa<TemplateTypeParmDecl>(FirstParam) &&
10930 isa<TemplateTypeParmDecl>(SecondParam)) {
10931 TemplateTypeParmDecl *FirstTTPD =
10932 cast<TemplateTypeParmDecl>(FirstParam);
10933 TemplateTypeParmDecl *SecondTTPD =
10934 cast<TemplateTypeParmDecl>(SecondParam);
10935 bool HasFirstDefaultArgument =
10936 FirstTTPD->hasDefaultArgument() &&
10937 !FirstTTPD->defaultArgumentWasInherited();
10938 bool HasSecondDefaultArgument =
10939 SecondTTPD->hasDefaultArgument() &&
10940 !SecondTTPD->defaultArgumentWasInherited();
10941 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010942 ODRDiagDeclError(FirstRecord, FirstModule,
10943 FirstTemplate->getLocation(),
10944 FirstTemplate->getSourceRange(),
10945 FunctionTemplateParameterSingleDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010946 << FirstTemplate << (i + 1) << HasFirstDefaultArgument;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010947 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
10948 SecondTemplate->getSourceRange(),
10949 FunctionTemplateParameterSingleDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010950 << SecondTemplate << (i + 1) << HasSecondDefaultArgument;
10951 ParameterMismatch = true;
10952 break;
10953 }
10954
10955 if (HasFirstDefaultArgument && HasSecondDefaultArgument) {
10956 QualType FirstType = FirstTTPD->getDefaultArgument();
10957 QualType SecondType = SecondTTPD->getDefaultArgument();
10958 if (ComputeQualTypeODRHash(FirstType) !=
10959 ComputeQualTypeODRHash(SecondType)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010960 ODRDiagDeclError(
10961 FirstRecord, FirstModule, FirstTemplate->getLocation(),
10962 FirstTemplate->getSourceRange(),
10963 FunctionTemplateParameterDifferentDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010964 << FirstTemplate << (i + 1) << FirstType;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010965 ODRDiagDeclNote(
10966 SecondModule, SecondTemplate->getLocation(),
10967 SecondTemplate->getSourceRange(),
10968 FunctionTemplateParameterDifferentDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010969 << SecondTemplate << (i + 1) << SecondType;
10970 ParameterMismatch = true;
10971 break;
10972 }
10973 }
10974
10975 if (FirstTTPD->isParameterPack() !=
10976 SecondTTPD->isParameterPack()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010977 ODRDiagDeclError(FirstRecord, FirstModule,
10978 FirstTemplate->getLocation(),
10979 FirstTemplate->getSourceRange(),
10980 FunctionTemplatePackParameter)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010981 << FirstTemplate << (i + 1) << FirstTTPD->isParameterPack();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080010982 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
10983 SecondTemplate->getSourceRange(),
10984 FunctionTemplatePackParameter)
Richard Trieu9359e8f2018-05-30 01:12:26 +000010985 << SecondTemplate << (i + 1) << SecondTTPD->isParameterPack();
10986 ParameterMismatch = true;
10987 break;
10988 }
10989 }
10990
10991 if (isa<TemplateTemplateParmDecl>(FirstParam) &&
10992 isa<TemplateTemplateParmDecl>(SecondParam)) {
10993 TemplateTemplateParmDecl *FirstTTPD =
10994 cast<TemplateTemplateParmDecl>(FirstParam);
10995 TemplateTemplateParmDecl *SecondTTPD =
10996 cast<TemplateTemplateParmDecl>(SecondParam);
10997
10998 TemplateParameterList *FirstTPL =
10999 FirstTTPD->getTemplateParameters();
11000 TemplateParameterList *SecondTPL =
11001 SecondTTPD->getTemplateParameters();
11002
11003 if (ComputeTemplateParameterListODRHash(FirstTPL) !=
11004 ComputeTemplateParameterListODRHash(SecondTPL)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011005 ODRDiagDeclError(FirstRecord, FirstModule,
11006 FirstTemplate->getLocation(),
11007 FirstTemplate->getSourceRange(),
11008 FunctionTemplateParameterDifferentType)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011009 << FirstTemplate << (i + 1);
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011010 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
11011 SecondTemplate->getSourceRange(),
11012 FunctionTemplateParameterDifferentType)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011013 << SecondTemplate << (i + 1);
11014 ParameterMismatch = true;
11015 break;
11016 }
11017
11018 bool HasFirstDefaultArgument =
11019 FirstTTPD->hasDefaultArgument() &&
11020 !FirstTTPD->defaultArgumentWasInherited();
11021 bool HasSecondDefaultArgument =
11022 SecondTTPD->hasDefaultArgument() &&
11023 !SecondTTPD->defaultArgumentWasInherited();
11024 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011025 ODRDiagDeclError(FirstRecord, FirstModule,
11026 FirstTemplate->getLocation(),
11027 FirstTemplate->getSourceRange(),
11028 FunctionTemplateParameterSingleDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011029 << FirstTemplate << (i + 1) << HasFirstDefaultArgument;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011030 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
11031 SecondTemplate->getSourceRange(),
11032 FunctionTemplateParameterSingleDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011033 << SecondTemplate << (i + 1) << HasSecondDefaultArgument;
11034 ParameterMismatch = true;
11035 break;
11036 }
11037
11038 if (HasFirstDefaultArgument && HasSecondDefaultArgument) {
11039 TemplateArgument FirstTA =
11040 FirstTTPD->getDefaultArgument().getArgument();
11041 TemplateArgument SecondTA =
11042 SecondTTPD->getDefaultArgument().getArgument();
11043 if (ComputeTemplateArgumentODRHash(FirstTA) !=
11044 ComputeTemplateArgumentODRHash(SecondTA)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011045 ODRDiagDeclError(
11046 FirstRecord, FirstModule, FirstTemplate->getLocation(),
11047 FirstTemplate->getSourceRange(),
11048 FunctionTemplateParameterDifferentDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011049 << FirstTemplate << (i + 1) << FirstTA;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011050 ODRDiagDeclNote(
11051 SecondModule, SecondTemplate->getLocation(),
11052 SecondTemplate->getSourceRange(),
11053 FunctionTemplateParameterDifferentDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011054 << SecondTemplate << (i + 1) << SecondTA;
11055 ParameterMismatch = true;
11056 break;
11057 }
11058 }
11059
11060 if (FirstTTPD->isParameterPack() !=
11061 SecondTTPD->isParameterPack()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011062 ODRDiagDeclError(FirstRecord, FirstModule,
11063 FirstTemplate->getLocation(),
11064 FirstTemplate->getSourceRange(),
11065 FunctionTemplatePackParameter)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011066 << FirstTemplate << (i + 1) << FirstTTPD->isParameterPack();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011067 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
11068 SecondTemplate->getSourceRange(),
11069 FunctionTemplatePackParameter)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011070 << SecondTemplate << (i + 1) << SecondTTPD->isParameterPack();
11071 ParameterMismatch = true;
11072 break;
11073 }
11074 }
11075
11076 if (isa<NonTypeTemplateParmDecl>(FirstParam) &&
11077 isa<NonTypeTemplateParmDecl>(SecondParam)) {
11078 NonTypeTemplateParmDecl *FirstNTTPD =
11079 cast<NonTypeTemplateParmDecl>(FirstParam);
11080 NonTypeTemplateParmDecl *SecondNTTPD =
11081 cast<NonTypeTemplateParmDecl>(SecondParam);
11082
11083 QualType FirstType = FirstNTTPD->getType();
11084 QualType SecondType = SecondNTTPD->getType();
11085 if (ComputeQualTypeODRHash(FirstType) !=
11086 ComputeQualTypeODRHash(SecondType)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011087 ODRDiagDeclError(FirstRecord, FirstModule,
11088 FirstTemplate->getLocation(),
11089 FirstTemplate->getSourceRange(),
11090 FunctionTemplateParameterDifferentType)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011091 << FirstTemplate << (i + 1);
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011092 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
11093 SecondTemplate->getSourceRange(),
11094 FunctionTemplateParameterDifferentType)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011095 << SecondTemplate << (i + 1);
11096 ParameterMismatch = true;
11097 break;
11098 }
11099
11100 bool HasFirstDefaultArgument =
11101 FirstNTTPD->hasDefaultArgument() &&
11102 !FirstNTTPD->defaultArgumentWasInherited();
11103 bool HasSecondDefaultArgument =
11104 SecondNTTPD->hasDefaultArgument() &&
11105 !SecondNTTPD->defaultArgumentWasInherited();
11106 if (HasFirstDefaultArgument != HasSecondDefaultArgument) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011107 ODRDiagDeclError(FirstRecord, FirstModule,
11108 FirstTemplate->getLocation(),
11109 FirstTemplate->getSourceRange(),
11110 FunctionTemplateParameterSingleDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011111 << FirstTemplate << (i + 1) << HasFirstDefaultArgument;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011112 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
11113 SecondTemplate->getSourceRange(),
11114 FunctionTemplateParameterSingleDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011115 << SecondTemplate << (i + 1) << HasSecondDefaultArgument;
11116 ParameterMismatch = true;
11117 break;
11118 }
11119
11120 if (HasFirstDefaultArgument && HasSecondDefaultArgument) {
11121 Expr *FirstDefaultArgument = FirstNTTPD->getDefaultArgument();
11122 Expr *SecondDefaultArgument = SecondNTTPD->getDefaultArgument();
11123 if (ComputeODRHash(FirstDefaultArgument) !=
11124 ComputeODRHash(SecondDefaultArgument)) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011125 ODRDiagDeclError(
11126 FirstRecord, FirstModule, FirstTemplate->getLocation(),
11127 FirstTemplate->getSourceRange(),
11128 FunctionTemplateParameterDifferentDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011129 << FirstTemplate << (i + 1) << FirstDefaultArgument;
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011130 ODRDiagDeclNote(
11131 SecondModule, SecondTemplate->getLocation(),
11132 SecondTemplate->getSourceRange(),
11133 FunctionTemplateParameterDifferentDefaultArgument)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011134 << SecondTemplate << (i + 1) << SecondDefaultArgument;
11135 ParameterMismatch = true;
11136 break;
11137 }
11138 }
11139
11140 if (FirstNTTPD->isParameterPack() !=
11141 SecondNTTPD->isParameterPack()) {
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011142 ODRDiagDeclError(FirstRecord, FirstModule,
11143 FirstTemplate->getLocation(),
11144 FirstTemplate->getSourceRange(),
11145 FunctionTemplatePackParameter)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011146 << FirstTemplate << (i + 1) << FirstNTTPD->isParameterPack();
Bruno Cardoso Lopes90f58ea2020-01-22 12:43:19 -080011147 ODRDiagDeclNote(SecondModule, SecondTemplate->getLocation(),
11148 SecondTemplate->getSourceRange(),
11149 FunctionTemplatePackParameter)
Richard Trieu9359e8f2018-05-30 01:12:26 +000011150 << SecondTemplate << (i + 1)
11151 << SecondNTTPD->isParameterPack();
11152 ParameterMismatch = true;
11153 break;
11154 }
11155 }
11156 }
11157
11158 if (ParameterMismatch) {
11159 Diagnosed = true;
11160 break;
11161 }
11162
11163 break;
11164 }
Richard Trieu639d7b62017-02-22 22:22:42 +000011165 }
11166
Eugene Zelenkob8c9e2a2017-11-08 01:03:16 +000011167 if (Diagnosed)
Richard Trieue7f7ed22017-02-22 01:11:25 +000011168 continue;
11169
Richard Trieu708859a2017-06-08 00:56:21 +000011170 Diag(FirstDecl->getLocation(),
11171 diag::err_module_odr_violation_mismatch_decl_unknown)
11172 << FirstRecord << FirstModule.empty() << FirstModule << FirstDiffType
11173 << FirstDecl->getSourceRange();
11174 Diag(SecondDecl->getLocation(),
11175 diag::note_module_odr_violation_mismatch_decl_unknown)
11176 << SecondModule << FirstDiffType << SecondDecl->getSourceRange();
Richard Trieue7f7ed22017-02-22 01:11:25 +000011177 Diagnosed = true;
Richard Smithcd45dbc2014-04-19 03:48:30 +000011178 }
11179
11180 if (!Diagnosed) {
11181 // All definitions are updates to the same declaration. This happens if a
11182 // module instantiates the declaration of a class template specialization
11183 // and two or more other modules instantiate its definition.
11184 //
11185 // FIXME: Indicate which modules had instantiations of this definition.
11186 // FIXME: How can this even happen?
11187 Diag(Merge.first->getLocation(),
11188 diag::err_module_odr_violation_different_instantiations)
11189 << Merge.first;
11190 }
11191 }
Richard Trieue6caa262017-12-23 00:41:01 +000011192
11193 // Issue ODR failures diagnostics for functions.
11194 for (auto &Merge : FunctionOdrMergeFailures) {
11195 enum ODRFunctionDifference {
11196 ReturnType,
11197 ParameterName,
11198 ParameterType,
11199 ParameterSingleDefaultArgument,
11200 ParameterDifferentDefaultArgument,
11201 FunctionBody,
11202 };
11203
11204 FunctionDecl *FirstFunction = Merge.first;
11205 std::string FirstModule = getOwningModuleNameForDiagnostic(FirstFunction);
11206
11207 bool Diagnosed = false;
11208 for (auto &SecondFunction : Merge.second) {
Vedant Kumar48b4f762018-04-14 01:40:48 +000011209
Richard Trieue6caa262017-12-23 00:41:01 +000011210 if (FirstFunction == SecondFunction)
11211 continue;
11212
11213 std::string SecondModule =
11214 getOwningModuleNameForDiagnostic(SecondFunction);
11215
11216 auto ODRDiagError = [FirstFunction, &FirstModule,
11217 this](SourceLocation Loc, SourceRange Range,
11218 ODRFunctionDifference DiffType) {
11219 return Diag(Loc, diag::err_module_odr_violation_function)
11220 << FirstFunction << FirstModule.empty() << FirstModule << Range
11221 << DiffType;
11222 };
11223 auto ODRDiagNote = [&SecondModule, this](SourceLocation Loc,
11224 SourceRange Range,
11225 ODRFunctionDifference DiffType) {
11226 return Diag(Loc, diag::note_module_odr_violation_function)
11227 << SecondModule << Range << DiffType;
11228 };
11229
11230 if (ComputeQualTypeODRHash(FirstFunction->getReturnType()) !=
11231 ComputeQualTypeODRHash(SecondFunction->getReturnType())) {
11232 ODRDiagError(FirstFunction->getReturnTypeSourceRange().getBegin(),
11233 FirstFunction->getReturnTypeSourceRange(), ReturnType)
11234 << FirstFunction->getReturnType();
11235 ODRDiagNote(SecondFunction->getReturnTypeSourceRange().getBegin(),
11236 SecondFunction->getReturnTypeSourceRange(), ReturnType)
11237 << SecondFunction->getReturnType();
11238 Diagnosed = true;
11239 break;
11240 }
11241
11242 assert(FirstFunction->param_size() == SecondFunction->param_size() &&
11243 "Merged functions with different number of parameters");
11244
11245 auto ParamSize = FirstFunction->param_size();
11246 bool ParameterMismatch = false;
11247 for (unsigned I = 0; I < ParamSize; ++I) {
11248 auto *FirstParam = FirstFunction->getParamDecl(I);
11249 auto *SecondParam = SecondFunction->getParamDecl(I);
11250
11251 assert(getContext().hasSameType(FirstParam->getType(),
11252 SecondParam->getType()) &&
11253 "Merged function has different parameter types.");
11254
11255 if (FirstParam->getDeclName() != SecondParam->getDeclName()) {
11256 ODRDiagError(FirstParam->getLocation(), FirstParam->getSourceRange(),
11257 ParameterName)
11258 << I + 1 << FirstParam->getDeclName();
11259 ODRDiagNote(SecondParam->getLocation(), SecondParam->getSourceRange(),
11260 ParameterName)
11261 << I + 1 << SecondParam->getDeclName();
11262 ParameterMismatch = true;
11263 break;
11264 };
11265
11266 QualType FirstParamType = FirstParam->getType();
11267 QualType SecondParamType = SecondParam->getType();
11268 if (FirstParamType != SecondParamType &&
11269 ComputeQualTypeODRHash(FirstParamType) !=
11270 ComputeQualTypeODRHash(SecondParamType)) {
Vedant Kumar48b4f762018-04-14 01:40:48 +000011271 if (const DecayedType *ParamDecayedType =
Richard Trieue6caa262017-12-23 00:41:01 +000011272 FirstParamType->getAs<DecayedType>()) {
11273 ODRDiagError(FirstParam->getLocation(),
11274 FirstParam->getSourceRange(), ParameterType)
11275 << (I + 1) << FirstParamType << true
11276 << ParamDecayedType->getOriginalType();
11277 } else {
11278 ODRDiagError(FirstParam->getLocation(),
11279 FirstParam->getSourceRange(), ParameterType)
11280 << (I + 1) << FirstParamType << false;
11281 }
11282
Vedant Kumar48b4f762018-04-14 01:40:48 +000011283 if (const DecayedType *ParamDecayedType =
Richard Trieue6caa262017-12-23 00:41:01 +000011284 SecondParamType->getAs<DecayedType>()) {
11285 ODRDiagNote(SecondParam->getLocation(),
11286 SecondParam->getSourceRange(), ParameterType)
11287 << (I + 1) << SecondParamType << true
11288 << ParamDecayedType->getOriginalType();
11289 } else {
11290 ODRDiagNote(SecondParam->getLocation(),
11291 SecondParam->getSourceRange(), ParameterType)
11292 << (I + 1) << SecondParamType << false;
11293 }
11294 ParameterMismatch = true;
11295 break;
11296 }
11297
11298 const Expr *FirstInit = FirstParam->getInit();
11299 const Expr *SecondInit = SecondParam->getInit();
11300 if ((FirstInit == nullptr) != (SecondInit == nullptr)) {
11301 ODRDiagError(FirstParam->getLocation(), FirstParam->getSourceRange(),
11302 ParameterSingleDefaultArgument)
11303 << (I + 1) << (FirstInit == nullptr)
11304 << (FirstInit ? FirstInit->getSourceRange() : SourceRange());
11305 ODRDiagNote(SecondParam->getLocation(), SecondParam->getSourceRange(),
11306 ParameterSingleDefaultArgument)
11307 << (I + 1) << (SecondInit == nullptr)
11308 << (SecondInit ? SecondInit->getSourceRange() : SourceRange());
11309 ParameterMismatch = true;
11310 break;
11311 }
11312
11313 if (FirstInit && SecondInit &&
11314 ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
11315 ODRDiagError(FirstParam->getLocation(), FirstParam->getSourceRange(),
11316 ParameterDifferentDefaultArgument)
11317 << (I + 1) << FirstInit->getSourceRange();
11318 ODRDiagNote(SecondParam->getLocation(), SecondParam->getSourceRange(),
11319 ParameterDifferentDefaultArgument)
11320 << (I + 1) << SecondInit->getSourceRange();
11321 ParameterMismatch = true;
11322 break;
11323 }
11324
11325 assert(ComputeSubDeclODRHash(FirstParam) ==
11326 ComputeSubDeclODRHash(SecondParam) &&
11327 "Undiagnosed parameter difference.");
11328 }
11329
11330 if (ParameterMismatch) {
11331 Diagnosed = true;
11332 break;
11333 }
11334
11335 // If no error has been generated before now, assume the problem is in
11336 // the body and generate a message.
11337 ODRDiagError(FirstFunction->getLocation(),
11338 FirstFunction->getSourceRange(), FunctionBody);
11339 ODRDiagNote(SecondFunction->getLocation(),
11340 SecondFunction->getSourceRange(), FunctionBody);
11341 Diagnosed = true;
11342 break;
11343 }
Evgeny Stupachenkobf25d672018-01-05 02:22:52 +000011344 (void)Diagnosed;
Richard Trieue6caa262017-12-23 00:41:01 +000011345 assert(Diagnosed && "Unable to emit ODR diagnostic.");
11346 }
Richard Trieuab4d7302018-07-25 22:52:05 +000011347
11348 // Issue ODR failures diagnostics for enums.
11349 for (auto &Merge : EnumOdrMergeFailures) {
11350 enum ODREnumDifference {
11351 SingleScopedEnum,
11352 EnumTagKeywordMismatch,
11353 SingleSpecifiedType,
11354 DifferentSpecifiedTypes,
11355 DifferentNumberEnumConstants,
11356 EnumConstantName,
11357 EnumConstantSingleInitilizer,
11358 EnumConstantDifferentInitilizer,
11359 };
11360
11361 // If we've already pointed out a specific problem with this enum, don't
11362 // bother issuing a general "something's different" diagnostic.
11363 if (!DiagnosedOdrMergeFailures.insert(Merge.first).second)
11364 continue;
11365
11366 EnumDecl *FirstEnum = Merge.first;
11367 std::string FirstModule = getOwningModuleNameForDiagnostic(FirstEnum);
11368
11369 using DeclHashes =
11370 llvm::SmallVector<std::pair<EnumConstantDecl *, unsigned>, 4>;
11371 auto PopulateHashes = [&ComputeSubDeclODRHash, FirstEnum](
11372 DeclHashes &Hashes, EnumDecl *Enum) {
11373 for (auto *D : Enum->decls()) {
11374 // Due to decl merging, the first EnumDecl is the parent of
11375 // Decls in both records.
11376 if (!ODRHash::isWhitelistedDecl(D, FirstEnum))
11377 continue;
11378 assert(isa<EnumConstantDecl>(D) && "Unexpected Decl kind");
11379 Hashes.emplace_back(cast<EnumConstantDecl>(D),
11380 ComputeSubDeclODRHash(D));
11381 }
11382 };
11383 DeclHashes FirstHashes;
11384 PopulateHashes(FirstHashes, FirstEnum);
11385 bool Diagnosed = false;
11386 for (auto &SecondEnum : Merge.second) {
11387
11388 if (FirstEnum == SecondEnum)
11389 continue;
11390
11391 std::string SecondModule =
11392 getOwningModuleNameForDiagnostic(SecondEnum);
11393
11394 auto ODRDiagError = [FirstEnum, &FirstModule,
11395 this](SourceLocation Loc, SourceRange Range,
11396 ODREnumDifference DiffType) {
11397 return Diag(Loc, diag::err_module_odr_violation_enum)
11398 << FirstEnum << FirstModule.empty() << FirstModule << Range
11399 << DiffType;
11400 };
11401 auto ODRDiagNote = [&SecondModule, this](SourceLocation Loc,
11402 SourceRange Range,
11403 ODREnumDifference DiffType) {
11404 return Diag(Loc, diag::note_module_odr_violation_enum)
11405 << SecondModule << Range << DiffType;
11406 };
11407
11408 if (FirstEnum->isScoped() != SecondEnum->isScoped()) {
11409 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11410 SingleScopedEnum)
11411 << FirstEnum->isScoped();
11412 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11413 SingleScopedEnum)
11414 << SecondEnum->isScoped();
11415 Diagnosed = true;
11416 continue;
11417 }
11418
11419 if (FirstEnum->isScoped() && SecondEnum->isScoped()) {
11420 if (FirstEnum->isScopedUsingClassTag() !=
11421 SecondEnum->isScopedUsingClassTag()) {
11422 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11423 EnumTagKeywordMismatch)
11424 << FirstEnum->isScopedUsingClassTag();
11425 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11426 EnumTagKeywordMismatch)
11427 << SecondEnum->isScopedUsingClassTag();
11428 Diagnosed = true;
11429 continue;
11430 }
11431 }
11432
11433 QualType FirstUnderlyingType =
11434 FirstEnum->getIntegerTypeSourceInfo()
11435 ? FirstEnum->getIntegerTypeSourceInfo()->getType()
11436 : QualType();
11437 QualType SecondUnderlyingType =
11438 SecondEnum->getIntegerTypeSourceInfo()
11439 ? SecondEnum->getIntegerTypeSourceInfo()->getType()
11440 : QualType();
11441 if (FirstUnderlyingType.isNull() != SecondUnderlyingType.isNull()) {
11442 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11443 SingleSpecifiedType)
11444 << !FirstUnderlyingType.isNull();
11445 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11446 SingleSpecifiedType)
11447 << !SecondUnderlyingType.isNull();
11448 Diagnosed = true;
11449 continue;
11450 }
11451
11452 if (!FirstUnderlyingType.isNull() && !SecondUnderlyingType.isNull()) {
11453 if (ComputeQualTypeODRHash(FirstUnderlyingType) !=
11454 ComputeQualTypeODRHash(SecondUnderlyingType)) {
11455 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11456 DifferentSpecifiedTypes)
11457 << FirstUnderlyingType;
11458 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11459 DifferentSpecifiedTypes)
11460 << SecondUnderlyingType;
11461 Diagnosed = true;
11462 continue;
11463 }
11464 }
11465
11466 DeclHashes SecondHashes;
11467 PopulateHashes(SecondHashes, SecondEnum);
11468
11469 if (FirstHashes.size() != SecondHashes.size()) {
11470 ODRDiagError(FirstEnum->getLocation(), FirstEnum->getSourceRange(),
11471 DifferentNumberEnumConstants)
11472 << (int)FirstHashes.size();
11473 ODRDiagNote(SecondEnum->getLocation(), SecondEnum->getSourceRange(),
11474 DifferentNumberEnumConstants)
11475 << (int)SecondHashes.size();
11476 Diagnosed = true;
11477 continue;
11478 }
11479
11480 for (unsigned I = 0; I < FirstHashes.size(); ++I) {
11481 if (FirstHashes[I].second == SecondHashes[I].second)
11482 continue;
11483 const EnumConstantDecl *FirstEnumConstant = FirstHashes[I].first;
11484 const EnumConstantDecl *SecondEnumConstant = SecondHashes[I].first;
11485
11486 if (FirstEnumConstant->getDeclName() !=
11487 SecondEnumConstant->getDeclName()) {
11488
11489 ODRDiagError(FirstEnumConstant->getLocation(),
11490 FirstEnumConstant->getSourceRange(), EnumConstantName)
11491 << I + 1 << FirstEnumConstant;
11492 ODRDiagNote(SecondEnumConstant->getLocation(),
11493 SecondEnumConstant->getSourceRange(), EnumConstantName)
11494 << I + 1 << SecondEnumConstant;
11495 Diagnosed = true;
11496 break;
11497 }
11498
11499 const Expr *FirstInit = FirstEnumConstant->getInitExpr();
11500 const Expr *SecondInit = SecondEnumConstant->getInitExpr();
11501 if (!FirstInit && !SecondInit)
11502 continue;
11503
11504 if (!FirstInit || !SecondInit) {
11505 ODRDiagError(FirstEnumConstant->getLocation(),
11506 FirstEnumConstant->getSourceRange(),
11507 EnumConstantSingleInitilizer)
11508 << I + 1 << FirstEnumConstant << (FirstInit != nullptr);
11509 ODRDiagNote(SecondEnumConstant->getLocation(),
11510 SecondEnumConstant->getSourceRange(),
11511 EnumConstantSingleInitilizer)
11512 << I + 1 << SecondEnumConstant << (SecondInit != nullptr);
11513 Diagnosed = true;
11514 break;
11515 }
11516
11517 if (ComputeODRHash(FirstInit) != ComputeODRHash(SecondInit)) {
11518 ODRDiagError(FirstEnumConstant->getLocation(),
11519 FirstEnumConstant->getSourceRange(),
11520 EnumConstantDifferentInitilizer)
11521 << I + 1 << FirstEnumConstant;
11522 ODRDiagNote(SecondEnumConstant->getLocation(),
11523 SecondEnumConstant->getSourceRange(),
11524 EnumConstantDifferentInitilizer)
11525 << I + 1 << SecondEnumConstant;
11526 Diagnosed = true;
11527 break;
11528 }
11529 }
11530 }
11531
11532 (void)Diagnosed;
11533 assert(Diagnosed && "Unable to emit ODR diagnostic.");
11534 }
Guy Benyei11169dd2012-12-18 14:30:41 +000011535}
11536
Richard Smithce18a182015-07-14 00:26:00 +000011537void ASTReader::StartedDeserializing() {
David L. Jonesc4808b9e2016-12-15 20:53:26 +000011538 if (++NumCurrentElementsDeserializing == 1 && ReadTimer.get())
Richard Smithce18a182015-07-14 00:26:00 +000011539 ReadTimer->startTimer();
11540}
11541
Guy Benyei11169dd2012-12-18 14:30:41 +000011542void ASTReader::FinishedDeserializing() {
11543 assert(NumCurrentElementsDeserializing &&
11544 "FinishedDeserializing not paired with StartedDeserializing");
11545 if (NumCurrentElementsDeserializing == 1) {
11546 // We decrease NumCurrentElementsDeserializing only after pending actions
11547 // are finished, to avoid recursively re-calling finishPendingActions().
11548 finishPendingActions();
11549 }
11550 --NumCurrentElementsDeserializing;
11551
Richard Smitha0ce9c42014-07-29 23:23:27 +000011552 if (NumCurrentElementsDeserializing == 0) {
Richard Smitha62d1982018-08-03 01:00:01 +000011553 // Propagate exception specification and deduced type updates along
11554 // redeclaration chains.
11555 //
11556 // We do this now rather than in finishPendingActions because we want to
11557 // be able to walk the complete redeclaration chains of the updated decls.
11558 while (!PendingExceptionSpecUpdates.empty() ||
11559 !PendingDeducedTypeUpdates.empty()) {
11560 auto ESUpdates = std::move(PendingExceptionSpecUpdates);
Richard Smith7226f2a2015-03-23 19:54:56 +000011561 PendingExceptionSpecUpdates.clear();
Richard Smitha62d1982018-08-03 01:00:01 +000011562 for (auto Update : ESUpdates) {
Vassil Vassilev19765fb2016-07-22 21:08:24 +000011563 ProcessingUpdatesRAIIObj ProcessingUpdates(*this);
Richard Smith7226f2a2015-03-23 19:54:56 +000011564 auto *FPT = Update.second->getType()->castAs<FunctionProtoType>();
Richard Smith1d0f1992015-08-19 21:09:32 +000011565 auto ESI = FPT->getExtProtoInfo().ExceptionSpec;
Richard Smithdbafb6c2017-06-29 23:23:46 +000011566 if (auto *Listener = getContext().getASTMutationListener())
Richard Smithd88a7f12015-09-01 20:35:42 +000011567 Listener->ResolvedExceptionSpec(cast<FunctionDecl>(Update.second));
Richard Smith1d0f1992015-08-19 21:09:32 +000011568 for (auto *Redecl : Update.second->redecls())
Richard Smithdbafb6c2017-06-29 23:23:46 +000011569 getContext().adjustExceptionSpec(cast<FunctionDecl>(Redecl), ESI);
Richard Smith7226f2a2015-03-23 19:54:56 +000011570 }
Richard Smitha62d1982018-08-03 01:00:01 +000011571
11572 auto DTUpdates = std::move(PendingDeducedTypeUpdates);
11573 PendingDeducedTypeUpdates.clear();
11574 for (auto Update : DTUpdates) {
11575 ProcessingUpdatesRAIIObj ProcessingUpdates(*this);
11576 // FIXME: If the return type is already deduced, check that it matches.
11577 getContext().adjustDeducedFunctionResultType(Update.first,
11578 Update.second);
11579 }
Richard Smith9e2341d2015-03-23 03:25:59 +000011580 }
11581
Richard Smithce18a182015-07-14 00:26:00 +000011582 if (ReadTimer)
11583 ReadTimer->stopTimer();
11584
Richard Smith0f4e2c42015-08-06 04:23:48 +000011585 diagnoseOdrViolations();
11586
Richard Smith04d05b52014-03-23 00:27:18 +000011587 // We are not in recursive loading, so it's safe to pass the "interesting"
11588 // decls to the consumer.
Richard Smitha0ce9c42014-07-29 23:23:27 +000011589 if (Consumer)
11590 PassInterestingDeclsToConsumer();
Guy Benyei11169dd2012-12-18 14:30:41 +000011591 }
11592}
11593
Argyrios Kyrtzidise5edbf92013-04-26 21:33:35 +000011594void ASTReader::pushExternalDeclIntoScope(NamedDecl *D, DeclarationName Name) {
Richard Smith9e2341d2015-03-23 03:25:59 +000011595 if (IdentifierInfo *II = Name.getAsIdentifierInfo()) {
11596 // Remove any fake results before adding any real ones.
11597 auto It = PendingFakeLookupResults.find(II);
11598 if (It != PendingFakeLookupResults.end()) {
Richard Smitha534a312015-07-21 23:54:07 +000011599 for (auto *ND : It->second)
Richard Smith9e2341d2015-03-23 03:25:59 +000011600 SemaObj->IdResolver.RemoveDecl(ND);
Ben Langmuireb8bd2d2015-04-10 22:25:42 +000011601 // FIXME: this works around module+PCH performance issue.
11602 // Rather than erase the result from the map, which is O(n), just clear
11603 // the vector of NamedDecls.
11604 It->second.clear();
Richard Smith9e2341d2015-03-23 03:25:59 +000011605 }
11606 }
Argyrios Kyrtzidise5edbf92013-04-26 21:33:35 +000011607
11608 if (SemaObj->IdResolver.tryAddTopLevelDecl(D, Name) && SemaObj->TUScope) {
11609 SemaObj->TUScope->AddDecl(D);
11610 } else if (SemaObj->TUScope) {
11611 // Adding the decl to IdResolver may have failed because it was already in
11612 // (even though it was not added in scope). If it is already in, make sure
11613 // it gets in the scope as well.
11614 if (std::find(SemaObj->IdResolver.begin(Name),
11615 SemaObj->IdResolver.end(), D) != SemaObj->IdResolver.end())
11616 SemaObj->TUScope->AddDecl(D);
11617 }
11618}
11619
Duncan P. N. Exon Smith8bef5cd2019-03-09 17:33:56 +000011620ASTReader::ASTReader(Preprocessor &PP, InMemoryModuleCache &ModuleCache,
11621 ASTContext *Context,
David Blaikie61137e12017-01-05 18:23:18 +000011622 const PCHContainerReader &PCHContainerRdr,
11623 ArrayRef<std::shared_ptr<ModuleFileExtension>> Extensions,
11624 StringRef isysroot, bool DisableValidation,
11625 bool AllowASTWithCompilerErrors,
11626 bool AllowConfigurationMismatch, bool ValidateSystemInputs,
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +000011627 bool ValidateASTInputFilesContent, bool UseGlobalIndex,
David Blaikie61137e12017-01-05 18:23:18 +000011628 std::unique_ptr<llvm::Timer> ReadTimer)
11629 : Listener(DisableValidation
11630 ? cast<ASTReaderListener>(new SimpleASTReaderListener(PP))
11631 : cast<ASTReaderListener>(new PCHValidator(PP, *this))),
David Blaikie61137e12017-01-05 18:23:18 +000011632 SourceMgr(PP.getSourceManager()), FileMgr(PP.getFileManager()),
David Blaikie9d7c1ba2017-01-05 18:45:43 +000011633 PCHContainerRdr(PCHContainerRdr), Diags(PP.getDiagnostics()), PP(PP),
Duncan P. N. Exon Smith8bef5cd2019-03-09 17:33:56 +000011634 ContextObj(Context), ModuleMgr(PP.getFileManager(), ModuleCache,
11635 PCHContainerRdr, PP.getHeaderSearchInfo()),
11636 DummyIdResolver(PP), ReadTimer(std::move(ReadTimer)), isysroot(isysroot),
David Blaikie61137e12017-01-05 18:23:18 +000011637 DisableValidation(DisableValidation),
Nico Weber824285e2014-05-08 04:26:47 +000011638 AllowASTWithCompilerErrors(AllowASTWithCompilerErrors),
11639 AllowConfigurationMismatch(AllowConfigurationMismatch),
11640 ValidateSystemInputs(ValidateSystemInputs),
Bruno Cardoso Lopes1731fc82019-10-15 14:23:55 +000011641 ValidateASTInputFilesContent(ValidateASTInputFilesContent),
David Blaikie9d7c1ba2017-01-05 18:45:43 +000011642 UseGlobalIndex(UseGlobalIndex), CurrSwitchCaseStmts(&SwitchCaseStmts) {
Guy Benyei11169dd2012-12-18 14:30:41 +000011643 SourceMgr.setExternalSLocEntrySource(this);
Douglas Gregor6623e1f2015-11-03 18:33:07 +000011644
11645 for (const auto &Ext : Extensions) {
11646 auto BlockName = Ext->getExtensionMetadata().BlockName;
11647 auto Known = ModuleFileExtensions.find(BlockName);
11648 if (Known != ModuleFileExtensions.end()) {
11649 Diags.Report(diag::warn_duplicate_module_file_extension)
11650 << BlockName;
11651 continue;
11652 }
11653
11654 ModuleFileExtensions.insert({BlockName, Ext});
11655 }
Guy Benyei11169dd2012-12-18 14:30:41 +000011656}
11657
11658ASTReader::~ASTReader() {
Nico Weber824285e2014-05-08 04:26:47 +000011659 if (OwnsDeserializationListener)
11660 delete DeserializationListener;
Guy Benyei11169dd2012-12-18 14:30:41 +000011661}
Richard Smith10379092016-05-06 23:14:07 +000011662
11663IdentifierResolver &ASTReader::getIdResolver() {
11664 return SemaObj ? SemaObj->IdResolver : DummyIdResolver;
11665}
David L. Jonesbe1557a2016-12-21 00:17:49 +000011666
JF Bastien0e828952019-06-26 19:50:12 +000011667Expected<unsigned> ASTRecordReader::readRecord(llvm::BitstreamCursor &Cursor,
11668 unsigned AbbrevID) {
David L. Jonesbe1557a2016-12-21 00:17:49 +000011669 Idx = 0;
11670 Record.clear();
11671 return Cursor.readRecord(AbbrevID, Record);
11672}
Kelvin Libe286f52018-09-15 13:54:15 +000011673//===----------------------------------------------------------------------===//
11674//// OMPClauseReader implementation
11675////===----------------------------------------------------------------------===//
11676
John McCallc2f18312019-12-14 03:01:28 -050011677// This has to be in namespace clang because it's friended by all
11678// of the OMP clauses.
11679namespace clang {
11680
11681class OMPClauseReader : public OMPClauseVisitor<OMPClauseReader> {
11682 ASTRecordReader &Record;
11683 ASTContext &Context;
11684
11685public:
11686 OMPClauseReader(ASTRecordReader &Record)
11687 : Record(Record), Context(Record.getContext()) {}
11688
Johannes Doerfert419a5592020-03-30 19:58:40 -050011689#define OMP_CLAUSE_CLASS(Enum, Str, Class) void Visit##Class(Class *C);
11690#include "llvm/Frontend/OpenMP/OMPKinds.def"
John McCallc2f18312019-12-14 03:01:28 -050011691 OMPClause *readClause();
11692 void VisitOMPClauseWithPreInit(OMPClauseWithPreInit *C);
11693 void VisitOMPClauseWithPostUpdate(OMPClauseWithPostUpdate *C);
11694};
11695
11696} // end namespace clang
11697
11698OMPClause *ASTRecordReader::readOMPClause() {
11699 return OMPClauseReader(*this).readClause();
11700}
11701
Kelvin Libe286f52018-09-15 13:54:15 +000011702OMPClause *OMPClauseReader::readClause() {
Simon Pilgrim556fbfe2019-09-15 16:05:20 +000011703 OMPClause *C = nullptr;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011704 switch (llvm::omp::Clause(Record.readInt())) {
11705 case llvm::omp::OMPC_if:
Kelvin Libe286f52018-09-15 13:54:15 +000011706 C = new (Context) OMPIfClause();
11707 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011708 case llvm::omp::OMPC_final:
Kelvin Libe286f52018-09-15 13:54:15 +000011709 C = new (Context) OMPFinalClause();
11710 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011711 case llvm::omp::OMPC_num_threads:
Kelvin Libe286f52018-09-15 13:54:15 +000011712 C = new (Context) OMPNumThreadsClause();
11713 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011714 case llvm::omp::OMPC_safelen:
Kelvin Libe286f52018-09-15 13:54:15 +000011715 C = new (Context) OMPSafelenClause();
11716 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011717 case llvm::omp::OMPC_simdlen:
Kelvin Libe286f52018-09-15 13:54:15 +000011718 C = new (Context) OMPSimdlenClause();
11719 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011720 case llvm::omp::OMPC_allocator:
Alexey Bataev9cc10fc2019-03-12 18:52:33 +000011721 C = new (Context) OMPAllocatorClause();
11722 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011723 case llvm::omp::OMPC_collapse:
Kelvin Libe286f52018-09-15 13:54:15 +000011724 C = new (Context) OMPCollapseClause();
11725 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011726 case llvm::omp::OMPC_default:
Kelvin Libe286f52018-09-15 13:54:15 +000011727 C = new (Context) OMPDefaultClause();
11728 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011729 case llvm::omp::OMPC_proc_bind:
Kelvin Libe286f52018-09-15 13:54:15 +000011730 C = new (Context) OMPProcBindClause();
11731 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011732 case llvm::omp::OMPC_schedule:
Kelvin Libe286f52018-09-15 13:54:15 +000011733 C = new (Context) OMPScheduleClause();
11734 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011735 case llvm::omp::OMPC_ordered:
Kelvin Libe286f52018-09-15 13:54:15 +000011736 C = OMPOrderedClause::CreateEmpty(Context, Record.readInt());
11737 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011738 case llvm::omp::OMPC_nowait:
Kelvin Libe286f52018-09-15 13:54:15 +000011739 C = new (Context) OMPNowaitClause();
11740 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011741 case llvm::omp::OMPC_untied:
Kelvin Libe286f52018-09-15 13:54:15 +000011742 C = new (Context) OMPUntiedClause();
11743 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011744 case llvm::omp::OMPC_mergeable:
Kelvin Libe286f52018-09-15 13:54:15 +000011745 C = new (Context) OMPMergeableClause();
11746 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011747 case llvm::omp::OMPC_read:
Kelvin Libe286f52018-09-15 13:54:15 +000011748 C = new (Context) OMPReadClause();
11749 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011750 case llvm::omp::OMPC_write:
Kelvin Libe286f52018-09-15 13:54:15 +000011751 C = new (Context) OMPWriteClause();
11752 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011753 case llvm::omp::OMPC_update:
Alexey Bataev82f7c202020-03-03 13:22:35 -050011754 C = OMPUpdateClause::CreateEmpty(Context, Record.readInt());
Kelvin Libe286f52018-09-15 13:54:15 +000011755 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011756 case llvm::omp::OMPC_capture:
Kelvin Libe286f52018-09-15 13:54:15 +000011757 C = new (Context) OMPCaptureClause();
11758 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011759 case llvm::omp::OMPC_seq_cst:
Kelvin Libe286f52018-09-15 13:54:15 +000011760 C = new (Context) OMPSeqCstClause();
11761 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011762 case llvm::omp::OMPC_acq_rel:
Alexey Bataevea9166b2020-02-06 16:30:23 -050011763 C = new (Context) OMPAcqRelClause();
11764 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011765 case llvm::omp::OMPC_acquire:
Alexey Bataev04a830f2020-02-10 14:30:39 -050011766 C = new (Context) OMPAcquireClause();
11767 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011768 case llvm::omp::OMPC_release:
Alexey Bataev95598342020-02-10 15:49:05 -050011769 C = new (Context) OMPReleaseClause();
11770 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011771 case llvm::omp::OMPC_relaxed:
Alexey Bataev9a8defc2020-02-11 11:10:43 -050011772 C = new (Context) OMPRelaxedClause();
11773 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011774 case llvm::omp::OMPC_threads:
Kelvin Libe286f52018-09-15 13:54:15 +000011775 C = new (Context) OMPThreadsClause();
11776 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011777 case llvm::omp::OMPC_simd:
Kelvin Libe286f52018-09-15 13:54:15 +000011778 C = new (Context) OMPSIMDClause();
11779 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011780 case llvm::omp::OMPC_nogroup:
Kelvin Libe286f52018-09-15 13:54:15 +000011781 C = new (Context) OMPNogroupClause();
11782 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011783 case llvm::omp::OMPC_unified_address:
Kelvin Li1408f912018-09-26 04:28:39 +000011784 C = new (Context) OMPUnifiedAddressClause();
11785 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011786 case llvm::omp::OMPC_unified_shared_memory:
Patrick Lyster4a370b92018-10-01 13:47:43 +000011787 C = new (Context) OMPUnifiedSharedMemoryClause();
11788 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011789 case llvm::omp::OMPC_reverse_offload:
Patrick Lyster6bdf63b2018-10-03 20:07:58 +000011790 C = new (Context) OMPReverseOffloadClause();
11791 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011792 case llvm::omp::OMPC_dynamic_allocators:
Patrick Lyster3fe9e392018-10-11 14:41:10 +000011793 C = new (Context) OMPDynamicAllocatorsClause();
11794 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011795 case llvm::omp::OMPC_atomic_default_mem_order:
Patrick Lyster7a2a27c2018-11-02 12:18:11 +000011796 C = new (Context) OMPAtomicDefaultMemOrderClause();
11797 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011798 case llvm::omp::OMPC_private:
Kelvin Libe286f52018-09-15 13:54:15 +000011799 C = OMPPrivateClause::CreateEmpty(Context, Record.readInt());
11800 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011801 case llvm::omp::OMPC_firstprivate:
Kelvin Libe286f52018-09-15 13:54:15 +000011802 C = OMPFirstprivateClause::CreateEmpty(Context, Record.readInt());
11803 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011804 case llvm::omp::OMPC_lastprivate:
Kelvin Libe286f52018-09-15 13:54:15 +000011805 C = OMPLastprivateClause::CreateEmpty(Context, Record.readInt());
11806 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011807 case llvm::omp::OMPC_shared:
Kelvin Libe286f52018-09-15 13:54:15 +000011808 C = OMPSharedClause::CreateEmpty(Context, Record.readInt());
11809 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011810 case llvm::omp::OMPC_reduction:
Kelvin Libe286f52018-09-15 13:54:15 +000011811 C = OMPReductionClause::CreateEmpty(Context, Record.readInt());
11812 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011813 case llvm::omp::OMPC_task_reduction:
Kelvin Libe286f52018-09-15 13:54:15 +000011814 C = OMPTaskReductionClause::CreateEmpty(Context, Record.readInt());
11815 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011816 case llvm::omp::OMPC_in_reduction:
Kelvin Libe286f52018-09-15 13:54:15 +000011817 C = OMPInReductionClause::CreateEmpty(Context, Record.readInt());
11818 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011819 case llvm::omp::OMPC_linear:
Kelvin Libe286f52018-09-15 13:54:15 +000011820 C = OMPLinearClause::CreateEmpty(Context, Record.readInt());
11821 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011822 case llvm::omp::OMPC_aligned:
Kelvin Libe286f52018-09-15 13:54:15 +000011823 C = OMPAlignedClause::CreateEmpty(Context, Record.readInt());
11824 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011825 case llvm::omp::OMPC_copyin:
Kelvin Libe286f52018-09-15 13:54:15 +000011826 C = OMPCopyinClause::CreateEmpty(Context, Record.readInt());
11827 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011828 case llvm::omp::OMPC_copyprivate:
Kelvin Libe286f52018-09-15 13:54:15 +000011829 C = OMPCopyprivateClause::CreateEmpty(Context, Record.readInt());
11830 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011831 case llvm::omp::OMPC_flush:
Kelvin Libe286f52018-09-15 13:54:15 +000011832 C = OMPFlushClause::CreateEmpty(Context, Record.readInt());
11833 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011834 case llvm::omp::OMPC_depobj:
Alexey Bataevc112e942020-02-28 09:52:15 -050011835 C = OMPDepobjClause::CreateEmpty(Context);
11836 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011837 case llvm::omp::OMPC_depend: {
Kelvin Libe286f52018-09-15 13:54:15 +000011838 unsigned NumVars = Record.readInt();
11839 unsigned NumLoops = Record.readInt();
11840 C = OMPDependClause::CreateEmpty(Context, NumVars, NumLoops);
11841 break;
11842 }
Johannes Doerfert419a5592020-03-30 19:58:40 -050011843 case llvm::omp::OMPC_device:
Kelvin Libe286f52018-09-15 13:54:15 +000011844 C = new (Context) OMPDeviceClause();
11845 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011846 case llvm::omp::OMPC_map: {
Michael Kruse4304e9d2019-02-19 16:38:20 +000011847 OMPMappableExprListSizeTy Sizes;
11848 Sizes.NumVars = Record.readInt();
11849 Sizes.NumUniqueDeclarations = Record.readInt();
11850 Sizes.NumComponentLists = Record.readInt();
11851 Sizes.NumComponents = Record.readInt();
11852 C = OMPMapClause::CreateEmpty(Context, Sizes);
Kelvin Libe286f52018-09-15 13:54:15 +000011853 break;
11854 }
Johannes Doerfert419a5592020-03-30 19:58:40 -050011855 case llvm::omp::OMPC_num_teams:
Kelvin Libe286f52018-09-15 13:54:15 +000011856 C = new (Context) OMPNumTeamsClause();
11857 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011858 case llvm::omp::OMPC_thread_limit:
Kelvin Libe286f52018-09-15 13:54:15 +000011859 C = new (Context) OMPThreadLimitClause();
11860 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011861 case llvm::omp::OMPC_priority:
Kelvin Libe286f52018-09-15 13:54:15 +000011862 C = new (Context) OMPPriorityClause();
11863 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011864 case llvm::omp::OMPC_grainsize:
Kelvin Libe286f52018-09-15 13:54:15 +000011865 C = new (Context) OMPGrainsizeClause();
11866 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011867 case llvm::omp::OMPC_num_tasks:
Kelvin Libe286f52018-09-15 13:54:15 +000011868 C = new (Context) OMPNumTasksClause();
11869 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011870 case llvm::omp::OMPC_hint:
Kelvin Libe286f52018-09-15 13:54:15 +000011871 C = new (Context) OMPHintClause();
11872 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011873 case llvm::omp::OMPC_dist_schedule:
Kelvin Libe286f52018-09-15 13:54:15 +000011874 C = new (Context) OMPDistScheduleClause();
11875 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011876 case llvm::omp::OMPC_defaultmap:
Kelvin Libe286f52018-09-15 13:54:15 +000011877 C = new (Context) OMPDefaultmapClause();
11878 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011879 case llvm::omp::OMPC_to: {
Michael Kruse4304e9d2019-02-19 16:38:20 +000011880 OMPMappableExprListSizeTy Sizes;
11881 Sizes.NumVars = Record.readInt();
11882 Sizes.NumUniqueDeclarations = Record.readInt();
11883 Sizes.NumComponentLists = Record.readInt();
11884 Sizes.NumComponents = Record.readInt();
11885 C = OMPToClause::CreateEmpty(Context, Sizes);
Kelvin Libe286f52018-09-15 13:54:15 +000011886 break;
11887 }
Johannes Doerfert419a5592020-03-30 19:58:40 -050011888 case llvm::omp::OMPC_from: {
Michael Kruse4304e9d2019-02-19 16:38:20 +000011889 OMPMappableExprListSizeTy Sizes;
11890 Sizes.NumVars = Record.readInt();
11891 Sizes.NumUniqueDeclarations = Record.readInt();
11892 Sizes.NumComponentLists = Record.readInt();
11893 Sizes.NumComponents = Record.readInt();
11894 C = OMPFromClause::CreateEmpty(Context, Sizes);
Kelvin Libe286f52018-09-15 13:54:15 +000011895 break;
11896 }
Johannes Doerfert419a5592020-03-30 19:58:40 -050011897 case llvm::omp::OMPC_use_device_ptr: {
Michael Kruse4304e9d2019-02-19 16:38:20 +000011898 OMPMappableExprListSizeTy Sizes;
11899 Sizes.NumVars = Record.readInt();
11900 Sizes.NumUniqueDeclarations = Record.readInt();
11901 Sizes.NumComponentLists = Record.readInt();
11902 Sizes.NumComponents = Record.readInt();
11903 C = OMPUseDevicePtrClause::CreateEmpty(Context, Sizes);
Kelvin Libe286f52018-09-15 13:54:15 +000011904 break;
11905 }
Johannes Doerfert419a5592020-03-30 19:58:40 -050011906 case llvm::omp::OMPC_is_device_ptr: {
Michael Kruse4304e9d2019-02-19 16:38:20 +000011907 OMPMappableExprListSizeTy Sizes;
11908 Sizes.NumVars = Record.readInt();
11909 Sizes.NumUniqueDeclarations = Record.readInt();
11910 Sizes.NumComponentLists = Record.readInt();
11911 Sizes.NumComponents = Record.readInt();
11912 C = OMPIsDevicePtrClause::CreateEmpty(Context, Sizes);
Kelvin Libe286f52018-09-15 13:54:15 +000011913 break;
11914 }
Johannes Doerfert419a5592020-03-30 19:58:40 -050011915 case llvm::omp::OMPC_allocate:
Alexey Bataeve04483e2019-03-27 14:14:31 +000011916 C = OMPAllocateClause::CreateEmpty(Context, Record.readInt());
11917 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011918 case llvm::omp::OMPC_nontemporal:
Alexey Bataevb6e70842019-12-16 15:54:17 -050011919 C = OMPNontemporalClause::CreateEmpty(Context, Record.readInt());
11920 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011921 case llvm::omp::OMPC_inclusive:
Alexey Bataev06dea732020-03-20 09:41:22 -040011922 C = OMPInclusiveClause::CreateEmpty(Context, Record.readInt());
11923 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011924 case llvm::omp::OMPC_exclusive:
Alexey Bataev63828a32020-03-23 10:41:08 -040011925 C = OMPExclusiveClause::CreateEmpty(Context, Record.readInt());
11926 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011927 case llvm::omp::OMPC_order:
Alexey Bataevcb8e6912020-01-31 16:09:26 -050011928 C = new (Context) OMPOrderClause();
11929 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011930 case llvm::omp::OMPC_destroy:
Alexey Bataev375437a2020-03-02 14:21:20 -050011931 C = new (Context) OMPDestroyClause();
11932 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011933 case llvm::omp::OMPC_detach:
Alexey Bataev0f0564b2020-03-17 09:17:42 -040011934 C = new (Context) OMPDetachClause();
11935 break;
Alexey Bataevb5be1c52020-04-21 13:21:00 -040011936 case llvm::omp::OMPC_uses_allocators:
11937 C = OMPUsesAllocatorsClause::CreateEmpty(Context, Record.readInt());
11938 break;
Johannes Doerfert419a5592020-03-30 19:58:40 -050011939#define OMP_CLAUSE_NO_CLASS(Enum, Str) \
11940 case llvm::omp::Enum: \
11941 break;
11942#include "llvm/Frontend/OpenMP/OMPKinds.def"
Kelvin Libe286f52018-09-15 13:54:15 +000011943 }
Simon Pilgrim556fbfe2019-09-15 16:05:20 +000011944 assert(C && "Unknown OMPClause type");
11945
Kelvin Libe286f52018-09-15 13:54:15 +000011946 Visit(C);
11947 C->setLocStart(Record.readSourceLocation());
11948 C->setLocEnd(Record.readSourceLocation());
11949
11950 return C;
11951}
11952
11953void OMPClauseReader::VisitOMPClauseWithPreInit(OMPClauseWithPreInit *C) {
11954 C->setPreInitStmt(Record.readSubStmt(),
11955 static_cast<OpenMPDirectiveKind>(Record.readInt()));
11956}
11957
11958void OMPClauseReader::VisitOMPClauseWithPostUpdate(OMPClauseWithPostUpdate *C) {
11959 VisitOMPClauseWithPreInit(C);
11960 C->setPostUpdateExpr(Record.readSubExpr());
11961}
11962
11963void OMPClauseReader::VisitOMPIfClause(OMPIfClause *C) {
11964 VisitOMPClauseWithPreInit(C);
11965 C->setNameModifier(static_cast<OpenMPDirectiveKind>(Record.readInt()));
11966 C->setNameModifierLoc(Record.readSourceLocation());
11967 C->setColonLoc(Record.readSourceLocation());
11968 C->setCondition(Record.readSubExpr());
11969 C->setLParenLoc(Record.readSourceLocation());
11970}
11971
11972void OMPClauseReader::VisitOMPFinalClause(OMPFinalClause *C) {
Alexey Bataev3a842ec2019-10-15 19:37:05 +000011973 VisitOMPClauseWithPreInit(C);
Kelvin Libe286f52018-09-15 13:54:15 +000011974 C->setCondition(Record.readSubExpr());
11975 C->setLParenLoc(Record.readSourceLocation());
11976}
11977
11978void OMPClauseReader::VisitOMPNumThreadsClause(OMPNumThreadsClause *C) {
11979 VisitOMPClauseWithPreInit(C);
11980 C->setNumThreads(Record.readSubExpr());
11981 C->setLParenLoc(Record.readSourceLocation());
11982}
11983
11984void OMPClauseReader::VisitOMPSafelenClause(OMPSafelenClause *C) {
11985 C->setSafelen(Record.readSubExpr());
11986 C->setLParenLoc(Record.readSourceLocation());
11987}
11988
11989void OMPClauseReader::VisitOMPSimdlenClause(OMPSimdlenClause *C) {
11990 C->setSimdlen(Record.readSubExpr());
11991 C->setLParenLoc(Record.readSourceLocation());
11992}
11993
Alexey Bataev9cc10fc2019-03-12 18:52:33 +000011994void OMPClauseReader::VisitOMPAllocatorClause(OMPAllocatorClause *C) {
11995 C->setAllocator(Record.readExpr());
11996 C->setLParenLoc(Record.readSourceLocation());
11997}
11998
Kelvin Libe286f52018-09-15 13:54:15 +000011999void OMPClauseReader::VisitOMPCollapseClause(OMPCollapseClause *C) {
12000 C->setNumForLoops(Record.readSubExpr());
12001 C->setLParenLoc(Record.readSourceLocation());
12002}
12003
12004void OMPClauseReader::VisitOMPDefaultClause(OMPDefaultClause *C) {
Atmn Patel577c9b02020-02-14 21:45:49 -060012005 C->setDefaultKind(static_cast<llvm::omp::DefaultKind>(Record.readInt()));
Kelvin Libe286f52018-09-15 13:54:15 +000012006 C->setLParenLoc(Record.readSourceLocation());
12007 C->setDefaultKindKwLoc(Record.readSourceLocation());
12008}
12009
12010void OMPClauseReader::VisitOMPProcBindClause(OMPProcBindClause *C) {
Johannes Doerfert6c5d1f402019-12-25 18:15:36 -060012011 C->setProcBindKind(static_cast<llvm::omp::ProcBindKind>(Record.readInt()));
Kelvin Libe286f52018-09-15 13:54:15 +000012012 C->setLParenLoc(Record.readSourceLocation());
12013 C->setProcBindKindKwLoc(Record.readSourceLocation());
12014}
12015
12016void OMPClauseReader::VisitOMPScheduleClause(OMPScheduleClause *C) {
12017 VisitOMPClauseWithPreInit(C);
12018 C->setScheduleKind(
12019 static_cast<OpenMPScheduleClauseKind>(Record.readInt()));
12020 C->setFirstScheduleModifier(
12021 static_cast<OpenMPScheduleClauseModifier>(Record.readInt()));
12022 C->setSecondScheduleModifier(
12023 static_cast<OpenMPScheduleClauseModifier>(Record.readInt()));
12024 C->setChunkSize(Record.readSubExpr());
12025 C->setLParenLoc(Record.readSourceLocation());
12026 C->setFirstScheduleModifierLoc(Record.readSourceLocation());
12027 C->setSecondScheduleModifierLoc(Record.readSourceLocation());
12028 C->setScheduleKindLoc(Record.readSourceLocation());
12029 C->setCommaLoc(Record.readSourceLocation());
12030}
12031
12032void OMPClauseReader::VisitOMPOrderedClause(OMPOrderedClause *C) {
12033 C->setNumForLoops(Record.readSubExpr());
12034 for (unsigned I = 0, E = C->NumberOfLoops; I < E; ++I)
12035 C->setLoopNumIterations(I, Record.readSubExpr());
12036 for (unsigned I = 0, E = C->NumberOfLoops; I < E; ++I)
12037 C->setLoopCounter(I, Record.readSubExpr());
12038 C->setLParenLoc(Record.readSourceLocation());
12039}
12040
Alexey Bataev0f0564b2020-03-17 09:17:42 -040012041void OMPClauseReader::VisitOMPDetachClause(OMPDetachClause *C) {
12042 C->setEventHandler(Record.readSubExpr());
12043 C->setLParenLoc(Record.readSourceLocation());
12044}
12045
Kelvin Libe286f52018-09-15 13:54:15 +000012046void OMPClauseReader::VisitOMPNowaitClause(OMPNowaitClause *) {}
12047
12048void OMPClauseReader::VisitOMPUntiedClause(OMPUntiedClause *) {}
12049
12050void OMPClauseReader::VisitOMPMergeableClause(OMPMergeableClause *) {}
12051
12052void OMPClauseReader::VisitOMPReadClause(OMPReadClause *) {}
12053
12054void OMPClauseReader::VisitOMPWriteClause(OMPWriteClause *) {}
12055
Alexey Bataev82f7c202020-03-03 13:22:35 -050012056void OMPClauseReader::VisitOMPUpdateClause(OMPUpdateClause *C) {
12057 if (C->isExtended()) {
12058 C->setLParenLoc(Record.readSourceLocation());
12059 C->setArgumentLoc(Record.readSourceLocation());
12060 C->setDependencyKind(Record.readEnum<OpenMPDependClauseKind>());
12061 }
12062}
Kelvin Libe286f52018-09-15 13:54:15 +000012063
12064void OMPClauseReader::VisitOMPCaptureClause(OMPCaptureClause *) {}
12065
12066void OMPClauseReader::VisitOMPSeqCstClause(OMPSeqCstClause *) {}
12067
Alexey Bataevea9166b2020-02-06 16:30:23 -050012068void OMPClauseReader::VisitOMPAcqRelClause(OMPAcqRelClause *) {}
12069
Alexey Bataev04a830f2020-02-10 14:30:39 -050012070void OMPClauseReader::VisitOMPAcquireClause(OMPAcquireClause *) {}
12071
Alexey Bataev95598342020-02-10 15:49:05 -050012072void OMPClauseReader::VisitOMPReleaseClause(OMPReleaseClause *) {}
12073
Alexey Bataev9a8defc2020-02-11 11:10:43 -050012074void OMPClauseReader::VisitOMPRelaxedClause(OMPRelaxedClause *) {}
12075
Kelvin Libe286f52018-09-15 13:54:15 +000012076void OMPClauseReader::VisitOMPThreadsClause(OMPThreadsClause *) {}
12077
12078void OMPClauseReader::VisitOMPSIMDClause(OMPSIMDClause *) {}
12079
12080void OMPClauseReader::VisitOMPNogroupClause(OMPNogroupClause *) {}
12081
Alexey Bataev375437a2020-03-02 14:21:20 -050012082void OMPClauseReader::VisitOMPDestroyClause(OMPDestroyClause *) {}
12083
Kelvin Li1408f912018-09-26 04:28:39 +000012084void OMPClauseReader::VisitOMPUnifiedAddressClause(OMPUnifiedAddressClause *) {}
12085
Patrick Lyster4a370b92018-10-01 13:47:43 +000012086void OMPClauseReader::VisitOMPUnifiedSharedMemoryClause(
12087 OMPUnifiedSharedMemoryClause *) {}
12088
Patrick Lyster6bdf63b2018-10-03 20:07:58 +000012089void OMPClauseReader::VisitOMPReverseOffloadClause(OMPReverseOffloadClause *) {}
12090
Patrick Lyster3fe9e392018-10-11 14:41:10 +000012091void
12092OMPClauseReader::VisitOMPDynamicAllocatorsClause(OMPDynamicAllocatorsClause *) {
12093}
12094
Patrick Lyster7a2a27c2018-11-02 12:18:11 +000012095void OMPClauseReader::VisitOMPAtomicDefaultMemOrderClause(
12096 OMPAtomicDefaultMemOrderClause *C) {
12097 C->setAtomicDefaultMemOrderKind(
12098 static_cast<OpenMPAtomicDefaultMemOrderClauseKind>(Record.readInt()));
12099 C->setLParenLoc(Record.readSourceLocation());
12100 C->setAtomicDefaultMemOrderKindKwLoc(Record.readSourceLocation());
12101}
12102
Kelvin Libe286f52018-09-15 13:54:15 +000012103void OMPClauseReader::VisitOMPPrivateClause(OMPPrivateClause *C) {
12104 C->setLParenLoc(Record.readSourceLocation());
12105 unsigned NumVars = C->varlist_size();
12106 SmallVector<Expr *, 16> Vars;
12107 Vars.reserve(NumVars);
12108 for (unsigned i = 0; i != NumVars; ++i)
12109 Vars.push_back(Record.readSubExpr());
12110 C->setVarRefs(Vars);
12111 Vars.clear();
12112 for (unsigned i = 0; i != NumVars; ++i)
12113 Vars.push_back(Record.readSubExpr());
12114 C->setPrivateCopies(Vars);
12115}
12116
12117void OMPClauseReader::VisitOMPFirstprivateClause(OMPFirstprivateClause *C) {
12118 VisitOMPClauseWithPreInit(C);
12119 C->setLParenLoc(Record.readSourceLocation());
12120 unsigned NumVars = C->varlist_size();
12121 SmallVector<Expr *, 16> Vars;
12122 Vars.reserve(NumVars);
12123 for (unsigned i = 0; i != NumVars; ++i)
12124 Vars.push_back(Record.readSubExpr());
12125 C->setVarRefs(Vars);
12126 Vars.clear();
12127 for (unsigned i = 0; i != NumVars; ++i)
12128 Vars.push_back(Record.readSubExpr());
12129 C->setPrivateCopies(Vars);
12130 Vars.clear();
12131 for (unsigned i = 0; i != NumVars; ++i)
12132 Vars.push_back(Record.readSubExpr());
12133 C->setInits(Vars);
12134}
12135
12136void OMPClauseReader::VisitOMPLastprivateClause(OMPLastprivateClause *C) {
12137 VisitOMPClauseWithPostUpdate(C);
12138 C->setLParenLoc(Record.readSourceLocation());
Alexey Bataev93dc40d2019-12-20 11:04:57 -050012139 C->setKind(Record.readEnum<OpenMPLastprivateModifier>());
12140 C->setKindLoc(Record.readSourceLocation());
12141 C->setColonLoc(Record.readSourceLocation());
Kelvin Libe286f52018-09-15 13:54:15 +000012142 unsigned NumVars = C->varlist_size();
12143 SmallVector<Expr *, 16> Vars;
12144 Vars.reserve(NumVars);
12145 for (unsigned i = 0; i != NumVars; ++i)
12146 Vars.push_back(Record.readSubExpr());
12147 C->setVarRefs(Vars);
12148 Vars.clear();
12149 for (unsigned i = 0; i != NumVars; ++i)
12150 Vars.push_back(Record.readSubExpr());
12151 C->setPrivateCopies(Vars);
12152 Vars.clear();
12153 for (unsigned i = 0; i != NumVars; ++i)
12154 Vars.push_back(Record.readSubExpr());
12155 C->setSourceExprs(Vars);
12156 Vars.clear();
12157 for (unsigned i = 0; i != NumVars; ++i)
12158 Vars.push_back(Record.readSubExpr());
12159 C->setDestinationExprs(Vars);
12160 Vars.clear();
12161 for (unsigned i = 0; i != NumVars; ++i)
12162 Vars.push_back(Record.readSubExpr());
12163 C->setAssignmentOps(Vars);
12164}
12165
12166void OMPClauseReader::VisitOMPSharedClause(OMPSharedClause *C) {
12167 C->setLParenLoc(Record.readSourceLocation());
12168 unsigned NumVars = C->varlist_size();
12169 SmallVector<Expr *, 16> Vars;
12170 Vars.reserve(NumVars);
12171 for (unsigned i = 0; i != NumVars; ++i)
12172 Vars.push_back(Record.readSubExpr());
12173 C->setVarRefs(Vars);
12174}
12175
12176void OMPClauseReader::VisitOMPReductionClause(OMPReductionClause *C) {
12177 VisitOMPClauseWithPostUpdate(C);
12178 C->setLParenLoc(Record.readSourceLocation());
Alexey Bataev1236eb62020-03-23 17:30:38 -040012179 C->setModifierLoc(Record.readSourceLocation());
Kelvin Libe286f52018-09-15 13:54:15 +000012180 C->setColonLoc(Record.readSourceLocation());
Alexey Bataev1236eb62020-03-23 17:30:38 -040012181 C->setModifier(Record.readEnum<OpenMPReductionClauseModifier>());
Kelvin Libe286f52018-09-15 13:54:15 +000012182 NestedNameSpecifierLoc NNSL = Record.readNestedNameSpecifierLoc();
John McCall3ce3d232019-12-13 03:37:23 -050012183 DeclarationNameInfo DNI = Record.readDeclarationNameInfo();
Kelvin Libe286f52018-09-15 13:54:15 +000012184 C->setQualifierLoc(NNSL);
12185 C->setNameInfo(DNI);
12186
12187 unsigned NumVars = C->varlist_size();
12188 SmallVector<Expr *, 16> Vars;
12189 Vars.reserve(NumVars);
12190 for (unsigned i = 0; i != NumVars; ++i)
12191 Vars.push_back(Record.readSubExpr());
12192 C->setVarRefs(Vars);
12193 Vars.clear();
12194 for (unsigned i = 0; i != NumVars; ++i)
12195 Vars.push_back(Record.readSubExpr());
12196 C->setPrivates(Vars);
12197 Vars.clear();
12198 for (unsigned i = 0; i != NumVars; ++i)
12199 Vars.push_back(Record.readSubExpr());
12200 C->setLHSExprs(Vars);
12201 Vars.clear();
12202 for (unsigned i = 0; i != NumVars; ++i)
12203 Vars.push_back(Record.readSubExpr());
12204 C->setRHSExprs(Vars);
12205 Vars.clear();
12206 for (unsigned i = 0; i != NumVars; ++i)
12207 Vars.push_back(Record.readSubExpr());
12208 C->setReductionOps(Vars);
12209}
12210
12211void OMPClauseReader::VisitOMPTaskReductionClause(OMPTaskReductionClause *C) {
12212 VisitOMPClauseWithPostUpdate(C);
12213 C->setLParenLoc(Record.readSourceLocation());
12214 C->setColonLoc(Record.readSourceLocation());
12215 NestedNameSpecifierLoc NNSL = Record.readNestedNameSpecifierLoc();
John McCall3ce3d232019-12-13 03:37:23 -050012216 DeclarationNameInfo DNI = Record.readDeclarationNameInfo();
Kelvin Libe286f52018-09-15 13:54:15 +000012217 C->setQualifierLoc(NNSL);
12218 C->setNameInfo(DNI);
12219
12220 unsigned NumVars = C->varlist_size();
12221 SmallVector<Expr *, 16> Vars;
12222 Vars.reserve(NumVars);
12223 for (unsigned I = 0; I != NumVars; ++I)
12224 Vars.push_back(Record.readSubExpr());
12225 C->setVarRefs(Vars);
12226 Vars.clear();
12227 for (unsigned I = 0; I != NumVars; ++I)
12228 Vars.push_back(Record.readSubExpr());
12229 C->setPrivates(Vars);
12230 Vars.clear();
12231 for (unsigned I = 0; I != NumVars; ++I)
12232 Vars.push_back(Record.readSubExpr());
12233 C->setLHSExprs(Vars);
12234 Vars.clear();
12235 for (unsigned I = 0; I != NumVars; ++I)
12236 Vars.push_back(Record.readSubExpr());
12237 C->setRHSExprs(Vars);
12238 Vars.clear();
12239 for (unsigned I = 0; I != NumVars; ++I)
12240 Vars.push_back(Record.readSubExpr());
12241 C->setReductionOps(Vars);
12242}
12243
12244void OMPClauseReader::VisitOMPInReductionClause(OMPInReductionClause *C) {
12245 VisitOMPClauseWithPostUpdate(C);
12246 C->setLParenLoc(Record.readSourceLocation());
12247 C->setColonLoc(Record.readSourceLocation());
12248 NestedNameSpecifierLoc NNSL = Record.readNestedNameSpecifierLoc();
John McCall3ce3d232019-12-13 03:37:23 -050012249 DeclarationNameInfo DNI = Record.readDeclarationNameInfo();
Kelvin Libe286f52018-09-15 13:54:15 +000012250 C->setQualifierLoc(NNSL);
12251 C->setNameInfo(DNI);
12252
12253 unsigned NumVars = C->varlist_size();
12254 SmallVector<Expr *, 16> Vars;
12255 Vars.reserve(NumVars);
12256 for (unsigned I = 0; I != NumVars; ++I)
12257 Vars.push_back(Record.readSubExpr());
12258 C->setVarRefs(Vars);
12259 Vars.clear();
12260 for (unsigned I = 0; I != NumVars; ++I)
12261 Vars.push_back(Record.readSubExpr());
12262 C->setPrivates(Vars);
12263 Vars.clear();
12264 for (unsigned I = 0; I != NumVars; ++I)
12265 Vars.push_back(Record.readSubExpr());
12266 C->setLHSExprs(Vars);
12267 Vars.clear();
12268 for (unsigned I = 0; I != NumVars; ++I)
12269 Vars.push_back(Record.readSubExpr());
12270 C->setRHSExprs(Vars);
12271 Vars.clear();
12272 for (unsigned I = 0; I != NumVars; ++I)
12273 Vars.push_back(Record.readSubExpr());
12274 C->setReductionOps(Vars);
12275 Vars.clear();
12276 for (unsigned I = 0; I != NumVars; ++I)
12277 Vars.push_back(Record.readSubExpr());
12278 C->setTaskgroupDescriptors(Vars);
12279}
12280
12281void OMPClauseReader::VisitOMPLinearClause(OMPLinearClause *C) {
12282 VisitOMPClauseWithPostUpdate(C);
12283 C->setLParenLoc(Record.readSourceLocation());
12284 C->setColonLoc(Record.readSourceLocation());
12285 C->setModifier(static_cast<OpenMPLinearClauseKind>(Record.readInt()));
12286 C->setModifierLoc(Record.readSourceLocation());
12287 unsigned NumVars = C->varlist_size();
12288 SmallVector<Expr *, 16> Vars;
12289 Vars.reserve(NumVars);
12290 for (unsigned i = 0; i != NumVars; ++i)
12291 Vars.push_back(Record.readSubExpr());
12292 C->setVarRefs(Vars);
12293 Vars.clear();
12294 for (unsigned i = 0; i != NumVars; ++i)
12295 Vars.push_back(Record.readSubExpr());
12296 C->setPrivates(Vars);
12297 Vars.clear();
12298 for (unsigned i = 0; i != NumVars; ++i)
12299 Vars.push_back(Record.readSubExpr());
12300 C->setInits(Vars);
12301 Vars.clear();
12302 for (unsigned i = 0; i != NumVars; ++i)
12303 Vars.push_back(Record.readSubExpr());
12304 C->setUpdates(Vars);
12305 Vars.clear();
12306 for (unsigned i = 0; i != NumVars; ++i)
12307 Vars.push_back(Record.readSubExpr());
12308 C->setFinals(Vars);
12309 C->setStep(Record.readSubExpr());
12310 C->setCalcStep(Record.readSubExpr());
Alexey Bataev195ae902019-08-08 13:42:45 +000012311 Vars.clear();
12312 for (unsigned I = 0; I != NumVars + 1; ++I)
12313 Vars.push_back(Record.readSubExpr());
12314 C->setUsedExprs(Vars);
Kelvin Libe286f52018-09-15 13:54:15 +000012315}
12316
12317void OMPClauseReader::VisitOMPAlignedClause(OMPAlignedClause *C) {
12318 C->setLParenLoc(Record.readSourceLocation());
12319 C->setColonLoc(Record.readSourceLocation());
12320 unsigned NumVars = C->varlist_size();
12321 SmallVector<Expr *, 16> Vars;
12322 Vars.reserve(NumVars);
12323 for (unsigned i = 0; i != NumVars; ++i)
12324 Vars.push_back(Record.readSubExpr());
12325 C->setVarRefs(Vars);
12326 C->setAlignment(Record.readSubExpr());
12327}
12328
12329void OMPClauseReader::VisitOMPCopyinClause(OMPCopyinClause *C) {
12330 C->setLParenLoc(Record.readSourceLocation());
12331 unsigned NumVars = C->varlist_size();
12332 SmallVector<Expr *, 16> Exprs;
12333 Exprs.reserve(NumVars);
12334 for (unsigned i = 0; i != NumVars; ++i)
12335 Exprs.push_back(Record.readSubExpr());
12336 C->setVarRefs(Exprs);
12337 Exprs.clear();
12338 for (unsigned i = 0; i != NumVars; ++i)
12339 Exprs.push_back(Record.readSubExpr());
12340 C->setSourceExprs(Exprs);
12341 Exprs.clear();
12342 for (unsigned i = 0; i != NumVars; ++i)
12343 Exprs.push_back(Record.readSubExpr());
12344 C->setDestinationExprs(Exprs);
12345 Exprs.clear();
12346 for (unsigned i = 0; i != NumVars; ++i)
12347 Exprs.push_back(Record.readSubExpr());
12348 C->setAssignmentOps(Exprs);
12349}
12350
12351void OMPClauseReader::VisitOMPCopyprivateClause(OMPCopyprivateClause *C) {
12352 C->setLParenLoc(Record.readSourceLocation());
12353 unsigned NumVars = C->varlist_size();
12354 SmallVector<Expr *, 16> Exprs;
12355 Exprs.reserve(NumVars);
12356 for (unsigned i = 0; i != NumVars; ++i)
12357 Exprs.push_back(Record.readSubExpr());
12358 C->setVarRefs(Exprs);
12359 Exprs.clear();
12360 for (unsigned i = 0; i != NumVars; ++i)
12361 Exprs.push_back(Record.readSubExpr());
12362 C->setSourceExprs(Exprs);
12363 Exprs.clear();
12364 for (unsigned i = 0; i != NumVars; ++i)
12365 Exprs.push_back(Record.readSubExpr());
12366 C->setDestinationExprs(Exprs);
12367 Exprs.clear();
12368 for (unsigned i = 0; i != NumVars; ++i)
12369 Exprs.push_back(Record.readSubExpr());
12370 C->setAssignmentOps(Exprs);
12371}
12372
12373void OMPClauseReader::VisitOMPFlushClause(OMPFlushClause *C) {
12374 C->setLParenLoc(Record.readSourceLocation());
12375 unsigned NumVars = C->varlist_size();
12376 SmallVector<Expr *, 16> Vars;
12377 Vars.reserve(NumVars);
12378 for (unsigned i = 0; i != NumVars; ++i)
12379 Vars.push_back(Record.readSubExpr());
12380 C->setVarRefs(Vars);
12381}
12382
Alexey Bataevc112e942020-02-28 09:52:15 -050012383void OMPClauseReader::VisitOMPDepobjClause(OMPDepobjClause *C) {
12384 C->setDepobj(Record.readSubExpr());
12385 C->setLParenLoc(Record.readSourceLocation());
12386}
12387
Kelvin Libe286f52018-09-15 13:54:15 +000012388void OMPClauseReader::VisitOMPDependClause(OMPDependClause *C) {
12389 C->setLParenLoc(Record.readSourceLocation());
Alexey Bataev13a15042020-04-01 15:06:38 -040012390 C->setModifier(Record.readSubExpr());
Kelvin Libe286f52018-09-15 13:54:15 +000012391 C->setDependencyKind(
12392 static_cast<OpenMPDependClauseKind>(Record.readInt()));
12393 C->setDependencyLoc(Record.readSourceLocation());
12394 C->setColonLoc(Record.readSourceLocation());
12395 unsigned NumVars = C->varlist_size();
12396 SmallVector<Expr *, 16> Vars;
12397 Vars.reserve(NumVars);
12398 for (unsigned I = 0; I != NumVars; ++I)
12399 Vars.push_back(Record.readSubExpr());
12400 C->setVarRefs(Vars);
12401 for (unsigned I = 0, E = C->getNumLoops(); I < E; ++I)
12402 C->setLoopData(I, Record.readSubExpr());
12403}
12404
12405void OMPClauseReader::VisitOMPDeviceClause(OMPDeviceClause *C) {
12406 VisitOMPClauseWithPreInit(C);
Alexey Bataev2f8894a2020-03-18 15:01:15 -040012407 C->setModifier(Record.readEnum<OpenMPDeviceClauseModifier>());
Kelvin Libe286f52018-09-15 13:54:15 +000012408 C->setDevice(Record.readSubExpr());
Alexey Bataev2f8894a2020-03-18 15:01:15 -040012409 C->setModifierLoc(Record.readSourceLocation());
Kelvin Libe286f52018-09-15 13:54:15 +000012410 C->setLParenLoc(Record.readSourceLocation());
12411}
12412
12413void OMPClauseReader::VisitOMPMapClause(OMPMapClause *C) {
12414 C->setLParenLoc(Record.readSourceLocation());
Reid Klecknerba1ffd22020-04-03 12:35:30 -070012415 for (unsigned I = 0; I < NumberOfOMPMapClauseModifiers; ++I) {
Kelvin Lief579432018-12-18 22:18:41 +000012416 C->setMapTypeModifier(
12417 I, static_cast<OpenMPMapModifierKind>(Record.readInt()));
12418 C->setMapTypeModifierLoc(I, Record.readSourceLocation());
12419 }
Michael Kruse4304e9d2019-02-19 16:38:20 +000012420 C->setMapperQualifierLoc(Record.readNestedNameSpecifierLoc());
John McCall3ce3d232019-12-13 03:37:23 -050012421 C->setMapperIdInfo(Record.readDeclarationNameInfo());
Kelvin Libe286f52018-09-15 13:54:15 +000012422 C->setMapType(
12423 static_cast<OpenMPMapClauseKind>(Record.readInt()));
12424 C->setMapLoc(Record.readSourceLocation());
12425 C->setColonLoc(Record.readSourceLocation());
12426 auto NumVars = C->varlist_size();
12427 auto UniqueDecls = C->getUniqueDeclarationsNum();
12428 auto TotalLists = C->getTotalComponentListNum();
12429 auto TotalComponents = C->getTotalComponentsNum();
12430
12431 SmallVector<Expr *, 16> Vars;
12432 Vars.reserve(NumVars);
12433 for (unsigned i = 0; i != NumVars; ++i)
Michael Kruse251e1482019-02-01 20:25:04 +000012434 Vars.push_back(Record.readExpr());
Kelvin Libe286f52018-09-15 13:54:15 +000012435 C->setVarRefs(Vars);
12436
Michael Kruse4304e9d2019-02-19 16:38:20 +000012437 SmallVector<Expr *, 16> UDMappers;
12438 UDMappers.reserve(NumVars);
12439 for (unsigned I = 0; I < NumVars; ++I)
12440 UDMappers.push_back(Record.readExpr());
12441 C->setUDMapperRefs(UDMappers);
12442
Kelvin Libe286f52018-09-15 13:54:15 +000012443 SmallVector<ValueDecl *, 16> Decls;
12444 Decls.reserve(UniqueDecls);
12445 for (unsigned i = 0; i < UniqueDecls; ++i)
12446 Decls.push_back(Record.readDeclAs<ValueDecl>());
12447 C->setUniqueDecls(Decls);
12448
12449 SmallVector<unsigned, 16> ListsPerDecl;
12450 ListsPerDecl.reserve(UniqueDecls);
12451 for (unsigned i = 0; i < UniqueDecls; ++i)
12452 ListsPerDecl.push_back(Record.readInt());
12453 C->setDeclNumLists(ListsPerDecl);
12454
12455 SmallVector<unsigned, 32> ListSizes;
12456 ListSizes.reserve(TotalLists);
12457 for (unsigned i = 0; i < TotalLists; ++i)
12458 ListSizes.push_back(Record.readInt());
12459 C->setComponentListSizes(ListSizes);
12460
12461 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12462 Components.reserve(TotalComponents);
12463 for (unsigned i = 0; i < TotalComponents; ++i) {
Michael Kruse251e1482019-02-01 20:25:04 +000012464 Expr *AssociatedExpr = Record.readExpr();
Kelvin Libe286f52018-09-15 13:54:15 +000012465 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12466 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12467 AssociatedExpr, AssociatedDecl));
12468 }
12469 C->setComponents(Components, ListSizes);
12470}
12471
Alexey Bataeve04483e2019-03-27 14:14:31 +000012472void OMPClauseReader::VisitOMPAllocateClause(OMPAllocateClause *C) {
12473 C->setLParenLoc(Record.readSourceLocation());
12474 C->setColonLoc(Record.readSourceLocation());
12475 C->setAllocator(Record.readSubExpr());
12476 unsigned NumVars = C->varlist_size();
12477 SmallVector<Expr *, 16> Vars;
12478 Vars.reserve(NumVars);
12479 for (unsigned i = 0; i != NumVars; ++i)
12480 Vars.push_back(Record.readSubExpr());
12481 C->setVarRefs(Vars);
12482}
12483
Kelvin Libe286f52018-09-15 13:54:15 +000012484void OMPClauseReader::VisitOMPNumTeamsClause(OMPNumTeamsClause *C) {
12485 VisitOMPClauseWithPreInit(C);
12486 C->setNumTeams(Record.readSubExpr());
12487 C->setLParenLoc(Record.readSourceLocation());
12488}
12489
12490void OMPClauseReader::VisitOMPThreadLimitClause(OMPThreadLimitClause *C) {
12491 VisitOMPClauseWithPreInit(C);
12492 C->setThreadLimit(Record.readSubExpr());
12493 C->setLParenLoc(Record.readSourceLocation());
12494}
12495
12496void OMPClauseReader::VisitOMPPriorityClause(OMPPriorityClause *C) {
Alexey Bataev31ba4762019-10-16 18:09:37 +000012497 VisitOMPClauseWithPreInit(C);
Kelvin Libe286f52018-09-15 13:54:15 +000012498 C->setPriority(Record.readSubExpr());
12499 C->setLParenLoc(Record.readSourceLocation());
12500}
12501
12502void OMPClauseReader::VisitOMPGrainsizeClause(OMPGrainsizeClause *C) {
Alexey Bataevb9c55e22019-10-14 19:29:52 +000012503 VisitOMPClauseWithPreInit(C);
Kelvin Libe286f52018-09-15 13:54:15 +000012504 C->setGrainsize(Record.readSubExpr());
12505 C->setLParenLoc(Record.readSourceLocation());
12506}
12507
12508void OMPClauseReader::VisitOMPNumTasksClause(OMPNumTasksClause *C) {
Alexey Bataevd88c7de2019-10-14 20:44:34 +000012509 VisitOMPClauseWithPreInit(C);
Kelvin Libe286f52018-09-15 13:54:15 +000012510 C->setNumTasks(Record.readSubExpr());
12511 C->setLParenLoc(Record.readSourceLocation());
12512}
12513
12514void OMPClauseReader::VisitOMPHintClause(OMPHintClause *C) {
12515 C->setHint(Record.readSubExpr());
12516 C->setLParenLoc(Record.readSourceLocation());
12517}
12518
12519void OMPClauseReader::VisitOMPDistScheduleClause(OMPDistScheduleClause *C) {
12520 VisitOMPClauseWithPreInit(C);
12521 C->setDistScheduleKind(
12522 static_cast<OpenMPDistScheduleClauseKind>(Record.readInt()));
12523 C->setChunkSize(Record.readSubExpr());
12524 C->setLParenLoc(Record.readSourceLocation());
12525 C->setDistScheduleKindLoc(Record.readSourceLocation());
12526 C->setCommaLoc(Record.readSourceLocation());
12527}
12528
12529void OMPClauseReader::VisitOMPDefaultmapClause(OMPDefaultmapClause *C) {
12530 C->setDefaultmapKind(
12531 static_cast<OpenMPDefaultmapClauseKind>(Record.readInt()));
12532 C->setDefaultmapModifier(
12533 static_cast<OpenMPDefaultmapClauseModifier>(Record.readInt()));
12534 C->setLParenLoc(Record.readSourceLocation());
12535 C->setDefaultmapModifierLoc(Record.readSourceLocation());
12536 C->setDefaultmapKindLoc(Record.readSourceLocation());
12537}
12538
12539void OMPClauseReader::VisitOMPToClause(OMPToClause *C) {
12540 C->setLParenLoc(Record.readSourceLocation());
Michael Kruse01f670d2019-02-22 22:29:42 +000012541 C->setMapperQualifierLoc(Record.readNestedNameSpecifierLoc());
John McCall3ce3d232019-12-13 03:37:23 -050012542 C->setMapperIdInfo(Record.readDeclarationNameInfo());
Kelvin Libe286f52018-09-15 13:54:15 +000012543 auto NumVars = C->varlist_size();
12544 auto UniqueDecls = C->getUniqueDeclarationsNum();
12545 auto TotalLists = C->getTotalComponentListNum();
12546 auto TotalComponents = C->getTotalComponentsNum();
12547
12548 SmallVector<Expr *, 16> Vars;
12549 Vars.reserve(NumVars);
12550 for (unsigned i = 0; i != NumVars; ++i)
12551 Vars.push_back(Record.readSubExpr());
12552 C->setVarRefs(Vars);
12553
Michael Kruse01f670d2019-02-22 22:29:42 +000012554 SmallVector<Expr *, 16> UDMappers;
12555 UDMappers.reserve(NumVars);
12556 for (unsigned I = 0; I < NumVars; ++I)
12557 UDMappers.push_back(Record.readSubExpr());
12558 C->setUDMapperRefs(UDMappers);
12559
Kelvin Libe286f52018-09-15 13:54:15 +000012560 SmallVector<ValueDecl *, 16> Decls;
12561 Decls.reserve(UniqueDecls);
12562 for (unsigned i = 0; i < UniqueDecls; ++i)
12563 Decls.push_back(Record.readDeclAs<ValueDecl>());
12564 C->setUniqueDecls(Decls);
12565
12566 SmallVector<unsigned, 16> ListsPerDecl;
12567 ListsPerDecl.reserve(UniqueDecls);
12568 for (unsigned i = 0; i < UniqueDecls; ++i)
12569 ListsPerDecl.push_back(Record.readInt());
12570 C->setDeclNumLists(ListsPerDecl);
12571
12572 SmallVector<unsigned, 32> ListSizes;
12573 ListSizes.reserve(TotalLists);
12574 for (unsigned i = 0; i < TotalLists; ++i)
12575 ListSizes.push_back(Record.readInt());
12576 C->setComponentListSizes(ListSizes);
12577
12578 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12579 Components.reserve(TotalComponents);
12580 for (unsigned i = 0; i < TotalComponents; ++i) {
12581 Expr *AssociatedExpr = Record.readSubExpr();
12582 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12583 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12584 AssociatedExpr, AssociatedDecl));
12585 }
12586 C->setComponents(Components, ListSizes);
12587}
12588
12589void OMPClauseReader::VisitOMPFromClause(OMPFromClause *C) {
12590 C->setLParenLoc(Record.readSourceLocation());
Michael Kruse0336c752019-02-25 20:34:15 +000012591 C->setMapperQualifierLoc(Record.readNestedNameSpecifierLoc());
John McCall3ce3d232019-12-13 03:37:23 -050012592 C->setMapperIdInfo(Record.readDeclarationNameInfo());
Kelvin Libe286f52018-09-15 13:54:15 +000012593 auto NumVars = C->varlist_size();
12594 auto UniqueDecls = C->getUniqueDeclarationsNum();
12595 auto TotalLists = C->getTotalComponentListNum();
12596 auto TotalComponents = C->getTotalComponentsNum();
12597
12598 SmallVector<Expr *, 16> Vars;
12599 Vars.reserve(NumVars);
12600 for (unsigned i = 0; i != NumVars; ++i)
12601 Vars.push_back(Record.readSubExpr());
12602 C->setVarRefs(Vars);
12603
Michael Kruse0336c752019-02-25 20:34:15 +000012604 SmallVector<Expr *, 16> UDMappers;
12605 UDMappers.reserve(NumVars);
12606 for (unsigned I = 0; I < NumVars; ++I)
12607 UDMappers.push_back(Record.readSubExpr());
12608 C->setUDMapperRefs(UDMappers);
12609
Kelvin Libe286f52018-09-15 13:54:15 +000012610 SmallVector<ValueDecl *, 16> Decls;
12611 Decls.reserve(UniqueDecls);
12612 for (unsigned i = 0; i < UniqueDecls; ++i)
12613 Decls.push_back(Record.readDeclAs<ValueDecl>());
12614 C->setUniqueDecls(Decls);
12615
12616 SmallVector<unsigned, 16> ListsPerDecl;
12617 ListsPerDecl.reserve(UniqueDecls);
12618 for (unsigned i = 0; i < UniqueDecls; ++i)
12619 ListsPerDecl.push_back(Record.readInt());
12620 C->setDeclNumLists(ListsPerDecl);
12621
12622 SmallVector<unsigned, 32> ListSizes;
12623 ListSizes.reserve(TotalLists);
12624 for (unsigned i = 0; i < TotalLists; ++i)
12625 ListSizes.push_back(Record.readInt());
12626 C->setComponentListSizes(ListSizes);
12627
12628 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12629 Components.reserve(TotalComponents);
12630 for (unsigned i = 0; i < TotalComponents; ++i) {
12631 Expr *AssociatedExpr = Record.readSubExpr();
12632 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12633 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12634 AssociatedExpr, AssociatedDecl));
12635 }
12636 C->setComponents(Components, ListSizes);
12637}
12638
12639void OMPClauseReader::VisitOMPUseDevicePtrClause(OMPUseDevicePtrClause *C) {
12640 C->setLParenLoc(Record.readSourceLocation());
12641 auto NumVars = C->varlist_size();
12642 auto UniqueDecls = C->getUniqueDeclarationsNum();
12643 auto TotalLists = C->getTotalComponentListNum();
12644 auto TotalComponents = C->getTotalComponentsNum();
12645
12646 SmallVector<Expr *, 16> Vars;
12647 Vars.reserve(NumVars);
12648 for (unsigned i = 0; i != NumVars; ++i)
12649 Vars.push_back(Record.readSubExpr());
12650 C->setVarRefs(Vars);
12651 Vars.clear();
12652 for (unsigned i = 0; i != NumVars; ++i)
12653 Vars.push_back(Record.readSubExpr());
12654 C->setPrivateCopies(Vars);
12655 Vars.clear();
12656 for (unsigned i = 0; i != NumVars; ++i)
12657 Vars.push_back(Record.readSubExpr());
12658 C->setInits(Vars);
12659
12660 SmallVector<ValueDecl *, 16> Decls;
12661 Decls.reserve(UniqueDecls);
12662 for (unsigned i = 0; i < UniqueDecls; ++i)
12663 Decls.push_back(Record.readDeclAs<ValueDecl>());
12664 C->setUniqueDecls(Decls);
12665
12666 SmallVector<unsigned, 16> ListsPerDecl;
12667 ListsPerDecl.reserve(UniqueDecls);
12668 for (unsigned i = 0; i < UniqueDecls; ++i)
12669 ListsPerDecl.push_back(Record.readInt());
12670 C->setDeclNumLists(ListsPerDecl);
12671
12672 SmallVector<unsigned, 32> ListSizes;
12673 ListSizes.reserve(TotalLists);
12674 for (unsigned i = 0; i < TotalLists; ++i)
12675 ListSizes.push_back(Record.readInt());
12676 C->setComponentListSizes(ListSizes);
12677
12678 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12679 Components.reserve(TotalComponents);
12680 for (unsigned i = 0; i < TotalComponents; ++i) {
12681 Expr *AssociatedExpr = Record.readSubExpr();
12682 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12683 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12684 AssociatedExpr, AssociatedDecl));
12685 }
12686 C->setComponents(Components, ListSizes);
12687}
12688
12689void OMPClauseReader::VisitOMPIsDevicePtrClause(OMPIsDevicePtrClause *C) {
12690 C->setLParenLoc(Record.readSourceLocation());
12691 auto NumVars = C->varlist_size();
12692 auto UniqueDecls = C->getUniqueDeclarationsNum();
12693 auto TotalLists = C->getTotalComponentListNum();
12694 auto TotalComponents = C->getTotalComponentsNum();
12695
12696 SmallVector<Expr *, 16> Vars;
12697 Vars.reserve(NumVars);
12698 for (unsigned i = 0; i != NumVars; ++i)
12699 Vars.push_back(Record.readSubExpr());
12700 C->setVarRefs(Vars);
12701 Vars.clear();
12702
12703 SmallVector<ValueDecl *, 16> Decls;
12704 Decls.reserve(UniqueDecls);
12705 for (unsigned i = 0; i < UniqueDecls; ++i)
12706 Decls.push_back(Record.readDeclAs<ValueDecl>());
12707 C->setUniqueDecls(Decls);
12708
12709 SmallVector<unsigned, 16> ListsPerDecl;
12710 ListsPerDecl.reserve(UniqueDecls);
12711 for (unsigned i = 0; i < UniqueDecls; ++i)
12712 ListsPerDecl.push_back(Record.readInt());
12713 C->setDeclNumLists(ListsPerDecl);
12714
12715 SmallVector<unsigned, 32> ListSizes;
12716 ListSizes.reserve(TotalLists);
12717 for (unsigned i = 0; i < TotalLists; ++i)
12718 ListSizes.push_back(Record.readInt());
12719 C->setComponentListSizes(ListSizes);
12720
12721 SmallVector<OMPClauseMappableExprCommon::MappableComponent, 32> Components;
12722 Components.reserve(TotalComponents);
12723 for (unsigned i = 0; i < TotalComponents; ++i) {
12724 Expr *AssociatedExpr = Record.readSubExpr();
12725 auto *AssociatedDecl = Record.readDeclAs<ValueDecl>();
12726 Components.push_back(OMPClauseMappableExprCommon::MappableComponent(
12727 AssociatedExpr, AssociatedDecl));
12728 }
12729 C->setComponents(Components, ListSizes);
12730}
Alexey Bataevb6e70842019-12-16 15:54:17 -050012731
12732void OMPClauseReader::VisitOMPNontemporalClause(OMPNontemporalClause *C) {
12733 C->setLParenLoc(Record.readSourceLocation());
12734 unsigned NumVars = C->varlist_size();
12735 SmallVector<Expr *, 16> Vars;
12736 Vars.reserve(NumVars);
12737 for (unsigned i = 0; i != NumVars; ++i)
12738 Vars.push_back(Record.readSubExpr());
12739 C->setVarRefs(Vars);
Alexey Bataev0860db92019-12-19 10:01:10 -050012740 Vars.clear();
12741 Vars.reserve(NumVars);
12742 for (unsigned i = 0; i != NumVars; ++i)
12743 Vars.push_back(Record.readSubExpr());
12744 C->setPrivateRefs(Vars);
Alexey Bataevb6e70842019-12-16 15:54:17 -050012745}
Alexey Bataevcb8e6912020-01-31 16:09:26 -050012746
Alexey Bataev06dea732020-03-20 09:41:22 -040012747void OMPClauseReader::VisitOMPInclusiveClause(OMPInclusiveClause *C) {
12748 C->setLParenLoc(Record.readSourceLocation());
12749 unsigned NumVars = C->varlist_size();
12750 SmallVector<Expr *, 16> Vars;
12751 Vars.reserve(NumVars);
12752 for (unsigned i = 0; i != NumVars; ++i)
12753 Vars.push_back(Record.readSubExpr());
12754 C->setVarRefs(Vars);
12755}
12756
Alexey Bataev63828a32020-03-23 10:41:08 -040012757void OMPClauseReader::VisitOMPExclusiveClause(OMPExclusiveClause *C) {
12758 C->setLParenLoc(Record.readSourceLocation());
12759 unsigned NumVars = C->varlist_size();
12760 SmallVector<Expr *, 16> Vars;
12761 Vars.reserve(NumVars);
12762 for (unsigned i = 0; i != NumVars; ++i)
12763 Vars.push_back(Record.readSubExpr());
12764 C->setVarRefs(Vars);
12765}
12766
Alexey Bataevb5be1c52020-04-21 13:21:00 -040012767void OMPClauseReader::VisitOMPUsesAllocatorsClause(OMPUsesAllocatorsClause *C) {
12768 C->setLParenLoc(Record.readSourceLocation());
12769 unsigned NumOfAllocators = C->getNumberOfAllocators();
12770 SmallVector<OMPUsesAllocatorsClause::Data, 4> Data;
12771 Data.reserve(NumOfAllocators);
12772 for (unsigned I = 0; I != NumOfAllocators; ++I) {
12773 OMPUsesAllocatorsClause::Data &D = Data.emplace_back();
12774 D.Allocator = Record.readSubExpr();
12775 D.AllocatorTraits = Record.readSubExpr();
12776 D.LParenLoc = Record.readSourceLocation();
12777 D.RParenLoc = Record.readSourceLocation();
12778 }
12779 C->setAllocatorsData(Data);
12780}
12781
Alexey Bataevcb8e6912020-01-31 16:09:26 -050012782void OMPClauseReader::VisitOMPOrderClause(OMPOrderClause *C) {
12783 C->setKind(Record.readEnum<OpenMPOrderClauseKind>());
12784 C->setLParenLoc(Record.readSourceLocation());
12785 C->setKindKwLoc(Record.readSourceLocation());
12786}
Johannes Doerfert1228d422019-12-19 20:42:12 -060012787
Johannes Doerfert55eca282020-03-13 23:42:05 -050012788OMPTraitInfo *ASTRecordReader::readOMPTraitInfo() {
12789 OMPTraitInfo &TI = getContext().getNewOMPTraitInfo();
Johannes Doerfertb86bf832020-02-15 18:07:42 -060012790 TI.Sets.resize(readUInt32());
12791 for (auto &Set : TI.Sets) {
Johannes Doerfert1228d422019-12-19 20:42:12 -060012792 Set.Kind = readEnum<llvm::omp::TraitSet>();
12793 Set.Selectors.resize(readUInt32());
12794 for (auto &Selector : Set.Selectors) {
12795 Selector.Kind = readEnum<llvm::omp::TraitSelector>();
12796 Selector.ScoreOrCondition = nullptr;
12797 if (readBool())
12798 Selector.ScoreOrCondition = readExprRef();
12799 Selector.Properties.resize(readUInt32());
12800 for (auto &Property : Selector.Properties)
12801 Property.Kind = readEnum<llvm::omp::TraitProperty>();
12802 }
12803 }
Johannes Doerfert55eca282020-03-13 23:42:05 -050012804 return &TI;
Johannes Doerfert1228d422019-12-19 20:42:12 -060012805}