1 //===--- FrontendActions.cpp ----------------------------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 10 #include "clang/Frontend/FrontendActions.h" 11 #include "clang/AST/ASTConsumer.h" 12 #include "clang/Basic/FileManager.h" 13 #include "clang/Frontend/ASTConsumers.h" 14 #include "clang/Frontend/CompilerInstance.h" 15 #include "clang/Frontend/FrontendDiagnostic.h" 16 #include "clang/Frontend/MultiplexConsumer.h" 17 #include "clang/Frontend/Utils.h" 18 #include "clang/Lex/HeaderSearch.h" 19 #include "clang/Lex/Preprocessor.h" 20 #include "clang/Lex/PreprocessorOptions.h" 21 #include "clang/Serialization/ASTReader.h" 22 #include "clang/Serialization/ASTWriter.h" 23 #include "llvm/Support/FileSystem.h" 24 #include "llvm/Support/MemoryBuffer.h" 25 #include "llvm/Support/Path.h" 26 #include "llvm/Support/raw_ostream.h" 27 #include <memory> 28 #include <system_error> 29 30 using namespace clang; 31 32 //===----------------------------------------------------------------------===// 33 // Custom Actions 34 //===----------------------------------------------------------------------===// 35 36 std::unique_ptr<ASTConsumer> 37 InitOnlyAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 38 return llvm::make_unique<ASTConsumer>(); 39 } 40 41 void InitOnlyAction::ExecuteAction() { 42 } 43 44 //===----------------------------------------------------------------------===// 45 // AST Consumer Actions 46 //===----------------------------------------------------------------------===// 47 48 std::unique_ptr<ASTConsumer> 49 ASTPrintAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 50 if (std::unique_ptr<raw_ostream> OS = 51 CI.createDefaultOutputFile(false, InFile)) 52 return CreateASTPrinter(std::move(OS), CI.getFrontendOpts().ASTDumpFilter); 53 return nullptr; 54 } 55 56 std::unique_ptr<ASTConsumer> 57 ASTDumpAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 58 return CreateASTDumper(CI.getFrontendOpts().ASTDumpFilter, 59 CI.getFrontendOpts().ASTDumpDecls, 60 CI.getFrontendOpts().ASTDumpLookups); 61 } 62 63 std::unique_ptr<ASTConsumer> 64 ASTDeclListAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 65 return CreateASTDeclNodeLister(); 66 } 67 68 std::unique_ptr<ASTConsumer> 69 ASTViewAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 70 return CreateASTViewer(); 71 } 72 73 std::unique_ptr<ASTConsumer> 74 DeclContextPrintAction::CreateASTConsumer(CompilerInstance &CI, 75 StringRef InFile) { 76 return CreateDeclContextPrinter(); 77 } 78 79 std::unique_ptr<ASTConsumer> 80 GeneratePCHAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 81 std::string Sysroot; 82 std::string OutputFile; 83 std::unique_ptr<raw_pwrite_stream> OS = 84 ComputeASTConsumerArguments(CI, InFile, Sysroot, OutputFile); 85 if (!OS) 86 return nullptr; 87 88 if (!CI.getFrontendOpts().RelocatablePCH) 89 Sysroot.clear(); 90 91 auto Buffer = std::make_shared<PCHBuffer>(); 92 std::vector<std::unique_ptr<ASTConsumer>> Consumers; 93 Consumers.push_back(llvm::make_unique<PCHGenerator>( 94 CI.getPreprocessor(), OutputFile, nullptr, Sysroot, 95 Buffer, CI.getFrontendOpts().ModuleFileExtensions, 96 /*AllowASTWithErrors*/false, 97 /*IncludeTimestamps*/ 98 +CI.getFrontendOpts().IncludeTimestamps)); 99 Consumers.push_back(CI.getPCHContainerWriter().CreatePCHContainerGenerator( 100 CI, InFile, OutputFile, std::move(OS), Buffer)); 101 102 return llvm::make_unique<MultiplexConsumer>(std::move(Consumers)); 103 } 104 105 std::unique_ptr<raw_pwrite_stream> 106 GeneratePCHAction::ComputeASTConsumerArguments(CompilerInstance &CI, 107 StringRef InFile, 108 std::string &Sysroot, 109 std::string &OutputFile) { 110 Sysroot = CI.getHeaderSearchOpts().Sysroot; 111 if (CI.getFrontendOpts().RelocatablePCH && Sysroot.empty()) { 112 CI.getDiagnostics().Report(diag::err_relocatable_without_isysroot); 113 return nullptr; 114 } 115 116 // We use createOutputFile here because this is exposed via libclang, and we 117 // must disable the RemoveFileOnSignal behavior. 118 // We use a temporary to avoid race conditions. 119 std::unique_ptr<raw_pwrite_stream> OS = 120 CI.createOutputFile(CI.getFrontendOpts().OutputFile, /*Binary=*/true, 121 /*RemoveFileOnSignal=*/false, InFile, 122 /*Extension=*/"", /*useTemporary=*/true); 123 if (!OS) 124 return nullptr; 125 126 OutputFile = CI.getFrontendOpts().OutputFile; 127 return OS; 128 } 129 130 std::unique_ptr<ASTConsumer> 131 GenerateModuleAction::CreateASTConsumer(CompilerInstance &CI, 132 StringRef InFile) { 133 std::string Sysroot; 134 std::string OutputFile; 135 std::unique_ptr<raw_pwrite_stream> OS = 136 ComputeASTConsumerArguments(CI, InFile, Sysroot, OutputFile); 137 if (!OS) 138 return nullptr; 139 140 auto Buffer = std::make_shared<PCHBuffer>(); 141 std::vector<std::unique_ptr<ASTConsumer>> Consumers; 142 143 Consumers.push_back(llvm::make_unique<PCHGenerator>( 144 CI.getPreprocessor(), OutputFile, Module, Sysroot, 145 Buffer, CI.getFrontendOpts().ModuleFileExtensions, 146 /*AllowASTWithErrors=*/false, 147 /*IncludeTimestamps=*/ 148 +CI.getFrontendOpts().BuildingImplicitModule)); 149 Consumers.push_back(CI.getPCHContainerWriter().CreatePCHContainerGenerator( 150 CI, InFile, OutputFile, std::move(OS), Buffer)); 151 return llvm::make_unique<MultiplexConsumer>(std::move(Consumers)); 152 } 153 154 static SmallVectorImpl<char> & 155 operator+=(SmallVectorImpl<char> &Includes, StringRef RHS) { 156 Includes.append(RHS.begin(), RHS.end()); 157 return Includes; 158 } 159 160 static void addHeaderInclude(StringRef HeaderName, 161 SmallVectorImpl<char> &Includes, 162 const LangOptions &LangOpts, 163 bool IsExternC) { 164 if (IsExternC && LangOpts.CPlusPlus) 165 Includes += "extern \"C\" {\n"; 166 if (LangOpts.ObjC1) 167 Includes += "#import \""; 168 else 169 Includes += "#include \""; 170 171 Includes += HeaderName; 172 173 Includes += "\"\n"; 174 if (IsExternC && LangOpts.CPlusPlus) 175 Includes += "}\n"; 176 } 177 178 /// \brief Collect the set of header includes needed to construct the given 179 /// module and update the TopHeaders file set of the module. 180 /// 181 /// \param Module The module we're collecting includes from. 182 /// 183 /// \param Includes Will be augmented with the set of \#includes or \#imports 184 /// needed to load all of the named headers. 185 static std::error_code 186 collectModuleHeaderIncludes(const LangOptions &LangOpts, FileManager &FileMgr, 187 ModuleMap &ModMap, clang::Module *Module, 188 SmallVectorImpl<char> &Includes) { 189 // Don't collect any headers for unavailable modules. 190 if (!Module->isAvailable()) 191 return std::error_code(); 192 193 // Add includes for each of these headers. 194 for (auto HK : {Module::HK_Normal, Module::HK_Private}) { 195 for (Module::Header &H : Module->Headers[HK]) { 196 Module->addTopHeader(H.Entry); 197 // Use the path as specified in the module map file. We'll look for this 198 // file relative to the module build directory (the directory containing 199 // the module map file) so this will find the same file that we found 200 // while parsing the module map. 201 addHeaderInclude(H.NameAsWritten, Includes, LangOpts, Module->IsExternC); 202 } 203 } 204 // Note that Module->PrivateHeaders will not be a TopHeader. 205 206 if (Module::Header UmbrellaHeader = Module->getUmbrellaHeader()) { 207 Module->addTopHeader(UmbrellaHeader.Entry); 208 if (Module->Parent) 209 // Include the umbrella header for submodules. 210 addHeaderInclude(UmbrellaHeader.NameAsWritten, Includes, LangOpts, 211 Module->IsExternC); 212 } else if (Module::DirectoryName UmbrellaDir = Module->getUmbrellaDir()) { 213 // Add all of the headers we find in this subdirectory. 214 std::error_code EC; 215 SmallString<128> DirNative; 216 llvm::sys::path::native(UmbrellaDir.Entry->getName(), DirNative); 217 218 vfs::FileSystem &FS = *FileMgr.getVirtualFileSystem(); 219 for (vfs::recursive_directory_iterator Dir(FS, DirNative, EC), End; 220 Dir != End && !EC; Dir.increment(EC)) { 221 // Check whether this entry has an extension typically associated with 222 // headers. 223 if (!llvm::StringSwitch<bool>(llvm::sys::path::extension(Dir->getName())) 224 .Cases(".h", ".H", ".hh", ".hpp", true) 225 .Default(false)) 226 continue; 227 228 const FileEntry *Header = FileMgr.getFile(Dir->getName()); 229 // FIXME: This shouldn't happen unless there is a file system race. Is 230 // that worth diagnosing? 231 if (!Header) 232 continue; 233 234 // If this header is marked 'unavailable' in this module, don't include 235 // it. 236 if (ModMap.isHeaderUnavailableInModule(Header, Module)) 237 continue; 238 239 // Compute the relative path from the directory to this file. 240 SmallVector<StringRef, 16> Components; 241 auto PathIt = llvm::sys::path::rbegin(Dir->getName()); 242 for (int I = 0; I != Dir.level() + 1; ++I, ++PathIt) 243 Components.push_back(*PathIt); 244 SmallString<128> RelativeHeader(UmbrellaDir.NameAsWritten); 245 for (auto It = Components.rbegin(), End = Components.rend(); It != End; 246 ++It) 247 llvm::sys::path::append(RelativeHeader, *It); 248 249 // Include this header as part of the umbrella directory. 250 Module->addTopHeader(Header); 251 addHeaderInclude(RelativeHeader, Includes, LangOpts, Module->IsExternC); 252 } 253 254 if (EC) 255 return EC; 256 } 257 258 // Recurse into submodules. 259 for (clang::Module::submodule_iterator Sub = Module->submodule_begin(), 260 SubEnd = Module->submodule_end(); 261 Sub != SubEnd; ++Sub) 262 if (std::error_code Err = collectModuleHeaderIncludes( 263 LangOpts, FileMgr, ModMap, *Sub, Includes)) 264 return Err; 265 266 return std::error_code(); 267 } 268 269 bool GenerateModuleAction::BeginSourceFileAction(CompilerInstance &CI, 270 StringRef Filename) { 271 CI.getLangOpts().CompilingModule = true; 272 273 // Find the module map file. 274 const FileEntry *ModuleMap = 275 CI.getFileManager().getFile(Filename, /*openFile*/true); 276 if (!ModuleMap) { 277 CI.getDiagnostics().Report(diag::err_module_map_not_found) 278 << Filename; 279 return false; 280 } 281 282 // Set up embedding for any specified files. Do this before we load any 283 // source files, including the primary module map for the compilation. 284 for (const auto &F : CI.getFrontendOpts().ModulesEmbedFiles) { 285 if (const auto *FE = CI.getFileManager().getFile(F, /*openFile*/true)) 286 CI.getSourceManager().setFileIsTransient(FE); 287 else 288 CI.getDiagnostics().Report(diag::err_modules_embed_file_not_found) << F; 289 } 290 if (CI.getFrontendOpts().ModulesEmbedAllFiles) 291 CI.getSourceManager().setAllFilesAreTransient(true); 292 293 // Parse the module map file. 294 HeaderSearch &HS = CI.getPreprocessor().getHeaderSearchInfo(); 295 if (HS.loadModuleMapFile(ModuleMap, IsSystem)) 296 return false; 297 298 if (CI.getLangOpts().CurrentModule.empty()) { 299 CI.getDiagnostics().Report(diag::err_missing_module_name); 300 301 // FIXME: Eventually, we could consider asking whether there was just 302 // a single module described in the module map, and use that as a 303 // default. Then it would be fairly trivial to just "compile" a module 304 // map with a single module (the common case). 305 return false; 306 } 307 308 // If we're being run from the command-line, the module build stack will not 309 // have been filled in yet, so complete it now in order to allow us to detect 310 // module cycles. 311 SourceManager &SourceMgr = CI.getSourceManager(); 312 if (SourceMgr.getModuleBuildStack().empty()) 313 SourceMgr.pushModuleBuildStack(CI.getLangOpts().CurrentModule, 314 FullSourceLoc(SourceLocation(), SourceMgr)); 315 316 // Dig out the module definition. 317 Module = HS.lookupModule(CI.getLangOpts().CurrentModule, 318 /*AllowSearch=*/false); 319 if (!Module) { 320 CI.getDiagnostics().Report(diag::err_missing_module) 321 << CI.getLangOpts().CurrentModule << Filename; 322 323 return false; 324 } 325 326 // Check whether we can build this module at all. 327 clang::Module::Requirement Requirement; 328 clang::Module::UnresolvedHeaderDirective MissingHeader; 329 if (!Module->isAvailable(CI.getLangOpts(), CI.getTarget(), Requirement, 330 MissingHeader)) { 331 if (MissingHeader.FileNameLoc.isValid()) { 332 CI.getDiagnostics().Report(MissingHeader.FileNameLoc, 333 diag::err_module_header_missing) 334 << MissingHeader.IsUmbrella << MissingHeader.FileName; 335 } else { 336 CI.getDiagnostics().Report(diag::err_module_unavailable) 337 << Module->getFullModuleName() 338 << Requirement.second << Requirement.first; 339 } 340 341 return false; 342 } 343 344 if (ModuleMapForUniquing && ModuleMapForUniquing != ModuleMap) { 345 Module->IsInferred = true; 346 HS.getModuleMap().setInferredModuleAllowedBy(Module, ModuleMapForUniquing); 347 } else { 348 ModuleMapForUniquing = ModuleMap; 349 } 350 351 FileManager &FileMgr = CI.getFileManager(); 352 353 // Collect the set of #includes we need to build the module. 354 SmallString<256> HeaderContents; 355 std::error_code Err = std::error_code(); 356 if (Module::Header UmbrellaHeader = Module->getUmbrellaHeader()) 357 addHeaderInclude(UmbrellaHeader.NameAsWritten, HeaderContents, 358 CI.getLangOpts(), Module->IsExternC); 359 Err = collectModuleHeaderIncludes( 360 CI.getLangOpts(), FileMgr, 361 CI.getPreprocessor().getHeaderSearchInfo().getModuleMap(), Module, 362 HeaderContents); 363 364 if (Err) { 365 CI.getDiagnostics().Report(diag::err_module_cannot_create_includes) 366 << Module->getFullModuleName() << Err.message(); 367 return false; 368 } 369 370 // Inform the preprocessor that includes from within the input buffer should 371 // be resolved relative to the build directory of the module map file. 372 CI.getPreprocessor().setMainFileDir(Module->Directory); 373 374 std::unique_ptr<llvm::MemoryBuffer> InputBuffer = 375 llvm::MemoryBuffer::getMemBufferCopy(HeaderContents, 376 Module::getModuleInputBufferName()); 377 // Ownership of InputBuffer will be transferred to the SourceManager. 378 setCurrentInput(FrontendInputFile(InputBuffer.release(), getCurrentFileKind(), 379 Module->IsSystem)); 380 return true; 381 } 382 383 std::unique_ptr<raw_pwrite_stream> 384 GenerateModuleAction::ComputeASTConsumerArguments(CompilerInstance &CI, 385 StringRef InFile, 386 std::string &Sysroot, 387 std::string &OutputFile) { 388 // If no output file was provided, figure out where this module would go 389 // in the module cache. 390 if (CI.getFrontendOpts().OutputFile.empty()) { 391 HeaderSearch &HS = CI.getPreprocessor().getHeaderSearchInfo(); 392 CI.getFrontendOpts().OutputFile = 393 HS.getModuleFileName(CI.getLangOpts().CurrentModule, 394 ModuleMapForUniquing->getName(), 395 /*UsePrebuiltPath=*/false); 396 } 397 398 // We use createOutputFile here because this is exposed via libclang, and we 399 // must disable the RemoveFileOnSignal behavior. 400 // We use a temporary to avoid race conditions. 401 std::unique_ptr<raw_pwrite_stream> OS = 402 CI.createOutputFile(CI.getFrontendOpts().OutputFile, /*Binary=*/true, 403 /*RemoveFileOnSignal=*/false, InFile, 404 /*Extension=*/"", /*useTemporary=*/true, 405 /*CreateMissingDirectories=*/true); 406 if (!OS) 407 return nullptr; 408 409 OutputFile = CI.getFrontendOpts().OutputFile; 410 return OS; 411 } 412 413 SyntaxOnlyAction::~SyntaxOnlyAction() { 414 } 415 416 std::unique_ptr<ASTConsumer> 417 SyntaxOnlyAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 418 return llvm::make_unique<ASTConsumer>(); 419 } 420 421 std::unique_ptr<ASTConsumer> 422 DumpModuleInfoAction::CreateASTConsumer(CompilerInstance &CI, 423 StringRef InFile) { 424 return llvm::make_unique<ASTConsumer>(); 425 } 426 427 std::unique_ptr<ASTConsumer> 428 VerifyPCHAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) { 429 return llvm::make_unique<ASTConsumer>(); 430 } 431 432 void VerifyPCHAction::ExecuteAction() { 433 CompilerInstance &CI = getCompilerInstance(); 434 bool Preamble = CI.getPreprocessorOpts().PrecompiledPreambleBytes.first != 0; 435 const std::string &Sysroot = CI.getHeaderSearchOpts().Sysroot; 436 std::unique_ptr<ASTReader> Reader(new ASTReader( 437 CI.getPreprocessor(), CI.getASTContext(), CI.getPCHContainerReader(), 438 CI.getFrontendOpts().ModuleFileExtensions, 439 Sysroot.empty() ? "" : Sysroot.c_str(), 440 /*DisableValidation*/ false, 441 /*AllowPCHWithCompilerErrors*/ false, 442 /*AllowConfigurationMismatch*/ true, 443 /*ValidateSystemInputs*/ true)); 444 445 Reader->ReadAST(getCurrentFile(), 446 Preamble ? serialization::MK_Preamble 447 : serialization::MK_PCH, 448 SourceLocation(), 449 ASTReader::ARR_ConfigurationMismatch); 450 } 451 452 namespace { 453 /// \brief AST reader listener that dumps module information for a module 454 /// file. 455 class DumpModuleInfoListener : public ASTReaderListener { 456 llvm::raw_ostream &Out; 457 458 public: 459 DumpModuleInfoListener(llvm::raw_ostream &Out) : Out(Out) { } 460 461 #define DUMP_BOOLEAN(Value, Text) \ 462 Out.indent(4) << Text << ": " << (Value? "Yes" : "No") << "\n" 463 464 bool ReadFullVersionInformation(StringRef FullVersion) override { 465 Out.indent(2) 466 << "Generated by " 467 << (FullVersion == getClangFullRepositoryVersion()? "this" 468 : "a different") 469 << " Clang: " << FullVersion << "\n"; 470 return ASTReaderListener::ReadFullVersionInformation(FullVersion); 471 } 472 473 void ReadModuleName(StringRef ModuleName) override { 474 Out.indent(2) << "Module name: " << ModuleName << "\n"; 475 } 476 void ReadModuleMapFile(StringRef ModuleMapPath) override { 477 Out.indent(2) << "Module map file: " << ModuleMapPath << "\n"; 478 } 479 480 bool ReadLanguageOptions(const LangOptions &LangOpts, bool Complain, 481 bool AllowCompatibleDifferences) override { 482 Out.indent(2) << "Language options:\n"; 483 #define LANGOPT(Name, Bits, Default, Description) \ 484 DUMP_BOOLEAN(LangOpts.Name, Description); 485 #define ENUM_LANGOPT(Name, Type, Bits, Default, Description) \ 486 Out.indent(4) << Description << ": " \ 487 << static_cast<unsigned>(LangOpts.get##Name()) << "\n"; 488 #define VALUE_LANGOPT(Name, Bits, Default, Description) \ 489 Out.indent(4) << Description << ": " << LangOpts.Name << "\n"; 490 #define BENIGN_LANGOPT(Name, Bits, Default, Description) 491 #define BENIGN_ENUM_LANGOPT(Name, Type, Bits, Default, Description) 492 #include "clang/Basic/LangOptions.def" 493 494 if (!LangOpts.ModuleFeatures.empty()) { 495 Out.indent(4) << "Module features:\n"; 496 for (StringRef Feature : LangOpts.ModuleFeatures) 497 Out.indent(6) << Feature << "\n"; 498 } 499 500 return false; 501 } 502 503 bool ReadTargetOptions(const TargetOptions &TargetOpts, bool Complain, 504 bool AllowCompatibleDifferences) override { 505 Out.indent(2) << "Target options:\n"; 506 Out.indent(4) << " Triple: " << TargetOpts.Triple << "\n"; 507 Out.indent(4) << " CPU: " << TargetOpts.CPU << "\n"; 508 Out.indent(4) << " ABI: " << TargetOpts.ABI << "\n"; 509 510 if (!TargetOpts.FeaturesAsWritten.empty()) { 511 Out.indent(4) << "Target features:\n"; 512 for (unsigned I = 0, N = TargetOpts.FeaturesAsWritten.size(); 513 I != N; ++I) { 514 Out.indent(6) << TargetOpts.FeaturesAsWritten[I] << "\n"; 515 } 516 } 517 518 return false; 519 } 520 521 bool ReadDiagnosticOptions(IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts, 522 bool Complain) override { 523 Out.indent(2) << "Diagnostic options:\n"; 524 #define DIAGOPT(Name, Bits, Default) DUMP_BOOLEAN(DiagOpts->Name, #Name); 525 #define ENUM_DIAGOPT(Name, Type, Bits, Default) \ 526 Out.indent(4) << #Name << ": " << DiagOpts->get##Name() << "\n"; 527 #define VALUE_DIAGOPT(Name, Bits, Default) \ 528 Out.indent(4) << #Name << ": " << DiagOpts->Name << "\n"; 529 #include "clang/Basic/DiagnosticOptions.def" 530 531 Out.indent(4) << "Diagnostic flags:\n"; 532 for (const std::string &Warning : DiagOpts->Warnings) 533 Out.indent(6) << "-W" << Warning << "\n"; 534 for (const std::string &Remark : DiagOpts->Remarks) 535 Out.indent(6) << "-R" << Remark << "\n"; 536 537 return false; 538 } 539 540 bool ReadHeaderSearchOptions(const HeaderSearchOptions &HSOpts, 541 StringRef SpecificModuleCachePath, 542 bool Complain) override { 543 Out.indent(2) << "Header search options:\n"; 544 Out.indent(4) << "System root [-isysroot=]: '" << HSOpts.Sysroot << "'\n"; 545 Out.indent(4) << "Module Cache: '" << SpecificModuleCachePath << "'\n"; 546 DUMP_BOOLEAN(HSOpts.UseBuiltinIncludes, 547 "Use builtin include directories [-nobuiltininc]"); 548 DUMP_BOOLEAN(HSOpts.UseStandardSystemIncludes, 549 "Use standard system include directories [-nostdinc]"); 550 DUMP_BOOLEAN(HSOpts.UseStandardCXXIncludes, 551 "Use standard C++ include directories [-nostdinc++]"); 552 DUMP_BOOLEAN(HSOpts.UseLibcxx, 553 "Use libc++ (rather than libstdc++) [-stdlib=]"); 554 return false; 555 } 556 557 bool ReadPreprocessorOptions(const PreprocessorOptions &PPOpts, 558 bool Complain, 559 std::string &SuggestedPredefines) override { 560 Out.indent(2) << "Preprocessor options:\n"; 561 DUMP_BOOLEAN(PPOpts.UsePredefines, 562 "Uses compiler/target-specific predefines [-undef]"); 563 DUMP_BOOLEAN(PPOpts.DetailedRecord, 564 "Uses detailed preprocessing record (for indexing)"); 565 566 if (!PPOpts.Macros.empty()) { 567 Out.indent(4) << "Predefined macros:\n"; 568 } 569 570 for (std::vector<std::pair<std::string, bool/*isUndef*/> >::const_iterator 571 I = PPOpts.Macros.begin(), IEnd = PPOpts.Macros.end(); 572 I != IEnd; ++I) { 573 Out.indent(6); 574 if (I->second) 575 Out << "-U"; 576 else 577 Out << "-D"; 578 Out << I->first << "\n"; 579 } 580 return false; 581 } 582 583 /// Indicates that a particular module file extension has been read. 584 void readModuleFileExtension( 585 const ModuleFileExtensionMetadata &Metadata) override { 586 Out.indent(2) << "Module file extension '" 587 << Metadata.BlockName << "' " << Metadata.MajorVersion 588 << "." << Metadata.MinorVersion; 589 if (!Metadata.UserInfo.empty()) { 590 Out << ": "; 591 Out.write_escaped(Metadata.UserInfo); 592 } 593 594 Out << "\n"; 595 } 596 #undef DUMP_BOOLEAN 597 }; 598 } 599 600 bool DumpModuleInfoAction::BeginInvocation(CompilerInstance &CI) { 601 // The Object file reader also supports raw ast files and there is no point in 602 // being strict about the module file format in -module-file-info mode. 603 CI.getHeaderSearchOpts().ModuleFormat = "obj"; 604 return true; 605 } 606 607 void DumpModuleInfoAction::ExecuteAction() { 608 // Set up the output file. 609 std::unique_ptr<llvm::raw_fd_ostream> OutFile; 610 StringRef OutputFileName = getCompilerInstance().getFrontendOpts().OutputFile; 611 if (!OutputFileName.empty() && OutputFileName != "-") { 612 std::error_code EC; 613 OutFile.reset(new llvm::raw_fd_ostream(OutputFileName.str(), EC, 614 llvm::sys::fs::F_Text)); 615 } 616 llvm::raw_ostream &Out = OutFile.get()? *OutFile.get() : llvm::outs(); 617 618 Out << "Information for module file '" << getCurrentFile() << "':\n"; 619 auto &FileMgr = getCompilerInstance().getFileManager(); 620 auto Buffer = FileMgr.getBufferForFile(getCurrentFile()); 621 StringRef Magic = (*Buffer)->getMemBufferRef().getBuffer(); 622 bool IsRaw = (Magic.size() >= 4 && Magic[0] == 'C' && Magic[1] == 'P' && 623 Magic[2] == 'C' && Magic[3] == 'H'); 624 Out << " Module format: " << (IsRaw ? "raw" : "obj") << "\n"; 625 626 Preprocessor &PP = getCompilerInstance().getPreprocessor(); 627 DumpModuleInfoListener Listener(Out); 628 HeaderSearchOptions &HSOpts = 629 PP.getHeaderSearchInfo().getHeaderSearchOpts(); 630 ASTReader::readASTFileControlBlock( 631 getCurrentFile(), FileMgr, getCompilerInstance().getPCHContainerReader(), 632 /*FindModuleFileExtensions=*/true, Listener, 633 HSOpts.ModulesValidateDiagnosticOptions); 634 } 635 636 //===----------------------------------------------------------------------===// 637 // Preprocessor Actions 638 //===----------------------------------------------------------------------===// 639 640 void DumpRawTokensAction::ExecuteAction() { 641 Preprocessor &PP = getCompilerInstance().getPreprocessor(); 642 SourceManager &SM = PP.getSourceManager(); 643 644 // Start lexing the specified input file. 645 const llvm::MemoryBuffer *FromFile = SM.getBuffer(SM.getMainFileID()); 646 Lexer RawLex(SM.getMainFileID(), FromFile, SM, PP.getLangOpts()); 647 RawLex.SetKeepWhitespaceMode(true); 648 649 Token RawTok; 650 RawLex.LexFromRawLexer(RawTok); 651 while (RawTok.isNot(tok::eof)) { 652 PP.DumpToken(RawTok, true); 653 llvm::errs() << "\n"; 654 RawLex.LexFromRawLexer(RawTok); 655 } 656 } 657 658 void DumpTokensAction::ExecuteAction() { 659 Preprocessor &PP = getCompilerInstance().getPreprocessor(); 660 // Start preprocessing the specified input file. 661 Token Tok; 662 PP.EnterMainSourceFile(); 663 do { 664 PP.Lex(Tok); 665 PP.DumpToken(Tok, true); 666 llvm::errs() << "\n"; 667 } while (Tok.isNot(tok::eof)); 668 } 669 670 void GeneratePTHAction::ExecuteAction() { 671 CompilerInstance &CI = getCompilerInstance(); 672 std::unique_ptr<raw_pwrite_stream> OS = 673 CI.createDefaultOutputFile(true, getCurrentFile()); 674 if (!OS) 675 return; 676 677 CacheTokens(CI.getPreprocessor(), OS.get()); 678 } 679 680 void PreprocessOnlyAction::ExecuteAction() { 681 Preprocessor &PP = getCompilerInstance().getPreprocessor(); 682 683 // Ignore unknown pragmas. 684 PP.IgnorePragmas(); 685 686 Token Tok; 687 // Start parsing the specified input file. 688 PP.EnterMainSourceFile(); 689 do { 690 PP.Lex(Tok); 691 } while (Tok.isNot(tok::eof)); 692 } 693 694 void PrintPreprocessedAction::ExecuteAction() { 695 CompilerInstance &CI = getCompilerInstance(); 696 // Output file may need to be set to 'Binary', to avoid converting Unix style 697 // line feeds (<LF>) to Microsoft style line feeds (<CR><LF>). 698 // 699 // Look to see what type of line endings the file uses. If there's a 700 // CRLF, then we won't open the file up in binary mode. If there is 701 // just an LF or CR, then we will open the file up in binary mode. 702 // In this fashion, the output format should match the input format, unless 703 // the input format has inconsistent line endings. 704 // 705 // This should be a relatively fast operation since most files won't have 706 // all of their source code on a single line. However, that is still a 707 // concern, so if we scan for too long, we'll just assume the file should 708 // be opened in binary mode. 709 bool BinaryMode = true; 710 bool InvalidFile = false; 711 const SourceManager& SM = CI.getSourceManager(); 712 const llvm::MemoryBuffer *Buffer = SM.getBuffer(SM.getMainFileID(), 713 &InvalidFile); 714 if (!InvalidFile) { 715 const char *cur = Buffer->getBufferStart(); 716 const char *end = Buffer->getBufferEnd(); 717 const char *next = (cur != end) ? cur + 1 : end; 718 719 // Limit ourselves to only scanning 256 characters into the source 720 // file. This is mostly a sanity check in case the file has no 721 // newlines whatsoever. 722 if (end - cur > 256) end = cur + 256; 723 724 while (next < end) { 725 if (*cur == 0x0D) { // CR 726 if (*next == 0x0A) // CRLF 727 BinaryMode = false; 728 729 break; 730 } else if (*cur == 0x0A) // LF 731 break; 732 733 ++cur; 734 ++next; 735 } 736 } 737 738 std::unique_ptr<raw_ostream> OS = 739 CI.createDefaultOutputFile(BinaryMode, getCurrentFile()); 740 if (!OS) return; 741 742 DoPrintPreprocessedInput(CI.getPreprocessor(), OS.get(), 743 CI.getPreprocessorOutputOpts()); 744 } 745 746 void PrintPreambleAction::ExecuteAction() { 747 switch (getCurrentFileKind()) { 748 case IK_C: 749 case IK_CXX: 750 case IK_ObjC: 751 case IK_ObjCXX: 752 case IK_OpenCL: 753 case IK_CUDA: 754 break; 755 756 case IK_None: 757 case IK_Asm: 758 case IK_PreprocessedC: 759 case IK_PreprocessedCuda: 760 case IK_PreprocessedCXX: 761 case IK_PreprocessedObjC: 762 case IK_PreprocessedObjCXX: 763 case IK_AST: 764 case IK_LLVM_IR: 765 case IK_RenderScript: 766 // We can't do anything with these. 767 return; 768 } 769 770 CompilerInstance &CI = getCompilerInstance(); 771 auto Buffer = CI.getFileManager().getBufferForFile(getCurrentFile()); 772 if (Buffer) { 773 unsigned Preamble = 774 Lexer::ComputePreamble((*Buffer)->getBuffer(), CI.getLangOpts()).first; 775 llvm::outs().write((*Buffer)->getBufferStart(), Preamble); 776 } 777 } 778