1 //===- ASTUnit.cpp - ASTUnit utility --------------------------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 // ASTUnit Implementation.
11 //===----------------------------------------------------------------------===//
13 #include "clang/Frontend/ASTUnit.h"
14 #include "clang/AST/ASTConsumer.h"
15 #include "clang/AST/ASTContext.h"
16 #include "clang/AST/CommentCommandTraits.h"
17 #include "clang/AST/Decl.h"
18 #include "clang/AST/DeclBase.h"
19 #include "clang/AST/DeclCXX.h"
20 #include "clang/AST/DeclGroup.h"
21 #include "clang/AST/DeclObjC.h"
22 #include "clang/AST/DeclTemplate.h"
23 #include "clang/AST/DeclarationName.h"
24 #include "clang/AST/ExternalASTSource.h"
25 #include "clang/AST/PrettyPrinter.h"
26 #include "clang/AST/Type.h"
27 #include "clang/AST/TypeOrdering.h"
28 #include "clang/Basic/Diagnostic.h"
29 #include "clang/Basic/FileManager.h"
30 #include "clang/Basic/IdentifierTable.h"
31 #include "clang/Basic/LLVM.h"
32 #include "clang/Basic/LangOptions.h"
33 #include "clang/Basic/LangStandard.h"
34 #include "clang/Basic/Module.h"
35 #include "clang/Basic/SourceLocation.h"
36 #include "clang/Basic/SourceManager.h"
37 #include "clang/Basic/TargetInfo.h"
38 #include "clang/Basic/TargetOptions.h"
39 #include "clang/Frontend/CompilerInstance.h"
40 #include "clang/Frontend/CompilerInvocation.h"
41 #include "clang/Frontend/FrontendAction.h"
42 #include "clang/Frontend/FrontendActions.h"
43 #include "clang/Frontend/FrontendDiagnostic.h"
44 #include "clang/Frontend/FrontendOptions.h"
45 #include "clang/Frontend/MultiplexConsumer.h"
46 #include "clang/Frontend/PrecompiledPreamble.h"
47 #include "clang/Frontend/Utils.h"
48 #include "clang/Lex/HeaderSearch.h"
49 #include "clang/Lex/HeaderSearchOptions.h"
50 #include "clang/Lex/Lexer.h"
51 #include "clang/Lex/PPCallbacks.h"
52 #include "clang/Lex/PreprocessingRecord.h"
53 #include "clang/Lex/Preprocessor.h"
54 #include "clang/Lex/PreprocessorOptions.h"
55 #include "clang/Lex/Token.h"
56 #include "clang/Sema/CodeCompleteConsumer.h"
57 #include "clang/Sema/CodeCompleteOptions.h"
58 #include "clang/Sema/Sema.h"
59 #include "clang/Sema/SemaCodeCompletion.h"
60 #include "clang/Serialization/ASTBitCodes.h"
61 #include "clang/Serialization/ASTReader.h"
62 #include "clang/Serialization/ASTWriter.h"
63 #include "clang/Serialization/ContinuousRangeMap.h"
64 #include "clang/Serialization/InMemoryModuleCache.h"
65 #include "clang/Serialization/ModuleFile.h"
66 #include "clang/Serialization/PCHContainerOperations.h"
67 #include "llvm/ADT/ArrayRef.h"
68 #include "llvm/ADT/DenseMap.h"
69 #include "llvm/ADT/IntrusiveRefCntPtr.h"
70 #include "llvm/ADT/STLExtras.h"
71 #include "llvm/ADT/ScopeExit.h"
72 #include "llvm/ADT/SmallVector.h"
73 #include "llvm/ADT/StringMap.h"
74 #include "llvm/ADT/StringRef.h"
75 #include "llvm/ADT/StringSet.h"
76 #include "llvm/ADT/Twine.h"
77 #include "llvm/ADT/iterator_range.h"
78 #include "llvm/Bitstream/BitstreamWriter.h"
79 #include "llvm/Support/Allocator.h"
80 #include "llvm/Support/Casting.h"
81 #include "llvm/Support/CrashRecoveryContext.h"
82 #include "llvm/Support/DJB.h"
83 #include "llvm/Support/ErrorHandling.h"
84 #include "llvm/Support/ErrorOr.h"
85 #include "llvm/Support/FileSystem.h"
86 #include "llvm/Support/MemoryBuffer.h"
87 #include "llvm/Support/SaveAndRestore.h"
88 #include "llvm/Support/Timer.h"
89 #include "llvm/Support/VirtualFileSystem.h"
90 #include "llvm/Support/raw_ostream.h"
105 using namespace clang
;
107 using llvm::TimeRecord
;
117 explicit SimpleTimer(bool WantTiming
) : WantTiming(WantTiming
) {
119 Start
= TimeRecord::getCurrentTime();
124 TimeRecord Elapsed
= TimeRecord::getCurrentTime();
126 llvm::errs() << Output
<< ':';
127 Elapsed
.print(Elapsed
, llvm::errs());
128 llvm::errs() << '\n';
132 void setOutput(const Twine
&Output
) {
134 this->Output
= Output
.str();
141 static std::unique_ptr
<T
> valueOrNull(llvm::ErrorOr
<std::unique_ptr
<T
>> Val
) {
144 return std::move(*Val
);
148 static bool moveOnNoError(llvm::ErrorOr
<T
> Val
, T
&Output
) {
151 Output
= std::move(*Val
);
155 /// Get a source buffer for \p MainFilePath, handling all file-to-file
156 /// and file-to-buffer remappings inside \p Invocation.
157 static std::unique_ptr
<llvm::MemoryBuffer
>
158 getBufferForFileHandlingRemapping(const CompilerInvocation
&Invocation
,
159 llvm::vfs::FileSystem
*VFS
,
160 StringRef FilePath
, bool isVolatile
) {
161 const auto &PreprocessorOpts
= Invocation
.getPreprocessorOpts();
163 // Try to determine if the main file has been remapped, either from the
164 // command line (to another file) or directly through the compiler
165 // invocation (to a memory buffer).
166 llvm::MemoryBuffer
*Buffer
= nullptr;
167 std::unique_ptr
<llvm::MemoryBuffer
> BufferOwner
;
168 auto FileStatus
= VFS
->status(FilePath
);
170 llvm::sys::fs::UniqueID MainFileID
= FileStatus
->getUniqueID();
172 // Check whether there is a file-file remapping of the main file
173 for (const auto &RF
: PreprocessorOpts
.RemappedFiles
) {
174 std::string
MPath(RF
.first
);
175 auto MPathStatus
= VFS
->status(MPath
);
177 llvm::sys::fs::UniqueID MID
= MPathStatus
->getUniqueID();
178 if (MainFileID
== MID
) {
179 // We found a remapping. Try to load the resulting, remapped source.
180 BufferOwner
= valueOrNull(VFS
->getBufferForFile(RF
.second
, -1, true, isVolatile
));
187 // Check whether there is a file-buffer remapping. It supercedes the
188 // file-file remapping.
189 for (const auto &RB
: PreprocessorOpts
.RemappedFileBuffers
) {
190 std::string
MPath(RB
.first
);
191 auto MPathStatus
= VFS
->status(MPath
);
193 llvm::sys::fs::UniqueID MID
= MPathStatus
->getUniqueID();
194 if (MainFileID
== MID
) {
195 // We found a remapping.
197 Buffer
= const_cast<llvm::MemoryBuffer
*>(RB
.second
);
203 // If the main source file was not remapped, load it now.
204 if (!Buffer
&& !BufferOwner
) {
205 BufferOwner
= valueOrNull(VFS
->getBufferForFile(FilePath
, -1, true, isVolatile
));
214 return llvm::MemoryBuffer::getMemBufferCopy(Buffer
->getBuffer(), FilePath
);
217 struct ASTUnit::ASTWriterData
{
218 SmallString
<128> Buffer
;
219 llvm::BitstreamWriter Stream
;
222 ASTWriterData(InMemoryModuleCache
&ModuleCache
)
223 : Stream(Buffer
), Writer(Stream
, Buffer
, ModuleCache
, {}) {}
226 void ASTUnit::clearFileLevelDecls() {
230 /// After failing to build a precompiled preamble (due to
231 /// errors in the source that occurs in the preamble), the number of
232 /// reparses during which we'll skip even trying to precompile the
234 const unsigned DefaultPreambleRebuildInterval
= 5;
236 /// Tracks the number of ASTUnit objects that are currently active.
238 /// Used for debugging purposes only.
239 static std::atomic
<unsigned> ActiveASTUnitObjects
;
241 ASTUnit::ASTUnit(bool _MainFileIsAST
)
242 : MainFileIsAST(_MainFileIsAST
), WantTiming(getenv("LIBCLANG_TIMING")),
243 ShouldCacheCodeCompletionResults(false),
244 IncludeBriefCommentsInCodeCompletion(false), UserFilesAreVolatile(false),
245 UnsafeToFree(false) {
246 if (getenv("LIBCLANG_OBJTRACKING"))
247 fprintf(stderr
, "+++ %u translation units\n", ++ActiveASTUnitObjects
);
250 ASTUnit::~ASTUnit() {
251 // If we loaded from an AST file, balance out the BeginSourceFile call.
252 if (MainFileIsAST
&& getDiagnostics().getClient()) {
253 getDiagnostics().getClient()->EndSourceFile();
256 clearFileLevelDecls();
258 // Free the buffers associated with remapped files. We are required to
259 // perform this operation here because we explicitly request that the
260 // compiler instance *not* free these buffers for each invocation of the
262 if (Invocation
&& OwnsRemappedFileBuffers
) {
263 PreprocessorOptions
&PPOpts
= Invocation
->getPreprocessorOpts();
264 for (const auto &RB
: PPOpts
.RemappedFileBuffers
)
268 ClearCachedCompletionResults();
270 if (getenv("LIBCLANG_OBJTRACKING"))
271 fprintf(stderr
, "--- %u translation units\n", --ActiveASTUnitObjects
);
274 void ASTUnit::setPreprocessor(std::shared_ptr
<Preprocessor
> PP
) {
275 this->PP
= std::move(PP
);
278 void ASTUnit::enableSourceFileDiagnostics() {
279 assert(getDiagnostics().getClient() && Ctx
&&
280 "Bad context for source file");
281 getDiagnostics().getClient()->BeginSourceFile(Ctx
->getLangOpts(), PP
.get());
284 /// Determine the set of code-completion contexts in which this
285 /// declaration should be shown.
286 static uint64_t getDeclShowContexts(const NamedDecl
*ND
,
287 const LangOptions
&LangOpts
,
288 bool &IsNestedNameSpecifier
) {
289 IsNestedNameSpecifier
= false;
291 if (isa
<UsingShadowDecl
>(ND
))
292 ND
= ND
->getUnderlyingDecl();
296 uint64_t Contexts
= 0;
297 if (isa
<TypeDecl
>(ND
) || isa
<ObjCInterfaceDecl
>(ND
) ||
298 isa
<ClassTemplateDecl
>(ND
) || isa
<TemplateTemplateParmDecl
>(ND
) ||
299 isa
<TypeAliasTemplateDecl
>(ND
)) {
300 // Types can appear in these contexts.
301 if (LangOpts
.CPlusPlus
|| !isa
<TagDecl
>(ND
))
302 Contexts
|= (1LL << CodeCompletionContext::CCC_TopLevel
)
303 | (1LL << CodeCompletionContext::CCC_ObjCIvarList
)
304 | (1LL << CodeCompletionContext::CCC_ClassStructUnion
)
305 | (1LL << CodeCompletionContext::CCC_Statement
)
306 | (1LL << CodeCompletionContext::CCC_Type
)
307 | (1LL << CodeCompletionContext::CCC_ParenthesizedExpression
);
309 // In C++, types can appear in expressions contexts (for functional casts).
310 if (LangOpts
.CPlusPlus
)
311 Contexts
|= (1LL << CodeCompletionContext::CCC_Expression
);
313 // In Objective-C, message sends can send interfaces. In Objective-C++,
314 // all types are available due to functional casts.
315 if (LangOpts
.CPlusPlus
|| isa
<ObjCInterfaceDecl
>(ND
))
316 Contexts
|= (1LL << CodeCompletionContext::CCC_ObjCMessageReceiver
);
318 // In Objective-C, you can only be a subclass of another Objective-C class
319 if (const auto *ID
= dyn_cast
<ObjCInterfaceDecl
>(ND
)) {
320 // Objective-C interfaces can be used in a class property expression.
321 if (ID
->getDefinition())
322 Contexts
|= (1LL << CodeCompletionContext::CCC_Expression
);
323 Contexts
|= (1LL << CodeCompletionContext::CCC_ObjCInterfaceName
);
324 Contexts
|= (1LL << CodeCompletionContext::CCC_ObjCClassForwardDecl
);
327 // Deal with tag names.
328 if (isa
<EnumDecl
>(ND
)) {
329 Contexts
|= (1LL << CodeCompletionContext::CCC_EnumTag
);
331 // Part of the nested-name-specifier in C++0x.
332 if (LangOpts
.CPlusPlus11
)
333 IsNestedNameSpecifier
= true;
334 } else if (const auto *Record
= dyn_cast
<RecordDecl
>(ND
)) {
335 if (Record
->isUnion())
336 Contexts
|= (1LL << CodeCompletionContext::CCC_UnionTag
);
338 Contexts
|= (1LL << CodeCompletionContext::CCC_ClassOrStructTag
);
340 if (LangOpts
.CPlusPlus
)
341 IsNestedNameSpecifier
= true;
342 } else if (isa
<ClassTemplateDecl
>(ND
))
343 IsNestedNameSpecifier
= true;
344 } else if (isa
<ValueDecl
>(ND
) || isa
<FunctionTemplateDecl
>(ND
)) {
345 // Values can appear in these contexts.
346 Contexts
= (1LL << CodeCompletionContext::CCC_Statement
)
347 | (1LL << CodeCompletionContext::CCC_Expression
)
348 | (1LL << CodeCompletionContext::CCC_ParenthesizedExpression
)
349 | (1LL << CodeCompletionContext::CCC_ObjCMessageReceiver
);
350 } else if (isa
<ObjCProtocolDecl
>(ND
)) {
351 Contexts
= (1LL << CodeCompletionContext::CCC_ObjCProtocolName
);
352 } else if (isa
<ObjCCategoryDecl
>(ND
)) {
353 Contexts
= (1LL << CodeCompletionContext::CCC_ObjCCategoryName
);
354 } else if (isa
<NamespaceDecl
>(ND
) || isa
<NamespaceAliasDecl
>(ND
)) {
355 Contexts
= (1LL << CodeCompletionContext::CCC_Namespace
);
357 // Part of the nested-name-specifier.
358 IsNestedNameSpecifier
= true;
364 void ASTUnit::CacheCodeCompletionResults() {
368 SimpleTimer
Timer(WantTiming
);
369 Timer
.setOutput("Cache global code completions for " + getMainFileName());
371 // Clear out the previous results.
372 ClearCachedCompletionResults();
374 // Gather the set of global code completions.
375 using Result
= CodeCompletionResult
;
376 SmallVector
<Result
, 8> Results
;
377 CachedCompletionAllocator
= std::make_shared
<GlobalCodeCompletionAllocator
>();
378 CodeCompletionTUInfo
CCTUInfo(CachedCompletionAllocator
);
379 TheSema
->CodeCompletion().GatherGlobalCodeCompletions(
380 *CachedCompletionAllocator
, CCTUInfo
, Results
);
382 // Translate global code completions into cached completions.
383 llvm::DenseMap
<CanQualType
, unsigned> CompletionTypes
;
384 CodeCompletionContext
CCContext(CodeCompletionContext::CCC_TopLevel
);
386 for (auto &R
: Results
) {
388 case Result::RK_Declaration
: {
389 bool IsNestedNameSpecifier
= false;
390 CachedCodeCompletionResult CachedResult
;
391 CachedResult
.Completion
= R
.CreateCodeCompletionString(
392 *TheSema
, CCContext
, *CachedCompletionAllocator
, CCTUInfo
,
393 IncludeBriefCommentsInCodeCompletion
);
394 CachedResult
.ShowInContexts
= getDeclShowContexts(
395 R
.Declaration
, Ctx
->getLangOpts(), IsNestedNameSpecifier
);
396 CachedResult
.Priority
= R
.Priority
;
397 CachedResult
.Kind
= R
.CursorKind
;
398 CachedResult
.Availability
= R
.Availability
;
400 // Keep track of the type of this completion in an ASTContext-agnostic
402 QualType UsageType
= getDeclUsageType(*Ctx
, R
.Declaration
);
403 if (UsageType
.isNull()) {
404 CachedResult
.TypeClass
= STC_Void
;
405 CachedResult
.Type
= 0;
407 CanQualType CanUsageType
408 = Ctx
->getCanonicalType(UsageType
.getUnqualifiedType());
409 CachedResult
.TypeClass
= getSimplifiedTypeClass(CanUsageType
);
411 // Determine whether we have already seen this type. If so, we save
412 // ourselves the work of formatting the type string by using the
413 // temporary, CanQualType-based hash table to find the associated value.
414 unsigned &TypeValue
= CompletionTypes
[CanUsageType
];
415 if (TypeValue
== 0) {
416 TypeValue
= CompletionTypes
.size();
417 CachedCompletionTypes
[QualType(CanUsageType
).getAsString()]
421 CachedResult
.Type
= TypeValue
;
424 CachedCompletionResults
.push_back(CachedResult
);
426 /// Handle nested-name-specifiers in C++.
427 if (TheSema
->Context
.getLangOpts().CPlusPlus
&& IsNestedNameSpecifier
&&
428 !R
.StartsNestedNameSpecifier
) {
429 // The contexts in which a nested-name-specifier can appear in C++.
431 = (1LL << CodeCompletionContext::CCC_TopLevel
)
432 | (1LL << CodeCompletionContext::CCC_ObjCIvarList
)
433 | (1LL << CodeCompletionContext::CCC_ClassStructUnion
)
434 | (1LL << CodeCompletionContext::CCC_Statement
)
435 | (1LL << CodeCompletionContext::CCC_Expression
)
436 | (1LL << CodeCompletionContext::CCC_ObjCMessageReceiver
)
437 | (1LL << CodeCompletionContext::CCC_EnumTag
)
438 | (1LL << CodeCompletionContext::CCC_UnionTag
)
439 | (1LL << CodeCompletionContext::CCC_ClassOrStructTag
)
440 | (1LL << CodeCompletionContext::CCC_Type
)
441 | (1LL << CodeCompletionContext::CCC_SymbolOrNewName
)
442 | (1LL << CodeCompletionContext::CCC_ParenthesizedExpression
);
444 if (isa
<NamespaceDecl
>(R
.Declaration
) ||
445 isa
<NamespaceAliasDecl
>(R
.Declaration
))
446 NNSContexts
|= (1LL << CodeCompletionContext::CCC_Namespace
);
448 if (uint64_t RemainingContexts
449 = NNSContexts
& ~CachedResult
.ShowInContexts
) {
450 // If there any contexts where this completion can be a
451 // nested-name-specifier but isn't already an option, create a
452 // nested-name-specifier completion.
453 R
.StartsNestedNameSpecifier
= true;
454 CachedResult
.Completion
= R
.CreateCodeCompletionString(
455 *TheSema
, CCContext
, *CachedCompletionAllocator
, CCTUInfo
,
456 IncludeBriefCommentsInCodeCompletion
);
457 CachedResult
.ShowInContexts
= RemainingContexts
;
458 CachedResult
.Priority
= CCP_NestedNameSpecifier
;
459 CachedResult
.TypeClass
= STC_Void
;
460 CachedResult
.Type
= 0;
461 CachedCompletionResults
.push_back(CachedResult
);
467 case Result::RK_Keyword
:
468 case Result::RK_Pattern
:
469 // Ignore keywords and patterns; we don't care, since they are so
470 // easily regenerated.
473 case Result::RK_Macro
: {
474 CachedCodeCompletionResult CachedResult
;
475 CachedResult
.Completion
= R
.CreateCodeCompletionString(
476 *TheSema
, CCContext
, *CachedCompletionAllocator
, CCTUInfo
,
477 IncludeBriefCommentsInCodeCompletion
);
478 CachedResult
.ShowInContexts
479 = (1LL << CodeCompletionContext::CCC_TopLevel
)
480 | (1LL << CodeCompletionContext::CCC_ObjCInterface
)
481 | (1LL << CodeCompletionContext::CCC_ObjCImplementation
)
482 | (1LL << CodeCompletionContext::CCC_ObjCIvarList
)
483 | (1LL << CodeCompletionContext::CCC_ClassStructUnion
)
484 | (1LL << CodeCompletionContext::CCC_Statement
)
485 | (1LL << CodeCompletionContext::CCC_Expression
)
486 | (1LL << CodeCompletionContext::CCC_ObjCMessageReceiver
)
487 | (1LL << CodeCompletionContext::CCC_MacroNameUse
)
488 | (1LL << CodeCompletionContext::CCC_PreprocessorExpression
)
489 | (1LL << CodeCompletionContext::CCC_ParenthesizedExpression
)
490 | (1LL << CodeCompletionContext::CCC_OtherWithMacros
);
492 CachedResult
.Priority
= R
.Priority
;
493 CachedResult
.Kind
= R
.CursorKind
;
494 CachedResult
.Availability
= R
.Availability
;
495 CachedResult
.TypeClass
= STC_Void
;
496 CachedResult
.Type
= 0;
497 CachedCompletionResults
.push_back(CachedResult
);
503 // Save the current top-level hash value.
504 CompletionCacheTopLevelHashValue
= CurrentTopLevelHashValue
;
507 void ASTUnit::ClearCachedCompletionResults() {
508 CachedCompletionResults
.clear();
509 CachedCompletionTypes
.clear();
510 CachedCompletionAllocator
= nullptr;
515 /// Gathers information from ASTReader that will be used to initialize
517 class ASTInfoCollector
: public ASTReaderListener
{
520 HeaderSearchOptions
&HSOpts
;
521 PreprocessorOptions
&PPOpts
;
522 LangOptions
&LangOpt
;
523 std::shared_ptr
<TargetOptions
> &TargetOpts
;
524 IntrusiveRefCntPtr
<TargetInfo
> &Target
;
526 bool InitializedLanguage
= false;
527 bool InitializedHeaderSearchPaths
= false;
530 ASTInfoCollector(Preprocessor
&PP
, ASTContext
*Context
,
531 HeaderSearchOptions
&HSOpts
, PreprocessorOptions
&PPOpts
,
532 LangOptions
&LangOpt
,
533 std::shared_ptr
<TargetOptions
> &TargetOpts
,
534 IntrusiveRefCntPtr
<TargetInfo
> &Target
, unsigned &Counter
)
535 : PP(PP
), Context(Context
), HSOpts(HSOpts
), PPOpts(PPOpts
),
536 LangOpt(LangOpt
), TargetOpts(TargetOpts
), Target(Target
),
539 bool ReadLanguageOptions(const LangOptions
&LangOpts
,
540 StringRef ModuleFilename
, bool Complain
,
541 bool AllowCompatibleDifferences
) override
{
542 if (InitializedLanguage
)
545 // FIXME: We did similar things in ReadHeaderSearchOptions too. But such
546 // style is not scaling. Probably we need to invite some mechanism to
547 // handle such patterns generally.
548 auto PICLevel
= LangOpt
.PICLevel
;
549 auto PIE
= LangOpt
.PIE
;
553 LangOpt
.PICLevel
= PICLevel
;
556 InitializedLanguage
= true;
562 bool ReadHeaderSearchOptions(const HeaderSearchOptions
&HSOpts
,
563 StringRef ModuleFilename
,
564 StringRef SpecificModuleCachePath
,
565 bool Complain
) override
{
566 // llvm::SaveAndRestore doesn't support bit field.
567 auto ForceCheckCXX20ModulesInputFiles
=
568 this->HSOpts
.ForceCheckCXX20ModulesInputFiles
;
569 llvm::SaveAndRestore
X(this->HSOpts
.UserEntries
);
570 llvm::SaveAndRestore
Y(this->HSOpts
.SystemHeaderPrefixes
);
571 llvm::SaveAndRestore
Z(this->HSOpts
.VFSOverlayFiles
);
573 this->HSOpts
= HSOpts
;
574 this->HSOpts
.ForceCheckCXX20ModulesInputFiles
=
575 ForceCheckCXX20ModulesInputFiles
;
580 bool ReadHeaderSearchPaths(const HeaderSearchOptions
&HSOpts
,
581 bool Complain
) override
{
582 if (InitializedHeaderSearchPaths
)
585 this->HSOpts
.UserEntries
= HSOpts
.UserEntries
;
586 this->HSOpts
.SystemHeaderPrefixes
= HSOpts
.SystemHeaderPrefixes
;
587 this->HSOpts
.VFSOverlayFiles
= HSOpts
.VFSOverlayFiles
;
589 // Initialize the FileManager. We can't do this in update(), since that
590 // performs the initialization too late (once both target and language
591 // options are read).
592 PP
.getFileManager().setVirtualFileSystem(createVFSFromOverlayFiles(
593 HSOpts
.VFSOverlayFiles
, PP
.getDiagnostics(),
594 PP
.getFileManager().getVirtualFileSystemPtr()));
596 InitializedHeaderSearchPaths
= true;
601 bool ReadPreprocessorOptions(const PreprocessorOptions
&PPOpts
,
602 StringRef ModuleFilename
, bool ReadMacros
,
604 std::string
&SuggestedPredefines
) override
{
605 this->PPOpts
= PPOpts
;
609 bool ReadTargetOptions(const TargetOptions
&TargetOpts
,
610 StringRef ModuleFilename
, bool Complain
,
611 bool AllowCompatibleDifferences
) override
{
612 // If we've already initialized the target, don't do it again.
616 this->TargetOpts
= std::make_shared
<TargetOptions
>(TargetOpts
);
618 TargetInfo::CreateTargetInfo(PP
.getDiagnostics(), this->TargetOpts
);
624 void ReadCounter(const serialization::ModuleFile
&M
,
625 unsigned Value
) override
{
631 if (!Target
|| !InitializedLanguage
)
634 // Inform the target of the language options.
636 // FIXME: We shouldn't need to do this, the target should be immutable once
637 // created. This complexity should be lifted elsewhere.
638 Target
->adjust(PP
.getDiagnostics(), LangOpt
);
640 // Initialize the preprocessor.
641 PP
.Initialize(*Target
);
646 // Initialize the ASTContext
647 Context
->InitBuiltinTypes(*Target
);
649 // Adjust printing policy based on language options.
650 Context
->setPrintingPolicy(PrintingPolicy(LangOpt
));
652 // We didn't have access to the comment options when the ASTContext was
653 // constructed, so register them now.
654 Context
->getCommentCommandTraits().registerCommentOptions(
655 LangOpt
.CommentOpts
);
659 /// Diagnostic consumer that saves each diagnostic it is given.
660 class FilterAndStoreDiagnosticConsumer
: public DiagnosticConsumer
{
661 SmallVectorImpl
<StoredDiagnostic
> *StoredDiags
;
662 SmallVectorImpl
<ASTUnit::StandaloneDiagnostic
> *StandaloneDiags
;
663 bool CaptureNonErrorsFromIncludes
= true;
664 const LangOptions
*LangOpts
= nullptr;
665 SourceManager
*SourceMgr
= nullptr;
668 FilterAndStoreDiagnosticConsumer(
669 SmallVectorImpl
<StoredDiagnostic
> *StoredDiags
,
670 SmallVectorImpl
<ASTUnit::StandaloneDiagnostic
> *StandaloneDiags
,
671 bool CaptureNonErrorsFromIncludes
)
672 : StoredDiags(StoredDiags
), StandaloneDiags(StandaloneDiags
),
673 CaptureNonErrorsFromIncludes(CaptureNonErrorsFromIncludes
) {
674 assert((StoredDiags
|| StandaloneDiags
) &&
675 "No output collections were passed to StoredDiagnosticConsumer.");
678 void BeginSourceFile(const LangOptions
&LangOpts
,
679 const Preprocessor
*PP
= nullptr) override
{
680 this->LangOpts
= &LangOpts
;
682 SourceMgr
= &PP
->getSourceManager();
685 void HandleDiagnostic(DiagnosticsEngine::Level Level
,
686 const Diagnostic
&Info
) override
;
689 /// RAII object that optionally captures and filters diagnostics, if
690 /// there is no diagnostic client to capture them already.
691 class CaptureDroppedDiagnostics
{
692 DiagnosticsEngine
&Diags
;
693 FilterAndStoreDiagnosticConsumer Client
;
694 DiagnosticConsumer
*PreviousClient
= nullptr;
695 std::unique_ptr
<DiagnosticConsumer
> OwningPreviousClient
;
698 CaptureDroppedDiagnostics(
699 CaptureDiagsKind CaptureDiagnostics
, DiagnosticsEngine
&Diags
,
700 SmallVectorImpl
<StoredDiagnostic
> *StoredDiags
,
701 SmallVectorImpl
<ASTUnit::StandaloneDiagnostic
> *StandaloneDiags
)
703 Client(StoredDiags
, StandaloneDiags
,
704 CaptureDiagnostics
!=
705 CaptureDiagsKind::AllWithoutNonErrorsFromIncludes
) {
706 if (CaptureDiagnostics
!= CaptureDiagsKind::None
||
707 Diags
.getClient() == nullptr) {
708 OwningPreviousClient
= Diags
.takeClient();
709 PreviousClient
= Diags
.getClient();
710 Diags
.setClient(&Client
, false);
714 ~CaptureDroppedDiagnostics() {
715 if (Diags
.getClient() == &Client
)
716 Diags
.setClient(PreviousClient
, !!OwningPreviousClient
.release());
722 static ASTUnit::StandaloneDiagnostic
723 makeStandaloneDiagnostic(const LangOptions
&LangOpts
,
724 const StoredDiagnostic
&InDiag
);
726 static bool isInMainFile(const clang::Diagnostic
&D
) {
727 if (!D
.hasSourceManager() || !D
.getLocation().isValid())
730 auto &M
= D
.getSourceManager();
731 return M
.isWrittenInMainFile(M
.getExpansionLoc(D
.getLocation()));
734 void FilterAndStoreDiagnosticConsumer::HandleDiagnostic(
735 DiagnosticsEngine::Level Level
, const Diagnostic
&Info
) {
736 // Default implementation (Warnings/errors count).
737 DiagnosticConsumer::HandleDiagnostic(Level
, Info
);
739 // Only record the diagnostic if it's part of the source manager we know
740 // about. This effectively drops diagnostics from modules we're building.
741 // FIXME: In the long run, ee don't want to drop source managers from modules.
742 if (!Info
.hasSourceManager() || &Info
.getSourceManager() == SourceMgr
) {
743 if (!CaptureNonErrorsFromIncludes
&& Level
<= DiagnosticsEngine::Warning
&&
744 !isInMainFile(Info
)) {
748 StoredDiagnostic
*ResultDiag
= nullptr;
750 StoredDiags
->emplace_back(Level
, Info
);
751 ResultDiag
= &StoredDiags
->back();
754 if (StandaloneDiags
) {
755 std::optional
<StoredDiagnostic
> StoredDiag
;
757 StoredDiag
.emplace(Level
, Info
);
758 ResultDiag
= &*StoredDiag
;
760 StandaloneDiags
->push_back(
761 makeStandaloneDiagnostic(*LangOpts
, *ResultDiag
));
766 IntrusiveRefCntPtr
<ASTReader
> ASTUnit::getASTReader() const {
770 ASTMutationListener
*ASTUnit::getASTMutationListener() {
772 return &WriterData
->Writer
;
776 ASTDeserializationListener
*ASTUnit::getDeserializationListener() {
778 return &WriterData
->Writer
;
782 std::unique_ptr
<llvm::MemoryBuffer
>
783 ASTUnit::getBufferForFile(StringRef Filename
, std::string
*ErrorStr
) {
785 auto Buffer
= FileMgr
->getBufferForFile(Filename
, UserFilesAreVolatile
);
787 return std::move(*Buffer
);
789 *ErrorStr
= Buffer
.getError().message();
793 /// Configure the diagnostics object for use with ASTUnit.
794 void ASTUnit::ConfigureDiags(IntrusiveRefCntPtr
<DiagnosticsEngine
> Diags
,
796 CaptureDiagsKind CaptureDiagnostics
) {
797 assert(Diags
.get() && "no DiagnosticsEngine was provided");
798 if (CaptureDiagnostics
!= CaptureDiagsKind::None
)
799 Diags
->setClient(new FilterAndStoreDiagnosticConsumer(
800 &AST
.StoredDiagnostics
, nullptr,
801 CaptureDiagnostics
!= CaptureDiagsKind::AllWithoutNonErrorsFromIncludes
));
804 std::unique_ptr
<ASTUnit
> ASTUnit::LoadFromASTFile(
805 StringRef Filename
, const PCHContainerReader
&PCHContainerRdr
,
806 WhatToLoad ToLoad
, IntrusiveRefCntPtr
<DiagnosticsEngine
> Diags
,
807 const FileSystemOptions
&FileSystemOpts
,
808 std::shared_ptr
<HeaderSearchOptions
> HSOpts
,
809 std::shared_ptr
<LangOptions
> LangOpts
, bool OnlyLocalDecls
,
810 CaptureDiagsKind CaptureDiagnostics
, bool AllowASTWithCompilerErrors
,
811 bool UserFilesAreVolatile
, IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
) {
812 std::unique_ptr
<ASTUnit
> AST(new ASTUnit(true));
814 // Recover resources if we crash before exiting this method.
815 llvm::CrashRecoveryContextCleanupRegistrar
<ASTUnit
>
816 ASTUnitCleanup(AST
.get());
817 llvm::CrashRecoveryContextCleanupRegistrar
<DiagnosticsEngine
,
818 llvm::CrashRecoveryContextReleaseRefCleanup
<DiagnosticsEngine
>>
819 DiagCleanup(Diags
.get());
821 ConfigureDiags(Diags
, *AST
, CaptureDiagnostics
);
823 AST
->LangOpts
= LangOpts
? LangOpts
: std::make_shared
<LangOptions
>();
824 AST
->OnlyLocalDecls
= OnlyLocalDecls
;
825 AST
->CaptureDiagnostics
= CaptureDiagnostics
;
826 AST
->Diagnostics
= Diags
;
827 AST
->FileMgr
= new FileManager(FileSystemOpts
, VFS
);
828 AST
->UserFilesAreVolatile
= UserFilesAreVolatile
;
829 AST
->SourceMgr
= new SourceManager(AST
->getDiagnostics(),
830 AST
->getFileManager(),
831 UserFilesAreVolatile
);
832 AST
->ModuleCache
= new InMemoryModuleCache
;
833 AST
->HSOpts
= HSOpts
? HSOpts
: std::make_shared
<HeaderSearchOptions
>();
834 AST
->HSOpts
->ModuleFormat
= std::string(PCHContainerRdr
.getFormats().front());
835 AST
->HeaderInfo
.reset(new HeaderSearch(AST
->HSOpts
,
836 AST
->getSourceManager(),
837 AST
->getDiagnostics(),
839 /*Target=*/nullptr));
840 AST
->PPOpts
= std::make_shared
<PreprocessorOptions
>();
842 // Gather Info for preprocessor construction later on.
844 HeaderSearch
&HeaderInfo
= *AST
->HeaderInfo
;
846 AST
->PP
= std::make_shared
<Preprocessor
>(
847 AST
->PPOpts
, AST
->getDiagnostics(), *AST
->LangOpts
,
848 AST
->getSourceManager(), HeaderInfo
, AST
->ModuleLoader
,
849 /*IILookup=*/nullptr,
850 /*OwnsHeaderSearch=*/false);
851 Preprocessor
&PP
= *AST
->PP
;
853 if (ToLoad
>= LoadASTOnly
)
854 AST
->Ctx
= new ASTContext(*AST
->LangOpts
, AST
->getSourceManager(),
855 PP
.getIdentifierTable(), PP
.getSelectorTable(),
857 AST
->getTranslationUnitKind());
859 DisableValidationForModuleKind disableValid
=
860 DisableValidationForModuleKind::None
;
861 if (::getenv("LIBCLANG_DISABLE_PCH_VALIDATION"))
862 disableValid
= DisableValidationForModuleKind::All
;
863 AST
->Reader
= new ASTReader(
864 PP
, *AST
->ModuleCache
, AST
->Ctx
.get(), PCHContainerRdr
, {},
866 /*DisableValidationKind=*/disableValid
, AllowASTWithCompilerErrors
);
868 unsigned Counter
= 0;
869 AST
->Reader
->setListener(std::make_unique
<ASTInfoCollector
>(
870 *AST
->PP
, AST
->Ctx
.get(), *AST
->HSOpts
, *AST
->PPOpts
, *AST
->LangOpts
,
871 AST
->TargetOpts
, AST
->Target
, Counter
));
873 // Attach the AST reader to the AST context as an external AST
874 // source, so that declarations will be deserialized from the
875 // AST file as needed.
876 // We need the external source to be set up before we read the AST, because
877 // eagerly-deserialized declarations may use it.
879 AST
->Ctx
->setExternalSource(AST
->Reader
);
881 switch (AST
->Reader
->ReadAST(Filename
, serialization::MK_MainFile
,
882 SourceLocation(), ASTReader::ARR_None
)) {
883 case ASTReader::Success
:
886 case ASTReader::Failure
:
887 case ASTReader::Missing
:
888 case ASTReader::OutOfDate
:
889 case ASTReader::VersionMismatch
:
890 case ASTReader::ConfigurationMismatch
:
891 case ASTReader::HadErrors
:
892 AST
->getDiagnostics().Report(diag::err_fe_unable_to_load_pch
);
896 AST
->OriginalSourceFile
= std::string(AST
->Reader
->getOriginalSourceFile());
898 PP
.setCounterValue(Counter
);
900 Module
*M
= HeaderInfo
.lookupModule(AST
->getLangOpts().CurrentModule
);
901 if (M
&& AST
->getLangOpts().isCompilingModule() && M
->isNamedModule())
902 AST
->Ctx
->setCurrentNamedModule(M
);
904 // Create an AST consumer, even though it isn't used.
905 if (ToLoad
>= LoadASTOnly
)
906 AST
->Consumer
.reset(new ASTConsumer
);
908 // Create a semantic analysis object and tell the AST reader about it.
909 if (ToLoad
>= LoadEverything
) {
910 AST
->TheSema
.reset(new Sema(PP
, *AST
->Ctx
, *AST
->Consumer
));
911 AST
->TheSema
->Initialize();
912 AST
->Reader
->InitializeSema(*AST
->TheSema
);
915 // Tell the diagnostic client that we have started a source file.
916 AST
->getDiagnostics().getClient()->BeginSourceFile(PP
.getLangOpts(), &PP
);
921 /// Add the given macro to the hash of all top-level entities.
922 static void AddDefinedMacroToHash(const Token
&MacroNameTok
, unsigned &Hash
) {
923 Hash
= llvm::djbHash(MacroNameTok
.getIdentifierInfo()->getName(), Hash
);
928 /// Preprocessor callback class that updates a hash value with the names
929 /// of all macros that have been defined by the translation unit.
930 class MacroDefinitionTrackerPPCallbacks
: public PPCallbacks
{
934 explicit MacroDefinitionTrackerPPCallbacks(unsigned &Hash
) : Hash(Hash
) {}
936 void MacroDefined(const Token
&MacroNameTok
,
937 const MacroDirective
*MD
) override
{
938 AddDefinedMacroToHash(MacroNameTok
, Hash
);
944 /// Add the given declaration to the hash of all top-level entities.
945 static void AddTopLevelDeclarationToHash(Decl
*D
, unsigned &Hash
) {
949 DeclContext
*DC
= D
->getDeclContext();
953 if (!(DC
->isTranslationUnit() || DC
->getLookupParent()->isTranslationUnit()))
956 if (const auto *ND
= dyn_cast
<NamedDecl
>(D
)) {
957 if (const auto *EnumD
= dyn_cast
<EnumDecl
>(D
)) {
958 // For an unscoped enum include the enumerators in the hash since they
959 // enter the top-level namespace.
960 if (!EnumD
->isScoped()) {
961 for (const auto *EI
: EnumD
->enumerators()) {
962 if (EI
->getIdentifier())
963 Hash
= llvm::djbHash(EI
->getIdentifier()->getName(), Hash
);
968 if (ND
->getIdentifier())
969 Hash
= llvm::djbHash(ND
->getIdentifier()->getName(), Hash
);
970 else if (DeclarationName Name
= ND
->getDeclName()) {
971 std::string NameStr
= Name
.getAsString();
972 Hash
= llvm::djbHash(NameStr
, Hash
);
977 if (const auto *ImportD
= dyn_cast
<ImportDecl
>(D
)) {
978 if (const Module
*Mod
= ImportD
->getImportedModule()) {
979 std::string ModName
= Mod
->getFullModuleName();
980 Hash
= llvm::djbHash(ModName
, Hash
);
988 class TopLevelDeclTrackerConsumer
: public ASTConsumer
{
993 TopLevelDeclTrackerConsumer(ASTUnit
&_Unit
, unsigned &Hash
)
994 : Unit(_Unit
), Hash(Hash
) {
998 void handleTopLevelDecl(Decl
*D
) {
1002 // FIXME: Currently ObjC method declarations are incorrectly being
1003 // reported as top-level declarations, even though their DeclContext
1004 // is the containing ObjC @interface/@implementation. This is a
1005 // fundamental problem in the parser right now.
1006 if (isa
<ObjCMethodDecl
>(D
))
1009 AddTopLevelDeclarationToHash(D
, Hash
);
1010 Unit
.addTopLevelDecl(D
);
1012 handleFileLevelDecl(D
);
1015 void handleFileLevelDecl(Decl
*D
) {
1016 Unit
.addFileLevelDecl(D
);
1017 if (auto *NSD
= dyn_cast
<NamespaceDecl
>(D
)) {
1018 for (auto *I
: NSD
->decls())
1019 handleFileLevelDecl(I
);
1023 bool HandleTopLevelDecl(DeclGroupRef D
) override
{
1024 for (auto *TopLevelDecl
: D
)
1025 handleTopLevelDecl(TopLevelDecl
);
1029 // We're not interested in "interesting" decls.
1030 void HandleInterestingDecl(DeclGroupRef
) override
{}
1032 void HandleTopLevelDeclInObjCContainer(DeclGroupRef D
) override
{
1033 for (auto *TopLevelDecl
: D
)
1034 handleTopLevelDecl(TopLevelDecl
);
1037 ASTMutationListener
*GetASTMutationListener() override
{
1038 return Unit
.getASTMutationListener();
1041 ASTDeserializationListener
*GetASTDeserializationListener() override
{
1042 return Unit
.getDeserializationListener();
1046 class TopLevelDeclTrackerAction
: public ASTFrontendAction
{
1050 std::unique_ptr
<ASTConsumer
> CreateASTConsumer(CompilerInstance
&CI
,
1051 StringRef InFile
) override
{
1052 CI
.getPreprocessor().addPPCallbacks(
1053 std::make_unique
<MacroDefinitionTrackerPPCallbacks
>(
1054 Unit
.getCurrentTopLevelHashValue()));
1055 return std::make_unique
<TopLevelDeclTrackerConsumer
>(
1056 Unit
, Unit
.getCurrentTopLevelHashValue());
1060 TopLevelDeclTrackerAction(ASTUnit
&_Unit
) : Unit(_Unit
) {}
1062 bool hasCodeCompletionSupport() const override
{ return false; }
1064 TranslationUnitKind
getTranslationUnitKind() override
{
1065 return Unit
.getTranslationUnitKind();
1069 class ASTUnitPreambleCallbacks
: public PreambleCallbacks
{
1071 unsigned getHash() const { return Hash
; }
1073 std::vector
<Decl
*> takeTopLevelDecls() { return std::move(TopLevelDecls
); }
1075 std::vector
<LocalDeclID
> takeTopLevelDeclIDs() {
1076 return std::move(TopLevelDeclIDs
);
1079 void AfterPCHEmitted(ASTWriter
&Writer
) override
{
1080 TopLevelDeclIDs
.reserve(TopLevelDecls
.size());
1081 for (const auto *D
: TopLevelDecls
) {
1082 // Invalid top-level decls may not have been serialized.
1083 if (D
->isInvalidDecl())
1085 TopLevelDeclIDs
.push_back(Writer
.getDeclID(D
));
1089 void HandleTopLevelDecl(DeclGroupRef DG
) override
{
1090 for (auto *D
: DG
) {
1091 // FIXME: Currently ObjC method declarations are incorrectly being
1092 // reported as top-level declarations, even though their DeclContext
1093 // is the containing ObjC @interface/@implementation. This is a
1094 // fundamental problem in the parser right now.
1095 if (isa
<ObjCMethodDecl
>(D
))
1097 AddTopLevelDeclarationToHash(D
, Hash
);
1098 TopLevelDecls
.push_back(D
);
1102 std::unique_ptr
<PPCallbacks
> createPPCallbacks() override
{
1103 return std::make_unique
<MacroDefinitionTrackerPPCallbacks
>(Hash
);
1108 std::vector
<Decl
*> TopLevelDecls
;
1109 std::vector
<LocalDeclID
> TopLevelDeclIDs
;
1110 llvm::SmallVector
<ASTUnit::StandaloneDiagnostic
, 4> PreambleDiags
;
1115 static bool isNonDriverDiag(const StoredDiagnostic
&StoredDiag
) {
1116 return StoredDiag
.getLocation().isValid();
1120 checkAndRemoveNonDriverDiags(SmallVectorImpl
<StoredDiagnostic
> &StoredDiags
) {
1121 // Get rid of stored diagnostics except the ones from the driver which do not
1122 // have a source location.
1123 llvm::erase_if(StoredDiags
, isNonDriverDiag
);
1126 static void checkAndSanitizeDiags(SmallVectorImpl
<StoredDiagnostic
> &
1128 SourceManager
&SM
) {
1129 // The stored diagnostic has the old source manager in it; update
1130 // the locations to refer into the new source manager. Since we've
1131 // been careful to make sure that the source manager's state
1132 // before and after are identical, so that we can reuse the source
1134 for (auto &SD
: StoredDiagnostics
) {
1135 if (SD
.getLocation().isValid()) {
1136 FullSourceLoc
Loc(SD
.getLocation(), SM
);
1137 SD
.setLocation(Loc
);
1142 /// Parse the source file into a translation unit using the given compiler
1143 /// invocation, replacing the current translation unit.
1145 /// \returns True if a failure occurred that causes the ASTUnit not to
1146 /// contain any translation-unit information, false otherwise.
1147 bool ASTUnit::Parse(std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
1148 std::unique_ptr
<llvm::MemoryBuffer
> OverrideMainBuffer
,
1149 IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
) {
1154 assert(VFS
== &FileMgr
->getVirtualFileSystem() &&
1155 "VFS passed to Parse and VFS in FileMgr are different");
1157 auto CCInvocation
= std::make_shared
<CompilerInvocation
>(*Invocation
);
1158 if (OverrideMainBuffer
) {
1160 "No preamble was built, but OverrideMainBuffer is not null");
1161 Preamble
->AddImplicitPreamble(*CCInvocation
, VFS
, OverrideMainBuffer
.get());
1162 // VFS may have changed...
1165 // Create the compiler instance to use for building the AST.
1166 std::unique_ptr
<CompilerInstance
> Clang(
1167 new CompilerInstance(std::move(PCHContainerOps
)));
1168 Clang
->setInvocation(CCInvocation
);
1170 // Clean up on error, disengage it if the function returns successfully.
1171 auto CleanOnError
= llvm::make_scope_exit([&]() {
1172 // Remove the overridden buffer we used for the preamble.
1173 SavedMainFileBuffer
= nullptr;
1175 // Keep the ownership of the data in the ASTUnit because the client may
1176 // want to see the diagnostics.
1177 transferASTDataFromCompilerInstance(*Clang
);
1178 FailedParseDiagnostics
.swap(StoredDiagnostics
);
1179 StoredDiagnostics
.clear();
1180 NumStoredDiagnosticsFromDriver
= 0;
1183 // Ensure that Clang has a FileManager with the right VFS, which may have
1184 // changed above in AddImplicitPreamble. If VFS is nullptr, rely on
1185 // createFileManager to create one.
1186 if (VFS
&& FileMgr
&& &FileMgr
->getVirtualFileSystem() == VFS
)
1187 Clang
->setFileManager(&*FileMgr
);
1189 FileMgr
= Clang
->createFileManager(std::move(VFS
));
1191 // Recover resources if we crash before exiting this method.
1192 llvm::CrashRecoveryContextCleanupRegistrar
<CompilerInstance
>
1193 CICleanup(Clang
.get());
1195 OriginalSourceFile
=
1196 std::string(Clang
->getFrontendOpts().Inputs
[0].getFile());
1198 // Set up diagnostics, capturing any diagnostics that would
1199 // otherwise be dropped.
1200 Clang
->setDiagnostics(&getDiagnostics());
1202 // Create the target instance.
1203 if (!Clang
->createTarget())
1206 assert(Clang
->getFrontendOpts().Inputs
.size() == 1 &&
1207 "Invocation must have exactly one source file!");
1208 assert(Clang
->getFrontendOpts().Inputs
[0].getKind().getFormat() ==
1209 InputKind::Source
&&
1210 "FIXME: AST inputs not yet supported here!");
1211 assert(Clang
->getFrontendOpts().Inputs
[0].getKind().getLanguage() !=
1212 Language::LLVM_IR
&&
1213 "IR inputs not support here!");
1215 // Configure the various subsystems.
1216 LangOpts
= Clang
->getInvocation().LangOpts
;
1217 FileSystemOpts
= Clang
->getFileSystemOpts();
1221 SourceMgr
= new SourceManager(getDiagnostics(), *FileMgr
,
1222 UserFilesAreVolatile
);
1223 if (!OverrideMainBuffer
) {
1224 checkAndRemoveNonDriverDiags(StoredDiagnostics
);
1225 TopLevelDeclsInPreamble
.clear();
1228 // Create the source manager.
1229 Clang
->setSourceManager(&getSourceManager());
1231 // If the main file has been overridden due to the use of a preamble,
1232 // make that override happen and introduce the preamble.
1233 if (OverrideMainBuffer
) {
1234 // The stored diagnostic has the old source manager in it; update
1235 // the locations to refer into the new source manager. Since we've
1236 // been careful to make sure that the source manager's state
1237 // before and after are identical, so that we can reuse the source
1239 checkAndSanitizeDiags(StoredDiagnostics
, getSourceManager());
1241 // Keep track of the override buffer;
1242 SavedMainFileBuffer
= std::move(OverrideMainBuffer
);
1245 std::unique_ptr
<TopLevelDeclTrackerAction
> Act(
1246 new TopLevelDeclTrackerAction(*this));
1248 // Recover resources if we crash before exiting this method.
1249 llvm::CrashRecoveryContextCleanupRegistrar
<TopLevelDeclTrackerAction
>
1250 ActCleanup(Act
.get());
1252 if (!Act
->BeginSourceFile(*Clang
.get(), Clang
->getFrontendOpts().Inputs
[0]))
1255 if (SavedMainFileBuffer
)
1256 TranslateStoredDiagnostics(getFileManager(), getSourceManager(),
1257 PreambleDiagnostics
, StoredDiagnostics
);
1259 PreambleSrcLocCache
.clear();
1261 if (llvm::Error Err
= Act
->Execute()) {
1262 consumeError(std::move(Err
)); // FIXME this drops errors on the floor.
1266 transferASTDataFromCompilerInstance(*Clang
);
1268 Act
->EndSourceFile();
1270 FailedParseDiagnostics
.clear();
1272 CleanOnError
.release();
1277 static std::pair
<unsigned, unsigned>
1278 makeStandaloneRange(CharSourceRange Range
, const SourceManager
&SM
,
1279 const LangOptions
&LangOpts
) {
1280 CharSourceRange FileRange
= Lexer::makeFileCharRange(Range
, SM
, LangOpts
);
1281 unsigned Offset
= SM
.getFileOffset(FileRange
.getBegin());
1282 unsigned EndOffset
= SM
.getFileOffset(FileRange
.getEnd());
1283 return std::make_pair(Offset
, EndOffset
);
1286 static ASTUnit::StandaloneFixIt
makeStandaloneFixIt(const SourceManager
&SM
,
1287 const LangOptions
&LangOpts
,
1288 const FixItHint
&InFix
) {
1289 ASTUnit::StandaloneFixIt OutFix
;
1290 OutFix
.RemoveRange
= makeStandaloneRange(InFix
.RemoveRange
, SM
, LangOpts
);
1291 OutFix
.InsertFromRange
= makeStandaloneRange(InFix
.InsertFromRange
, SM
,
1293 OutFix
.CodeToInsert
= InFix
.CodeToInsert
;
1294 OutFix
.BeforePreviousInsertions
= InFix
.BeforePreviousInsertions
;
1298 static ASTUnit::StandaloneDiagnostic
1299 makeStandaloneDiagnostic(const LangOptions
&LangOpts
,
1300 const StoredDiagnostic
&InDiag
) {
1301 ASTUnit::StandaloneDiagnostic OutDiag
;
1302 OutDiag
.ID
= InDiag
.getID();
1303 OutDiag
.Level
= InDiag
.getLevel();
1304 OutDiag
.Message
= std::string(InDiag
.getMessage());
1305 OutDiag
.LocOffset
= 0;
1306 if (InDiag
.getLocation().isInvalid())
1308 const SourceManager
&SM
= InDiag
.getLocation().getManager();
1309 SourceLocation FileLoc
= SM
.getFileLoc(InDiag
.getLocation());
1310 OutDiag
.Filename
= std::string(SM
.getFilename(FileLoc
));
1311 if (OutDiag
.Filename
.empty())
1313 OutDiag
.LocOffset
= SM
.getFileOffset(FileLoc
);
1314 for (const auto &Range
: InDiag
.getRanges())
1315 OutDiag
.Ranges
.push_back(makeStandaloneRange(Range
, SM
, LangOpts
));
1316 for (const auto &FixIt
: InDiag
.getFixIts())
1317 OutDiag
.FixIts
.push_back(makeStandaloneFixIt(SM
, LangOpts
, FixIt
));
1322 /// Attempt to build or re-use a precompiled preamble when (re-)parsing
1323 /// the source file.
1325 /// This routine will compute the preamble of the main source file. If a
1326 /// non-trivial preamble is found, it will precompile that preamble into a
1327 /// precompiled header so that the precompiled preamble can be used to reduce
1328 /// reparsing time. If a precompiled preamble has already been constructed,
1329 /// this routine will determine if it is still valid and, if so, avoid
1330 /// rebuilding the precompiled preamble.
1332 /// \param AllowRebuild When true (the default), this routine is
1333 /// allowed to rebuild the precompiled preamble if it is found to be
1336 /// \param MaxLines When non-zero, the maximum number of lines that
1337 /// can occur within the preamble.
1339 /// \returns If the precompiled preamble can be used, returns a newly-allocated
1340 /// buffer that should be used in place of the main file when doing so.
1341 /// Otherwise, returns a NULL pointer.
1342 std::unique_ptr
<llvm::MemoryBuffer
>
1343 ASTUnit::getMainBufferWithPrecompiledPreamble(
1344 std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
1345 CompilerInvocation
&PreambleInvocationIn
,
1346 IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
, bool AllowRebuild
,
1347 unsigned MaxLines
) {
1349 PreambleInvocationIn
.getFrontendOpts().Inputs
[0].getFile();
1350 std::unique_ptr
<llvm::MemoryBuffer
> MainFileBuffer
=
1351 getBufferForFileHandlingRemapping(PreambleInvocationIn
, VFS
.get(),
1352 MainFilePath
, UserFilesAreVolatile
);
1353 if (!MainFileBuffer
)
1356 PreambleBounds Bounds
= ComputePreambleBounds(
1357 PreambleInvocationIn
.getLangOpts(), *MainFileBuffer
, MaxLines
);
1362 if (Preamble
->CanReuse(PreambleInvocationIn
, *MainFileBuffer
, Bounds
,
1364 // Okay! We can re-use the precompiled preamble.
1366 // Set the state of the diagnostic object to mimic its state
1367 // after parsing the preamble.
1368 getDiagnostics().Reset();
1369 ProcessWarningOptions(getDiagnostics(),
1370 PreambleInvocationIn
.getDiagnosticOpts(), *VFS
);
1371 getDiagnostics().setNumWarnings(NumWarningsInPreamble
);
1373 PreambleRebuildCountdown
= 1;
1374 return MainFileBuffer
;
1377 PreambleDiagnostics
.clear();
1378 TopLevelDeclsInPreamble
.clear();
1379 PreambleSrcLocCache
.clear();
1380 PreambleRebuildCountdown
= 1;
1384 // If the preamble rebuild counter > 1, it's because we previously
1385 // failed to build a preamble and we're not yet ready to try
1386 // again. Decrement the counter and return a failure.
1387 if (PreambleRebuildCountdown
> 1) {
1388 --PreambleRebuildCountdown
;
1392 assert(!Preamble
&& "No Preamble should be stored at that point");
1393 // If we aren't allowed to rebuild the precompiled preamble, just
1400 SmallVector
<StandaloneDiagnostic
, 4> NewPreambleDiagsStandalone
;
1401 SmallVector
<StoredDiagnostic
, 4> NewPreambleDiags
;
1402 ASTUnitPreambleCallbacks Callbacks
;
1404 std::optional
<CaptureDroppedDiagnostics
> Capture
;
1405 if (CaptureDiagnostics
!= CaptureDiagsKind::None
)
1406 Capture
.emplace(CaptureDiagnostics
, *Diagnostics
, &NewPreambleDiags
,
1407 &NewPreambleDiagsStandalone
);
1409 // We did not previously compute a preamble, or it can't be reused anyway.
1410 SimpleTimer
PreambleTimer(WantTiming
);
1411 PreambleTimer
.setOutput("Precompiling preamble");
1413 const bool PreviousSkipFunctionBodies
=
1414 PreambleInvocationIn
.getFrontendOpts().SkipFunctionBodies
;
1415 if (SkipFunctionBodies
== SkipFunctionBodiesScope::Preamble
)
1416 PreambleInvocationIn
.getFrontendOpts().SkipFunctionBodies
= true;
1418 llvm::ErrorOr
<PrecompiledPreamble
> NewPreamble
= PrecompiledPreamble::Build(
1419 PreambleInvocationIn
, MainFileBuffer
.get(), Bounds
, *Diagnostics
, VFS
,
1420 PCHContainerOps
, StorePreamblesInMemory
, PreambleStoragePath
,
1423 PreambleInvocationIn
.getFrontendOpts().SkipFunctionBodies
=
1424 PreviousSkipFunctionBodies
;
1427 Preamble
= std::move(*NewPreamble
);
1428 PreambleRebuildCountdown
= 1;
1430 switch (static_cast<BuildPreambleError
>(NewPreamble
.getError().value())) {
1431 case BuildPreambleError::CouldntCreateTempFile
:
1432 // Try again next time.
1433 PreambleRebuildCountdown
= 1;
1435 case BuildPreambleError::CouldntCreateTargetInfo
:
1436 case BuildPreambleError::BeginSourceFileFailed
:
1437 case BuildPreambleError::CouldntEmitPCH
:
1438 case BuildPreambleError::BadInputs
:
1439 // These erros are more likely to repeat, retry after some period.
1440 PreambleRebuildCountdown
= DefaultPreambleRebuildInterval
;
1443 llvm_unreachable("unexpected BuildPreambleError");
1447 assert(Preamble
&& "Preamble wasn't built");
1449 TopLevelDecls
.clear();
1450 TopLevelDeclsInPreamble
= Callbacks
.takeTopLevelDeclIDs();
1451 PreambleTopLevelHashValue
= Callbacks
.getHash();
1453 NumWarningsInPreamble
= getDiagnostics().getNumWarnings();
1455 checkAndRemoveNonDriverDiags(NewPreambleDiags
);
1456 StoredDiagnostics
= std::move(NewPreambleDiags
);
1457 PreambleDiagnostics
= std::move(NewPreambleDiagsStandalone
);
1459 // If the hash of top-level entities differs from the hash of the top-level
1460 // entities the last time we rebuilt the preamble, clear out the completion
1462 if (CurrentTopLevelHashValue
!= PreambleTopLevelHashValue
) {
1463 CompletionCacheTopLevelHashValue
= 0;
1464 PreambleTopLevelHashValue
= CurrentTopLevelHashValue
;
1467 return MainFileBuffer
;
1470 void ASTUnit::RealizeTopLevelDeclsFromPreamble() {
1471 assert(Preamble
&& "Should only be called when preamble was built");
1473 std::vector
<Decl
*> Resolved
;
1474 Resolved
.reserve(TopLevelDeclsInPreamble
.size());
1475 // The module file of the preamble.
1476 serialization::ModuleFile
&MF
= Reader
->getModuleManager().getPrimaryModule();
1477 for (const auto TopLevelDecl
: TopLevelDeclsInPreamble
) {
1478 // Resolve the declaration ID to an actual declaration, possibly
1479 // deserializing the declaration in the process.
1480 if (Decl
*D
= Reader
->GetLocalDecl(MF
, TopLevelDecl
))
1481 Resolved
.push_back(D
);
1483 TopLevelDeclsInPreamble
.clear();
1484 TopLevelDecls
.insert(TopLevelDecls
.begin(), Resolved
.begin(), Resolved
.end());
1487 void ASTUnit::transferASTDataFromCompilerInstance(CompilerInstance
&CI
) {
1488 // Steal the created target, context, and preprocessor if they have been
1490 assert(CI
.hasInvocation() && "missing invocation");
1491 LangOpts
= CI
.getInvocation().LangOpts
;
1492 TheSema
= CI
.takeSema();
1493 Consumer
= CI
.takeASTConsumer();
1494 if (CI
.hasASTContext())
1495 Ctx
= &CI
.getASTContext();
1496 if (CI
.hasPreprocessor())
1497 PP
= CI
.getPreprocessorPtr();
1498 CI
.setSourceManager(nullptr);
1499 CI
.setFileManager(nullptr);
1501 Target
= &CI
.getTarget();
1502 Reader
= CI
.getASTReader();
1503 HadModuleLoaderFatalFailure
= CI
.hadModuleLoaderFatalFailure();
1506 StringRef
ASTUnit::getMainFileName() const {
1507 if (Invocation
&& !Invocation
->getFrontendOpts().Inputs
.empty()) {
1508 const FrontendInputFile
&Input
= Invocation
->getFrontendOpts().Inputs
[0];
1510 return Input
.getFile();
1512 return Input
.getBuffer().getBufferIdentifier();
1516 if (OptionalFileEntryRef FE
=
1517 SourceMgr
->getFileEntryRefForID(SourceMgr
->getMainFileID()))
1518 return FE
->getName();
1524 StringRef
ASTUnit::getASTFileName() const {
1525 if (!isMainFileAST())
1528 serialization::ModuleFile
&
1529 Mod
= Reader
->getModuleManager().getPrimaryModule();
1530 return Mod
.FileName
;
1533 std::unique_ptr
<ASTUnit
>
1534 ASTUnit::create(std::shared_ptr
<CompilerInvocation
> CI
,
1535 IntrusiveRefCntPtr
<DiagnosticsEngine
> Diags
,
1536 CaptureDiagsKind CaptureDiagnostics
,
1537 bool UserFilesAreVolatile
) {
1538 std::unique_ptr
<ASTUnit
> AST(new ASTUnit(false));
1539 ConfigureDiags(Diags
, *AST
, CaptureDiagnostics
);
1540 IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
=
1541 createVFSFromCompilerInvocation(*CI
, *Diags
);
1542 AST
->Diagnostics
= Diags
;
1543 AST
->FileSystemOpts
= CI
->getFileSystemOpts();
1544 AST
->Invocation
= std::move(CI
);
1545 AST
->FileMgr
= new FileManager(AST
->FileSystemOpts
, VFS
);
1546 AST
->UserFilesAreVolatile
= UserFilesAreVolatile
;
1547 AST
->SourceMgr
= new SourceManager(AST
->getDiagnostics(), *AST
->FileMgr
,
1548 UserFilesAreVolatile
);
1549 AST
->ModuleCache
= new InMemoryModuleCache
;
1554 ASTUnit
*ASTUnit::LoadFromCompilerInvocationAction(
1555 std::shared_ptr
<CompilerInvocation
> CI
,
1556 std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
1557 IntrusiveRefCntPtr
<DiagnosticsEngine
> Diags
, FrontendAction
*Action
,
1558 ASTUnit
*Unit
, bool Persistent
, StringRef ResourceFilesPath
,
1559 bool OnlyLocalDecls
, CaptureDiagsKind CaptureDiagnostics
,
1560 unsigned PrecompilePreambleAfterNParses
, bool CacheCodeCompletionResults
,
1561 bool UserFilesAreVolatile
, std::unique_ptr
<ASTUnit
> *ErrAST
) {
1562 assert(CI
&& "A CompilerInvocation is required");
1564 std::unique_ptr
<ASTUnit
> OwnAST
;
1565 ASTUnit
*AST
= Unit
;
1567 // Create the AST unit.
1568 OwnAST
= create(CI
, Diags
, CaptureDiagnostics
, UserFilesAreVolatile
);
1574 if (!ResourceFilesPath
.empty()) {
1575 // Override the resources path.
1576 CI
->getHeaderSearchOpts().ResourceDir
= std::string(ResourceFilesPath
);
1578 AST
->OnlyLocalDecls
= OnlyLocalDecls
;
1579 AST
->CaptureDiagnostics
= CaptureDiagnostics
;
1580 if (PrecompilePreambleAfterNParses
> 0)
1581 AST
->PreambleRebuildCountdown
= PrecompilePreambleAfterNParses
;
1582 AST
->TUKind
= Action
? Action
->getTranslationUnitKind() : TU_Complete
;
1583 AST
->ShouldCacheCodeCompletionResults
= CacheCodeCompletionResults
;
1584 AST
->IncludeBriefCommentsInCodeCompletion
= false;
1586 // Recover resources if we crash before exiting this method.
1587 llvm::CrashRecoveryContextCleanupRegistrar
<ASTUnit
>
1588 ASTUnitCleanup(OwnAST
.get());
1589 llvm::CrashRecoveryContextCleanupRegistrar
<DiagnosticsEngine
,
1590 llvm::CrashRecoveryContextReleaseRefCleanup
<DiagnosticsEngine
>>
1591 DiagCleanup(Diags
.get());
1593 // We'll manage file buffers ourselves.
1594 CI
->getPreprocessorOpts().RetainRemappedFileBuffers
= true;
1595 CI
->getFrontendOpts().DisableFree
= false;
1596 ProcessWarningOptions(AST
->getDiagnostics(), CI
->getDiagnosticOpts(),
1597 AST
->getFileManager().getVirtualFileSystem());
1599 // Create the compiler instance to use for building the AST.
1600 std::unique_ptr
<CompilerInstance
> Clang(
1601 new CompilerInstance(std::move(PCHContainerOps
)));
1603 // Recover resources if we crash before exiting this method.
1604 llvm::CrashRecoveryContextCleanupRegistrar
<CompilerInstance
>
1605 CICleanup(Clang
.get());
1607 Clang
->setInvocation(std::move(CI
));
1608 AST
->OriginalSourceFile
=
1609 std::string(Clang
->getFrontendOpts().Inputs
[0].getFile());
1611 // Set up diagnostics, capturing any diagnostics that would
1612 // otherwise be dropped.
1613 Clang
->setDiagnostics(&AST
->getDiagnostics());
1615 // Create the target instance.
1616 if (!Clang
->createTarget())
1619 assert(Clang
->getFrontendOpts().Inputs
.size() == 1 &&
1620 "Invocation must have exactly one source file!");
1621 assert(Clang
->getFrontendOpts().Inputs
[0].getKind().getFormat() ==
1622 InputKind::Source
&&
1623 "FIXME: AST inputs not yet supported here!");
1624 assert(Clang
->getFrontendOpts().Inputs
[0].getKind().getLanguage() !=
1625 Language::LLVM_IR
&&
1626 "IR inputs not support here!");
1628 // Configure the various subsystems.
1629 AST
->TheSema
.reset();
1632 AST
->Reader
= nullptr;
1634 // Create a file manager object to provide access to and cache the filesystem.
1635 Clang
->setFileManager(&AST
->getFileManager());
1637 // Create the source manager.
1638 Clang
->setSourceManager(&AST
->getSourceManager());
1640 FrontendAction
*Act
= Action
;
1642 std::unique_ptr
<TopLevelDeclTrackerAction
> TrackerAct
;
1644 TrackerAct
.reset(new TopLevelDeclTrackerAction(*AST
));
1645 Act
= TrackerAct
.get();
1648 // Recover resources if we crash before exiting this method.
1649 llvm::CrashRecoveryContextCleanupRegistrar
<TopLevelDeclTrackerAction
>
1650 ActCleanup(TrackerAct
.get());
1652 if (!Act
->BeginSourceFile(*Clang
.get(), Clang
->getFrontendOpts().Inputs
[0])) {
1653 AST
->transferASTDataFromCompilerInstance(*Clang
);
1654 if (OwnAST
&& ErrAST
)
1655 ErrAST
->swap(OwnAST
);
1660 if (Persistent
&& !TrackerAct
) {
1661 Clang
->getPreprocessor().addPPCallbacks(
1662 std::make_unique
<MacroDefinitionTrackerPPCallbacks
>(
1663 AST
->getCurrentTopLevelHashValue()));
1664 std::vector
<std::unique_ptr
<ASTConsumer
>> Consumers
;
1665 if (Clang
->hasASTConsumer())
1666 Consumers
.push_back(Clang
->takeASTConsumer());
1667 Consumers
.push_back(std::make_unique
<TopLevelDeclTrackerConsumer
>(
1668 *AST
, AST
->getCurrentTopLevelHashValue()));
1669 Clang
->setASTConsumer(
1670 std::make_unique
<MultiplexConsumer
>(std::move(Consumers
)));
1672 if (llvm::Error Err
= Act
->Execute()) {
1673 consumeError(std::move(Err
)); // FIXME this drops errors on the floor.
1674 AST
->transferASTDataFromCompilerInstance(*Clang
);
1675 if (OwnAST
&& ErrAST
)
1676 ErrAST
->swap(OwnAST
);
1681 // Steal the created target, context, and preprocessor.
1682 AST
->transferASTDataFromCompilerInstance(*Clang
);
1684 Act
->EndSourceFile();
1687 return OwnAST
.release();
1692 bool ASTUnit::LoadFromCompilerInvocation(
1693 std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
1694 unsigned PrecompilePreambleAfterNParses
,
1695 IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
) {
1699 assert(VFS
&& "VFS is null");
1701 // We'll manage file buffers ourselves.
1702 Invocation
->getPreprocessorOpts().RetainRemappedFileBuffers
= true;
1703 Invocation
->getFrontendOpts().DisableFree
= false;
1704 getDiagnostics().Reset();
1705 ProcessWarningOptions(getDiagnostics(), Invocation
->getDiagnosticOpts(),
1708 std::unique_ptr
<llvm::MemoryBuffer
> OverrideMainBuffer
;
1709 if (PrecompilePreambleAfterNParses
> 0) {
1710 PreambleRebuildCountdown
= PrecompilePreambleAfterNParses
;
1711 OverrideMainBuffer
=
1712 getMainBufferWithPrecompiledPreamble(PCHContainerOps
, *Invocation
, VFS
);
1713 getDiagnostics().Reset();
1714 ProcessWarningOptions(getDiagnostics(), Invocation
->getDiagnosticOpts(),
1718 SimpleTimer
ParsingTimer(WantTiming
);
1719 ParsingTimer
.setOutput("Parsing " + getMainFileName());
1721 // Recover resources if we crash before exiting this method.
1722 llvm::CrashRecoveryContextCleanupRegistrar
<llvm::MemoryBuffer
>
1723 MemBufferCleanup(OverrideMainBuffer
.get());
1725 return Parse(std::move(PCHContainerOps
), std::move(OverrideMainBuffer
), VFS
);
1728 std::unique_ptr
<ASTUnit
> ASTUnit::LoadFromCompilerInvocation(
1729 std::shared_ptr
<CompilerInvocation
> CI
,
1730 std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
1731 IntrusiveRefCntPtr
<DiagnosticsEngine
> Diags
, FileManager
*FileMgr
,
1732 bool OnlyLocalDecls
, CaptureDiagsKind CaptureDiagnostics
,
1733 unsigned PrecompilePreambleAfterNParses
, TranslationUnitKind TUKind
,
1734 bool CacheCodeCompletionResults
, bool IncludeBriefCommentsInCodeCompletion
,
1735 bool UserFilesAreVolatile
) {
1736 // Create the AST unit.
1737 std::unique_ptr
<ASTUnit
> AST(new ASTUnit(false));
1738 ConfigureDiags(Diags
, *AST
, CaptureDiagnostics
);
1739 AST
->Diagnostics
= Diags
;
1740 AST
->OnlyLocalDecls
= OnlyLocalDecls
;
1741 AST
->CaptureDiagnostics
= CaptureDiagnostics
;
1742 AST
->TUKind
= TUKind
;
1743 AST
->ShouldCacheCodeCompletionResults
= CacheCodeCompletionResults
;
1744 AST
->IncludeBriefCommentsInCodeCompletion
1745 = IncludeBriefCommentsInCodeCompletion
;
1746 AST
->Invocation
= std::move(CI
);
1747 AST
->FileSystemOpts
= FileMgr
->getFileSystemOpts();
1748 AST
->FileMgr
= FileMgr
;
1749 AST
->UserFilesAreVolatile
= UserFilesAreVolatile
;
1751 // Recover resources if we crash before exiting this method.
1752 llvm::CrashRecoveryContextCleanupRegistrar
<ASTUnit
>
1753 ASTUnitCleanup(AST
.get());
1754 llvm::CrashRecoveryContextCleanupRegistrar
<DiagnosticsEngine
,
1755 llvm::CrashRecoveryContextReleaseRefCleanup
<DiagnosticsEngine
>>
1756 DiagCleanup(Diags
.get());
1758 if (AST
->LoadFromCompilerInvocation(std::move(PCHContainerOps
),
1759 PrecompilePreambleAfterNParses
,
1760 &AST
->FileMgr
->getVirtualFileSystem()))
1765 std::unique_ptr
<ASTUnit
> ASTUnit::LoadFromCommandLine(
1766 const char **ArgBegin
, const char **ArgEnd
,
1767 std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
1768 IntrusiveRefCntPtr
<DiagnosticsEngine
> Diags
, StringRef ResourceFilesPath
,
1769 bool StorePreamblesInMemory
, StringRef PreambleStoragePath
,
1770 bool OnlyLocalDecls
, CaptureDiagsKind CaptureDiagnostics
,
1771 ArrayRef
<RemappedFile
> RemappedFiles
, bool RemappedFilesKeepOriginalName
,
1772 unsigned PrecompilePreambleAfterNParses
, TranslationUnitKind TUKind
,
1773 bool CacheCodeCompletionResults
, bool IncludeBriefCommentsInCodeCompletion
,
1774 bool AllowPCHWithCompilerErrors
, SkipFunctionBodiesScope SkipFunctionBodies
,
1775 bool SingleFileParse
, bool UserFilesAreVolatile
, bool ForSerialization
,
1776 bool RetainExcludedConditionalBlocks
, std::optional
<StringRef
> ModuleFormat
,
1777 std::unique_ptr
<ASTUnit
> *ErrAST
,
1778 IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
) {
1779 assert(Diags
.get() && "no DiagnosticsEngine was provided");
1781 // If no VFS was provided, create one that tracks the physical file system.
1782 // If '-working-directory' was passed as an argument, 'createInvocation' will
1783 // set this as the current working directory of the VFS.
1785 VFS
= llvm::vfs::createPhysicalFileSystem();
1787 SmallVector
<StoredDiagnostic
, 4> StoredDiagnostics
;
1789 std::shared_ptr
<CompilerInvocation
> CI
;
1792 CaptureDroppedDiagnostics
Capture(CaptureDiagnostics
, *Diags
,
1793 &StoredDiagnostics
, nullptr);
1795 CreateInvocationOptions CIOpts
;
1797 CIOpts
.Diags
= Diags
;
1798 CIOpts
.ProbePrecompiled
= true; // FIXME: historical default. Needed?
1799 CI
= createInvocation(llvm::ArrayRef(ArgBegin
, ArgEnd
), std::move(CIOpts
));
1804 // Override any files that need remapping
1805 for (const auto &RemappedFile
: RemappedFiles
) {
1806 CI
->getPreprocessorOpts().addRemappedFile(RemappedFile
.first
,
1807 RemappedFile
.second
);
1809 PreprocessorOptions
&PPOpts
= CI
->getPreprocessorOpts();
1810 PPOpts
.RemappedFilesKeepOriginalName
= RemappedFilesKeepOriginalName
;
1811 PPOpts
.AllowPCHWithCompilerErrors
= AllowPCHWithCompilerErrors
;
1812 PPOpts
.SingleFileParseMode
= SingleFileParse
;
1813 PPOpts
.RetainExcludedConditionalBlocks
= RetainExcludedConditionalBlocks
;
1815 // Override the resources path.
1816 CI
->getHeaderSearchOpts().ResourceDir
= std::string(ResourceFilesPath
);
1818 CI
->getFrontendOpts().SkipFunctionBodies
=
1819 SkipFunctionBodies
== SkipFunctionBodiesScope::PreambleAndMainFile
;
1822 CI
->getHeaderSearchOpts().ModuleFormat
= std::string(*ModuleFormat
);
1824 // Create the AST unit.
1825 std::unique_ptr
<ASTUnit
> AST
;
1826 AST
.reset(new ASTUnit(false));
1827 AST
->NumStoredDiagnosticsFromDriver
= StoredDiagnostics
.size();
1828 AST
->StoredDiagnostics
.swap(StoredDiagnostics
);
1829 ConfigureDiags(Diags
, *AST
, CaptureDiagnostics
);
1830 AST
->Diagnostics
= Diags
;
1831 AST
->FileSystemOpts
= CI
->getFileSystemOpts();
1832 VFS
= createVFSFromCompilerInvocation(*CI
, *Diags
, VFS
);
1833 AST
->FileMgr
= new FileManager(AST
->FileSystemOpts
, VFS
);
1834 AST
->StorePreamblesInMemory
= StorePreamblesInMemory
;
1835 AST
->PreambleStoragePath
= PreambleStoragePath
;
1836 AST
->ModuleCache
= new InMemoryModuleCache
;
1837 AST
->OnlyLocalDecls
= OnlyLocalDecls
;
1838 AST
->CaptureDiagnostics
= CaptureDiagnostics
;
1839 AST
->TUKind
= TUKind
;
1840 AST
->ShouldCacheCodeCompletionResults
= CacheCodeCompletionResults
;
1841 AST
->IncludeBriefCommentsInCodeCompletion
1842 = IncludeBriefCommentsInCodeCompletion
;
1843 AST
->UserFilesAreVolatile
= UserFilesAreVolatile
;
1844 AST
->Invocation
= CI
;
1845 AST
->SkipFunctionBodies
= SkipFunctionBodies
;
1846 if (ForSerialization
)
1847 AST
->WriterData
.reset(new ASTWriterData(*AST
->ModuleCache
));
1848 // Zero out now to ease cleanup during crash recovery.
1852 // Recover resources if we crash before exiting this method.
1853 llvm::CrashRecoveryContextCleanupRegistrar
<ASTUnit
>
1854 ASTUnitCleanup(AST
.get());
1856 if (AST
->LoadFromCompilerInvocation(std::move(PCHContainerOps
),
1857 PrecompilePreambleAfterNParses
,
1859 // Some error occurred, if caller wants to examine diagnostics, pass it the
1862 AST
->StoredDiagnostics
.swap(AST
->FailedParseDiagnostics
);
1871 bool ASTUnit::Reparse(std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
1872 ArrayRef
<RemappedFile
> RemappedFiles
,
1873 IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
) {
1878 assert(FileMgr
&& "FileMgr is null on Reparse call");
1879 VFS
= &FileMgr
->getVirtualFileSystem();
1882 clearFileLevelDecls();
1884 SimpleTimer
ParsingTimer(WantTiming
);
1885 ParsingTimer
.setOutput("Reparsing " + getMainFileName());
1888 PreprocessorOptions
&PPOpts
= Invocation
->getPreprocessorOpts();
1889 for (const auto &RB
: PPOpts
.RemappedFileBuffers
)
1892 Invocation
->getPreprocessorOpts().clearRemappedFiles();
1893 for (const auto &RemappedFile
: RemappedFiles
) {
1894 Invocation
->getPreprocessorOpts().addRemappedFile(RemappedFile
.first
,
1895 RemappedFile
.second
);
1898 // If we have a preamble file lying around, or if we might try to
1899 // build a precompiled preamble, do so now.
1900 std::unique_ptr
<llvm::MemoryBuffer
> OverrideMainBuffer
;
1901 if (Preamble
|| PreambleRebuildCountdown
> 0)
1902 OverrideMainBuffer
=
1903 getMainBufferWithPrecompiledPreamble(PCHContainerOps
, *Invocation
, VFS
);
1905 // Clear out the diagnostics state.
1907 getDiagnostics().Reset();
1908 ProcessWarningOptions(getDiagnostics(), Invocation
->getDiagnosticOpts(),
1910 if (OverrideMainBuffer
)
1911 getDiagnostics().setNumWarnings(NumWarningsInPreamble
);
1913 // Parse the sources
1915 Parse(std::move(PCHContainerOps
), std::move(OverrideMainBuffer
), VFS
);
1917 // If we're caching global code-completion results, and the top-level
1918 // declarations have changed, clear out the code-completion cache.
1919 if (!Result
&& ShouldCacheCodeCompletionResults
&&
1920 CurrentTopLevelHashValue
!= CompletionCacheTopLevelHashValue
)
1921 CacheCodeCompletionResults();
1923 // We now need to clear out the completion info related to this translation
1924 // unit; it'll be recreated if necessary.
1930 void ASTUnit::ResetForParse() {
1931 SavedMainFileBuffer
.reset();
1939 TopLevelDecls
.clear();
1940 clearFileLevelDecls();
1943 //----------------------------------------------------------------------------//
1945 //----------------------------------------------------------------------------//
1949 /// Code completion consumer that combines the cached code-completion
1950 /// results from an ASTUnit with the code-completion results provided to it,
1951 /// then passes the result on to
1952 class AugmentedCodeCompleteConsumer
: public CodeCompleteConsumer
{
1953 uint64_t NormalContexts
;
1955 CodeCompleteConsumer
&Next
;
1958 AugmentedCodeCompleteConsumer(ASTUnit
&AST
, CodeCompleteConsumer
&Next
,
1959 const CodeCompleteOptions
&CodeCompleteOpts
)
1960 : CodeCompleteConsumer(CodeCompleteOpts
), AST(AST
), Next(Next
) {
1961 // Compute the set of contexts in which we will look when we don't have
1962 // any information about the specific context.
1964 = (1LL << CodeCompletionContext::CCC_TopLevel
)
1965 | (1LL << CodeCompletionContext::CCC_ObjCInterface
)
1966 | (1LL << CodeCompletionContext::CCC_ObjCImplementation
)
1967 | (1LL << CodeCompletionContext::CCC_ObjCIvarList
)
1968 | (1LL << CodeCompletionContext::CCC_Statement
)
1969 | (1LL << CodeCompletionContext::CCC_Expression
)
1970 | (1LL << CodeCompletionContext::CCC_ObjCMessageReceiver
)
1971 | (1LL << CodeCompletionContext::CCC_DotMemberAccess
)
1972 | (1LL << CodeCompletionContext::CCC_ArrowMemberAccess
)
1973 | (1LL << CodeCompletionContext::CCC_ObjCPropertyAccess
)
1974 | (1LL << CodeCompletionContext::CCC_ObjCProtocolName
)
1975 | (1LL << CodeCompletionContext::CCC_ParenthesizedExpression
)
1976 | (1LL << CodeCompletionContext::CCC_Recovery
);
1978 if (AST
.getASTContext().getLangOpts().CPlusPlus
)
1979 NormalContexts
|= (1LL << CodeCompletionContext::CCC_EnumTag
)
1980 | (1LL << CodeCompletionContext::CCC_UnionTag
)
1981 | (1LL << CodeCompletionContext::CCC_ClassOrStructTag
);
1984 void ProcessCodeCompleteResults(Sema
&S
, CodeCompletionContext Context
,
1985 CodeCompletionResult
*Results
,
1986 unsigned NumResults
) override
;
1988 void ProcessOverloadCandidates(Sema
&S
, unsigned CurrentArg
,
1989 OverloadCandidate
*Candidates
,
1990 unsigned NumCandidates
,
1991 SourceLocation OpenParLoc
,
1992 bool Braced
) override
{
1993 Next
.ProcessOverloadCandidates(S
, CurrentArg
, Candidates
, NumCandidates
,
1994 OpenParLoc
, Braced
);
1997 CodeCompletionAllocator
&getAllocator() override
{
1998 return Next
.getAllocator();
2001 CodeCompletionTUInfo
&getCodeCompletionTUInfo() override
{
2002 return Next
.getCodeCompletionTUInfo();
2008 /// Helper function that computes which global names are hidden by the
2009 /// local code-completion results.
2010 static void CalculateHiddenNames(const CodeCompletionContext
&Context
,
2011 CodeCompletionResult
*Results
,
2012 unsigned NumResults
,
2014 llvm::StringSet
<llvm::BumpPtrAllocator
> &HiddenNames
){
2015 bool OnlyTagNames
= false;
2016 switch (Context
.getKind()) {
2017 case CodeCompletionContext::CCC_Recovery
:
2018 case CodeCompletionContext::CCC_TopLevel
:
2019 case CodeCompletionContext::CCC_ObjCInterface
:
2020 case CodeCompletionContext::CCC_ObjCImplementation
:
2021 case CodeCompletionContext::CCC_ObjCIvarList
:
2022 case CodeCompletionContext::CCC_ClassStructUnion
:
2023 case CodeCompletionContext::CCC_Statement
:
2024 case CodeCompletionContext::CCC_Expression
:
2025 case CodeCompletionContext::CCC_ObjCMessageReceiver
:
2026 case CodeCompletionContext::CCC_DotMemberAccess
:
2027 case CodeCompletionContext::CCC_ArrowMemberAccess
:
2028 case CodeCompletionContext::CCC_ObjCPropertyAccess
:
2029 case CodeCompletionContext::CCC_Namespace
:
2030 case CodeCompletionContext::CCC_Type
:
2031 case CodeCompletionContext::CCC_Symbol
:
2032 case CodeCompletionContext::CCC_SymbolOrNewName
:
2033 case CodeCompletionContext::CCC_ParenthesizedExpression
:
2034 case CodeCompletionContext::CCC_ObjCInterfaceName
:
2035 case CodeCompletionContext::CCC_TopLevelOrExpression
:
2038 case CodeCompletionContext::CCC_EnumTag
:
2039 case CodeCompletionContext::CCC_UnionTag
:
2040 case CodeCompletionContext::CCC_ClassOrStructTag
:
2041 OnlyTagNames
= true;
2044 case CodeCompletionContext::CCC_ObjCProtocolName
:
2045 case CodeCompletionContext::CCC_MacroName
:
2046 case CodeCompletionContext::CCC_MacroNameUse
:
2047 case CodeCompletionContext::CCC_PreprocessorExpression
:
2048 case CodeCompletionContext::CCC_PreprocessorDirective
:
2049 case CodeCompletionContext::CCC_NaturalLanguage
:
2050 case CodeCompletionContext::CCC_SelectorName
:
2051 case CodeCompletionContext::CCC_TypeQualifiers
:
2052 case CodeCompletionContext::CCC_Other
:
2053 case CodeCompletionContext::CCC_OtherWithMacros
:
2054 case CodeCompletionContext::CCC_ObjCInstanceMessage
:
2055 case CodeCompletionContext::CCC_ObjCClassMessage
:
2056 case CodeCompletionContext::CCC_ObjCCategoryName
:
2057 case CodeCompletionContext::CCC_IncludedFile
:
2058 case CodeCompletionContext::CCC_Attribute
:
2059 case CodeCompletionContext::CCC_NewName
:
2060 case CodeCompletionContext::CCC_ObjCClassForwardDecl
:
2061 // We're looking for nothing, or we're looking for names that cannot
2066 using Result
= CodeCompletionResult
;
2067 for (unsigned I
= 0; I
!= NumResults
; ++I
) {
2068 if (Results
[I
].Kind
!= Result::RK_Declaration
)
2072 = Results
[I
].Declaration
->getUnderlyingDecl()->getIdentifierNamespace();
2074 bool Hiding
= false;
2076 Hiding
= (IDNS
& Decl::IDNS_Tag
);
2078 unsigned HiddenIDNS
= (Decl::IDNS_Type
| Decl::IDNS_Member
|
2079 Decl::IDNS_Namespace
| Decl::IDNS_Ordinary
|
2080 Decl::IDNS_NonMemberOperator
);
2081 if (Ctx
.getLangOpts().CPlusPlus
)
2082 HiddenIDNS
|= Decl::IDNS_Tag
;
2083 Hiding
= (IDNS
& HiddenIDNS
);
2089 DeclarationName Name
= Results
[I
].Declaration
->getDeclName();
2090 if (IdentifierInfo
*Identifier
= Name
.getAsIdentifierInfo())
2091 HiddenNames
.insert(Identifier
->getName());
2093 HiddenNames
.insert(Name
.getAsString());
2097 void AugmentedCodeCompleteConsumer::ProcessCodeCompleteResults(Sema
&S
,
2098 CodeCompletionContext Context
,
2099 CodeCompletionResult
*Results
,
2100 unsigned NumResults
) {
2101 // Merge the results we were given with the results we cached.
2102 bool AddedResult
= false;
2103 uint64_t InContexts
=
2104 Context
.getKind() == CodeCompletionContext::CCC_Recovery
2105 ? NormalContexts
: (1LL << Context
.getKind());
2106 // Contains the set of names that are hidden by "local" completion results.
2107 llvm::StringSet
<llvm::BumpPtrAllocator
> HiddenNames
;
2108 using Result
= CodeCompletionResult
;
2109 SmallVector
<Result
, 8> AllResults
;
2110 for (ASTUnit::cached_completion_iterator
2111 C
= AST
.cached_completion_begin(),
2112 CEnd
= AST
.cached_completion_end();
2114 // If the context we are in matches any of the contexts we are
2115 // interested in, we'll add this result.
2116 if ((C
->ShowInContexts
& InContexts
) == 0)
2119 // If we haven't added any results previously, do so now.
2121 CalculateHiddenNames(Context
, Results
, NumResults
, S
.Context
,
2123 AllResults
.insert(AllResults
.end(), Results
, Results
+ NumResults
);
2127 // Determine whether this global completion result is hidden by a local
2128 // completion result. If so, skip it.
2129 if (C
->Kind
!= CXCursor_MacroDefinition
&&
2130 HiddenNames
.count(C
->Completion
->getTypedText()))
2133 // Adjust priority based on similar type classes.
2134 unsigned Priority
= C
->Priority
;
2135 CodeCompletionString
*Completion
= C
->Completion
;
2136 if (!Context
.getPreferredType().isNull()) {
2137 if (C
->Kind
== CXCursor_MacroDefinition
) {
2138 Priority
= getMacroUsagePriority(C
->Completion
->getTypedText(),
2140 Context
.getPreferredType()->isAnyPointerType());
2141 } else if (C
->Type
) {
2142 CanQualType Expected
2143 = S
.Context
.getCanonicalType(
2144 Context
.getPreferredType().getUnqualifiedType());
2145 SimplifiedTypeClass ExpectedSTC
= getSimplifiedTypeClass(Expected
);
2146 if (ExpectedSTC
== C
->TypeClass
) {
2147 // We know this type is similar; check for an exact match.
2148 llvm::StringMap
<unsigned> &CachedCompletionTypes
2149 = AST
.getCachedCompletionTypes();
2150 llvm::StringMap
<unsigned>::iterator Pos
2151 = CachedCompletionTypes
.find(QualType(Expected
).getAsString());
2152 if (Pos
!= CachedCompletionTypes
.end() && Pos
->second
== C
->Type
)
2153 Priority
/= CCF_ExactTypeMatch
;
2155 Priority
/= CCF_SimilarTypeMatch
;
2160 // Adjust the completion string, if required.
2161 if (C
->Kind
== CXCursor_MacroDefinition
&&
2162 Context
.getKind() == CodeCompletionContext::CCC_MacroNameUse
) {
2163 // Create a new code-completion string that just contains the
2164 // macro name, without its arguments.
2165 CodeCompletionBuilder
Builder(getAllocator(), getCodeCompletionTUInfo(),
2166 CCP_CodePattern
, C
->Availability
);
2167 Builder
.AddTypedTextChunk(C
->Completion
->getTypedText());
2168 Priority
= CCP_CodePattern
;
2169 Completion
= Builder
.TakeString();
2172 AllResults
.push_back(Result(Completion
, Priority
, C
->Kind
,
2176 // If we did not add any cached completion results, just forward the
2177 // results we were given to the next consumer.
2179 Next
.ProcessCodeCompleteResults(S
, Context
, Results
, NumResults
);
2183 Next
.ProcessCodeCompleteResults(S
, Context
, AllResults
.data(),
2187 void ASTUnit::CodeComplete(
2188 StringRef File
, unsigned Line
, unsigned Column
,
2189 ArrayRef
<RemappedFile
> RemappedFiles
, bool IncludeMacros
,
2190 bool IncludeCodePatterns
, bool IncludeBriefComments
,
2191 CodeCompleteConsumer
&Consumer
,
2192 std::shared_ptr
<PCHContainerOperations
> PCHContainerOps
,
2193 DiagnosticsEngine
&Diag
, LangOptions
&LangOpts
, SourceManager
&SourceMgr
,
2194 FileManager
&FileMgr
, SmallVectorImpl
<StoredDiagnostic
> &StoredDiagnostics
,
2195 SmallVectorImpl
<const llvm::MemoryBuffer
*> &OwnedBuffers
,
2196 std::unique_ptr
<SyntaxOnlyAction
> Act
) {
2200 SimpleTimer
CompletionTimer(WantTiming
);
2201 CompletionTimer
.setOutput("Code completion @ " + File
+ ":" +
2202 Twine(Line
) + ":" + Twine(Column
));
2204 auto CCInvocation
= std::make_shared
<CompilerInvocation
>(*Invocation
);
2206 FrontendOptions
&FrontendOpts
= CCInvocation
->getFrontendOpts();
2207 CodeCompleteOptions
&CodeCompleteOpts
= FrontendOpts
.CodeCompleteOpts
;
2208 PreprocessorOptions
&PreprocessorOpts
= CCInvocation
->getPreprocessorOpts();
2210 CodeCompleteOpts
.IncludeMacros
= IncludeMacros
&&
2211 CachedCompletionResults
.empty();
2212 CodeCompleteOpts
.IncludeCodePatterns
= IncludeCodePatterns
;
2213 CodeCompleteOpts
.IncludeGlobals
= CachedCompletionResults
.empty();
2214 CodeCompleteOpts
.IncludeBriefComments
= IncludeBriefComments
;
2215 CodeCompleteOpts
.LoadExternal
= Consumer
.loadExternal();
2216 CodeCompleteOpts
.IncludeFixIts
= Consumer
.includeFixIts();
2218 assert(IncludeBriefComments
== this->IncludeBriefCommentsInCodeCompletion
);
2220 FrontendOpts
.CodeCompletionAt
.FileName
= std::string(File
);
2221 FrontendOpts
.CodeCompletionAt
.Line
= Line
;
2222 FrontendOpts
.CodeCompletionAt
.Column
= Column
;
2224 // Set the language options appropriately.
2225 LangOpts
= CCInvocation
->getLangOpts();
2227 // Spell-checking and warnings are wasteful during code-completion.
2228 LangOpts
.SpellChecking
= false;
2229 CCInvocation
->getDiagnosticOpts().IgnoreWarnings
= true;
2231 std::unique_ptr
<CompilerInstance
> Clang(
2232 new CompilerInstance(PCHContainerOps
));
2234 // Recover resources if we crash before exiting this method.
2235 llvm::CrashRecoveryContextCleanupRegistrar
<CompilerInstance
>
2236 CICleanup(Clang
.get());
2238 auto &Inv
= *CCInvocation
;
2239 Clang
->setInvocation(std::move(CCInvocation
));
2240 OriginalSourceFile
=
2241 std::string(Clang
->getFrontendOpts().Inputs
[0].getFile());
2243 // Set up diagnostics, capturing any diagnostics produced.
2244 Clang
->setDiagnostics(&Diag
);
2245 CaptureDroppedDiagnostics
Capture(CaptureDiagsKind::All
,
2246 Clang
->getDiagnostics(),
2247 &StoredDiagnostics
, nullptr);
2248 ProcessWarningOptions(Diag
, Inv
.getDiagnosticOpts(),
2249 FileMgr
.getVirtualFileSystem());
2251 // Create the target instance.
2252 if (!Clang
->createTarget()) {
2253 Clang
->setInvocation(nullptr);
2257 assert(Clang
->getFrontendOpts().Inputs
.size() == 1 &&
2258 "Invocation must have exactly one source file!");
2259 assert(Clang
->getFrontendOpts().Inputs
[0].getKind().getFormat() ==
2260 InputKind::Source
&&
2261 "FIXME: AST inputs not yet supported here!");
2262 assert(Clang
->getFrontendOpts().Inputs
[0].getKind().getLanguage() !=
2263 Language::LLVM_IR
&&
2264 "IR inputs not support here!");
2266 // Use the source and file managers that we were given.
2267 Clang
->setFileManager(&FileMgr
);
2268 Clang
->setSourceManager(&SourceMgr
);
2271 PreprocessorOpts
.clearRemappedFiles();
2272 PreprocessorOpts
.RetainRemappedFileBuffers
= true;
2273 for (const auto &RemappedFile
: RemappedFiles
) {
2274 PreprocessorOpts
.addRemappedFile(RemappedFile
.first
, RemappedFile
.second
);
2275 OwnedBuffers
.push_back(RemappedFile
.second
);
2278 // Use the code completion consumer we were given, but adding any cached
2279 // code-completion results.
2280 AugmentedCodeCompleteConsumer
*AugmentedConsumer
2281 = new AugmentedCodeCompleteConsumer(*this, Consumer
, CodeCompleteOpts
);
2282 Clang
->setCodeCompletionConsumer(AugmentedConsumer
);
2285 [&FileMgr
](StringRef Filename
) -> std::optional
<llvm::sys::fs::UniqueID
> {
2286 if (auto Status
= FileMgr
.getVirtualFileSystem().status(Filename
))
2287 return Status
->getUniqueID();
2288 return std::nullopt
;
2291 auto hasSameUniqueID
= [getUniqueID
](StringRef LHS
, StringRef RHS
) {
2294 if (auto LHSID
= getUniqueID(LHS
))
2295 if (auto RHSID
= getUniqueID(RHS
))
2296 return *LHSID
== *RHSID
;
2300 // If we have a precompiled preamble, try to use it. We only allow
2301 // the use of the precompiled preamble if we're if the completion
2302 // point is within the main file, after the end of the precompiled
2304 std::unique_ptr
<llvm::MemoryBuffer
> OverrideMainBuffer
;
2305 if (Preamble
&& Line
> 1 && hasSameUniqueID(File
, OriginalSourceFile
)) {
2306 OverrideMainBuffer
= getMainBufferWithPrecompiledPreamble(
2307 PCHContainerOps
, Inv
, &FileMgr
.getVirtualFileSystem(), false, Line
- 1);
2310 // If the main file has been overridden due to the use of a preamble,
2311 // make that override happen and introduce the preamble.
2312 if (OverrideMainBuffer
) {
2314 "No preamble was built, but OverrideMainBuffer is not null");
2316 IntrusiveRefCntPtr
<llvm::vfs::FileSystem
> VFS
=
2317 &FileMgr
.getVirtualFileSystem();
2318 Preamble
->AddImplicitPreamble(Clang
->getInvocation(), VFS
,
2319 OverrideMainBuffer
.get());
2320 // FIXME: there is no way to update VFS if it was changed by
2321 // AddImplicitPreamble as FileMgr is accepted as a parameter by this method.
2322 // We use on-disk preambles instead and rely on FileMgr's VFS to ensure the
2323 // PCH files are always readable.
2324 OwnedBuffers
.push_back(OverrideMainBuffer
.release());
2326 PreprocessorOpts
.PrecompiledPreambleBytes
.first
= 0;
2327 PreprocessorOpts
.PrecompiledPreambleBytes
.second
= false;
2330 // Disable the preprocessing record if modules are not enabled.
2331 if (!Clang
->getLangOpts().Modules
)
2332 PreprocessorOpts
.DetailedRecord
= false;
2335 Act
.reset(new SyntaxOnlyAction
);
2337 if (Act
->BeginSourceFile(*Clang
.get(), Clang
->getFrontendOpts().Inputs
[0])) {
2338 if (llvm::Error Err
= Act
->Execute()) {
2339 consumeError(std::move(Err
)); // FIXME this drops errors on the floor.
2341 Act
->EndSourceFile();
2345 bool ASTUnit::Save(StringRef File
) {
2346 if (HadModuleLoaderFatalFailure
)
2349 // FIXME: Can we somehow regenerate the stat cache here, or do we need to
2350 // unconditionally create a stat cache when we parse the file?
2352 if (llvm::Error Err
= llvm::writeToOutput(
2353 File
, [this](llvm::raw_ostream
&Out
) {
2354 return serialize(Out
) ? llvm::make_error
<llvm::StringError
>(
2355 "ASTUnit serialization failed",
2356 llvm::inconvertibleErrorCode())
2357 : llvm::Error::success();
2359 consumeError(std::move(Err
));
2365 static bool serializeUnit(ASTWriter
&Writer
, SmallVectorImpl
<char> &Buffer
,
2366 Sema
&S
, raw_ostream
&OS
) {
2367 Writer
.WriteAST(&S
, std::string(), nullptr, "");
2369 // Write the generated bitstream to "Out".
2370 if (!Buffer
.empty())
2371 OS
.write(Buffer
.data(), Buffer
.size());
2376 bool ASTUnit::serialize(raw_ostream
&OS
) {
2378 return serializeUnit(WriterData
->Writer
, WriterData
->Buffer
, getSema(), OS
);
2380 SmallString
<128> Buffer
;
2381 llvm::BitstreamWriter
Stream(Buffer
);
2382 InMemoryModuleCache ModuleCache
;
2383 ASTWriter
Writer(Stream
, Buffer
, ModuleCache
, {});
2384 return serializeUnit(Writer
, Buffer
, getSema(), OS
);
2387 void ASTUnit::TranslateStoredDiagnostics(
2388 FileManager
&FileMgr
,
2389 SourceManager
&SrcMgr
,
2390 const SmallVectorImpl
<StandaloneDiagnostic
> &Diags
,
2391 SmallVectorImpl
<StoredDiagnostic
> &Out
) {
2392 // Map the standalone diagnostic into the new source manager. We also need to
2393 // remap all the locations to the new view. This includes the diag location,
2394 // any associated source ranges, and the source ranges of associated fix-its.
2395 // FIXME: There should be a cleaner way to do this.
2396 SmallVector
<StoredDiagnostic
, 4> Result
;
2397 Result
.reserve(Diags
.size());
2399 for (const auto &SD
: Diags
) {
2400 // Rebuild the StoredDiagnostic.
2401 if (SD
.Filename
.empty())
2403 auto FE
= FileMgr
.getOptionalFileRef(SD
.Filename
);
2406 SourceLocation FileLoc
;
2407 auto ItFileID
= PreambleSrcLocCache
.find(SD
.Filename
);
2408 if (ItFileID
== PreambleSrcLocCache
.end()) {
2409 FileID FID
= SrcMgr
.translateFile(*FE
);
2410 FileLoc
= SrcMgr
.getLocForStartOfFile(FID
);
2411 PreambleSrcLocCache
[SD
.Filename
] = FileLoc
;
2413 FileLoc
= ItFileID
->getValue();
2416 if (FileLoc
.isInvalid())
2418 SourceLocation L
= FileLoc
.getLocWithOffset(SD
.LocOffset
);
2419 FullSourceLoc
Loc(L
, SrcMgr
);
2421 SmallVector
<CharSourceRange
, 4> Ranges
;
2422 Ranges
.reserve(SD
.Ranges
.size());
2423 for (const auto &Range
: SD
.Ranges
) {
2424 SourceLocation BL
= FileLoc
.getLocWithOffset(Range
.first
);
2425 SourceLocation EL
= FileLoc
.getLocWithOffset(Range
.second
);
2426 Ranges
.push_back(CharSourceRange::getCharRange(BL
, EL
));
2429 SmallVector
<FixItHint
, 2> FixIts
;
2430 FixIts
.reserve(SD
.FixIts
.size());
2431 for (const auto &FixIt
: SD
.FixIts
) {
2432 FixIts
.push_back(FixItHint());
2433 FixItHint
&FH
= FixIts
.back();
2434 FH
.CodeToInsert
= FixIt
.CodeToInsert
;
2435 SourceLocation BL
= FileLoc
.getLocWithOffset(FixIt
.RemoveRange
.first
);
2436 SourceLocation EL
= FileLoc
.getLocWithOffset(FixIt
.RemoveRange
.second
);
2437 FH
.RemoveRange
= CharSourceRange::getCharRange(BL
, EL
);
2440 Result
.push_back(StoredDiagnostic(SD
.Level
, SD
.ID
,
2441 SD
.Message
, Loc
, Ranges
, FixIts
));
2446 void ASTUnit::addFileLevelDecl(Decl
*D
) {
2449 // We only care about local declarations.
2450 if (D
->isFromASTFile())
2453 SourceManager
&SM
= *SourceMgr
;
2454 SourceLocation Loc
= D
->getLocation();
2455 if (Loc
.isInvalid() || !SM
.isLocalSourceLocation(Loc
))
2458 // We only keep track of the file-level declarations of each file.
2459 if (!D
->getLexicalDeclContext()->isFileContext())
2462 SourceLocation FileLoc
= SM
.getFileLoc(Loc
);
2463 assert(SM
.isLocalSourceLocation(FileLoc
));
2466 std::tie(FID
, Offset
) = SM
.getDecomposedLoc(FileLoc
);
2467 if (FID
.isInvalid())
2470 std::unique_ptr
<LocDeclsTy
> &Decls
= FileDecls
[FID
];
2472 Decls
= std::make_unique
<LocDeclsTy
>();
2474 std::pair
<unsigned, Decl
*> LocDecl(Offset
, D
);
2476 if (Decls
->empty() || Decls
->back().first
<= Offset
) {
2477 Decls
->push_back(LocDecl
);
2481 LocDeclsTy::iterator I
=
2482 llvm::upper_bound(*Decls
, LocDecl
, llvm::less_first());
2484 Decls
->insert(I
, LocDecl
);
2487 void ASTUnit::findFileRegionDecls(FileID File
, unsigned Offset
, unsigned Length
,
2488 SmallVectorImpl
<Decl
*> &Decls
) {
2489 if (File
.isInvalid())
2492 if (SourceMgr
->isLoadedFileID(File
)) {
2493 assert(Ctx
->getExternalSource() && "No external source!");
2494 return Ctx
->getExternalSource()->FindFileRegionDecls(File
, Offset
, Length
,
2498 FileDeclsTy::iterator I
= FileDecls
.find(File
);
2499 if (I
== FileDecls
.end())
2502 LocDeclsTy
&LocDecls
= *I
->second
;
2503 if (LocDecls
.empty())
2506 LocDeclsTy::iterator BeginIt
=
2507 llvm::partition_point(LocDecls
, [=](std::pair
<unsigned, Decl
*> LD
) {
2508 return LD
.first
< Offset
;
2510 if (BeginIt
!= LocDecls
.begin())
2513 // If we are pointing at a top-level decl inside an objc container, we need
2514 // to backtrack until we find it otherwise we will fail to report that the
2515 // region overlaps with an objc container.
2516 while (BeginIt
!= LocDecls
.begin() &&
2517 BeginIt
->second
->isTopLevelDeclInObjCContainer())
2520 LocDeclsTy::iterator EndIt
= llvm::upper_bound(
2521 LocDecls
, std::make_pair(Offset
+ Length
, (Decl
*)nullptr),
2522 llvm::less_first());
2523 if (EndIt
!= LocDecls
.end())
2526 for (LocDeclsTy::iterator DIt
= BeginIt
; DIt
!= EndIt
; ++DIt
)
2527 Decls
.push_back(DIt
->second
);
2530 SourceLocation
ASTUnit::getLocation(const FileEntry
*File
,
2531 unsigned Line
, unsigned Col
) const {
2532 const SourceManager
&SM
= getSourceManager();
2533 SourceLocation Loc
= SM
.translateFileLineCol(File
, Line
, Col
);
2534 return SM
.getMacroArgExpandedLocation(Loc
);
2537 SourceLocation
ASTUnit::getLocation(const FileEntry
*File
,
2538 unsigned Offset
) const {
2539 const SourceManager
&SM
= getSourceManager();
2540 SourceLocation FileLoc
= SM
.translateFileLineCol(File
, 1, 1);
2541 return SM
.getMacroArgExpandedLocation(FileLoc
.getLocWithOffset(Offset
));
2544 /// If \arg Loc is a loaded location from the preamble, returns
2545 /// the corresponding local location of the main file, otherwise it returns
2547 SourceLocation
ASTUnit::mapLocationFromPreamble(SourceLocation Loc
) const {
2550 PreambleID
= SourceMgr
->getPreambleFileID();
2552 if (Loc
.isInvalid() || !Preamble
|| PreambleID
.isInvalid())
2556 if (SourceMgr
->isInFileID(Loc
, PreambleID
, &Offs
) && Offs
< Preamble
->getBounds().Size
) {
2557 SourceLocation FileLoc
2558 = SourceMgr
->getLocForStartOfFile(SourceMgr
->getMainFileID());
2559 return FileLoc
.getLocWithOffset(Offs
);
2565 /// If \arg Loc is a local location of the main file but inside the
2566 /// preamble chunk, returns the corresponding loaded location from the
2567 /// preamble, otherwise it returns \arg Loc.
2568 SourceLocation
ASTUnit::mapLocationToPreamble(SourceLocation Loc
) const {
2571 PreambleID
= SourceMgr
->getPreambleFileID();
2573 if (Loc
.isInvalid() || !Preamble
|| PreambleID
.isInvalid())
2577 if (SourceMgr
->isInFileID(Loc
, SourceMgr
->getMainFileID(), &Offs
) &&
2578 Offs
< Preamble
->getBounds().Size
) {
2579 SourceLocation FileLoc
= SourceMgr
->getLocForStartOfFile(PreambleID
);
2580 return FileLoc
.getLocWithOffset(Offs
);
2586 bool ASTUnit::isInPreambleFileID(SourceLocation Loc
) const {
2589 FID
= SourceMgr
->getPreambleFileID();
2591 if (Loc
.isInvalid() || FID
.isInvalid())
2594 return SourceMgr
->isInFileID(Loc
, FID
);
2597 bool ASTUnit::isInMainFileID(SourceLocation Loc
) const {
2600 FID
= SourceMgr
->getMainFileID();
2602 if (Loc
.isInvalid() || FID
.isInvalid())
2605 return SourceMgr
->isInFileID(Loc
, FID
);
2608 SourceLocation
ASTUnit::getEndOfPreambleFileID() const {
2611 FID
= SourceMgr
->getPreambleFileID();
2613 if (FID
.isInvalid())
2616 return SourceMgr
->getLocForEndOfFile(FID
);
2619 SourceLocation
ASTUnit::getStartOfMainFileID() const {
2622 FID
= SourceMgr
->getMainFileID();
2624 if (FID
.isInvalid())
2627 return SourceMgr
->getLocForStartOfFile(FID
);
2630 llvm::iterator_range
<PreprocessingRecord::iterator
>
2631 ASTUnit::getLocalPreprocessingEntities() const {
2632 if (isMainFileAST()) {
2633 serialization::ModuleFile
&
2634 Mod
= Reader
->getModuleManager().getPrimaryModule();
2635 return Reader
->getModulePreprocessedEntities(Mod
);
2638 if (PreprocessingRecord
*PPRec
= PP
->getPreprocessingRecord())
2639 return llvm::make_range(PPRec
->local_begin(), PPRec
->local_end());
2641 return llvm::make_range(PreprocessingRecord::iterator(),
2642 PreprocessingRecord::iterator());
2645 bool ASTUnit::visitLocalTopLevelDecls(void *context
, DeclVisitorFn Fn
) {
2646 if (isMainFileAST()) {
2647 serialization::ModuleFile
&
2648 Mod
= Reader
->getModuleManager().getPrimaryModule();
2649 for (const auto *D
: Reader
->getModuleFileLevelDecls(Mod
)) {
2650 if (!Fn(context
, D
))
2657 for (ASTUnit::top_level_iterator TL
= top_level_begin(),
2658 TLEnd
= top_level_end();
2659 TL
!= TLEnd
; ++TL
) {
2660 if (!Fn(context
, *TL
))
2667 OptionalFileEntryRef
ASTUnit::getPCHFile() {
2669 return std::nullopt
;
2671 serialization::ModuleFile
*Mod
= nullptr;
2672 Reader
->getModuleManager().visit([&Mod
](serialization::ModuleFile
&M
) {
2674 case serialization::MK_ImplicitModule
:
2675 case serialization::MK_ExplicitModule
:
2676 case serialization::MK_PrebuiltModule
:
2677 return true; // skip dependencies.
2678 case serialization::MK_PCH
:
2680 return true; // found it.
2681 case serialization::MK_Preamble
:
2682 return false; // look in dependencies.
2683 case serialization::MK_MainFile
:
2684 return false; // look in dependencies.
2692 return std::nullopt
;
2695 bool ASTUnit::isModuleFile() const {
2696 return isMainFileAST() && getLangOpts().isCompilingModule();
2699 InputKind
ASTUnit::getInputKind() const {
2700 auto &LangOpts
= getLangOpts();
2703 if (LangOpts
.OpenCL
)
2704 Lang
= Language::OpenCL
;
2705 else if (LangOpts
.CUDA
)
2706 Lang
= Language::CUDA
;
2707 else if (LangOpts
.CPlusPlus
)
2708 Lang
= LangOpts
.ObjC
? Language::ObjCXX
: Language::CXX
;
2710 Lang
= LangOpts
.ObjC
? Language::ObjC
: Language::C
;
2712 InputKind::Format Fmt
= InputKind::Source
;
2713 if (LangOpts
.getCompilingModule() == LangOptions::CMK_ModuleMap
)
2714 Fmt
= InputKind::ModuleMap
;
2716 // We don't know if input was preprocessed. Assume not.
2719 return InputKind(Lang
, Fmt
, PP
);
2723 ASTUnit::ConcurrencyState::ConcurrencyState() {
2724 Mutex
= new std::recursive_mutex
;
2727 ASTUnit::ConcurrencyState::~ConcurrencyState() {
2728 delete static_cast<std::recursive_mutex
*>(Mutex
);
2731 void ASTUnit::ConcurrencyState::start() {
2732 bool acquired
= static_cast<std::recursive_mutex
*>(Mutex
)->try_lock();
2733 assert(acquired
&& "Concurrent access to ASTUnit!");
2736 void ASTUnit::ConcurrencyState::finish() {
2737 static_cast<std::recursive_mutex
*>(Mutex
)->unlock();
2742 ASTUnit::ConcurrencyState::ConcurrencyState() { Mutex
= nullptr; }
2743 ASTUnit::ConcurrencyState::~ConcurrencyState() {}
2744 void ASTUnit::ConcurrencyState::start() {}
2745 void ASTUnit::ConcurrencyState::finish() {}