1 //===- ASTUnit.cpp - ASTUnit utility --------------------------------------===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 // 9 // ASTUnit Implementation. 10 // 11 //===----------------------------------------------------------------------===// 12 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/Serialization/ASTBitCodes.h" 60 #include "clang/Serialization/ASTReader.h" 61 #include "clang/Serialization/ASTWriter.h" 62 #include "clang/Serialization/ContinuousRangeMap.h" 63 #include "clang/Serialization/InMemoryModuleCache.h" 64 #include "clang/Serialization/ModuleFile.h" 65 #include "clang/Serialization/PCHContainerOperations.h" 66 #include "llvm/ADT/ArrayRef.h" 67 #include "llvm/ADT/DenseMap.h" 68 #include "llvm/ADT/IntrusiveRefCntPtr.h" 69 #include "llvm/ADT/None.h" 70 #include "llvm/ADT/Optional.h" 71 #include "llvm/ADT/STLExtras.h" 72 #include "llvm/ADT/ScopeExit.h" 73 #include "llvm/ADT/SmallString.h" 74 #include "llvm/ADT/SmallVector.h" 75 #include "llvm/ADT/StringMap.h" 76 #include "llvm/ADT/StringRef.h" 77 #include "llvm/ADT/StringSet.h" 78 #include "llvm/ADT/Twine.h" 79 #include "llvm/ADT/iterator_range.h" 80 #include "llvm/Bitstream/BitstreamWriter.h" 81 #include "llvm/Support/Allocator.h" 82 #include "llvm/Support/Casting.h" 83 #include "llvm/Support/CrashRecoveryContext.h" 84 #include "llvm/Support/DJB.h" 85 #include "llvm/Support/ErrorHandling.h" 86 #include "llvm/Support/ErrorOr.h" 87 #include "llvm/Support/FileSystem.h" 88 #include "llvm/Support/FileUtilities.h" 89 #include "llvm/Support/MemoryBuffer.h" 90 #include "llvm/Support/Timer.h" 91 #include "llvm/Support/VirtualFileSystem.h" 92 #include "llvm/Support/raw_ostream.h" 93 #include <algorithm> 94 #include <atomic> 95 #include <cassert> 96 #include <cstdint> 97 #include <cstdio> 98 #include <cstdlib> 99 #include <memory> 100 #include <mutex> 101 #include <string> 102 #include <tuple> 103 #include <utility> 104 #include <vector> 105 106 using namespace clang; 107 108 using llvm::TimeRecord; 109 110 namespace { 111 112 class SimpleTimer { 113 bool WantTiming; 114 TimeRecord Start; 115 std::string Output; 116 117 public: 118 explicit SimpleTimer(bool WantTiming) : WantTiming(WantTiming) { 119 if (WantTiming) 120 Start = TimeRecord::getCurrentTime(); 121 } 122 123 ~SimpleTimer() { 124 if (WantTiming) { 125 TimeRecord Elapsed = TimeRecord::getCurrentTime(); 126 Elapsed -= Start; 127 llvm::errs() << Output << ':'; 128 Elapsed.print(Elapsed, llvm::errs()); 129 llvm::errs() << '\n'; 130 } 131 } 132 133 void setOutput(const Twine &Output) { 134 if (WantTiming) 135 this->Output = Output.str(); 136 } 137 }; 138 139 } // namespace 140 141 template <class T> 142 static std::unique_ptr<T> valueOrNull(llvm::ErrorOr<std::unique_ptr<T>> Val) { 143 if (!Val) 144 return nullptr; 145 return std::move(*Val); 146 } 147 148 template <class T> 149 static bool moveOnNoError(llvm::ErrorOr<T> Val, T &Output) { 150 if (!Val) 151 return false; 152 Output = std::move(*Val); 153 return true; 154 } 155 156 /// Get a source buffer for \p MainFilePath, handling all file-to-file 157 /// and file-to-buffer remappings inside \p Invocation. 158 static std::unique_ptr<llvm::MemoryBuffer> 159 getBufferForFileHandlingRemapping(const CompilerInvocation &Invocation, 160 llvm::vfs::FileSystem *VFS, 161 StringRef FilePath, bool isVolatile) { 162 const auto &PreprocessorOpts = Invocation.getPreprocessorOpts(); 163 164 // Try to determine if the main file has been remapped, either from the 165 // command line (to another file) or directly through the compiler 166 // invocation (to a memory buffer). 167 llvm::MemoryBuffer *Buffer = nullptr; 168 std::unique_ptr<llvm::MemoryBuffer> BufferOwner; 169 auto FileStatus = VFS->status(FilePath); 170 if (FileStatus) { 171 llvm::sys::fs::UniqueID MainFileID = FileStatus->getUniqueID(); 172 173 // Check whether there is a file-file remapping of the main file 174 for (const auto &RF : PreprocessorOpts.RemappedFiles) { 175 std::string MPath(RF.first); 176 auto MPathStatus = VFS->status(MPath); 177 if (MPathStatus) { 178 llvm::sys::fs::UniqueID MID = MPathStatus->getUniqueID(); 179 if (MainFileID == MID) { 180 // We found a remapping. Try to load the resulting, remapped source. 181 BufferOwner = valueOrNull(VFS->getBufferForFile(RF.second, -1, true, isVolatile)); 182 if (!BufferOwner) 183 return nullptr; 184 } 185 } 186 } 187 188 // Check whether there is a file-buffer remapping. It supercedes the 189 // file-file remapping. 190 for (const auto &RB : PreprocessorOpts.RemappedFileBuffers) { 191 std::string MPath(RB.first); 192 auto MPathStatus = VFS->status(MPath); 193 if (MPathStatus) { 194 llvm::sys::fs::UniqueID MID = MPathStatus->getUniqueID(); 195 if (MainFileID == MID) { 196 // We found a remapping. 197 BufferOwner.reset(); 198 Buffer = const_cast<llvm::MemoryBuffer *>(RB.second); 199 } 200 } 201 } 202 } 203 204 // If the main source file was not remapped, load it now. 205 if (!Buffer && !BufferOwner) { 206 BufferOwner = valueOrNull(VFS->getBufferForFile(FilePath, -1, true, isVolatile)); 207 if (!BufferOwner) 208 return nullptr; 209 } 210 211 if (BufferOwner) 212 return BufferOwner; 213 if (!Buffer) 214 return nullptr; 215 return llvm::MemoryBuffer::getMemBufferCopy(Buffer->getBuffer(), FilePath); 216 } 217 218 struct ASTUnit::ASTWriterData { 219 SmallString<128> Buffer; 220 llvm::BitstreamWriter Stream; 221 ASTWriter Writer; 222 223 ASTWriterData(InMemoryModuleCache &ModuleCache) 224 : Stream(Buffer), Writer(Stream, Buffer, ModuleCache, {}) {} 225 }; 226 227 void ASTUnit::clearFileLevelDecls() { 228 FileDecls.clear(); 229 } 230 231 /// After failing to build a precompiled preamble (due to 232 /// errors in the source that occurs in the preamble), the number of 233 /// reparses during which we'll skip even trying to precompile the 234 /// preamble. 235 const unsigned DefaultPreambleRebuildInterval = 5; 236 237 /// Tracks the number of ASTUnit objects that are currently active. 238 /// 239 /// Used for debugging purposes only. 240 static std::atomic<unsigned> ActiveASTUnitObjects; 241 242 ASTUnit::ASTUnit(bool _MainFileIsAST) 243 : MainFileIsAST(_MainFileIsAST), WantTiming(getenv("LIBCLANG_TIMING")), 244 ShouldCacheCodeCompletionResults(false), 245 IncludeBriefCommentsInCodeCompletion(false), UserFilesAreVolatile(false), 246 UnsafeToFree(false) { 247 if (getenv("LIBCLANG_OBJTRACKING")) 248 fprintf(stderr, "+++ %u translation units\n", ++ActiveASTUnitObjects); 249 } 250 251 ASTUnit::~ASTUnit() { 252 // If we loaded from an AST file, balance out the BeginSourceFile call. 253 if (MainFileIsAST && getDiagnostics().getClient()) { 254 getDiagnostics().getClient()->EndSourceFile(); 255 } 256 257 clearFileLevelDecls(); 258 259 // Free the buffers associated with remapped files. We are required to 260 // perform this operation here because we explicitly request that the 261 // compiler instance *not* free these buffers for each invocation of the 262 // parser. 263 if (Invocation && OwnsRemappedFileBuffers) { 264 PreprocessorOptions &PPOpts = Invocation->getPreprocessorOpts(); 265 for (const auto &RB : PPOpts.RemappedFileBuffers) 266 delete RB.second; 267 } 268 269 ClearCachedCompletionResults(); 270 271 if (getenv("LIBCLANG_OBJTRACKING")) 272 fprintf(stderr, "--- %u translation units\n", --ActiveASTUnitObjects); 273 } 274 275 void ASTUnit::setPreprocessor(std::shared_ptr<Preprocessor> PP) { 276 this->PP = std::move(PP); 277 } 278 279 void ASTUnit::enableSourceFileDiagnostics() { 280 assert(getDiagnostics().getClient() && Ctx && 281 "Bad context for source file"); 282 getDiagnostics().getClient()->BeginSourceFile(Ctx->getLangOpts(), PP.get()); 283 } 284 285 /// Determine the set of code-completion contexts in which this 286 /// declaration should be shown. 287 static uint64_t getDeclShowContexts(const NamedDecl *ND, 288 const LangOptions &LangOpts, 289 bool &IsNestedNameSpecifier) { 290 IsNestedNameSpecifier = false; 291 292 if (isa<UsingShadowDecl>(ND)) 293 ND = ND->getUnderlyingDecl(); 294 if (!ND) 295 return 0; 296 297 uint64_t Contexts = 0; 298 if (isa<TypeDecl>(ND) || isa<ObjCInterfaceDecl>(ND) || 299 isa<ClassTemplateDecl>(ND) || isa<TemplateTemplateParmDecl>(ND) || 300 isa<TypeAliasTemplateDecl>(ND)) { 301 // Types can appear in these contexts. 302 if (LangOpts.CPlusPlus || !isa<TagDecl>(ND)) 303 Contexts |= (1LL << CodeCompletionContext::CCC_TopLevel) 304 | (1LL << CodeCompletionContext::CCC_ObjCIvarList) 305 | (1LL << CodeCompletionContext::CCC_ClassStructUnion) 306 | (1LL << CodeCompletionContext::CCC_Statement) 307 | (1LL << CodeCompletionContext::CCC_Type) 308 | (1LL << CodeCompletionContext::CCC_ParenthesizedExpression); 309 310 // In C++, types can appear in expressions contexts (for functional casts). 311 if (LangOpts.CPlusPlus) 312 Contexts |= (1LL << CodeCompletionContext::CCC_Expression); 313 314 // In Objective-C, message sends can send interfaces. In Objective-C++, 315 // all types are available due to functional casts. 316 if (LangOpts.CPlusPlus || isa<ObjCInterfaceDecl>(ND)) 317 Contexts |= (1LL << CodeCompletionContext::CCC_ObjCMessageReceiver); 318 319 // In Objective-C, you can only be a subclass of another Objective-C class 320 if (const auto *ID = dyn_cast<ObjCInterfaceDecl>(ND)) { 321 // Objective-C interfaces can be used in a class property expression. 322 if (ID->getDefinition()) 323 Contexts |= (1LL << CodeCompletionContext::CCC_Expression); 324 Contexts |= (1LL << CodeCompletionContext::CCC_ObjCInterfaceName); 325 } 326 327 // Deal with tag names. 328 if (isa<EnumDecl>(ND)) { 329 Contexts |= (1LL << CodeCompletionContext::CCC_EnumTag); 330 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); 337 else 338 Contexts |= (1LL << CodeCompletionContext::CCC_ClassOrStructTag); 339 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); 356 357 // Part of the nested-name-specifier. 358 IsNestedNameSpecifier = true; 359 } 360 361 return Contexts; 362 } 363 364 void ASTUnit::CacheCodeCompletionResults() { 365 if (!TheSema) 366 return; 367 368 SimpleTimer Timer(WantTiming); 369 Timer.setOutput("Cache global code completions for " + getMainFileName()); 370 371 // Clear out the previous results. 372 ClearCachedCompletionResults(); 373 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->GatherGlobalCodeCompletions(*CachedCompletionAllocator, 380 CCTUInfo, Results); 381 382 // Translate global code completions into cached completions. 383 llvm::DenseMap<CanQualType, unsigned> CompletionTypes; 384 CodeCompletionContext CCContext(CodeCompletionContext::CCC_TopLevel); 385 386 for (auto &R : Results) { 387 switch (R.Kind) { 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; 399 400 // Keep track of the type of this completion in an ASTContext-agnostic 401 // way. 402 QualType UsageType = getDeclUsageType(*Ctx, R.Declaration); 403 if (UsageType.isNull()) { 404 CachedResult.TypeClass = STC_Void; 405 CachedResult.Type = 0; 406 } else { 407 CanQualType CanUsageType 408 = Ctx->getCanonicalType(UsageType.getUnqualifiedType()); 409 CachedResult.TypeClass = getSimplifiedTypeClass(CanUsageType); 410 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()] 418 = TypeValue; 419 } 420 421 CachedResult.Type = TypeValue; 422 } 423 424 CachedCompletionResults.push_back(CachedResult); 425 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++. 430 uint64_t NNSContexts 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); 443 444 if (isa<NamespaceDecl>(R.Declaration) || 445 isa<NamespaceAliasDecl>(R.Declaration)) 446 NNSContexts |= (1LL << CodeCompletionContext::CCC_Namespace); 447 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); 462 } 463 } 464 break; 465 } 466 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. 471 break; 472 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); 491 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); 498 break; 499 } 500 } 501 } 502 503 // Save the current top-level hash value. 504 CompletionCacheTopLevelHashValue = CurrentTopLevelHashValue; 505 } 506 507 void ASTUnit::ClearCachedCompletionResults() { 508 CachedCompletionResults.clear(); 509 CachedCompletionTypes.clear(); 510 CachedCompletionAllocator = nullptr; 511 } 512 513 namespace { 514 515 /// Gathers information from ASTReader that will be used to initialize 516 /// a Preprocessor. 517 class ASTInfoCollector : public ASTReaderListener { 518 Preprocessor &PP; 519 ASTContext *Context; 520 HeaderSearchOptions &HSOpts; 521 PreprocessorOptions &PPOpts; 522 LangOptions &LangOpt; 523 std::shared_ptr<TargetOptions> &TargetOpts; 524 IntrusiveRefCntPtr<TargetInfo> &Target; 525 unsigned &Counter; 526 bool InitializedLanguage = false; 527 528 public: 529 ASTInfoCollector(Preprocessor &PP, ASTContext *Context, 530 HeaderSearchOptions &HSOpts, PreprocessorOptions &PPOpts, 531 LangOptions &LangOpt, 532 std::shared_ptr<TargetOptions> &TargetOpts, 533 IntrusiveRefCntPtr<TargetInfo> &Target, unsigned &Counter) 534 : PP(PP), Context(Context), HSOpts(HSOpts), PPOpts(PPOpts), 535 LangOpt(LangOpt), TargetOpts(TargetOpts), Target(Target), 536 Counter(Counter) {} 537 538 bool ReadLanguageOptions(const LangOptions &LangOpts, bool Complain, 539 bool AllowCompatibleDifferences) override { 540 if (InitializedLanguage) 541 return false; 542 543 LangOpt = LangOpts; 544 InitializedLanguage = true; 545 546 updated(); 547 return false; 548 } 549 550 bool ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts, 551 StringRef SpecificModuleCachePath, 552 bool Complain) override { 553 this->HSOpts = HSOpts; 554 return false; 555 } 556 557 bool ReadPreprocessorOptions(const PreprocessorOptions &PPOpts, bool Complain, 558 std::string &SuggestedPredefines) override { 559 this->PPOpts = PPOpts; 560 return false; 561 } 562 563 bool ReadTargetOptions(const TargetOptions &TargetOpts, bool Complain, 564 bool AllowCompatibleDifferences) override { 565 // If we've already initialized the target, don't do it again. 566 if (Target) 567 return false; 568 569 this->TargetOpts = std::make_shared<TargetOptions>(TargetOpts); 570 Target = 571 TargetInfo::CreateTargetInfo(PP.getDiagnostics(), this->TargetOpts); 572 573 updated(); 574 return false; 575 } 576 577 void ReadCounter(const serialization::ModuleFile &M, 578 unsigned Value) override { 579 Counter = Value; 580 } 581 582 private: 583 void updated() { 584 if (!Target || !InitializedLanguage) 585 return; 586 587 // Inform the target of the language options. 588 // 589 // FIXME: We shouldn't need to do this, the target should be immutable once 590 // created. This complexity should be lifted elsewhere. 591 Target->adjust(PP.getDiagnostics(), LangOpt); 592 593 // Initialize the preprocessor. 594 PP.Initialize(*Target); 595 596 if (!Context) 597 return; 598 599 // Initialize the ASTContext 600 Context->InitBuiltinTypes(*Target); 601 602 // Adjust printing policy based on language options. 603 Context->setPrintingPolicy(PrintingPolicy(LangOpt)); 604 605 // We didn't have access to the comment options when the ASTContext was 606 // constructed, so register them now. 607 Context->getCommentCommandTraits().registerCommentOptions( 608 LangOpt.CommentOpts); 609 } 610 }; 611 612 /// Diagnostic consumer that saves each diagnostic it is given. 613 class FilterAndStoreDiagnosticConsumer : public DiagnosticConsumer { 614 SmallVectorImpl<StoredDiagnostic> *StoredDiags; 615 SmallVectorImpl<ASTUnit::StandaloneDiagnostic> *StandaloneDiags; 616 bool CaptureNonErrorsFromIncludes = true; 617 const LangOptions *LangOpts = nullptr; 618 SourceManager *SourceMgr = nullptr; 619 620 public: 621 FilterAndStoreDiagnosticConsumer( 622 SmallVectorImpl<StoredDiagnostic> *StoredDiags, 623 SmallVectorImpl<ASTUnit::StandaloneDiagnostic> *StandaloneDiags, 624 bool CaptureNonErrorsFromIncludes) 625 : StoredDiags(StoredDiags), StandaloneDiags(StandaloneDiags), 626 CaptureNonErrorsFromIncludes(CaptureNonErrorsFromIncludes) { 627 assert((StoredDiags || StandaloneDiags) && 628 "No output collections were passed to StoredDiagnosticConsumer."); 629 } 630 631 void BeginSourceFile(const LangOptions &LangOpts, 632 const Preprocessor *PP = nullptr) override { 633 this->LangOpts = &LangOpts; 634 if (PP) 635 SourceMgr = &PP->getSourceManager(); 636 } 637 638 void HandleDiagnostic(DiagnosticsEngine::Level Level, 639 const Diagnostic &Info) override; 640 }; 641 642 /// RAII object that optionally captures and filters diagnostics, if 643 /// there is no diagnostic client to capture them already. 644 class CaptureDroppedDiagnostics { 645 DiagnosticsEngine &Diags; 646 FilterAndStoreDiagnosticConsumer Client; 647 DiagnosticConsumer *PreviousClient = nullptr; 648 std::unique_ptr<DiagnosticConsumer> OwningPreviousClient; 649 650 public: 651 CaptureDroppedDiagnostics( 652 CaptureDiagsKind CaptureDiagnostics, DiagnosticsEngine &Diags, 653 SmallVectorImpl<StoredDiagnostic> *StoredDiags, 654 SmallVectorImpl<ASTUnit::StandaloneDiagnostic> *StandaloneDiags) 655 : Diags(Diags), 656 Client(StoredDiags, StandaloneDiags, 657 CaptureDiagnostics != 658 CaptureDiagsKind::AllWithoutNonErrorsFromIncludes) { 659 if (CaptureDiagnostics != CaptureDiagsKind::None || 660 Diags.getClient() == nullptr) { 661 OwningPreviousClient = Diags.takeClient(); 662 PreviousClient = Diags.getClient(); 663 Diags.setClient(&Client, false); 664 } 665 } 666 667 ~CaptureDroppedDiagnostics() { 668 if (Diags.getClient() == &Client) 669 Diags.setClient(PreviousClient, !!OwningPreviousClient.release()); 670 } 671 }; 672 673 } // namespace 674 675 static ASTUnit::StandaloneDiagnostic 676 makeStandaloneDiagnostic(const LangOptions &LangOpts, 677 const StoredDiagnostic &InDiag); 678 679 static bool isInMainFile(const clang::Diagnostic &D) { 680 if (!D.hasSourceManager() || !D.getLocation().isValid()) 681 return false; 682 683 auto &M = D.getSourceManager(); 684 return M.isWrittenInMainFile(M.getExpansionLoc(D.getLocation())); 685 } 686 687 void FilterAndStoreDiagnosticConsumer::HandleDiagnostic( 688 DiagnosticsEngine::Level Level, const Diagnostic &Info) { 689 // Default implementation (Warnings/errors count). 690 DiagnosticConsumer::HandleDiagnostic(Level, Info); 691 692 // Only record the diagnostic if it's part of the source manager we know 693 // about. This effectively drops diagnostics from modules we're building. 694 // FIXME: In the long run, ee don't want to drop source managers from modules. 695 if (!Info.hasSourceManager() || &Info.getSourceManager() == SourceMgr) { 696 if (!CaptureNonErrorsFromIncludes && Level <= DiagnosticsEngine::Warning && 697 !isInMainFile(Info)) { 698 return; 699 } 700 701 StoredDiagnostic *ResultDiag = nullptr; 702 if (StoredDiags) { 703 StoredDiags->emplace_back(Level, Info); 704 ResultDiag = &StoredDiags->back(); 705 } 706 707 if (StandaloneDiags) { 708 llvm::Optional<StoredDiagnostic> StoredDiag = None; 709 if (!ResultDiag) { 710 StoredDiag.emplace(Level, Info); 711 ResultDiag = StoredDiag.getPointer(); 712 } 713 StandaloneDiags->push_back( 714 makeStandaloneDiagnostic(*LangOpts, *ResultDiag)); 715 } 716 } 717 } 718 719 IntrusiveRefCntPtr<ASTReader> ASTUnit::getASTReader() const { 720 return Reader; 721 } 722 723 ASTMutationListener *ASTUnit::getASTMutationListener() { 724 if (WriterData) 725 return &WriterData->Writer; 726 return nullptr; 727 } 728 729 ASTDeserializationListener *ASTUnit::getDeserializationListener() { 730 if (WriterData) 731 return &WriterData->Writer; 732 return nullptr; 733 } 734 735 std::unique_ptr<llvm::MemoryBuffer> 736 ASTUnit::getBufferForFile(StringRef Filename, std::string *ErrorStr) { 737 assert(FileMgr); 738 auto Buffer = FileMgr->getBufferForFile(Filename, UserFilesAreVolatile); 739 if (Buffer) 740 return std::move(*Buffer); 741 if (ErrorStr) 742 *ErrorStr = Buffer.getError().message(); 743 return nullptr; 744 } 745 746 /// Configure the diagnostics object for use with ASTUnit. 747 void ASTUnit::ConfigureDiags(IntrusiveRefCntPtr<DiagnosticsEngine> Diags, 748 ASTUnit &AST, 749 CaptureDiagsKind CaptureDiagnostics) { 750 assert(Diags.get() && "no DiagnosticsEngine was provided"); 751 if (CaptureDiagnostics != CaptureDiagsKind::None) 752 Diags->setClient(new FilterAndStoreDiagnosticConsumer( 753 &AST.StoredDiagnostics, nullptr, 754 CaptureDiagnostics != CaptureDiagsKind::AllWithoutNonErrorsFromIncludes)); 755 } 756 757 std::unique_ptr<ASTUnit> ASTUnit::LoadFromASTFile( 758 const std::string &Filename, const PCHContainerReader &PCHContainerRdr, 759 WhatToLoad ToLoad, IntrusiveRefCntPtr<DiagnosticsEngine> Diags, 760 const FileSystemOptions &FileSystemOpts, bool UseDebugInfo, 761 bool OnlyLocalDecls, CaptureDiagsKind CaptureDiagnostics, 762 bool AllowASTWithCompilerErrors, bool UserFilesAreVolatile, 763 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS) { 764 std::unique_ptr<ASTUnit> AST(new ASTUnit(true)); 765 766 // Recover resources if we crash before exiting this method. 767 llvm::CrashRecoveryContextCleanupRegistrar<ASTUnit> 768 ASTUnitCleanup(AST.get()); 769 llvm::CrashRecoveryContextCleanupRegistrar<DiagnosticsEngine, 770 llvm::CrashRecoveryContextReleaseRefCleanup<DiagnosticsEngine>> 771 DiagCleanup(Diags.get()); 772 773 ConfigureDiags(Diags, *AST, CaptureDiagnostics); 774 775 AST->LangOpts = std::make_shared<LangOptions>(); 776 AST->OnlyLocalDecls = OnlyLocalDecls; 777 AST->CaptureDiagnostics = CaptureDiagnostics; 778 AST->Diagnostics = Diags; 779 AST->FileMgr = new FileManager(FileSystemOpts, VFS); 780 AST->UserFilesAreVolatile = UserFilesAreVolatile; 781 AST->SourceMgr = new SourceManager(AST->getDiagnostics(), 782 AST->getFileManager(), 783 UserFilesAreVolatile); 784 AST->ModuleCache = new InMemoryModuleCache; 785 AST->HSOpts = std::make_shared<HeaderSearchOptions>(); 786 AST->HSOpts->ModuleFormat = std::string(PCHContainerRdr.getFormat()); 787 AST->HeaderInfo.reset(new HeaderSearch(AST->HSOpts, 788 AST->getSourceManager(), 789 AST->getDiagnostics(), 790 AST->getLangOpts(), 791 /*Target=*/nullptr)); 792 AST->PPOpts = std::make_shared<PreprocessorOptions>(); 793 794 // Gather Info for preprocessor construction later on. 795 796 HeaderSearch &HeaderInfo = *AST->HeaderInfo; 797 unsigned Counter; 798 799 AST->PP = std::make_shared<Preprocessor>( 800 AST->PPOpts, AST->getDiagnostics(), *AST->LangOpts, 801 AST->getSourceManager(), HeaderInfo, AST->ModuleLoader, 802 /*IILookup=*/nullptr, 803 /*OwnsHeaderSearch=*/false); 804 Preprocessor &PP = *AST->PP; 805 806 if (ToLoad >= LoadASTOnly) 807 AST->Ctx = new ASTContext(*AST->LangOpts, AST->getSourceManager(), 808 PP.getIdentifierTable(), PP.getSelectorTable(), 809 PP.getBuiltinInfo(), 810 AST->getTranslationUnitKind()); 811 812 DisableValidationForModuleKind disableValid = 813 DisableValidationForModuleKind::None; 814 if (::getenv("LIBCLANG_DISABLE_PCH_VALIDATION")) 815 disableValid = DisableValidationForModuleKind::All; 816 AST->Reader = new ASTReader( 817 PP, *AST->ModuleCache, AST->Ctx.get(), PCHContainerRdr, {}, 818 /*isysroot=*/"", 819 /*DisableValidationKind=*/disableValid, AllowASTWithCompilerErrors); 820 821 AST->Reader->setListener(std::make_unique<ASTInfoCollector>( 822 *AST->PP, AST->Ctx.get(), *AST->HSOpts, *AST->PPOpts, *AST->LangOpts, 823 AST->TargetOpts, AST->Target, Counter)); 824 825 // Attach the AST reader to the AST context as an external AST 826 // source, so that declarations will be deserialized from the 827 // AST file as needed. 828 // We need the external source to be set up before we read the AST, because 829 // eagerly-deserialized declarations may use it. 830 if (AST->Ctx) 831 AST->Ctx->setExternalSource(AST->Reader); 832 833 switch (AST->Reader->ReadAST(Filename, serialization::MK_MainFile, 834 SourceLocation(), ASTReader::ARR_None)) { 835 case ASTReader::Success: 836 break; 837 838 case ASTReader::Failure: 839 case ASTReader::Missing: 840 case ASTReader::OutOfDate: 841 case ASTReader::VersionMismatch: 842 case ASTReader::ConfigurationMismatch: 843 case ASTReader::HadErrors: 844 AST->getDiagnostics().Report(diag::err_fe_unable_to_load_pch); 845 return nullptr; 846 } 847 848 AST->OriginalSourceFile = std::string(AST->Reader->getOriginalSourceFile()); 849 850 PP.setCounterValue(Counter); 851 852 // Create an AST consumer, even though it isn't used. 853 if (ToLoad >= LoadASTOnly) 854 AST->Consumer.reset(new ASTConsumer); 855 856 // Create a semantic analysis object and tell the AST reader about it. 857 if (ToLoad >= LoadEverything) { 858 AST->TheSema.reset(new Sema(PP, *AST->Ctx, *AST->Consumer)); 859 AST->TheSema->Initialize(); 860 AST->Reader->InitializeSema(*AST->TheSema); 861 } 862 863 // Tell the diagnostic client that we have started a source file. 864 AST->getDiagnostics().getClient()->BeginSourceFile(PP.getLangOpts(), &PP); 865 866 return AST; 867 } 868 869 /// Add the given macro to the hash of all top-level entities. 870 static void AddDefinedMacroToHash(const Token &MacroNameTok, unsigned &Hash) { 871 Hash = llvm::djbHash(MacroNameTok.getIdentifierInfo()->getName(), Hash); 872 } 873 874 namespace { 875 876 /// Preprocessor callback class that updates a hash value with the names 877 /// of all macros that have been defined by the translation unit. 878 class MacroDefinitionTrackerPPCallbacks : public PPCallbacks { 879 unsigned &Hash; 880 881 public: 882 explicit MacroDefinitionTrackerPPCallbacks(unsigned &Hash) : Hash(Hash) {} 883 884 void MacroDefined(const Token &MacroNameTok, 885 const MacroDirective *MD) override { 886 AddDefinedMacroToHash(MacroNameTok, Hash); 887 } 888 }; 889 890 } // namespace 891 892 /// Add the given declaration to the hash of all top-level entities. 893 static void AddTopLevelDeclarationToHash(Decl *D, unsigned &Hash) { 894 if (!D) 895 return; 896 897 DeclContext *DC = D->getDeclContext(); 898 if (!DC) 899 return; 900 901 if (!(DC->isTranslationUnit() || DC->getLookupParent()->isTranslationUnit())) 902 return; 903 904 if (const auto *ND = dyn_cast<NamedDecl>(D)) { 905 if (const auto *EnumD = dyn_cast<EnumDecl>(D)) { 906 // For an unscoped enum include the enumerators in the hash since they 907 // enter the top-level namespace. 908 if (!EnumD->isScoped()) { 909 for (const auto *EI : EnumD->enumerators()) { 910 if (EI->getIdentifier()) 911 Hash = llvm::djbHash(EI->getIdentifier()->getName(), Hash); 912 } 913 } 914 } 915 916 if (ND->getIdentifier()) 917 Hash = llvm::djbHash(ND->getIdentifier()->getName(), Hash); 918 else if (DeclarationName Name = ND->getDeclName()) { 919 std::string NameStr = Name.getAsString(); 920 Hash = llvm::djbHash(NameStr, Hash); 921 } 922 return; 923 } 924 925 if (const auto *ImportD = dyn_cast<ImportDecl>(D)) { 926 if (const Module *Mod = ImportD->getImportedModule()) { 927 std::string ModName = Mod->getFullModuleName(); 928 Hash = llvm::djbHash(ModName, Hash); 929 } 930 return; 931 } 932 } 933 934 namespace { 935 936 class TopLevelDeclTrackerConsumer : public ASTConsumer { 937 ASTUnit &Unit; 938 unsigned &Hash; 939 940 public: 941 TopLevelDeclTrackerConsumer(ASTUnit &_Unit, unsigned &Hash) 942 : Unit(_Unit), Hash(Hash) { 943 Hash = 0; 944 } 945 946 void handleTopLevelDecl(Decl *D) { 947 if (!D) 948 return; 949 950 // FIXME: Currently ObjC method declarations are incorrectly being 951 // reported as top-level declarations, even though their DeclContext 952 // is the containing ObjC @interface/@implementation. This is a 953 // fundamental problem in the parser right now. 954 if (isa<ObjCMethodDecl>(D)) 955 return; 956 957 AddTopLevelDeclarationToHash(D, Hash); 958 Unit.addTopLevelDecl(D); 959 960 handleFileLevelDecl(D); 961 } 962 963 void handleFileLevelDecl(Decl *D) { 964 Unit.addFileLevelDecl(D); 965 if (auto *NSD = dyn_cast<NamespaceDecl>(D)) { 966 for (auto *I : NSD->decls()) 967 handleFileLevelDecl(I); 968 } 969 } 970 971 bool HandleTopLevelDecl(DeclGroupRef D) override { 972 for (auto *TopLevelDecl : D) 973 handleTopLevelDecl(TopLevelDecl); 974 return true; 975 } 976 977 // We're not interested in "interesting" decls. 978 void HandleInterestingDecl(DeclGroupRef) override {} 979 980 void HandleTopLevelDeclInObjCContainer(DeclGroupRef D) override { 981 for (auto *TopLevelDecl : D) 982 handleTopLevelDecl(TopLevelDecl); 983 } 984 985 ASTMutationListener *GetASTMutationListener() override { 986 return Unit.getASTMutationListener(); 987 } 988 989 ASTDeserializationListener *GetASTDeserializationListener() override { 990 return Unit.getDeserializationListener(); 991 } 992 }; 993 994 class TopLevelDeclTrackerAction : public ASTFrontendAction { 995 public: 996 ASTUnit &Unit; 997 998 std::unique_ptr<ASTConsumer> CreateASTConsumer(CompilerInstance &CI, 999 StringRef InFile) override { 1000 CI.getPreprocessor().addPPCallbacks( 1001 std::make_unique<MacroDefinitionTrackerPPCallbacks>( 1002 Unit.getCurrentTopLevelHashValue())); 1003 return std::make_unique<TopLevelDeclTrackerConsumer>( 1004 Unit, Unit.getCurrentTopLevelHashValue()); 1005 } 1006 1007 public: 1008 TopLevelDeclTrackerAction(ASTUnit &_Unit) : Unit(_Unit) {} 1009 1010 bool hasCodeCompletionSupport() const override { return false; } 1011 1012 TranslationUnitKind getTranslationUnitKind() override { 1013 return Unit.getTranslationUnitKind(); 1014 } 1015 }; 1016 1017 class ASTUnitPreambleCallbacks : public PreambleCallbacks { 1018 public: 1019 unsigned getHash() const { return Hash; } 1020 1021 std::vector<Decl *> takeTopLevelDecls() { return std::move(TopLevelDecls); } 1022 1023 std::vector<serialization::DeclID> takeTopLevelDeclIDs() { 1024 return std::move(TopLevelDeclIDs); 1025 } 1026 1027 void AfterPCHEmitted(ASTWriter &Writer) override { 1028 TopLevelDeclIDs.reserve(TopLevelDecls.size()); 1029 for (const auto *D : TopLevelDecls) { 1030 // Invalid top-level decls may not have been serialized. 1031 if (D->isInvalidDecl()) 1032 continue; 1033 TopLevelDeclIDs.push_back(Writer.getDeclID(D)); 1034 } 1035 } 1036 1037 void HandleTopLevelDecl(DeclGroupRef DG) override { 1038 for (auto *D : DG) { 1039 // FIXME: Currently ObjC method declarations are incorrectly being 1040 // reported as top-level declarations, even though their DeclContext 1041 // is the containing ObjC @interface/@implementation. This is a 1042 // fundamental problem in the parser right now. 1043 if (isa<ObjCMethodDecl>(D)) 1044 continue; 1045 AddTopLevelDeclarationToHash(D, Hash); 1046 TopLevelDecls.push_back(D); 1047 } 1048 } 1049 1050 std::unique_ptr<PPCallbacks> createPPCallbacks() override { 1051 return std::make_unique<MacroDefinitionTrackerPPCallbacks>(Hash); 1052 } 1053 1054 private: 1055 unsigned Hash = 0; 1056 std::vector<Decl *> TopLevelDecls; 1057 std::vector<serialization::DeclID> TopLevelDeclIDs; 1058 llvm::SmallVector<ASTUnit::StandaloneDiagnostic, 4> PreambleDiags; 1059 }; 1060 1061 } // namespace 1062 1063 static bool isNonDriverDiag(const StoredDiagnostic &StoredDiag) { 1064 return StoredDiag.getLocation().isValid(); 1065 } 1066 1067 static void 1068 checkAndRemoveNonDriverDiags(SmallVectorImpl<StoredDiagnostic> &StoredDiags) { 1069 // Get rid of stored diagnostics except the ones from the driver which do not 1070 // have a source location. 1071 llvm::erase_if(StoredDiags, isNonDriverDiag); 1072 } 1073 1074 static void checkAndSanitizeDiags(SmallVectorImpl<StoredDiagnostic> & 1075 StoredDiagnostics, 1076 SourceManager &SM) { 1077 // The stored diagnostic has the old source manager in it; update 1078 // the locations to refer into the new source manager. Since we've 1079 // been careful to make sure that the source manager's state 1080 // before and after are identical, so that we can reuse the source 1081 // location itself. 1082 for (auto &SD : StoredDiagnostics) { 1083 if (SD.getLocation().isValid()) { 1084 FullSourceLoc Loc(SD.getLocation(), SM); 1085 SD.setLocation(Loc); 1086 } 1087 } 1088 } 1089 1090 /// Parse the source file into a translation unit using the given compiler 1091 /// invocation, replacing the current translation unit. 1092 /// 1093 /// \returns True if a failure occurred that causes the ASTUnit not to 1094 /// contain any translation-unit information, false otherwise. 1095 bool ASTUnit::Parse(std::shared_ptr<PCHContainerOperations> PCHContainerOps, 1096 std::unique_ptr<llvm::MemoryBuffer> OverrideMainBuffer, 1097 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS) { 1098 if (!Invocation) 1099 return true; 1100 1101 if (VFS && FileMgr) 1102 assert(VFS == &FileMgr->getVirtualFileSystem() && 1103 "VFS passed to Parse and VFS in FileMgr are different"); 1104 1105 auto CCInvocation = std::make_shared<CompilerInvocation>(*Invocation); 1106 if (OverrideMainBuffer) { 1107 assert(Preamble && 1108 "No preamble was built, but OverrideMainBuffer is not null"); 1109 Preamble->AddImplicitPreamble(*CCInvocation, VFS, OverrideMainBuffer.get()); 1110 // VFS may have changed... 1111 } 1112 1113 // Create the compiler instance to use for building the AST. 1114 std::unique_ptr<CompilerInstance> Clang( 1115 new CompilerInstance(std::move(PCHContainerOps))); 1116 1117 // Clean up on error, disengage it if the function returns successfully. 1118 auto CleanOnError = llvm::make_scope_exit([&]() { 1119 // Remove the overridden buffer we used for the preamble. 1120 SavedMainFileBuffer = nullptr; 1121 1122 // Keep the ownership of the data in the ASTUnit because the client may 1123 // want to see the diagnostics. 1124 transferASTDataFromCompilerInstance(*Clang); 1125 FailedParseDiagnostics.swap(StoredDiagnostics); 1126 StoredDiagnostics.clear(); 1127 NumStoredDiagnosticsFromDriver = 0; 1128 }); 1129 1130 // Ensure that Clang has a FileManager with the right VFS, which may have 1131 // changed above in AddImplicitPreamble. If VFS is nullptr, rely on 1132 // createFileManager to create one. 1133 if (VFS && FileMgr && &FileMgr->getVirtualFileSystem() == VFS) 1134 Clang->setFileManager(&*FileMgr); 1135 else 1136 FileMgr = Clang->createFileManager(std::move(VFS)); 1137 1138 // Recover resources if we crash before exiting this method. 1139 llvm::CrashRecoveryContextCleanupRegistrar<CompilerInstance> 1140 CICleanup(Clang.get()); 1141 1142 Clang->setInvocation(CCInvocation); 1143 OriginalSourceFile = 1144 std::string(Clang->getFrontendOpts().Inputs[0].getFile()); 1145 1146 // Set up diagnostics, capturing any diagnostics that would 1147 // otherwise be dropped. 1148 Clang->setDiagnostics(&getDiagnostics()); 1149 1150 // Create the target instance. 1151 if (!Clang->createTarget()) 1152 return true; 1153 1154 assert(Clang->getFrontendOpts().Inputs.size() == 1 && 1155 "Invocation must have exactly one source file!"); 1156 assert(Clang->getFrontendOpts().Inputs[0].getKind().getFormat() == 1157 InputKind::Source && 1158 "FIXME: AST inputs not yet supported here!"); 1159 assert(Clang->getFrontendOpts().Inputs[0].getKind().getLanguage() != 1160 Language::LLVM_IR && 1161 "IR inputs not support here!"); 1162 1163 // Configure the various subsystems. 1164 LangOpts = Clang->getInvocation().LangOpts; 1165 FileSystemOpts = Clang->getFileSystemOpts(); 1166 1167 ResetForParse(); 1168 1169 SourceMgr = new SourceManager(getDiagnostics(), *FileMgr, 1170 UserFilesAreVolatile); 1171 if (!OverrideMainBuffer) { 1172 checkAndRemoveNonDriverDiags(StoredDiagnostics); 1173 TopLevelDeclsInPreamble.clear(); 1174 } 1175 1176 // Create the source manager. 1177 Clang->setSourceManager(&getSourceManager()); 1178 1179 // If the main file has been overridden due to the use of a preamble, 1180 // make that override happen and introduce the preamble. 1181 if (OverrideMainBuffer) { 1182 // The stored diagnostic has the old source manager in it; update 1183 // the locations to refer into the new source manager. Since we've 1184 // been careful to make sure that the source manager's state 1185 // before and after are identical, so that we can reuse the source 1186 // location itself. 1187 checkAndSanitizeDiags(StoredDiagnostics, getSourceManager()); 1188 1189 // Keep track of the override buffer; 1190 SavedMainFileBuffer = std::move(OverrideMainBuffer); 1191 } 1192 1193 std::unique_ptr<TopLevelDeclTrackerAction> Act( 1194 new TopLevelDeclTrackerAction(*this)); 1195 1196 // Recover resources if we crash before exiting this method. 1197 llvm::CrashRecoveryContextCleanupRegistrar<TopLevelDeclTrackerAction> 1198 ActCleanup(Act.get()); 1199 1200 if (!Act->BeginSourceFile(*Clang.get(), Clang->getFrontendOpts().Inputs[0])) 1201 return true; 1202 1203 if (SavedMainFileBuffer) 1204 TranslateStoredDiagnostics(getFileManager(), getSourceManager(), 1205 PreambleDiagnostics, StoredDiagnostics); 1206 else 1207 PreambleSrcLocCache.clear(); 1208 1209 if (llvm::Error Err = Act->Execute()) { 1210 consumeError(std::move(Err)); // FIXME this drops errors on the floor. 1211 return true; 1212 } 1213 1214 transferASTDataFromCompilerInstance(*Clang); 1215 1216 Act->EndSourceFile(); 1217 1218 FailedParseDiagnostics.clear(); 1219 1220 CleanOnError.release(); 1221 1222 return false; 1223 } 1224 1225 static std::pair<unsigned, unsigned> 1226 makeStandaloneRange(CharSourceRange Range, const SourceManager &SM, 1227 const LangOptions &LangOpts) { 1228 CharSourceRange FileRange = Lexer::makeFileCharRange(Range, SM, LangOpts); 1229 unsigned Offset = SM.getFileOffset(FileRange.getBegin()); 1230 unsigned EndOffset = SM.getFileOffset(FileRange.getEnd()); 1231 return std::make_pair(Offset, EndOffset); 1232 } 1233 1234 static ASTUnit::StandaloneFixIt makeStandaloneFixIt(const SourceManager &SM, 1235 const LangOptions &LangOpts, 1236 const FixItHint &InFix) { 1237 ASTUnit::StandaloneFixIt OutFix; 1238 OutFix.RemoveRange = makeStandaloneRange(InFix.RemoveRange, SM, LangOpts); 1239 OutFix.InsertFromRange = makeStandaloneRange(InFix.InsertFromRange, SM, 1240 LangOpts); 1241 OutFix.CodeToInsert = InFix.CodeToInsert; 1242 OutFix.BeforePreviousInsertions = InFix.BeforePreviousInsertions; 1243 return OutFix; 1244 } 1245 1246 static ASTUnit::StandaloneDiagnostic 1247 makeStandaloneDiagnostic(const LangOptions &LangOpts, 1248 const StoredDiagnostic &InDiag) { 1249 ASTUnit::StandaloneDiagnostic OutDiag; 1250 OutDiag.ID = InDiag.getID(); 1251 OutDiag.Level = InDiag.getLevel(); 1252 OutDiag.Message = std::string(InDiag.getMessage()); 1253 OutDiag.LocOffset = 0; 1254 if (InDiag.getLocation().isInvalid()) 1255 return OutDiag; 1256 const SourceManager &SM = InDiag.getLocation().getManager(); 1257 SourceLocation FileLoc = SM.getFileLoc(InDiag.getLocation()); 1258 OutDiag.Filename = std::string(SM.getFilename(FileLoc)); 1259 if (OutDiag.Filename.empty()) 1260 return OutDiag; 1261 OutDiag.LocOffset = SM.getFileOffset(FileLoc); 1262 for (const auto &Range : InDiag.getRanges()) 1263 OutDiag.Ranges.push_back(makeStandaloneRange(Range, SM, LangOpts)); 1264 for (const auto &FixIt : InDiag.getFixIts()) 1265 OutDiag.FixIts.push_back(makeStandaloneFixIt(SM, LangOpts, FixIt)); 1266 1267 return OutDiag; 1268 } 1269 1270 /// Attempt to build or re-use a precompiled preamble when (re-)parsing 1271 /// the source file. 1272 /// 1273 /// This routine will compute the preamble of the main source file. If a 1274 /// non-trivial preamble is found, it will precompile that preamble into a 1275 /// precompiled header so that the precompiled preamble can be used to reduce 1276 /// reparsing time. If a precompiled preamble has already been constructed, 1277 /// this routine will determine if it is still valid and, if so, avoid 1278 /// rebuilding the precompiled preamble. 1279 /// 1280 /// \param AllowRebuild When true (the default), this routine is 1281 /// allowed to rebuild the precompiled preamble if it is found to be 1282 /// out-of-date. 1283 /// 1284 /// \param MaxLines When non-zero, the maximum number of lines that 1285 /// can occur within the preamble. 1286 /// 1287 /// \returns If the precompiled preamble can be used, returns a newly-allocated 1288 /// buffer that should be used in place of the main file when doing so. 1289 /// Otherwise, returns a NULL pointer. 1290 std::unique_ptr<llvm::MemoryBuffer> 1291 ASTUnit::getMainBufferWithPrecompiledPreamble( 1292 std::shared_ptr<PCHContainerOperations> PCHContainerOps, 1293 CompilerInvocation &PreambleInvocationIn, 1294 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS, bool AllowRebuild, 1295 unsigned MaxLines) { 1296 auto MainFilePath = 1297 PreambleInvocationIn.getFrontendOpts().Inputs[0].getFile(); 1298 std::unique_ptr<llvm::MemoryBuffer> MainFileBuffer = 1299 getBufferForFileHandlingRemapping(PreambleInvocationIn, VFS.get(), 1300 MainFilePath, UserFilesAreVolatile); 1301 if (!MainFileBuffer) 1302 return nullptr; 1303 1304 PreambleBounds Bounds = ComputePreambleBounds( 1305 *PreambleInvocationIn.getLangOpts(), *MainFileBuffer, MaxLines); 1306 if (!Bounds.Size) 1307 return nullptr; 1308 1309 if (Preamble) { 1310 if (Preamble->CanReuse(PreambleInvocationIn, *MainFileBuffer, Bounds, 1311 *VFS)) { 1312 // Okay! We can re-use the precompiled preamble. 1313 1314 // Set the state of the diagnostic object to mimic its state 1315 // after parsing the preamble. 1316 getDiagnostics().Reset(); 1317 ProcessWarningOptions(getDiagnostics(), 1318 PreambleInvocationIn.getDiagnosticOpts()); 1319 getDiagnostics().setNumWarnings(NumWarningsInPreamble); 1320 1321 PreambleRebuildCountdown = 1; 1322 return MainFileBuffer; 1323 } else { 1324 Preamble.reset(); 1325 PreambleDiagnostics.clear(); 1326 TopLevelDeclsInPreamble.clear(); 1327 PreambleSrcLocCache.clear(); 1328 PreambleRebuildCountdown = 1; 1329 } 1330 } 1331 1332 // If the preamble rebuild counter > 1, it's because we previously 1333 // failed to build a preamble and we're not yet ready to try 1334 // again. Decrement the counter and return a failure. 1335 if (PreambleRebuildCountdown > 1) { 1336 --PreambleRebuildCountdown; 1337 return nullptr; 1338 } 1339 1340 assert(!Preamble && "No Preamble should be stored at that point"); 1341 // If we aren't allowed to rebuild the precompiled preamble, just 1342 // return now. 1343 if (!AllowRebuild) 1344 return nullptr; 1345 1346 ++PreambleCounter; 1347 1348 SmallVector<StandaloneDiagnostic, 4> NewPreambleDiagsStandalone; 1349 SmallVector<StoredDiagnostic, 4> NewPreambleDiags; 1350 ASTUnitPreambleCallbacks Callbacks; 1351 { 1352 llvm::Optional<CaptureDroppedDiagnostics> Capture; 1353 if (CaptureDiagnostics != CaptureDiagsKind::None) 1354 Capture.emplace(CaptureDiagnostics, *Diagnostics, &NewPreambleDiags, 1355 &NewPreambleDiagsStandalone); 1356 1357 // We did not previously compute a preamble, or it can't be reused anyway. 1358 SimpleTimer PreambleTimer(WantTiming); 1359 PreambleTimer.setOutput("Precompiling preamble"); 1360 1361 const bool PreviousSkipFunctionBodies = 1362 PreambleInvocationIn.getFrontendOpts().SkipFunctionBodies; 1363 if (SkipFunctionBodies == SkipFunctionBodiesScope::Preamble) 1364 PreambleInvocationIn.getFrontendOpts().SkipFunctionBodies = true; 1365 1366 llvm::ErrorOr<PrecompiledPreamble> NewPreamble = PrecompiledPreamble::Build( 1367 PreambleInvocationIn, MainFileBuffer.get(), Bounds, *Diagnostics, VFS, 1368 PCHContainerOps, /*StoreInMemory=*/false, Callbacks); 1369 1370 PreambleInvocationIn.getFrontendOpts().SkipFunctionBodies = 1371 PreviousSkipFunctionBodies; 1372 1373 if (NewPreamble) { 1374 Preamble = std::move(*NewPreamble); 1375 PreambleRebuildCountdown = 1; 1376 } else { 1377 switch (static_cast<BuildPreambleError>(NewPreamble.getError().value())) { 1378 case BuildPreambleError::CouldntCreateTempFile: 1379 // Try again next time. 1380 PreambleRebuildCountdown = 1; 1381 return nullptr; 1382 case BuildPreambleError::CouldntCreateTargetInfo: 1383 case BuildPreambleError::BeginSourceFileFailed: 1384 case BuildPreambleError::CouldntEmitPCH: 1385 case BuildPreambleError::BadInputs: 1386 // These erros are more likely to repeat, retry after some period. 1387 PreambleRebuildCountdown = DefaultPreambleRebuildInterval; 1388 return nullptr; 1389 } 1390 llvm_unreachable("unexpected BuildPreambleError"); 1391 } 1392 } 1393 1394 assert(Preamble && "Preamble wasn't built"); 1395 1396 TopLevelDecls.clear(); 1397 TopLevelDeclsInPreamble = Callbacks.takeTopLevelDeclIDs(); 1398 PreambleTopLevelHashValue = Callbacks.getHash(); 1399 1400 NumWarningsInPreamble = getDiagnostics().getNumWarnings(); 1401 1402 checkAndRemoveNonDriverDiags(NewPreambleDiags); 1403 StoredDiagnostics = std::move(NewPreambleDiags); 1404 PreambleDiagnostics = std::move(NewPreambleDiagsStandalone); 1405 1406 // If the hash of top-level entities differs from the hash of the top-level 1407 // entities the last time we rebuilt the preamble, clear out the completion 1408 // cache. 1409 if (CurrentTopLevelHashValue != PreambleTopLevelHashValue) { 1410 CompletionCacheTopLevelHashValue = 0; 1411 PreambleTopLevelHashValue = CurrentTopLevelHashValue; 1412 } 1413 1414 return MainFileBuffer; 1415 } 1416 1417 void ASTUnit::RealizeTopLevelDeclsFromPreamble() { 1418 assert(Preamble && "Should only be called when preamble was built"); 1419 1420 std::vector<Decl *> Resolved; 1421 Resolved.reserve(TopLevelDeclsInPreamble.size()); 1422 ExternalASTSource &Source = *getASTContext().getExternalSource(); 1423 for (const auto TopLevelDecl : TopLevelDeclsInPreamble) { 1424 // Resolve the declaration ID to an actual declaration, possibly 1425 // deserializing the declaration in the process. 1426 if (Decl *D = Source.GetExternalDecl(TopLevelDecl)) 1427 Resolved.push_back(D); 1428 } 1429 TopLevelDeclsInPreamble.clear(); 1430 TopLevelDecls.insert(TopLevelDecls.begin(), Resolved.begin(), Resolved.end()); 1431 } 1432 1433 void ASTUnit::transferASTDataFromCompilerInstance(CompilerInstance &CI) { 1434 // Steal the created target, context, and preprocessor if they have been 1435 // created. 1436 assert(CI.hasInvocation() && "missing invocation"); 1437 LangOpts = CI.getInvocation().LangOpts; 1438 TheSema = CI.takeSema(); 1439 Consumer = CI.takeASTConsumer(); 1440 if (CI.hasASTContext()) 1441 Ctx = &CI.getASTContext(); 1442 if (CI.hasPreprocessor()) 1443 PP = CI.getPreprocessorPtr(); 1444 CI.setSourceManager(nullptr); 1445 CI.setFileManager(nullptr); 1446 if (CI.hasTarget()) 1447 Target = &CI.getTarget(); 1448 Reader = CI.getASTReader(); 1449 HadModuleLoaderFatalFailure = CI.hadModuleLoaderFatalFailure(); 1450 } 1451 1452 StringRef ASTUnit::getMainFileName() const { 1453 if (Invocation && !Invocation->getFrontendOpts().Inputs.empty()) { 1454 const FrontendInputFile &Input = Invocation->getFrontendOpts().Inputs[0]; 1455 if (Input.isFile()) 1456 return Input.getFile(); 1457 else 1458 return Input.getBuffer().getBufferIdentifier(); 1459 } 1460 1461 if (SourceMgr) { 1462 if (const FileEntry * 1463 FE = SourceMgr->getFileEntryForID(SourceMgr->getMainFileID())) 1464 return FE->getName(); 1465 } 1466 1467 return {}; 1468 } 1469 1470 StringRef ASTUnit::getASTFileName() const { 1471 if (!isMainFileAST()) 1472 return {}; 1473 1474 serialization::ModuleFile & 1475 Mod = Reader->getModuleManager().getPrimaryModule(); 1476 return Mod.FileName; 1477 } 1478 1479 std::unique_ptr<ASTUnit> 1480 ASTUnit::create(std::shared_ptr<CompilerInvocation> CI, 1481 IntrusiveRefCntPtr<DiagnosticsEngine> Diags, 1482 CaptureDiagsKind CaptureDiagnostics, 1483 bool UserFilesAreVolatile) { 1484 std::unique_ptr<ASTUnit> AST(new ASTUnit(false)); 1485 ConfigureDiags(Diags, *AST, CaptureDiagnostics); 1486 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS = 1487 createVFSFromCompilerInvocation(*CI, *Diags); 1488 AST->Diagnostics = Diags; 1489 AST->FileSystemOpts = CI->getFileSystemOpts(); 1490 AST->Invocation = std::move(CI); 1491 AST->FileMgr = new FileManager(AST->FileSystemOpts, VFS); 1492 AST->UserFilesAreVolatile = UserFilesAreVolatile; 1493 AST->SourceMgr = new SourceManager(AST->getDiagnostics(), *AST->FileMgr, 1494 UserFilesAreVolatile); 1495 AST->ModuleCache = new InMemoryModuleCache; 1496 1497 return AST; 1498 } 1499 1500 ASTUnit *ASTUnit::LoadFromCompilerInvocationAction( 1501 std::shared_ptr<CompilerInvocation> CI, 1502 std::shared_ptr<PCHContainerOperations> PCHContainerOps, 1503 IntrusiveRefCntPtr<DiagnosticsEngine> Diags, FrontendAction *Action, 1504 ASTUnit *Unit, bool Persistent, StringRef ResourceFilesPath, 1505 bool OnlyLocalDecls, CaptureDiagsKind CaptureDiagnostics, 1506 unsigned PrecompilePreambleAfterNParses, bool CacheCodeCompletionResults, 1507 bool UserFilesAreVolatile, std::unique_ptr<ASTUnit> *ErrAST) { 1508 assert(CI && "A CompilerInvocation is required"); 1509 1510 std::unique_ptr<ASTUnit> OwnAST; 1511 ASTUnit *AST = Unit; 1512 if (!AST) { 1513 // Create the AST unit. 1514 OwnAST = create(CI, Diags, CaptureDiagnostics, UserFilesAreVolatile); 1515 AST = OwnAST.get(); 1516 if (!AST) 1517 return nullptr; 1518 } 1519 1520 if (!ResourceFilesPath.empty()) { 1521 // Override the resources path. 1522 CI->getHeaderSearchOpts().ResourceDir = std::string(ResourceFilesPath); 1523 } 1524 AST->OnlyLocalDecls = OnlyLocalDecls; 1525 AST->CaptureDiagnostics = CaptureDiagnostics; 1526 if (PrecompilePreambleAfterNParses > 0) 1527 AST->PreambleRebuildCountdown = PrecompilePreambleAfterNParses; 1528 AST->TUKind = Action ? Action->getTranslationUnitKind() : TU_Complete; 1529 AST->ShouldCacheCodeCompletionResults = CacheCodeCompletionResults; 1530 AST->IncludeBriefCommentsInCodeCompletion = false; 1531 1532 // Recover resources if we crash before exiting this method. 1533 llvm::CrashRecoveryContextCleanupRegistrar<ASTUnit> 1534 ASTUnitCleanup(OwnAST.get()); 1535 llvm::CrashRecoveryContextCleanupRegistrar<DiagnosticsEngine, 1536 llvm::CrashRecoveryContextReleaseRefCleanup<DiagnosticsEngine>> 1537 DiagCleanup(Diags.get()); 1538 1539 // We'll manage file buffers ourselves. 1540 CI->getPreprocessorOpts().RetainRemappedFileBuffers = true; 1541 CI->getFrontendOpts().DisableFree = false; 1542 ProcessWarningOptions(AST->getDiagnostics(), CI->getDiagnosticOpts()); 1543 1544 // Create the compiler instance to use for building the AST. 1545 std::unique_ptr<CompilerInstance> Clang( 1546 new CompilerInstance(std::move(PCHContainerOps))); 1547 1548 // Recover resources if we crash before exiting this method. 1549 llvm::CrashRecoveryContextCleanupRegistrar<CompilerInstance> 1550 CICleanup(Clang.get()); 1551 1552 Clang->setInvocation(std::move(CI)); 1553 AST->OriginalSourceFile = 1554 std::string(Clang->getFrontendOpts().Inputs[0].getFile()); 1555 1556 // Set up diagnostics, capturing any diagnostics that would 1557 // otherwise be dropped. 1558 Clang->setDiagnostics(&AST->getDiagnostics()); 1559 1560 // Create the target instance. 1561 if (!Clang->createTarget()) 1562 return nullptr; 1563 1564 assert(Clang->getFrontendOpts().Inputs.size() == 1 && 1565 "Invocation must have exactly one source file!"); 1566 assert(Clang->getFrontendOpts().Inputs[0].getKind().getFormat() == 1567 InputKind::Source && 1568 "FIXME: AST inputs not yet supported here!"); 1569 assert(Clang->getFrontendOpts().Inputs[0].getKind().getLanguage() != 1570 Language::LLVM_IR && 1571 "IR inputs not support here!"); 1572 1573 // Configure the various subsystems. 1574 AST->TheSema.reset(); 1575 AST->Ctx = nullptr; 1576 AST->PP = nullptr; 1577 AST->Reader = nullptr; 1578 1579 // Create a file manager object to provide access to and cache the filesystem. 1580 Clang->setFileManager(&AST->getFileManager()); 1581 1582 // Create the source manager. 1583 Clang->setSourceManager(&AST->getSourceManager()); 1584 1585 FrontendAction *Act = Action; 1586 1587 std::unique_ptr<TopLevelDeclTrackerAction> TrackerAct; 1588 if (!Act) { 1589 TrackerAct.reset(new TopLevelDeclTrackerAction(*AST)); 1590 Act = TrackerAct.get(); 1591 } 1592 1593 // Recover resources if we crash before exiting this method. 1594 llvm::CrashRecoveryContextCleanupRegistrar<TopLevelDeclTrackerAction> 1595 ActCleanup(TrackerAct.get()); 1596 1597 if (!Act->BeginSourceFile(*Clang.get(), Clang->getFrontendOpts().Inputs[0])) { 1598 AST->transferASTDataFromCompilerInstance(*Clang); 1599 if (OwnAST && ErrAST) 1600 ErrAST->swap(OwnAST); 1601 1602 return nullptr; 1603 } 1604 1605 if (Persistent && !TrackerAct) { 1606 Clang->getPreprocessor().addPPCallbacks( 1607 std::make_unique<MacroDefinitionTrackerPPCallbacks>( 1608 AST->getCurrentTopLevelHashValue())); 1609 std::vector<std::unique_ptr<ASTConsumer>> Consumers; 1610 if (Clang->hasASTConsumer()) 1611 Consumers.push_back(Clang->takeASTConsumer()); 1612 Consumers.push_back(std::make_unique<TopLevelDeclTrackerConsumer>( 1613 *AST, AST->getCurrentTopLevelHashValue())); 1614 Clang->setASTConsumer( 1615 std::make_unique<MultiplexConsumer>(std::move(Consumers))); 1616 } 1617 if (llvm::Error Err = Act->Execute()) { 1618 consumeError(std::move(Err)); // FIXME this drops errors on the floor. 1619 AST->transferASTDataFromCompilerInstance(*Clang); 1620 if (OwnAST && ErrAST) 1621 ErrAST->swap(OwnAST); 1622 1623 return nullptr; 1624 } 1625 1626 // Steal the created target, context, and preprocessor. 1627 AST->transferASTDataFromCompilerInstance(*Clang); 1628 1629 Act->EndSourceFile(); 1630 1631 if (OwnAST) 1632 return OwnAST.release(); 1633 else 1634 return AST; 1635 } 1636 1637 bool ASTUnit::LoadFromCompilerInvocation( 1638 std::shared_ptr<PCHContainerOperations> PCHContainerOps, 1639 unsigned PrecompilePreambleAfterNParses, 1640 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS) { 1641 if (!Invocation) 1642 return true; 1643 1644 assert(VFS && "VFS is null"); 1645 1646 // We'll manage file buffers ourselves. 1647 Invocation->getPreprocessorOpts().RetainRemappedFileBuffers = true; 1648 Invocation->getFrontendOpts().DisableFree = false; 1649 getDiagnostics().Reset(); 1650 ProcessWarningOptions(getDiagnostics(), Invocation->getDiagnosticOpts()); 1651 1652 std::unique_ptr<llvm::MemoryBuffer> OverrideMainBuffer; 1653 if (PrecompilePreambleAfterNParses > 0) { 1654 PreambleRebuildCountdown = PrecompilePreambleAfterNParses; 1655 OverrideMainBuffer = 1656 getMainBufferWithPrecompiledPreamble(PCHContainerOps, *Invocation, VFS); 1657 getDiagnostics().Reset(); 1658 ProcessWarningOptions(getDiagnostics(), Invocation->getDiagnosticOpts()); 1659 } 1660 1661 SimpleTimer ParsingTimer(WantTiming); 1662 ParsingTimer.setOutput("Parsing " + getMainFileName()); 1663 1664 // Recover resources if we crash before exiting this method. 1665 llvm::CrashRecoveryContextCleanupRegistrar<llvm::MemoryBuffer> 1666 MemBufferCleanup(OverrideMainBuffer.get()); 1667 1668 return Parse(std::move(PCHContainerOps), std::move(OverrideMainBuffer), VFS); 1669 } 1670 1671 std::unique_ptr<ASTUnit> ASTUnit::LoadFromCompilerInvocation( 1672 std::shared_ptr<CompilerInvocation> CI, 1673 std::shared_ptr<PCHContainerOperations> PCHContainerOps, 1674 IntrusiveRefCntPtr<DiagnosticsEngine> Diags, FileManager *FileMgr, 1675 bool OnlyLocalDecls, CaptureDiagsKind CaptureDiagnostics, 1676 unsigned PrecompilePreambleAfterNParses, TranslationUnitKind TUKind, 1677 bool CacheCodeCompletionResults, bool IncludeBriefCommentsInCodeCompletion, 1678 bool UserFilesAreVolatile) { 1679 // Create the AST unit. 1680 std::unique_ptr<ASTUnit> AST(new ASTUnit(false)); 1681 ConfigureDiags(Diags, *AST, CaptureDiagnostics); 1682 AST->Diagnostics = Diags; 1683 AST->OnlyLocalDecls = OnlyLocalDecls; 1684 AST->CaptureDiagnostics = CaptureDiagnostics; 1685 AST->TUKind = TUKind; 1686 AST->ShouldCacheCodeCompletionResults = CacheCodeCompletionResults; 1687 AST->IncludeBriefCommentsInCodeCompletion 1688 = IncludeBriefCommentsInCodeCompletion; 1689 AST->Invocation = std::move(CI); 1690 AST->FileSystemOpts = FileMgr->getFileSystemOpts(); 1691 AST->FileMgr = FileMgr; 1692 AST->UserFilesAreVolatile = UserFilesAreVolatile; 1693 1694 // Recover resources if we crash before exiting this method. 1695 llvm::CrashRecoveryContextCleanupRegistrar<ASTUnit> 1696 ASTUnitCleanup(AST.get()); 1697 llvm::CrashRecoveryContextCleanupRegistrar<DiagnosticsEngine, 1698 llvm::CrashRecoveryContextReleaseRefCleanup<DiagnosticsEngine>> 1699 DiagCleanup(Diags.get()); 1700 1701 if (AST->LoadFromCompilerInvocation(std::move(PCHContainerOps), 1702 PrecompilePreambleAfterNParses, 1703 &AST->FileMgr->getVirtualFileSystem())) 1704 return nullptr; 1705 return AST; 1706 } 1707 1708 ASTUnit *ASTUnit::LoadFromCommandLine( 1709 const char **ArgBegin, const char **ArgEnd, 1710 std::shared_ptr<PCHContainerOperations> PCHContainerOps, 1711 IntrusiveRefCntPtr<DiagnosticsEngine> Diags, StringRef ResourceFilesPath, 1712 bool OnlyLocalDecls, CaptureDiagsKind CaptureDiagnostics, 1713 ArrayRef<RemappedFile> RemappedFiles, bool RemappedFilesKeepOriginalName, 1714 unsigned PrecompilePreambleAfterNParses, TranslationUnitKind TUKind, 1715 bool CacheCodeCompletionResults, bool IncludeBriefCommentsInCodeCompletion, 1716 bool AllowPCHWithCompilerErrors, SkipFunctionBodiesScope SkipFunctionBodies, 1717 bool SingleFileParse, bool UserFilesAreVolatile, bool ForSerialization, 1718 bool RetainExcludedConditionalBlocks, 1719 llvm::Optional<StringRef> ModuleFormat, std::unique_ptr<ASTUnit> *ErrAST, 1720 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS) { 1721 assert(Diags.get() && "no DiagnosticsEngine was provided"); 1722 1723 SmallVector<StoredDiagnostic, 4> StoredDiagnostics; 1724 1725 std::shared_ptr<CompilerInvocation> CI; 1726 1727 { 1728 CaptureDroppedDiagnostics Capture(CaptureDiagnostics, *Diags, 1729 &StoredDiagnostics, nullptr); 1730 1731 CreateInvocationOptions CIOpts; 1732 CIOpts.VFS = VFS; 1733 CIOpts.Diags = Diags; 1734 CIOpts.ProbePrecompiled = true; // FIXME: historical default. Needed? 1735 CI = createInvocation(llvm::makeArrayRef(ArgBegin, ArgEnd), 1736 std::move(CIOpts)); 1737 if (!CI) 1738 return nullptr; 1739 } 1740 1741 // Override any files that need remapping 1742 for (const auto &RemappedFile : RemappedFiles) { 1743 CI->getPreprocessorOpts().addRemappedFile(RemappedFile.first, 1744 RemappedFile.second); 1745 } 1746 PreprocessorOptions &PPOpts = CI->getPreprocessorOpts(); 1747 PPOpts.RemappedFilesKeepOriginalName = RemappedFilesKeepOriginalName; 1748 PPOpts.AllowPCHWithCompilerErrors = AllowPCHWithCompilerErrors; 1749 PPOpts.SingleFileParseMode = SingleFileParse; 1750 PPOpts.RetainExcludedConditionalBlocks = RetainExcludedConditionalBlocks; 1751 1752 // Override the resources path. 1753 CI->getHeaderSearchOpts().ResourceDir = std::string(ResourceFilesPath); 1754 1755 CI->getFrontendOpts().SkipFunctionBodies = 1756 SkipFunctionBodies == SkipFunctionBodiesScope::PreambleAndMainFile; 1757 1758 if (ModuleFormat) 1759 CI->getHeaderSearchOpts().ModuleFormat = 1760 std::string(ModuleFormat.getValue()); 1761 1762 // Create the AST unit. 1763 std::unique_ptr<ASTUnit> AST; 1764 AST.reset(new ASTUnit(false)); 1765 AST->NumStoredDiagnosticsFromDriver = StoredDiagnostics.size(); 1766 AST->StoredDiagnostics.swap(StoredDiagnostics); 1767 ConfigureDiags(Diags, *AST, CaptureDiagnostics); 1768 AST->Diagnostics = Diags; 1769 AST->FileSystemOpts = CI->getFileSystemOpts(); 1770 if (!VFS) 1771 VFS = llvm::vfs::getRealFileSystem(); 1772 VFS = createVFSFromCompilerInvocation(*CI, *Diags, VFS); 1773 AST->FileMgr = new FileManager(AST->FileSystemOpts, VFS); 1774 AST->ModuleCache = new InMemoryModuleCache; 1775 AST->OnlyLocalDecls = OnlyLocalDecls; 1776 AST->CaptureDiagnostics = CaptureDiagnostics; 1777 AST->TUKind = TUKind; 1778 AST->ShouldCacheCodeCompletionResults = CacheCodeCompletionResults; 1779 AST->IncludeBriefCommentsInCodeCompletion 1780 = IncludeBriefCommentsInCodeCompletion; 1781 AST->UserFilesAreVolatile = UserFilesAreVolatile; 1782 AST->Invocation = CI; 1783 AST->SkipFunctionBodies = SkipFunctionBodies; 1784 if (ForSerialization) 1785 AST->WriterData.reset(new ASTWriterData(*AST->ModuleCache)); 1786 // Zero out now to ease cleanup during crash recovery. 1787 CI = nullptr; 1788 Diags = nullptr; 1789 1790 // Recover resources if we crash before exiting this method. 1791 llvm::CrashRecoveryContextCleanupRegistrar<ASTUnit> 1792 ASTUnitCleanup(AST.get()); 1793 1794 if (AST->LoadFromCompilerInvocation(std::move(PCHContainerOps), 1795 PrecompilePreambleAfterNParses, 1796 VFS)) { 1797 // Some error occurred, if caller wants to examine diagnostics, pass it the 1798 // ASTUnit. 1799 if (ErrAST) { 1800 AST->StoredDiagnostics.swap(AST->FailedParseDiagnostics); 1801 ErrAST->swap(AST); 1802 } 1803 return nullptr; 1804 } 1805 1806 return AST.release(); 1807 } 1808 1809 bool ASTUnit::Reparse(std::shared_ptr<PCHContainerOperations> PCHContainerOps, 1810 ArrayRef<RemappedFile> RemappedFiles, 1811 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS) { 1812 if (!Invocation) 1813 return true; 1814 1815 if (!VFS) { 1816 assert(FileMgr && "FileMgr is null on Reparse call"); 1817 VFS = &FileMgr->getVirtualFileSystem(); 1818 } 1819 1820 clearFileLevelDecls(); 1821 1822 SimpleTimer ParsingTimer(WantTiming); 1823 ParsingTimer.setOutput("Reparsing " + getMainFileName()); 1824 1825 // Remap files. 1826 PreprocessorOptions &PPOpts = Invocation->getPreprocessorOpts(); 1827 for (const auto &RB : PPOpts.RemappedFileBuffers) 1828 delete RB.second; 1829 1830 Invocation->getPreprocessorOpts().clearRemappedFiles(); 1831 for (const auto &RemappedFile : RemappedFiles) { 1832 Invocation->getPreprocessorOpts().addRemappedFile(RemappedFile.first, 1833 RemappedFile.second); 1834 } 1835 1836 // If we have a preamble file lying around, or if we might try to 1837 // build a precompiled preamble, do so now. 1838 std::unique_ptr<llvm::MemoryBuffer> OverrideMainBuffer; 1839 if (Preamble || PreambleRebuildCountdown > 0) 1840 OverrideMainBuffer = 1841 getMainBufferWithPrecompiledPreamble(PCHContainerOps, *Invocation, VFS); 1842 1843 // Clear out the diagnostics state. 1844 FileMgr.reset(); 1845 getDiagnostics().Reset(); 1846 ProcessWarningOptions(getDiagnostics(), Invocation->getDiagnosticOpts()); 1847 if (OverrideMainBuffer) 1848 getDiagnostics().setNumWarnings(NumWarningsInPreamble); 1849 1850 // Parse the sources 1851 bool Result = 1852 Parse(std::move(PCHContainerOps), std::move(OverrideMainBuffer), VFS); 1853 1854 // If we're caching global code-completion results, and the top-level 1855 // declarations have changed, clear out the code-completion cache. 1856 if (!Result && ShouldCacheCodeCompletionResults && 1857 CurrentTopLevelHashValue != CompletionCacheTopLevelHashValue) 1858 CacheCodeCompletionResults(); 1859 1860 // We now need to clear out the completion info related to this translation 1861 // unit; it'll be recreated if necessary. 1862 CCTUInfo.reset(); 1863 1864 return Result; 1865 } 1866 1867 void ASTUnit::ResetForParse() { 1868 SavedMainFileBuffer.reset(); 1869 1870 SourceMgr.reset(); 1871 TheSema.reset(); 1872 Ctx.reset(); 1873 PP.reset(); 1874 Reader.reset(); 1875 1876 TopLevelDecls.clear(); 1877 clearFileLevelDecls(); 1878 } 1879 1880 //----------------------------------------------------------------------------// 1881 // Code completion 1882 //----------------------------------------------------------------------------// 1883 1884 namespace { 1885 1886 /// Code completion consumer that combines the cached code-completion 1887 /// results from an ASTUnit with the code-completion results provided to it, 1888 /// then passes the result on to 1889 class AugmentedCodeCompleteConsumer : public CodeCompleteConsumer { 1890 uint64_t NormalContexts; 1891 ASTUnit &AST; 1892 CodeCompleteConsumer &Next; 1893 1894 public: 1895 AugmentedCodeCompleteConsumer(ASTUnit &AST, CodeCompleteConsumer &Next, 1896 const CodeCompleteOptions &CodeCompleteOpts) 1897 : CodeCompleteConsumer(CodeCompleteOpts), AST(AST), Next(Next) { 1898 // Compute the set of contexts in which we will look when we don't have 1899 // any information about the specific context. 1900 NormalContexts 1901 = (1LL << CodeCompletionContext::CCC_TopLevel) 1902 | (1LL << CodeCompletionContext::CCC_ObjCInterface) 1903 | (1LL << CodeCompletionContext::CCC_ObjCImplementation) 1904 | (1LL << CodeCompletionContext::CCC_ObjCIvarList) 1905 | (1LL << CodeCompletionContext::CCC_Statement) 1906 | (1LL << CodeCompletionContext::CCC_Expression) 1907 | (1LL << CodeCompletionContext::CCC_ObjCMessageReceiver) 1908 | (1LL << CodeCompletionContext::CCC_DotMemberAccess) 1909 | (1LL << CodeCompletionContext::CCC_ArrowMemberAccess) 1910 | (1LL << CodeCompletionContext::CCC_ObjCPropertyAccess) 1911 | (1LL << CodeCompletionContext::CCC_ObjCProtocolName) 1912 | (1LL << CodeCompletionContext::CCC_ParenthesizedExpression) 1913 | (1LL << CodeCompletionContext::CCC_Recovery); 1914 1915 if (AST.getASTContext().getLangOpts().CPlusPlus) 1916 NormalContexts |= (1LL << CodeCompletionContext::CCC_EnumTag) 1917 | (1LL << CodeCompletionContext::CCC_UnionTag) 1918 | (1LL << CodeCompletionContext::CCC_ClassOrStructTag); 1919 } 1920 1921 void ProcessCodeCompleteResults(Sema &S, CodeCompletionContext Context, 1922 CodeCompletionResult *Results, 1923 unsigned NumResults) override; 1924 1925 void ProcessOverloadCandidates(Sema &S, unsigned CurrentArg, 1926 OverloadCandidate *Candidates, 1927 unsigned NumCandidates, 1928 SourceLocation OpenParLoc, 1929 bool Braced) override { 1930 Next.ProcessOverloadCandidates(S, CurrentArg, Candidates, NumCandidates, 1931 OpenParLoc, Braced); 1932 } 1933 1934 CodeCompletionAllocator &getAllocator() override { 1935 return Next.getAllocator(); 1936 } 1937 1938 CodeCompletionTUInfo &getCodeCompletionTUInfo() override { 1939 return Next.getCodeCompletionTUInfo(); 1940 } 1941 }; 1942 1943 } // namespace 1944 1945 /// Helper function that computes which global names are hidden by the 1946 /// local code-completion results. 1947 static void CalculateHiddenNames(const CodeCompletionContext &Context, 1948 CodeCompletionResult *Results, 1949 unsigned NumResults, 1950 ASTContext &Ctx, 1951 llvm::StringSet<llvm::BumpPtrAllocator> &HiddenNames){ 1952 bool OnlyTagNames = false; 1953 switch (Context.getKind()) { 1954 case CodeCompletionContext::CCC_Recovery: 1955 case CodeCompletionContext::CCC_TopLevel: 1956 case CodeCompletionContext::CCC_ObjCInterface: 1957 case CodeCompletionContext::CCC_ObjCImplementation: 1958 case CodeCompletionContext::CCC_ObjCIvarList: 1959 case CodeCompletionContext::CCC_ClassStructUnion: 1960 case CodeCompletionContext::CCC_Statement: 1961 case CodeCompletionContext::CCC_Expression: 1962 case CodeCompletionContext::CCC_ObjCMessageReceiver: 1963 case CodeCompletionContext::CCC_DotMemberAccess: 1964 case CodeCompletionContext::CCC_ArrowMemberAccess: 1965 case CodeCompletionContext::CCC_ObjCPropertyAccess: 1966 case CodeCompletionContext::CCC_Namespace: 1967 case CodeCompletionContext::CCC_Type: 1968 case CodeCompletionContext::CCC_Symbol: 1969 case CodeCompletionContext::CCC_SymbolOrNewName: 1970 case CodeCompletionContext::CCC_ParenthesizedExpression: 1971 case CodeCompletionContext::CCC_ObjCInterfaceName: 1972 break; 1973 1974 case CodeCompletionContext::CCC_EnumTag: 1975 case CodeCompletionContext::CCC_UnionTag: 1976 case CodeCompletionContext::CCC_ClassOrStructTag: 1977 OnlyTagNames = true; 1978 break; 1979 1980 case CodeCompletionContext::CCC_ObjCProtocolName: 1981 case CodeCompletionContext::CCC_MacroName: 1982 case CodeCompletionContext::CCC_MacroNameUse: 1983 case CodeCompletionContext::CCC_PreprocessorExpression: 1984 case CodeCompletionContext::CCC_PreprocessorDirective: 1985 case CodeCompletionContext::CCC_NaturalLanguage: 1986 case CodeCompletionContext::CCC_SelectorName: 1987 case CodeCompletionContext::CCC_TypeQualifiers: 1988 case CodeCompletionContext::CCC_Other: 1989 case CodeCompletionContext::CCC_OtherWithMacros: 1990 case CodeCompletionContext::CCC_ObjCInstanceMessage: 1991 case CodeCompletionContext::CCC_ObjCClassMessage: 1992 case CodeCompletionContext::CCC_ObjCCategoryName: 1993 case CodeCompletionContext::CCC_IncludedFile: 1994 case CodeCompletionContext::CCC_Attribute: 1995 case CodeCompletionContext::CCC_NewName: 1996 // We're looking for nothing, or we're looking for names that cannot 1997 // be hidden. 1998 return; 1999 } 2000 2001 using Result = CodeCompletionResult; 2002 for (unsigned I = 0; I != NumResults; ++I) { 2003 if (Results[I].Kind != Result::RK_Declaration) 2004 continue; 2005 2006 unsigned IDNS 2007 = Results[I].Declaration->getUnderlyingDecl()->getIdentifierNamespace(); 2008 2009 bool Hiding = false; 2010 if (OnlyTagNames) 2011 Hiding = (IDNS & Decl::IDNS_Tag); 2012 else { 2013 unsigned HiddenIDNS = (Decl::IDNS_Type | Decl::IDNS_Member | 2014 Decl::IDNS_Namespace | Decl::IDNS_Ordinary | 2015 Decl::IDNS_NonMemberOperator); 2016 if (Ctx.getLangOpts().CPlusPlus) 2017 HiddenIDNS |= Decl::IDNS_Tag; 2018 Hiding = (IDNS & HiddenIDNS); 2019 } 2020 2021 if (!Hiding) 2022 continue; 2023 2024 DeclarationName Name = Results[I].Declaration->getDeclName(); 2025 if (IdentifierInfo *Identifier = Name.getAsIdentifierInfo()) 2026 HiddenNames.insert(Identifier->getName()); 2027 else 2028 HiddenNames.insert(Name.getAsString()); 2029 } 2030 } 2031 2032 void AugmentedCodeCompleteConsumer::ProcessCodeCompleteResults(Sema &S, 2033 CodeCompletionContext Context, 2034 CodeCompletionResult *Results, 2035 unsigned NumResults) { 2036 // Merge the results we were given with the results we cached. 2037 bool AddedResult = false; 2038 uint64_t InContexts = 2039 Context.getKind() == CodeCompletionContext::CCC_Recovery 2040 ? NormalContexts : (1LL << Context.getKind()); 2041 // Contains the set of names that are hidden by "local" completion results. 2042 llvm::StringSet<llvm::BumpPtrAllocator> HiddenNames; 2043 using Result = CodeCompletionResult; 2044 SmallVector<Result, 8> AllResults; 2045 for (ASTUnit::cached_completion_iterator 2046 C = AST.cached_completion_begin(), 2047 CEnd = AST.cached_completion_end(); 2048 C != CEnd; ++C) { 2049 // If the context we are in matches any of the contexts we are 2050 // interested in, we'll add this result. 2051 if ((C->ShowInContexts & InContexts) == 0) 2052 continue; 2053 2054 // If we haven't added any results previously, do so now. 2055 if (!AddedResult) { 2056 CalculateHiddenNames(Context, Results, NumResults, S.Context, 2057 HiddenNames); 2058 AllResults.insert(AllResults.end(), Results, Results + NumResults); 2059 AddedResult = true; 2060 } 2061 2062 // Determine whether this global completion result is hidden by a local 2063 // completion result. If so, skip it. 2064 if (C->Kind != CXCursor_MacroDefinition && 2065 HiddenNames.count(C->Completion->getTypedText())) 2066 continue; 2067 2068 // Adjust priority based on similar type classes. 2069 unsigned Priority = C->Priority; 2070 CodeCompletionString *Completion = C->Completion; 2071 if (!Context.getPreferredType().isNull()) { 2072 if (C->Kind == CXCursor_MacroDefinition) { 2073 Priority = getMacroUsagePriority(C->Completion->getTypedText(), 2074 S.getLangOpts(), 2075 Context.getPreferredType()->isAnyPointerType()); 2076 } else if (C->Type) { 2077 CanQualType Expected 2078 = S.Context.getCanonicalType( 2079 Context.getPreferredType().getUnqualifiedType()); 2080 SimplifiedTypeClass ExpectedSTC = getSimplifiedTypeClass(Expected); 2081 if (ExpectedSTC == C->TypeClass) { 2082 // We know this type is similar; check for an exact match. 2083 llvm::StringMap<unsigned> &CachedCompletionTypes 2084 = AST.getCachedCompletionTypes(); 2085 llvm::StringMap<unsigned>::iterator Pos 2086 = CachedCompletionTypes.find(QualType(Expected).getAsString()); 2087 if (Pos != CachedCompletionTypes.end() && Pos->second == C->Type) 2088 Priority /= CCF_ExactTypeMatch; 2089 else 2090 Priority /= CCF_SimilarTypeMatch; 2091 } 2092 } 2093 } 2094 2095 // Adjust the completion string, if required. 2096 if (C->Kind == CXCursor_MacroDefinition && 2097 Context.getKind() == CodeCompletionContext::CCC_MacroNameUse) { 2098 // Create a new code-completion string that just contains the 2099 // macro name, without its arguments. 2100 CodeCompletionBuilder Builder(getAllocator(), getCodeCompletionTUInfo(), 2101 CCP_CodePattern, C->Availability); 2102 Builder.AddTypedTextChunk(C->Completion->getTypedText()); 2103 Priority = CCP_CodePattern; 2104 Completion = Builder.TakeString(); 2105 } 2106 2107 AllResults.push_back(Result(Completion, Priority, C->Kind, 2108 C->Availability)); 2109 } 2110 2111 // If we did not add any cached completion results, just forward the 2112 // results we were given to the next consumer. 2113 if (!AddedResult) { 2114 Next.ProcessCodeCompleteResults(S, Context, Results, NumResults); 2115 return; 2116 } 2117 2118 Next.ProcessCodeCompleteResults(S, Context, AllResults.data(), 2119 AllResults.size()); 2120 } 2121 2122 void ASTUnit::CodeComplete( 2123 StringRef File, unsigned Line, unsigned Column, 2124 ArrayRef<RemappedFile> RemappedFiles, bool IncludeMacros, 2125 bool IncludeCodePatterns, bool IncludeBriefComments, 2126 CodeCompleteConsumer &Consumer, 2127 std::shared_ptr<PCHContainerOperations> PCHContainerOps, 2128 DiagnosticsEngine &Diag, LangOptions &LangOpts, SourceManager &SourceMgr, 2129 FileManager &FileMgr, SmallVectorImpl<StoredDiagnostic> &StoredDiagnostics, 2130 SmallVectorImpl<const llvm::MemoryBuffer *> &OwnedBuffers) { 2131 if (!Invocation) 2132 return; 2133 2134 SimpleTimer CompletionTimer(WantTiming); 2135 CompletionTimer.setOutput("Code completion @ " + File + ":" + 2136 Twine(Line) + ":" + Twine(Column)); 2137 2138 auto CCInvocation = std::make_shared<CompilerInvocation>(*Invocation); 2139 2140 FrontendOptions &FrontendOpts = CCInvocation->getFrontendOpts(); 2141 CodeCompleteOptions &CodeCompleteOpts = FrontendOpts.CodeCompleteOpts; 2142 PreprocessorOptions &PreprocessorOpts = CCInvocation->getPreprocessorOpts(); 2143 2144 CodeCompleteOpts.IncludeMacros = IncludeMacros && 2145 CachedCompletionResults.empty(); 2146 CodeCompleteOpts.IncludeCodePatterns = IncludeCodePatterns; 2147 CodeCompleteOpts.IncludeGlobals = CachedCompletionResults.empty(); 2148 CodeCompleteOpts.IncludeBriefComments = IncludeBriefComments; 2149 CodeCompleteOpts.LoadExternal = Consumer.loadExternal(); 2150 CodeCompleteOpts.IncludeFixIts = Consumer.includeFixIts(); 2151 2152 assert(IncludeBriefComments == this->IncludeBriefCommentsInCodeCompletion); 2153 2154 FrontendOpts.CodeCompletionAt.FileName = std::string(File); 2155 FrontendOpts.CodeCompletionAt.Line = Line; 2156 FrontendOpts.CodeCompletionAt.Column = Column; 2157 2158 // Set the language options appropriately. 2159 LangOpts = *CCInvocation->getLangOpts(); 2160 2161 // Spell-checking and warnings are wasteful during code-completion. 2162 LangOpts.SpellChecking = false; 2163 CCInvocation->getDiagnosticOpts().IgnoreWarnings = true; 2164 2165 std::unique_ptr<CompilerInstance> Clang( 2166 new CompilerInstance(PCHContainerOps)); 2167 2168 // Recover resources if we crash before exiting this method. 2169 llvm::CrashRecoveryContextCleanupRegistrar<CompilerInstance> 2170 CICleanup(Clang.get()); 2171 2172 auto &Inv = *CCInvocation; 2173 Clang->setInvocation(std::move(CCInvocation)); 2174 OriginalSourceFile = 2175 std::string(Clang->getFrontendOpts().Inputs[0].getFile()); 2176 2177 // Set up diagnostics, capturing any diagnostics produced. 2178 Clang->setDiagnostics(&Diag); 2179 CaptureDroppedDiagnostics Capture(CaptureDiagsKind::All, 2180 Clang->getDiagnostics(), 2181 &StoredDiagnostics, nullptr); 2182 ProcessWarningOptions(Diag, Inv.getDiagnosticOpts()); 2183 2184 // Create the target instance. 2185 if (!Clang->createTarget()) { 2186 Clang->setInvocation(nullptr); 2187 return; 2188 } 2189 2190 assert(Clang->getFrontendOpts().Inputs.size() == 1 && 2191 "Invocation must have exactly one source file!"); 2192 assert(Clang->getFrontendOpts().Inputs[0].getKind().getFormat() == 2193 InputKind::Source && 2194 "FIXME: AST inputs not yet supported here!"); 2195 assert(Clang->getFrontendOpts().Inputs[0].getKind().getLanguage() != 2196 Language::LLVM_IR && 2197 "IR inputs not support here!"); 2198 2199 // Use the source and file managers that we were given. 2200 Clang->setFileManager(&FileMgr); 2201 Clang->setSourceManager(&SourceMgr); 2202 2203 // Remap files. 2204 PreprocessorOpts.clearRemappedFiles(); 2205 PreprocessorOpts.RetainRemappedFileBuffers = true; 2206 for (const auto &RemappedFile : RemappedFiles) { 2207 PreprocessorOpts.addRemappedFile(RemappedFile.first, RemappedFile.second); 2208 OwnedBuffers.push_back(RemappedFile.second); 2209 } 2210 2211 // Use the code completion consumer we were given, but adding any cached 2212 // code-completion results. 2213 AugmentedCodeCompleteConsumer *AugmentedConsumer 2214 = new AugmentedCodeCompleteConsumer(*this, Consumer, CodeCompleteOpts); 2215 Clang->setCodeCompletionConsumer(AugmentedConsumer); 2216 2217 auto getUniqueID = 2218 [&FileMgr](StringRef Filename) -> Optional<llvm::sys::fs::UniqueID> { 2219 if (auto Status = FileMgr.getVirtualFileSystem().status(Filename)) 2220 return Status->getUniqueID(); 2221 return None; 2222 }; 2223 2224 auto hasSameUniqueID = [getUniqueID](StringRef LHS, StringRef RHS) { 2225 if (LHS == RHS) 2226 return true; 2227 if (auto LHSID = getUniqueID(LHS)) 2228 if (auto RHSID = getUniqueID(RHS)) 2229 return *LHSID == *RHSID; 2230 return false; 2231 }; 2232 2233 // If we have a precompiled preamble, try to use it. We only allow 2234 // the use of the precompiled preamble if we're if the completion 2235 // point is within the main file, after the end of the precompiled 2236 // preamble. 2237 std::unique_ptr<llvm::MemoryBuffer> OverrideMainBuffer; 2238 if (Preamble && Line > 1 && hasSameUniqueID(File, OriginalSourceFile)) { 2239 OverrideMainBuffer = getMainBufferWithPrecompiledPreamble( 2240 PCHContainerOps, Inv, &FileMgr.getVirtualFileSystem(), false, Line - 1); 2241 } 2242 2243 // If the main file has been overridden due to the use of a preamble, 2244 // make that override happen and introduce the preamble. 2245 if (OverrideMainBuffer) { 2246 assert(Preamble && 2247 "No preamble was built, but OverrideMainBuffer is not null"); 2248 2249 IntrusiveRefCntPtr<llvm::vfs::FileSystem> VFS = 2250 &FileMgr.getVirtualFileSystem(); 2251 Preamble->AddImplicitPreamble(Clang->getInvocation(), VFS, 2252 OverrideMainBuffer.get()); 2253 // FIXME: there is no way to update VFS if it was changed by 2254 // AddImplicitPreamble as FileMgr is accepted as a parameter by this method. 2255 // We use on-disk preambles instead and rely on FileMgr's VFS to ensure the 2256 // PCH files are always readable. 2257 OwnedBuffers.push_back(OverrideMainBuffer.release()); 2258 } else { 2259 PreprocessorOpts.PrecompiledPreambleBytes.first = 0; 2260 PreprocessorOpts.PrecompiledPreambleBytes.second = false; 2261 } 2262 2263 // Disable the preprocessing record if modules are not enabled. 2264 if (!Clang->getLangOpts().Modules) 2265 PreprocessorOpts.DetailedRecord = false; 2266 2267 std::unique_ptr<SyntaxOnlyAction> Act; 2268 Act.reset(new SyntaxOnlyAction); 2269 if (Act->BeginSourceFile(*Clang.get(), Clang->getFrontendOpts().Inputs[0])) { 2270 if (llvm::Error Err = Act->Execute()) { 2271 consumeError(std::move(Err)); // FIXME this drops errors on the floor. 2272 } 2273 Act->EndSourceFile(); 2274 } 2275 } 2276 2277 bool ASTUnit::Save(StringRef File) { 2278 if (HadModuleLoaderFatalFailure) 2279 return true; 2280 2281 // Write to a temporary file and later rename it to the actual file, to avoid 2282 // possible race conditions. 2283 SmallString<128> TempPath; 2284 TempPath = File; 2285 TempPath += "-%%%%%%%%"; 2286 // FIXME: Can we somehow regenerate the stat cache here, or do we need to 2287 // unconditionally create a stat cache when we parse the file? 2288 2289 if (llvm::Error Err = llvm::writeFileAtomically( 2290 TempPath, File, [this](llvm::raw_ostream &Out) { 2291 return serialize(Out) ? llvm::make_error<llvm::StringError>( 2292 "ASTUnit serialization failed", 2293 llvm::inconvertibleErrorCode()) 2294 : llvm::Error::success(); 2295 })) { 2296 consumeError(std::move(Err)); 2297 return true; 2298 } 2299 return false; 2300 } 2301 2302 static bool serializeUnit(ASTWriter &Writer, 2303 SmallVectorImpl<char> &Buffer, 2304 Sema &S, 2305 bool hasErrors, 2306 raw_ostream &OS) { 2307 Writer.WriteAST(S, std::string(), nullptr, "", hasErrors); 2308 2309 // Write the generated bitstream to "Out". 2310 if (!Buffer.empty()) 2311 OS.write(Buffer.data(), Buffer.size()); 2312 2313 return false; 2314 } 2315 2316 bool ASTUnit::serialize(raw_ostream &OS) { 2317 // For serialization we are lenient if the errors were only warn-as-error kind. 2318 bool hasErrors = getDiagnostics().hasUncompilableErrorOccurred(); 2319 2320 if (WriterData) 2321 return serializeUnit(WriterData->Writer, WriterData->Buffer, 2322 getSema(), hasErrors, OS); 2323 2324 SmallString<128> Buffer; 2325 llvm::BitstreamWriter Stream(Buffer); 2326 InMemoryModuleCache ModuleCache; 2327 ASTWriter Writer(Stream, Buffer, ModuleCache, {}); 2328 return serializeUnit(Writer, Buffer, getSema(), hasErrors, OS); 2329 } 2330 2331 using SLocRemap = ContinuousRangeMap<unsigned, int, 2>; 2332 2333 void ASTUnit::TranslateStoredDiagnostics( 2334 FileManager &FileMgr, 2335 SourceManager &SrcMgr, 2336 const SmallVectorImpl<StandaloneDiagnostic> &Diags, 2337 SmallVectorImpl<StoredDiagnostic> &Out) { 2338 // Map the standalone diagnostic into the new source manager. We also need to 2339 // remap all the locations to the new view. This includes the diag location, 2340 // any associated source ranges, and the source ranges of associated fix-its. 2341 // FIXME: There should be a cleaner way to do this. 2342 SmallVector<StoredDiagnostic, 4> Result; 2343 Result.reserve(Diags.size()); 2344 2345 for (const auto &SD : Diags) { 2346 // Rebuild the StoredDiagnostic. 2347 if (SD.Filename.empty()) 2348 continue; 2349 auto FE = FileMgr.getFile(SD.Filename); 2350 if (!FE) 2351 continue; 2352 SourceLocation FileLoc; 2353 auto ItFileID = PreambleSrcLocCache.find(SD.Filename); 2354 if (ItFileID == PreambleSrcLocCache.end()) { 2355 FileID FID = SrcMgr.translateFile(*FE); 2356 FileLoc = SrcMgr.getLocForStartOfFile(FID); 2357 PreambleSrcLocCache[SD.Filename] = FileLoc; 2358 } else { 2359 FileLoc = ItFileID->getValue(); 2360 } 2361 2362 if (FileLoc.isInvalid()) 2363 continue; 2364 SourceLocation L = FileLoc.getLocWithOffset(SD.LocOffset); 2365 FullSourceLoc Loc(L, SrcMgr); 2366 2367 SmallVector<CharSourceRange, 4> Ranges; 2368 Ranges.reserve(SD.Ranges.size()); 2369 for (const auto &Range : SD.Ranges) { 2370 SourceLocation BL = FileLoc.getLocWithOffset(Range.first); 2371 SourceLocation EL = FileLoc.getLocWithOffset(Range.second); 2372 Ranges.push_back(CharSourceRange::getCharRange(BL, EL)); 2373 } 2374 2375 SmallVector<FixItHint, 2> FixIts; 2376 FixIts.reserve(SD.FixIts.size()); 2377 for (const auto &FixIt : SD.FixIts) { 2378 FixIts.push_back(FixItHint()); 2379 FixItHint &FH = FixIts.back(); 2380 FH.CodeToInsert = FixIt.CodeToInsert; 2381 SourceLocation BL = FileLoc.getLocWithOffset(FixIt.RemoveRange.first); 2382 SourceLocation EL = FileLoc.getLocWithOffset(FixIt.RemoveRange.second); 2383 FH.RemoveRange = CharSourceRange::getCharRange(BL, EL); 2384 } 2385 2386 Result.push_back(StoredDiagnostic(SD.Level, SD.ID, 2387 SD.Message, Loc, Ranges, FixIts)); 2388 } 2389 Result.swap(Out); 2390 } 2391 2392 void ASTUnit::addFileLevelDecl(Decl *D) { 2393 assert(D); 2394 2395 // We only care about local declarations. 2396 if (D->isFromASTFile()) 2397 return; 2398 2399 SourceManager &SM = *SourceMgr; 2400 SourceLocation Loc = D->getLocation(); 2401 if (Loc.isInvalid() || !SM.isLocalSourceLocation(Loc)) 2402 return; 2403 2404 // We only keep track of the file-level declarations of each file. 2405 if (!D->getLexicalDeclContext()->isFileContext()) 2406 return; 2407 2408 SourceLocation FileLoc = SM.getFileLoc(Loc); 2409 assert(SM.isLocalSourceLocation(FileLoc)); 2410 FileID FID; 2411 unsigned Offset; 2412 std::tie(FID, Offset) = SM.getDecomposedLoc(FileLoc); 2413 if (FID.isInvalid()) 2414 return; 2415 2416 std::unique_ptr<LocDeclsTy> &Decls = FileDecls[FID]; 2417 if (!Decls) 2418 Decls = std::make_unique<LocDeclsTy>(); 2419 2420 std::pair<unsigned, Decl *> LocDecl(Offset, D); 2421 2422 if (Decls->empty() || Decls->back().first <= Offset) { 2423 Decls->push_back(LocDecl); 2424 return; 2425 } 2426 2427 LocDeclsTy::iterator I = 2428 llvm::upper_bound(*Decls, LocDecl, llvm::less_first()); 2429 2430 Decls->insert(I, LocDecl); 2431 } 2432 2433 void ASTUnit::findFileRegionDecls(FileID File, unsigned Offset, unsigned Length, 2434 SmallVectorImpl<Decl *> &Decls) { 2435 if (File.isInvalid()) 2436 return; 2437 2438 if (SourceMgr->isLoadedFileID(File)) { 2439 assert(Ctx->getExternalSource() && "No external source!"); 2440 return Ctx->getExternalSource()->FindFileRegionDecls(File, Offset, Length, 2441 Decls); 2442 } 2443 2444 FileDeclsTy::iterator I = FileDecls.find(File); 2445 if (I == FileDecls.end()) 2446 return; 2447 2448 LocDeclsTy &LocDecls = *I->second; 2449 if (LocDecls.empty()) 2450 return; 2451 2452 LocDeclsTy::iterator BeginIt = 2453 llvm::partition_point(LocDecls, [=](std::pair<unsigned, Decl *> LD) { 2454 return LD.first < Offset; 2455 }); 2456 if (BeginIt != LocDecls.begin()) 2457 --BeginIt; 2458 2459 // If we are pointing at a top-level decl inside an objc container, we need 2460 // to backtrack until we find it otherwise we will fail to report that the 2461 // region overlaps with an objc container. 2462 while (BeginIt != LocDecls.begin() && 2463 BeginIt->second->isTopLevelDeclInObjCContainer()) 2464 --BeginIt; 2465 2466 LocDeclsTy::iterator EndIt = llvm::upper_bound( 2467 LocDecls, std::make_pair(Offset + Length, (Decl *)nullptr), 2468 llvm::less_first()); 2469 if (EndIt != LocDecls.end()) 2470 ++EndIt; 2471 2472 for (LocDeclsTy::iterator DIt = BeginIt; DIt != EndIt; ++DIt) 2473 Decls.push_back(DIt->second); 2474 } 2475 2476 SourceLocation ASTUnit::getLocation(const FileEntry *File, 2477 unsigned Line, unsigned Col) const { 2478 const SourceManager &SM = getSourceManager(); 2479 SourceLocation Loc = SM.translateFileLineCol(File, Line, Col); 2480 return SM.getMacroArgExpandedLocation(Loc); 2481 } 2482 2483 SourceLocation ASTUnit::getLocation(const FileEntry *File, 2484 unsigned Offset) const { 2485 const SourceManager &SM = getSourceManager(); 2486 SourceLocation FileLoc = SM.translateFileLineCol(File, 1, 1); 2487 return SM.getMacroArgExpandedLocation(FileLoc.getLocWithOffset(Offset)); 2488 } 2489 2490 /// If \arg Loc is a loaded location from the preamble, returns 2491 /// the corresponding local location of the main file, otherwise it returns 2492 /// \arg Loc. 2493 SourceLocation ASTUnit::mapLocationFromPreamble(SourceLocation Loc) const { 2494 FileID PreambleID; 2495 if (SourceMgr) 2496 PreambleID = SourceMgr->getPreambleFileID(); 2497 2498 if (Loc.isInvalid() || !Preamble || PreambleID.isInvalid()) 2499 return Loc; 2500 2501 unsigned Offs; 2502 if (SourceMgr->isInFileID(Loc, PreambleID, &Offs) && Offs < Preamble->getBounds().Size) { 2503 SourceLocation FileLoc 2504 = SourceMgr->getLocForStartOfFile(SourceMgr->getMainFileID()); 2505 return FileLoc.getLocWithOffset(Offs); 2506 } 2507 2508 return Loc; 2509 } 2510 2511 /// If \arg Loc is a local location of the main file but inside the 2512 /// preamble chunk, returns the corresponding loaded location from the 2513 /// preamble, otherwise it returns \arg Loc. 2514 SourceLocation ASTUnit::mapLocationToPreamble(SourceLocation Loc) const { 2515 FileID PreambleID; 2516 if (SourceMgr) 2517 PreambleID = SourceMgr->getPreambleFileID(); 2518 2519 if (Loc.isInvalid() || !Preamble || PreambleID.isInvalid()) 2520 return Loc; 2521 2522 unsigned Offs; 2523 if (SourceMgr->isInFileID(Loc, SourceMgr->getMainFileID(), &Offs) && 2524 Offs < Preamble->getBounds().Size) { 2525 SourceLocation FileLoc = SourceMgr->getLocForStartOfFile(PreambleID); 2526 return FileLoc.getLocWithOffset(Offs); 2527 } 2528 2529 return Loc; 2530 } 2531 2532 bool ASTUnit::isInPreambleFileID(SourceLocation Loc) const { 2533 FileID FID; 2534 if (SourceMgr) 2535 FID = SourceMgr->getPreambleFileID(); 2536 2537 if (Loc.isInvalid() || FID.isInvalid()) 2538 return false; 2539 2540 return SourceMgr->isInFileID(Loc, FID); 2541 } 2542 2543 bool ASTUnit::isInMainFileID(SourceLocation Loc) const { 2544 FileID FID; 2545 if (SourceMgr) 2546 FID = SourceMgr->getMainFileID(); 2547 2548 if (Loc.isInvalid() || FID.isInvalid()) 2549 return false; 2550 2551 return SourceMgr->isInFileID(Loc, FID); 2552 } 2553 2554 SourceLocation ASTUnit::getEndOfPreambleFileID() const { 2555 FileID FID; 2556 if (SourceMgr) 2557 FID = SourceMgr->getPreambleFileID(); 2558 2559 if (FID.isInvalid()) 2560 return {}; 2561 2562 return SourceMgr->getLocForEndOfFile(FID); 2563 } 2564 2565 SourceLocation ASTUnit::getStartOfMainFileID() const { 2566 FileID FID; 2567 if (SourceMgr) 2568 FID = SourceMgr->getMainFileID(); 2569 2570 if (FID.isInvalid()) 2571 return {}; 2572 2573 return SourceMgr->getLocForStartOfFile(FID); 2574 } 2575 2576 llvm::iterator_range<PreprocessingRecord::iterator> 2577 ASTUnit::getLocalPreprocessingEntities() const { 2578 if (isMainFileAST()) { 2579 serialization::ModuleFile & 2580 Mod = Reader->getModuleManager().getPrimaryModule(); 2581 return Reader->getModulePreprocessedEntities(Mod); 2582 } 2583 2584 if (PreprocessingRecord *PPRec = PP->getPreprocessingRecord()) 2585 return llvm::make_range(PPRec->local_begin(), PPRec->local_end()); 2586 2587 return llvm::make_range(PreprocessingRecord::iterator(), 2588 PreprocessingRecord::iterator()); 2589 } 2590 2591 bool ASTUnit::visitLocalTopLevelDecls(void *context, DeclVisitorFn Fn) { 2592 if (isMainFileAST()) { 2593 serialization::ModuleFile & 2594 Mod = Reader->getModuleManager().getPrimaryModule(); 2595 for (const auto *D : Reader->getModuleFileLevelDecls(Mod)) { 2596 if (!Fn(context, D)) 2597 return false; 2598 } 2599 2600 return true; 2601 } 2602 2603 for (ASTUnit::top_level_iterator TL = top_level_begin(), 2604 TLEnd = top_level_end(); 2605 TL != TLEnd; ++TL) { 2606 if (!Fn(context, *TL)) 2607 return false; 2608 } 2609 2610 return true; 2611 } 2612 2613 const FileEntry *ASTUnit::getPCHFile() { 2614 if (!Reader) 2615 return nullptr; 2616 2617 serialization::ModuleFile *Mod = nullptr; 2618 Reader->getModuleManager().visit([&Mod](serialization::ModuleFile &M) { 2619 switch (M.Kind) { 2620 case serialization::MK_ImplicitModule: 2621 case serialization::MK_ExplicitModule: 2622 case serialization::MK_PrebuiltModule: 2623 return true; // skip dependencies. 2624 case serialization::MK_PCH: 2625 Mod = &M; 2626 return true; // found it. 2627 case serialization::MK_Preamble: 2628 return false; // look in dependencies. 2629 case serialization::MK_MainFile: 2630 return false; // look in dependencies. 2631 } 2632 2633 return true; 2634 }); 2635 if (Mod) 2636 return Mod->File; 2637 2638 return nullptr; 2639 } 2640 2641 bool ASTUnit::isModuleFile() const { 2642 return isMainFileAST() && getLangOpts().isCompilingModule(); 2643 } 2644 2645 InputKind ASTUnit::getInputKind() const { 2646 auto &LangOpts = getLangOpts(); 2647 2648 Language Lang; 2649 if (LangOpts.OpenCL) 2650 Lang = Language::OpenCL; 2651 else if (LangOpts.CUDA) 2652 Lang = Language::CUDA; 2653 else if (LangOpts.RenderScript) 2654 Lang = Language::RenderScript; 2655 else if (LangOpts.CPlusPlus) 2656 Lang = LangOpts.ObjC ? Language::ObjCXX : Language::CXX; 2657 else 2658 Lang = LangOpts.ObjC ? Language::ObjC : Language::C; 2659 2660 InputKind::Format Fmt = InputKind::Source; 2661 if (LangOpts.getCompilingModule() == LangOptions::CMK_ModuleMap) 2662 Fmt = InputKind::ModuleMap; 2663 2664 // We don't know if input was preprocessed. Assume not. 2665 bool PP = false; 2666 2667 return InputKind(Lang, Fmt, PP); 2668 } 2669 2670 #ifndef NDEBUG 2671 ASTUnit::ConcurrencyState::ConcurrencyState() { 2672 Mutex = new std::recursive_mutex; 2673 } 2674 2675 ASTUnit::ConcurrencyState::~ConcurrencyState() { 2676 delete static_cast<std::recursive_mutex *>(Mutex); 2677 } 2678 2679 void ASTUnit::ConcurrencyState::start() { 2680 bool acquired = static_cast<std::recursive_mutex *>(Mutex)->try_lock(); 2681 assert(acquired && "Concurrent access to ASTUnit!"); 2682 } 2683 2684 void ASTUnit::ConcurrencyState::finish() { 2685 static_cast<std::recursive_mutex *>(Mutex)->unlock(); 2686 } 2687 2688 #else // NDEBUG 2689 2690 ASTUnit::ConcurrencyState::ConcurrencyState() { Mutex = nullptr; } 2691 ASTUnit::ConcurrencyState::~ConcurrencyState() {} 2692 void ASTUnit::ConcurrencyState::start() {} 2693 void ASTUnit::ConcurrencyState::finish() {} 2694 2695 #endif // NDEBUG 2696