blob: 03ab20b083e12b4605220737b8a7617215337aec [file] [log] [blame]
Daniel Dunbar636404a2009-11-13 03:51:44 +00001//===--- CompilerInstance.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/CompilerInstance.h"
Daniel Dunbar56d9c292009-11-14 02:47:17 +000011#include "clang/AST/ASTConsumer.h"
Daniel Dunbardf3e30c2009-11-13 08:20:47 +000012#include "clang/AST/ASTContext.h"
Douglas Gregorbcfc7d02011-12-02 23:42:12 +000013#include "clang/AST/Decl.h"
Daniel Dunbar636404a2009-11-13 03:51:44 +000014#include "clang/Basic/Diagnostic.h"
Daniel Dunbar546a6762009-11-13 04:12:06 +000015#include "clang/Basic/FileManager.h"
16#include "clang/Basic/SourceManager.h"
Daniel Dunbar636404a2009-11-13 03:51:44 +000017#include "clang/Basic/TargetInfo.h"
Daniel Dunbar4f2bc552010-01-13 00:48:06 +000018#include "clang/Basic/Version.h"
Alp Tokerf988d002014-06-06 10:36:22 +000019#include "clang/Config/config.h"
David Blaikie8b00dcb2011-09-26 00:21:47 +000020#include "clang/Frontend/ChainedDiagnosticConsumer.h"
Daniel Dunbar4f2bc552010-01-13 00:48:06 +000021#include "clang/Frontend/FrontendAction.h"
Douglas Gregorfaeb1d42011-09-12 23:31:24 +000022#include "clang/Frontend/FrontendActions.h"
Daniel Dunbarf7093b52009-11-13 09:36:05 +000023#include "clang/Frontend/FrontendDiagnostic.h"
Daniel Dunbar2083c322011-04-07 18:31:10 +000024#include "clang/Frontend/LogDiagnosticPrinter.h"
Ted Kremenek4610ea22011-10-29 00:12:39 +000025#include "clang/Frontend/SerializedDiagnosticPrinter.h"
Daniel Dunbar7d75afc2009-11-13 05:52:34 +000026#include "clang/Frontend/TextDiagnosticPrinter.h"
Daniel Dunbaraaa148f2009-11-13 05:52:11 +000027#include "clang/Frontend/Utils.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000028#include "clang/Frontend/VerifyDiagnosticConsumer.h"
29#include "clang/Lex/HeaderSearch.h"
30#include "clang/Lex/PTHManager.h"
31#include "clang/Lex/Preprocessor.h"
Daniel Dunbarf7093b52009-11-13 09:36:05 +000032#include "clang/Sema/CodeCompleteConsumer.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000033#include "clang/Sema/Sema.h"
34#include "clang/Serialization/ASTReader.h"
John Thompson2255f2c2014-04-23 12:57:01 +000035#include "clang/Serialization/GlobalModuleIndex.h"
Douglas Gregor171b7802010-03-30 17:33:59 +000036#include "llvm/ADT/Statistic.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000037#include "llvm/Support/CrashRecoveryContext.h"
Rafael Espindola71de0b62014-06-13 17:20:50 +000038#include "llvm/Support/Errc.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000039#include "llvm/Support/FileSystem.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000040#include "llvm/Support/Host.h"
Douglas Gregore2124892012-01-29 20:15:24 +000041#include "llvm/Support/LockFileManager.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000042#include "llvm/Support/MemoryBuffer.h"
Michael J. Spencer8aaf4992010-11-29 18:12:39 +000043#include "llvm/Support/Path.h"
44#include "llvm/Support/Program.h"
45#include "llvm/Support/Signals.h"
Chandler Carruth3a022472012-12-04 09:13:33 +000046#include "llvm/Support/Timer.h"
47#include "llvm/Support/raw_ostream.h"
Douglas Gregor527b1c92013-03-25 21:19:16 +000048#include <sys/stat.h>
Rafael Espindola8a8e5542014-06-12 17:19:42 +000049#include <system_error>
Douglas Gregor37da3272013-03-25 21:51:16 +000050#include <time.h>
Douglas Gregor54a88812011-10-05 14:53:30 +000051
Daniel Dunbar636404a2009-11-13 03:51:44 +000052using namespace clang;
53
John Thompson2255f2c2014-04-23 12:57:01 +000054CompilerInstance::CompilerInstance(bool BuildingModule)
55 : ModuleLoader(BuildingModule),
Craig Topper49a27902014-05-22 04:46:25 +000056 Invocation(new CompilerInvocation()), ModuleManager(nullptr),
John Thompson2255f2c2014-04-23 12:57:01 +000057 BuildGlobalModuleIndex(false), HaveFullGlobalModuleIndex(false),
58 ModuleBuildFailed(false) {
Daniel Dunbar68242252010-01-30 21:47:07 +000059}
Daniel Dunbar636404a2009-11-13 03:51:44 +000060
61CompilerInstance::~CompilerInstance() {
Benjamin Kramer3c717b42012-10-14 19:21:21 +000062 assert(OutputFiles.empty() && "Still output files in flight?");
Daniel Dunbare922d9b2010-02-16 01:54:47 +000063}
64
Daniel Dunbar68242252010-01-30 21:47:07 +000065void CompilerInstance::setInvocation(CompilerInvocation *Value) {
Ted Kremenek5e14d392011-03-21 18:40:17 +000066 Invocation = Value;
Daniel Dunbar68242252010-01-30 21:47:07 +000067}
68
Douglas Gregorc1bbec82013-01-25 00:45:27 +000069bool CompilerInstance::shouldBuildGlobalModuleIndex() const {
Douglas Gregore060e572013-01-25 01:03:03 +000070 return (BuildGlobalModuleIndex ||
Douglas Gregor11ef0b72013-03-22 21:26:48 +000071 (ModuleManager && ModuleManager->isGlobalIndexUnavailable() &&
72 getFrontendOpts().GenerateGlobalModuleIndex)) &&
Douglas Gregore060e572013-01-25 01:03:03 +000073 !ModuleBuildFailed;
Douglas Gregorc1bbec82013-01-25 00:45:27 +000074}
75
David Blaikie9c902b52011-09-25 23:23:43 +000076void CompilerInstance::setDiagnostics(DiagnosticsEngine *Value) {
Douglas Gregor7f95d262010-04-05 23:52:57 +000077 Diagnostics = Value;
Daniel Dunbare01dc862009-11-14 01:20:40 +000078}
79
Daniel Dunbare01dc862009-11-14 01:20:40 +000080void CompilerInstance::setTarget(TargetInfo *Value) {
Ted Kremenek5e14d392011-03-21 18:40:17 +000081 Target = Value;
Daniel Dunbare01dc862009-11-14 01:20:40 +000082}
83
84void CompilerInstance::setFileManager(FileManager *Value) {
Ted Kremenek5e14d392011-03-21 18:40:17 +000085 FileMgr = Value;
Ben Langmuirc8130a72014-02-20 21:59:23 +000086 if (Value)
87 VirtualFileSystem = Value->getVirtualFileSystem();
88 else
89 VirtualFileSystem.reset();
Daniel Dunbare01dc862009-11-14 01:20:40 +000090}
91
NAKAMURA Takumi82a35112011-10-08 11:31:46 +000092void CompilerInstance::setSourceManager(SourceManager *Value) {
Ted Kremenek5e14d392011-03-21 18:40:17 +000093 SourceMgr = Value;
Daniel Dunbare01dc862009-11-14 01:20:40 +000094}
95
Ted Kremenek5e14d392011-03-21 18:40:17 +000096void CompilerInstance::setPreprocessor(Preprocessor *Value) { PP = Value; }
Daniel Dunbare01dc862009-11-14 01:20:40 +000097
Ted Kremenek5e14d392011-03-21 18:40:17 +000098void CompilerInstance::setASTContext(ASTContext *Value) { Context = Value; }
Daniel Dunbare01dc862009-11-14 01:20:40 +000099
Douglas Gregor0e93f012010-08-12 23:31:19 +0000100void CompilerInstance::setSema(Sema *S) {
101 TheSema.reset(S);
102}
103
David Blaikie6beb6aa2014-08-10 19:56:51 +0000104void CompilerInstance::setASTConsumer(std::unique_ptr<ASTConsumer> Value) {
105 Consumer = std::move(Value);
Daniel Dunbar56d9c292009-11-14 02:47:17 +0000106}
107
Daniel Dunbare01dc862009-11-14 01:20:40 +0000108void CompilerInstance::setCodeCompletionConsumer(CodeCompleteConsumer *Value) {
109 CompletionConsumer.reset(Value);
110}
David Blaikie61535812014-08-10 20:12:39 +0000111
112std::unique_ptr<Sema> CompilerInstance::takeSema() {
113 return std::move(TheSema);
114}
115
Argyrios Kyrtzidis1b7ed912014-02-27 04:11:59 +0000116IntrusiveRefCntPtr<ASTReader> CompilerInstance::getModuleManager() const {
117 return ModuleManager;
118}
119void CompilerInstance::setModuleManager(IntrusiveRefCntPtr<ASTReader> Reader) {
120 ModuleManager = Reader;
121}
Daniel Dunbare01dc862009-11-14 01:20:40 +0000122
Justin Bogner86d12592014-06-19 19:36:03 +0000123std::shared_ptr<ModuleDependencyCollector>
124CompilerInstance::getModuleDepCollector() const {
125 return ModuleDepCollector;
126}
127
128void CompilerInstance::setModuleDepCollector(
129 std::shared_ptr<ModuleDependencyCollector> Collector) {
130 ModuleDepCollector = Collector;
131}
132
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000133// Diagnostics
Douglas Gregor811db4e2012-10-23 22:26:28 +0000134static void SetUpDiagnosticLog(DiagnosticOptions *DiagOpts,
Daniel Dunbar7b833062011-04-07 18:59:02 +0000135 const CodeGenOptions *CodeGenOpts,
David Blaikie9c902b52011-09-25 23:23:43 +0000136 DiagnosticsEngine &Diags) {
Rafael Espindoladae941a2014-08-25 18:17:04 +0000137 std::error_code EC;
David Blaikie11f8a942014-09-15 17:30:56 +0000138 std::unique_ptr<raw_ostream> StreamOwner;
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000139 raw_ostream *OS = &llvm::errs();
Douglas Gregor811db4e2012-10-23 22:26:28 +0000140 if (DiagOpts->DiagnosticLogFile != "-") {
Daniel Dunbar2083c322011-04-07 18:31:10 +0000141 // Create the output stream.
David Blaikie11f8a942014-09-15 17:30:56 +0000142 auto FileOS = llvm::make_unique<llvm::raw_fd_ostream>(
Rafael Espindoladae941a2014-08-25 18:17:04 +0000143 DiagOpts->DiagnosticLogFile, EC,
David Blaikie11f8a942014-09-15 17:30:56 +0000144 llvm::sys::fs::F_Append | llvm::sys::fs::F_Text);
Rafael Espindoladae941a2014-08-25 18:17:04 +0000145 if (EC) {
Daniel Dunbar2083c322011-04-07 18:31:10 +0000146 Diags.Report(diag::warn_fe_cc_log_diagnostics_failure)
Rafael Espindoladae941a2014-08-25 18:17:04 +0000147 << DiagOpts->DiagnosticLogFile << EC.message();
Daniel Dunbar2083c322011-04-07 18:31:10 +0000148 } else {
149 FileOS->SetUnbuffered();
150 FileOS->SetUseAtomicWrites(true);
David Blaikie11f8a942014-09-15 17:30:56 +0000151 OS = FileOS.get();
152 StreamOwner = std::move(FileOS);
Daniel Dunbar2083c322011-04-07 18:31:10 +0000153 }
154 }
155
156 // Chain in the diagnostic client which will log the diagnostics.
David Blaikie7ee25502014-09-15 17:50:10 +0000157 auto Logger = llvm::make_unique<LogDiagnosticPrinter>(*OS, DiagOpts,
158 std::move(StreamOwner));
Daniel Dunbar7b833062011-04-07 18:59:02 +0000159 if (CodeGenOpts)
160 Logger->setDwarfDebugFlags(CodeGenOpts->DwarfDebugFlags);
David Blaikie7ee25502014-09-15 17:50:10 +0000161 assert(Diags.ownsClient());
162 Diags.setClient(new ChainedDiagnosticConsumer(
163 std::unique_ptr<DiagnosticConsumer>(Diags.takeClient()),
164 std::move(Logger)));
Daniel Dunbar2083c322011-04-07 18:31:10 +0000165}
166
Douglas Gregor811db4e2012-10-23 22:26:28 +0000167static void SetupSerializedDiagnostics(DiagnosticOptions *DiagOpts,
Ted Kremenek4610ea22011-10-29 00:12:39 +0000168 DiagnosticsEngine &Diags,
169 StringRef OutputFile) {
David Blaikie7ee25502014-09-15 17:50:10 +0000170 auto SerializedConsumer =
Justin Bogner5a6a2fc2014-10-23 22:20:11 +0000171 clang::serialized_diags::create(OutputFile, DiagOpts);
Ahmed Charles9a16beb2014-03-07 19:33:25 +0000172
David Blaikie7ee25502014-09-15 17:50:10 +0000173 assert(Diags.ownsClient());
174 Diags.setClient(new ChainedDiagnosticConsumer(
175 std::unique_ptr<DiagnosticConsumer>(Diags.takeClient()),
176 std::move(SerializedConsumer)));
Ted Kremenek4610ea22011-10-29 00:12:39 +0000177}
178
Sean Silvaf1b49e22013-01-20 01:58:28 +0000179void CompilerInstance::createDiagnostics(DiagnosticConsumer *Client,
Douglas Gregor30071cea2013-05-03 23:07:45 +0000180 bool ShouldOwnClient) {
Sean Silvaf1b49e22013-01-20 01:58:28 +0000181 Diagnostics = createDiagnostics(&getDiagnosticOpts(), Client,
Douglas Gregor30071cea2013-05-03 23:07:45 +0000182 ShouldOwnClient, &getCodeGenOpts());
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000183}
184
Dylan Noblesmithc95d8192012-02-20 14:00:23 +0000185IntrusiveRefCntPtr<DiagnosticsEngine>
Douglas Gregor811db4e2012-10-23 22:26:28 +0000186CompilerInstance::createDiagnostics(DiagnosticOptions *Opts,
David Blaikiee2eefae2011-09-25 23:39:51 +0000187 DiagnosticConsumer *Client,
Douglas Gregor2b9b4642011-09-13 01:26:44 +0000188 bool ShouldOwnClient,
Daniel Dunbar7b833062011-04-07 18:59:02 +0000189 const CodeGenOptions *CodeGenOpts) {
Dylan Noblesmithc95d8192012-02-20 14:00:23 +0000190 IntrusiveRefCntPtr<DiagnosticIDs> DiagID(new DiagnosticIDs());
191 IntrusiveRefCntPtr<DiagnosticsEngine>
Douglas Gregor811db4e2012-10-23 22:26:28 +0000192 Diags(new DiagnosticsEngine(DiagID, Opts));
Daniel Dunbar1b39a2e2009-11-14 07:53:24 +0000193
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000194 // Create the diagnostic client for reporting errors or for
195 // implementing -verify.
Douglas Gregord0e9e3a2011-09-29 00:38:00 +0000196 if (Client) {
Douglas Gregor30071cea2013-05-03 23:07:45 +0000197 Diags->setClient(Client, ShouldOwnClient);
Douglas Gregord0e9e3a2011-09-29 00:38:00 +0000198 } else
Douglas Gregor44c6ee72010-11-11 00:39:14 +0000199 Diags->setClient(new TextDiagnosticPrinter(llvm::errs(), Opts));
Daniel Dunbar50ec0da2009-11-14 03:24:39 +0000200
201 // Chain in -verify checker, if requested.
Douglas Gregor811db4e2012-10-23 22:26:28 +0000202 if (Opts->VerifyDiagnostics)
David Blaikie69609dc2011-09-26 00:38:03 +0000203 Diags->setClient(new VerifyDiagnosticConsumer(*Diags));
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000204
Daniel Dunbar2083c322011-04-07 18:31:10 +0000205 // Chain in -diagnostic-log-file dumper, if requested.
Douglas Gregor811db4e2012-10-23 22:26:28 +0000206 if (!Opts->DiagnosticLogFile.empty())
Daniel Dunbar7b833062011-04-07 18:59:02 +0000207 SetUpDiagnosticLog(Opts, CodeGenOpts, *Diags);
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000208
Douglas Gregor811db4e2012-10-23 22:26:28 +0000209 if (!Opts->DiagnosticSerializationFile.empty())
Ted Kremenek4610ea22011-10-29 00:12:39 +0000210 SetupSerializedDiagnostics(Opts, *Diags,
Douglas Gregor811db4e2012-10-23 22:26:28 +0000211 Opts->DiagnosticSerializationFile);
Ted Kremenek4610ea22011-10-29 00:12:39 +0000212
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000213 // Configure our handling of diagnostics.
Douglas Gregor811db4e2012-10-23 22:26:28 +0000214 ProcessWarningOptions(*Diags, *Opts);
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000215
Douglas Gregor7f95d262010-04-05 23:52:57 +0000216 return Diags;
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000217}
218
219// File Manager
220
Daniel Dunbar546a6762009-11-13 04:12:06 +0000221void CompilerInstance::createFileManager() {
Ben Langmuirc8130a72014-02-20 21:59:23 +0000222 if (!hasVirtualFileSystem()) {
223 // TODO: choose the virtual file system based on the CompilerInvocation.
224 setVirtualFileSystem(vfs::getRealFileSystem());
225 }
226 FileMgr = new FileManager(getFileSystemOpts(), VirtualFileSystem);
Daniel Dunbar546a6762009-11-13 04:12:06 +0000227}
228
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000229// Source Manager
230
Chris Lattner5159f612010-11-23 08:35:12 +0000231void CompilerInstance::createSourceManager(FileManager &FileMgr) {
Ted Kremenek5e14d392011-03-21 18:40:17 +0000232 SourceMgr = new SourceManager(getDiagnostics(), FileMgr);
Daniel Dunbar546a6762009-11-13 04:12:06 +0000233}
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000234
Alp Tokerc3580002014-07-07 06:05:00 +0000235// Initialize the remapping of files to alternative contents, e.g.,
236// those specified through other files.
237static void InitializeFileRemapping(DiagnosticsEngine &Diags,
238 SourceManager &SourceMgr,
239 FileManager &FileMgr,
240 const PreprocessorOptions &InitOpts) {
241 // Remap files in the source manager (with buffers).
Alp Toker1b070d22014-07-07 07:47:20 +0000242 for (const auto &RB : InitOpts.RemappedFileBuffers) {
Alp Tokerc3580002014-07-07 06:05:00 +0000243 // Create the file entry for the file that we're mapping from.
244 const FileEntry *FromFile =
Alp Toker1b070d22014-07-07 07:47:20 +0000245 FileMgr.getVirtualFile(RB.first, RB.second->getBufferSize(), 0);
Alp Tokerc3580002014-07-07 06:05:00 +0000246 if (!FromFile) {
Alp Toker1b070d22014-07-07 07:47:20 +0000247 Diags.Report(diag::err_fe_remap_missing_from_file) << RB.first;
Alp Tokerc3580002014-07-07 06:05:00 +0000248 if (!InitOpts.RetainRemappedFileBuffers)
Alp Toker1b070d22014-07-07 07:47:20 +0000249 delete RB.second;
Alp Tokerc3580002014-07-07 06:05:00 +0000250 continue;
251 }
252
253 // Override the contents of the "from" file with the contents of
254 // the "to" file.
Alp Toker1b070d22014-07-07 07:47:20 +0000255 SourceMgr.overrideFileContents(FromFile, RB.second,
Alp Tokerc3580002014-07-07 06:05:00 +0000256 InitOpts.RetainRemappedFileBuffers);
257 }
258
259 // Remap files in the source manager (with other files).
Alp Toker1b070d22014-07-07 07:47:20 +0000260 for (const auto &RF : InitOpts.RemappedFiles) {
Alp Tokerc3580002014-07-07 06:05:00 +0000261 // Find the file that we're mapping to.
Alp Toker1b070d22014-07-07 07:47:20 +0000262 const FileEntry *ToFile = FileMgr.getFile(RF.second);
Alp Tokerc3580002014-07-07 06:05:00 +0000263 if (!ToFile) {
Alp Toker1b070d22014-07-07 07:47:20 +0000264 Diags.Report(diag::err_fe_remap_missing_to_file) << RF.first << RF.second;
Alp Tokerc3580002014-07-07 06:05:00 +0000265 continue;
266 }
267
268 // Create the file entry for the file that we're mapping from.
269 const FileEntry *FromFile =
Alp Toker1b070d22014-07-07 07:47:20 +0000270 FileMgr.getVirtualFile(RF.first, ToFile->getSize(), 0);
Alp Tokerc3580002014-07-07 06:05:00 +0000271 if (!FromFile) {
Alp Toker1b070d22014-07-07 07:47:20 +0000272 Diags.Report(diag::err_fe_remap_missing_from_file) << RF.first;
Alp Tokerc3580002014-07-07 06:05:00 +0000273 continue;
274 }
275
276 // Override the contents of the "from" file with the contents of
277 // the "to" file.
278 SourceMgr.overrideFileContents(FromFile, ToFile);
279 }
280
281 SourceMgr.setOverridenFilesKeepOriginalName(
282 InitOpts.RemappedFilesKeepOriginalName);
283}
284
Daniel Dunbar7d75afc2009-11-13 05:52:34 +0000285// Preprocessor
286
Argyrios Kyrtzidise1974dc2014-03-07 07:47:58 +0000287void CompilerInstance::createPreprocessor(TranslationUnitKind TUKind) {
Douglas Gregor08142532011-08-26 23:56:07 +0000288 const PreprocessorOptions &PPOpts = getPreprocessorOpts();
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000289
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000290 // Create a PTH manager if we are using some form of a token cache.
Craig Topper49a27902014-05-22 04:46:25 +0000291 PTHManager *PTHMgr = nullptr;
Daniel Dunbard6ea9022009-11-17 05:52:41 +0000292 if (!PPOpts.TokenCache.empty())
Douglas Gregor08142532011-08-26 23:56:07 +0000293 PTHMgr = PTHManager::Create(PPOpts.TokenCache, getDiagnostics());
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000294
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000295 // Create the Preprocessor.
Douglas Gregorb85b9cc2012-10-24 16:19:39 +0000296 HeaderSearch *HeaderInfo = new HeaderSearch(&getHeaderSearchOpts(),
Manuel Klimek1f76c4e2013-10-24 07:51:24 +0000297 getSourceManager(),
Douglas Gregor1fb5c3a2011-12-31 04:05:44 +0000298 getDiagnostics(),
Douglas Gregor89929282012-01-30 06:01:29 +0000299 getLangOpts(),
300 &getTarget());
Alp Toker96637802014-05-02 03:43:38 +0000301 PP = new Preprocessor(&getPreprocessorOpts(), getDiagnostics(), getLangOpts(),
Douglas Gregor08142532011-08-26 23:56:07 +0000302 getSourceManager(), *HeaderInfo, *this, PTHMgr,
Alp Toker96637802014-05-02 03:43:38 +0000303 /*OwnsHeaderSearch=*/true, TUKind);
Alp Toker1ae02f62014-05-02 03:43:30 +0000304 PP->Initialize(getTarget());
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000305
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000306 // Note that this is different then passing PTHMgr to Preprocessor's ctor.
307 // That argument is used as the IdentifierInfoLookup argument to
308 // IdentifierTable's ctor.
309 if (PTHMgr) {
Douglas Gregor08142532011-08-26 23:56:07 +0000310 PTHMgr->setPreprocessor(&*PP);
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000311 PP->setPTHManager(PTHMgr);
312 }
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000313
Douglas Gregor7f6d60d2010-03-19 16:15:56 +0000314 if (PPOpts.DetailedRecord)
Argyrios Kyrtzidisf3d587e2012-12-04 07:27:05 +0000315 PP->createPreprocessingRecord();
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000316
Alp Tokerc3580002014-07-07 06:05:00 +0000317 // Apply remappings to the source manager.
318 InitializeFileRemapping(PP->getDiagnostics(), PP->getSourceManager(),
319 PP->getFileManager(), PPOpts);
320
321 // Predefine macros and configure the preprocessor.
322 InitializePreprocessor(*PP, PPOpts, getFrontendOpts());
323
324 // Initialize the header search object.
325 ApplyHeaderSearchOptions(PP->getHeaderSearchInfo(), getHeaderSearchOpts(),
326 PP->getLangOpts(), PP->getTargetInfo().getTriple());
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000327
Jordan Rose17441582013-01-30 01:52:57 +0000328 PP->setPreprocessedOutput(getPreprocessorOutputOpts().ShowCPP);
329
Douglas Gregor1735f4e2011-09-13 23:15:45 +0000330 // Set up the module path, including the hash for the
331 // module-creation options.
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000332 SmallString<256> SpecificModuleCache(
Douglas Gregor1735f4e2011-09-13 23:15:45 +0000333 getHeaderSearchOpts().ModuleCachePath);
334 if (!getHeaderSearchOpts().DisableModuleHash)
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000335 llvm::sys::path::append(SpecificModuleCache,
Douglas Gregor1735f4e2011-09-13 23:15:45 +0000336 getInvocation().getModuleHash());
Douglas Gregor2537a362011-12-08 17:01:29 +0000337 PP->getHeaderSearchInfo().setModuleCachePath(SpecificModuleCache);
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000338
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000339 // Handle generating dependencies, if requested.
Douglas Gregor08142532011-08-26 23:56:07 +0000340 const DependencyOutputOptions &DepOpts = getDependencyOutputOpts();
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000341 if (!DepOpts.OutputFile.empty())
Ben Langmuircb69b572014-03-07 06:40:32 +0000342 TheDependencyFileGenerator.reset(
343 DependencyFileGenerator::CreateAndAttachToPreprocessor(*PP, DepOpts));
Douglas Gregor2e129652012-02-02 23:45:13 +0000344 if (!DepOpts.DOTOutputFile.empty())
345 AttachDependencyGraphGen(*PP, DepOpts.DOTOutputFile,
Douglas Gregor83d46be2012-02-02 00:54:52 +0000346 getHeaderSearchOpts().Sysroot);
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000347
Ben Langmuir33c80902014-06-30 20:04:14 +0000348 for (auto &Listener : DependencyCollectors)
349 Listener->attachToPreprocessor(*PP);
350
Justin Bogner86d12592014-06-19 19:36:03 +0000351 // If we don't have a collector, but we are collecting module dependencies,
352 // then we're the top level compiler instance and need to create one.
353 if (!ModuleDepCollector && !DepOpts.ModuleDependencyOutputDir.empty())
354 ModuleDepCollector = std::make_shared<ModuleDependencyCollector>(
355 DepOpts.ModuleDependencyOutputDir);
Hans Wennborg0fd62072013-08-09 00:32:23 +0000356
Daniel Dunbar27734fd2011-02-02 15:41:17 +0000357 // Handle generating header include information, if requested.
358 if (DepOpts.ShowHeaderIncludes)
359 AttachHeaderIncludeGen(*PP);
Daniel Dunbar1af1d27512011-02-02 21:11:31 +0000360 if (!DepOpts.HeaderIncludeOutputFile.empty()) {
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000361 StringRef OutputPath = DepOpts.HeaderIncludeOutputFile;
Daniel Dunbar1af1d27512011-02-02 21:11:31 +0000362 if (OutputPath == "-")
363 OutputPath = "";
Daniel Dunbarfe908a82011-03-21 19:37:38 +0000364 AttachHeaderIncludeGen(*PP, /*ShowAllHeaders=*/true, OutputPath,
365 /*ShowDepth=*/false);
Daniel Dunbar1af1d27512011-02-02 21:11:31 +0000366 }
Hans Wennborg0fd62072013-08-09 00:32:23 +0000367
368 if (DepOpts.PrintShowIncludes) {
369 AttachHeaderIncludeGen(*PP, /*ShowAllHeaders=*/false, /*OutputPath=*/"",
370 /*ShowDepth=*/true, /*MSStyle=*/true);
371 }
Daniel Dunbaraaa148f2009-11-13 05:52:11 +0000372}
Daniel Dunbardf3e30c2009-11-13 08:20:47 +0000373
374// ASTContext
375
376void CompilerInstance::createASTContext() {
377 Preprocessor &PP = getPreprocessor();
Ted Kremenek5e14d392011-03-21 18:40:17 +0000378 Context = new ASTContext(getLangOpts(), PP.getSourceManager(),
Alp Toker08043432014-05-03 03:46:04 +0000379 PP.getIdentifierTable(), PP.getSelectorTable(),
380 PP.getBuiltinInfo());
381 Context->InitBuiltinTypes(getTarget());
Daniel Dunbardf3e30c2009-11-13 08:20:47 +0000382}
Daniel Dunbar599313e2009-11-13 08:21:10 +0000383
384// ExternalASTSource
385
Nico Weber824285e2014-05-08 04:26:47 +0000386void CompilerInstance::createPCHExternalASTSource(
387 StringRef Path, bool DisablePCHValidation, bool AllowPCHWithCompilerErrors,
388 void *DeserializationListener, bool OwnDeserializationListener) {
Argyrios Kyrtzidis1b7ed912014-02-27 04:11:59 +0000389 IntrusiveRefCntPtr<ExternalASTSource> Source;
Sebastian Redl009e7f22010-10-05 16:15:19 +0000390 bool Preamble = getPreprocessorOpts().PrecompiledPreambleBytes.first != 0;
Nico Weber824285e2014-05-08 04:26:47 +0000391 Source = createPCHExternalASTSource(
392 Path, getHeaderSearchOpts().Sysroot, DisablePCHValidation,
393 AllowPCHWithCompilerErrors, getPreprocessor(), getASTContext(),
394 DeserializationListener, OwnDeserializationListener, Preamble,
395 getFrontendOpts().UseGlobalModuleIndex);
Alp Tokerf994cef2014-07-05 03:08:06 +0000396 ModuleManager = static_cast<ASTReader*>(Source.get());
Daniel Dunbar599313e2009-11-13 08:21:10 +0000397 getASTContext().setExternalSource(Source);
398}
399
Nico Weber824285e2014-05-08 04:26:47 +0000400ExternalASTSource *CompilerInstance::createPCHExternalASTSource(
401 StringRef Path, const std::string &Sysroot, bool DisablePCHValidation,
402 bool AllowPCHWithCompilerErrors, Preprocessor &PP, ASTContext &Context,
403 void *DeserializationListener, bool OwnDeserializationListener,
404 bool Preamble, bool UseGlobalModuleIndex) {
Ben Langmuirdcf73862014-03-12 00:06:17 +0000405 HeaderSearchOptions &HSOpts = PP.getHeaderSearchInfo().getHeaderSearchOpts();
406
Ahmed Charlesb8984322014-03-07 20:03:18 +0000407 std::unique_ptr<ASTReader> Reader;
Douglas Gregor8835e032011-09-02 00:26:20 +0000408 Reader.reset(new ASTReader(PP, Context,
Douglas Gregorc567ba22011-07-22 16:35:34 +0000409 Sysroot.empty() ? "" : Sysroot.c_str(),
Argyrios Kyrtzidisd7c16b22012-10-31 20:59:50 +0000410 DisablePCHValidation,
Douglas Gregorc1bbec82013-01-25 00:45:27 +0000411 AllowPCHWithCompilerErrors,
Ben Langmuir3d4417c2014-02-07 17:31:11 +0000412 /*AllowConfigurationMismatch*/false,
Ben Langmuirdcf73862014-03-12 00:06:17 +0000413 HSOpts.ModulesValidateSystemHeaders,
Douglas Gregorc1bbec82013-01-25 00:45:27 +0000414 UseGlobalModuleIndex));
Daniel Dunbar599313e2009-11-13 08:21:10 +0000415
Sebastian Redl07a89a82010-07-30 00:29:29 +0000416 Reader->setDeserializationListener(
Nico Weber824285e2014-05-08 04:26:47 +0000417 static_cast<ASTDeserializationListener *>(DeserializationListener),
418 /*TakeOwnership=*/OwnDeserializationListener);
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000419 switch (Reader->ReadAST(Path,
420 Preamble ? serialization::MK_Preamble
Douglas Gregor4b29c162012-10-22 23:51:00 +0000421 : serialization::MK_PCH,
Argyrios Kyrtzidis2ec29362012-11-15 18:57:22 +0000422 SourceLocation(),
Ben Langmuir3d4417c2014-02-07 17:31:11 +0000423 ASTReader::ARR_None)) {
Sebastian Redl2c499f62010-08-18 23:56:43 +0000424 case ASTReader::Success:
Daniel Dunbar599313e2009-11-13 08:21:10 +0000425 // Set the predefines buffer as suggested by the PCH reader. Typically, the
426 // predefines buffer will be empty.
427 PP.setPredefines(Reader->getSuggestedPredefines());
Ahmed Charles9a16beb2014-03-07 19:33:25 +0000428 return Reader.release();
Daniel Dunbar599313e2009-11-13 08:21:10 +0000429
Sebastian Redl2c499f62010-08-18 23:56:43 +0000430 case ASTReader::Failure:
Daniel Dunbar599313e2009-11-13 08:21:10 +0000431 // Unrecoverable failure: don't even try to process the input file.
432 break;
433
Douglas Gregor7029ce12013-03-19 00:28:20 +0000434 case ASTReader::Missing:
Douglas Gregorc9ad5fb2012-10-22 22:50:17 +0000435 case ASTReader::OutOfDate:
436 case ASTReader::VersionMismatch:
437 case ASTReader::ConfigurationMismatch:
438 case ASTReader::HadErrors:
Daniel Dunbar599313e2009-11-13 08:21:10 +0000439 // No suitable PCH file could be found. Return an error.
440 break;
441 }
442
Craig Topper49a27902014-05-22 04:46:25 +0000443 return nullptr;
Daniel Dunbar599313e2009-11-13 08:21:10 +0000444}
Daniel Dunbarf7093b52009-11-13 09:36:05 +0000445
446// Code Completion
447
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000448static bool EnableCodeCompletion(Preprocessor &PP,
Douglas Gregor8e984da2010-08-04 16:47:14 +0000449 const std::string &Filename,
450 unsigned Line,
451 unsigned Column) {
452 // Tell the source manager to chop off the given file at a specific
453 // line and column.
Chris Lattner5159f612010-11-23 08:35:12 +0000454 const FileEntry *Entry = PP.getFileManager().getFile(Filename);
Douglas Gregor8e984da2010-08-04 16:47:14 +0000455 if (!Entry) {
456 PP.getDiagnostics().Report(diag::err_fe_invalid_code_complete_file)
457 << Filename;
458 return true;
459 }
460
461 // Truncate the named file at the given line/column.
462 PP.SetCodeCompletionPoint(Entry, Line, Column);
463 return false;
464}
465
Daniel Dunbarf7093b52009-11-13 09:36:05 +0000466void CompilerInstance::createCodeCompletionConsumer() {
467 const ParsedSourceLocation &Loc = getFrontendOpts().CodeCompletionAt;
Douglas Gregor8e984da2010-08-04 16:47:14 +0000468 if (!CompletionConsumer) {
Erik Verbruggen2fca3c22012-04-12 10:31:12 +0000469 setCodeCompletionConsumer(
Douglas Gregor8e984da2010-08-04 16:47:14 +0000470 createCodeCompletionConsumer(getPreprocessor(),
471 Loc.FileName, Loc.Line, Loc.Column,
Dmitri Gribenko3292d062012-07-02 17:35:10 +0000472 getFrontendOpts().CodeCompleteOpts,
Douglas Gregor8e984da2010-08-04 16:47:14 +0000473 llvm::outs()));
474 if (!CompletionConsumer)
475 return;
476 } else if (EnableCodeCompletion(getPreprocessor(), Loc.FileName,
477 Loc.Line, Loc.Column)) {
Craig Topper49a27902014-05-22 04:46:25 +0000478 setCodeCompletionConsumer(nullptr);
Douglas Gregor00a0cf72010-03-16 06:04:47 +0000479 return;
Douglas Gregor8e984da2010-08-04 16:47:14 +0000480 }
Douglas Gregorf09935f2009-12-01 05:55:20 +0000481
482 if (CompletionConsumer->isOutputBinary() &&
Rafael Espindolaa3346d82013-06-12 20:44:26 +0000483 llvm::sys::ChangeStdoutToBinary()) {
Douglas Gregorf09935f2009-12-01 05:55:20 +0000484 getPreprocessor().getDiagnostics().Report(diag::err_fe_stdout_binary);
Craig Topper49a27902014-05-22 04:46:25 +0000485 setCodeCompletionConsumer(nullptr);
Douglas Gregorf09935f2009-12-01 05:55:20 +0000486 }
Daniel Dunbarf7093b52009-11-13 09:36:05 +0000487}
488
Kovarththanan Rajaratnam5505dff2009-11-29 09:57:35 +0000489void CompilerInstance::createFrontendTimer() {
490 FrontendTimer.reset(new llvm::Timer("Clang front-end timer"));
491}
492
Daniel Dunbarf7093b52009-11-13 09:36:05 +0000493CodeCompleteConsumer *
494CompilerInstance::createCodeCompletionConsumer(Preprocessor &PP,
495 const std::string &Filename,
496 unsigned Line,
497 unsigned Column,
Dmitri Gribenko3292d062012-07-02 17:35:10 +0000498 const CodeCompleteOptions &Opts,
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000499 raw_ostream &OS) {
Douglas Gregor8e984da2010-08-04 16:47:14 +0000500 if (EnableCodeCompletion(PP, Filename, Line, Column))
Craig Topper49a27902014-05-22 04:46:25 +0000501 return nullptr;
Daniel Dunbarf7093b52009-11-13 09:36:05 +0000502
503 // Set up the creation routine for code-completion.
Dmitri Gribenko3292d062012-07-02 17:35:10 +0000504 return new PrintingCodeCompleteConsumer(Opts, OS);
Daniel Dunbarf7093b52009-11-13 09:36:05 +0000505}
Daniel Dunbar566eeb22009-11-13 10:37:48 +0000506
Douglas Gregor69f74f82011-08-25 22:30:56 +0000507void CompilerInstance::createSema(TranslationUnitKind TUKind,
Douglas Gregor0e93f012010-08-12 23:31:19 +0000508 CodeCompleteConsumer *CompletionConsumer) {
509 TheSema.reset(new Sema(getPreprocessor(), getASTContext(), getASTConsumer(),
Douglas Gregor69f74f82011-08-25 22:30:56 +0000510 TUKind, CompletionConsumer));
Douglas Gregor0e93f012010-08-12 23:31:19 +0000511}
512
Daniel Dunbar566eeb22009-11-13 10:37:48 +0000513// Output Files
514
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000515void CompilerInstance::addOutputFile(const OutputFile &OutFile) {
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000516 assert(OutFile.OS && "Attempt to add empty stream to output list!");
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000517 OutputFiles.push_back(OutFile);
Daniel Dunbar566eeb22009-11-13 10:37:48 +0000518}
519
Kovarththanan Rajaratnam1c558cd2010-03-06 12:07:48 +0000520void CompilerInstance::clearOutputFiles(bool EraseFiles) {
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000521 for (std::list<OutputFile>::iterator
Daniel Dunbar566eeb22009-11-13 10:37:48 +0000522 it = OutputFiles.begin(), ie = OutputFiles.end(); it != ie; ++it) {
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000523 delete it->OS;
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000524 if (!it->TempFilename.empty()) {
Anders Carlssonb5c356a2011-03-06 22:25:35 +0000525 if (EraseFiles) {
Rafael Espindola2a008782014-01-10 21:32:14 +0000526 llvm::sys::fs::remove(it->TempFilename);
Anders Carlssonb5c356a2011-03-06 22:25:35 +0000527 } else {
Dylan Noblesmith2c1dd272012-02-05 02:13:05 +0000528 SmallString<128> NewOutFile(it->Filename);
Anders Carlssonb5c356a2011-03-06 22:25:35 +0000529
Argyrios Kyrtzidis71731d62010-11-03 22:45:23 +0000530 // If '-working-directory' was passed, the output filename should be
531 // relative to that.
Anders Carlsson9ba8fb12011-03-14 01:13:54 +0000532 FileMgr->FixupRelativePath(NewOutFile);
Rafael Espindolac0809172014-06-12 14:02:15 +0000533 if (std::error_code ec =
534 llvm::sys::fs::rename(it->TempFilename, NewOutFile.str())) {
Manuel Klimek3ef9c442012-05-16 20:55:58 +0000535 getDiagnostics().Report(diag::err_unable_to_rename_temp)
Anders Carlssonb5c356a2011-03-06 22:25:35 +0000536 << it->TempFilename << it->Filename << ec.message();
537
Rafael Espindola2a008782014-01-10 21:32:14 +0000538 llvm::sys::fs::remove(it->TempFilename);
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000539 }
540 }
541 } else if (!it->Filename.empty() && EraseFiles)
Rafael Espindola399ab332013-06-26 04:32:59 +0000542 llvm::sys::fs::remove(it->Filename);
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000543
Daniel Dunbar566eeb22009-11-13 10:37:48 +0000544 }
545 OutputFiles.clear();
546}
547
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000548llvm::raw_fd_ostream *
549CompilerInstance::createDefaultOutputFile(bool Binary,
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000550 StringRef InFile,
551 StringRef Extension) {
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000552 return createOutputFile(getFrontendOpts().OutputFile, Binary,
Daniel Dunbarae77b3d2012-03-03 00:36:06 +0000553 /*RemoveFileOnSignal=*/true, InFile, Extension,
554 /*UseTemporary=*/true);
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000555}
556
Alp Tokerea046722014-06-03 17:23:34 +0000557llvm::raw_null_ostream *CompilerInstance::createNullOutputFile() {
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000558 llvm::raw_null_ostream *OS = new llvm::raw_null_ostream();
559 addOutputFile(OutputFile("", "", OS));
560 return OS;
Alp Tokerea046722014-06-03 17:23:34 +0000561}
562
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000563llvm::raw_fd_ostream *
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000564CompilerInstance::createOutputFile(StringRef OutputPath,
Daniel Dunbare326f9b2011-01-31 22:00:42 +0000565 bool Binary, bool RemoveFileOnSignal,
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000566 StringRef InFile,
Argyrios Kyrtzidis08a2bfd2011-07-28 00:45:10 +0000567 StringRef Extension,
Daniel Dunbarb9c62c02012-03-03 00:36:02 +0000568 bool UseTemporary,
569 bool CreateMissingDirectories) {
Rafael Espindoladae941a2014-08-25 18:17:04 +0000570 std::string OutputPathName, TempPathName;
571 std::error_code EC;
572 llvm::raw_fd_ostream *OS = createOutputFile(
573 OutputPath, EC, Binary, RemoveFileOnSignal, InFile, Extension,
574 UseTemporary, CreateMissingDirectories, &OutputPathName, &TempPathName);
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000575 if (!OS) {
Rafael Espindoladae941a2014-08-25 18:17:04 +0000576 getDiagnostics().Report(diag::err_fe_unable_to_open_output) << OutputPath
577 << EC.message();
Craig Topper49a27902014-05-22 04:46:25 +0000578 return nullptr;
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000579 }
580
581 // Add the output file -- but don't try to remove "-", since this means we are
582 // using stdin.
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000583 addOutputFile(OutputFile((OutputPathName != "-") ? OutputPathName : "",
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000584 TempPathName, OS));
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000585
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000586 return OS;
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000587}
588
Rafael Espindoladae941a2014-08-25 18:17:04 +0000589llvm::raw_fd_ostream *CompilerInstance::createOutputFile(
590 StringRef OutputPath, std::error_code &Error, bool Binary,
591 bool RemoveFileOnSignal, StringRef InFile, StringRef Extension,
592 bool UseTemporary, bool CreateMissingDirectories,
593 std::string *ResultPathName, std::string *TempPathName) {
Daniel Dunbarb9c62c02012-03-03 00:36:02 +0000594 assert((!CreateMissingDirectories || UseTemporary) &&
595 "CreateMissingDirectories is only allowed when using temporary files");
596
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000597 std::string OutFile, TempFile;
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000598 if (!OutputPath.empty()) {
599 OutFile = OutputPath;
600 } else if (InFile == "-") {
601 OutFile = "-";
602 } else if (!Extension.empty()) {
Rafael Espindola399ab332013-06-26 04:32:59 +0000603 SmallString<128> Path(InFile);
604 llvm::sys::path::replace_extension(Path, Extension);
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000605 OutFile = Path.str();
606 } else {
607 OutFile = "-";
608 }
Argyrios Kyrtzidis08a2bfd2011-07-28 00:45:10 +0000609
Ahmed Charlesb8984322014-03-07 20:03:18 +0000610 std::unique_ptr<llvm::raw_fd_ostream> OS;
Argyrios Kyrtzidis08a2bfd2011-07-28 00:45:10 +0000611 std::string OSFile;
612
Rafael Espindola73c23a72013-06-27 18:26:26 +0000613 if (UseTemporary) {
614 if (OutFile == "-")
615 UseTemporary = false;
616 else {
617 llvm::sys::fs::file_status Status;
618 llvm::sys::fs::status(OutputPath, Status);
619 if (llvm::sys::fs::exists(Status)) {
620 // Fail early if we can't write to the final destination.
621 if (!llvm::sys::fs::can_write(OutputPath))
Craig Topper49a27902014-05-22 04:46:25 +0000622 return nullptr;
Rafael Espindola73c23a72013-06-27 18:26:26 +0000623
624 // Don't use a temporary if the output is a special file. This handles
625 // things like '-o /dev/null'
626 if (!llvm::sys::fs::is_regular_file(Status))
627 UseTemporary = false;
Argyrios Kyrtzidis08a2bfd2011-07-28 00:45:10 +0000628 }
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000629 }
630 }
631
Rafael Espindola73c23a72013-06-27 18:26:26 +0000632 if (UseTemporary) {
Rafael Espindola73c23a72013-06-27 18:26:26 +0000633 // Create a temporary file.
634 SmallString<128> TempPath;
635 TempPath = OutFile;
636 TempPath += "-%%%%%%%%";
637 int fd;
Rafael Espindolac0809172014-06-12 14:02:15 +0000638 std::error_code EC =
Rafael Espindola18627112013-07-05 21:13:58 +0000639 llvm::sys::fs::createUniqueFile(TempPath.str(), fd, TempPath);
Rafael Espindola157f34b2013-06-28 03:49:04 +0000640
641 if (CreateMissingDirectories &&
Rafael Espindola71de0b62014-06-13 17:20:50 +0000642 EC == llvm::errc::no_such_file_or_directory) {
Rafael Espindola157f34b2013-06-28 03:49:04 +0000643 StringRef Parent = llvm::sys::path::parent_path(OutputPath);
644 EC = llvm::sys::fs::create_directories(Parent);
645 if (!EC) {
Rafael Espindola18627112013-07-05 21:13:58 +0000646 EC = llvm::sys::fs::createUniqueFile(TempPath.str(), fd, TempPath);
Rafael Espindola157f34b2013-06-28 03:49:04 +0000647 }
648 }
649
650 if (!EC) {
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000651 OS.reset(new llvm::raw_fd_ostream(fd, /*shouldClose=*/true));
Rafael Espindola73c23a72013-06-27 18:26:26 +0000652 OSFile = TempFile = TempPath.str();
653 }
654 // If we failed to create the temporary, fallback to writing to the file
655 // directly. This handles the corner case where we cannot write to the
656 // directory, but can write to the file.
657 }
658
Argyrios Kyrtzidis08a2bfd2011-07-28 00:45:10 +0000659 if (!OS) {
660 OSFile = OutFile;
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000661 OS.reset(new llvm::raw_fd_ostream(
Rafael Espindoladae941a2014-08-25 18:17:04 +0000662 OSFile, Error,
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000663 (Binary ? llvm::sys::fs::F_None : llvm::sys::fs::F_Text)));
Rafael Espindoladae941a2014-08-25 18:17:04 +0000664 if (Error)
Craig Topper49a27902014-05-22 04:46:25 +0000665 return nullptr;
Argyrios Kyrtzidis08a2bfd2011-07-28 00:45:10 +0000666 }
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000667
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000668 // Make sure the out stream file gets removed if we crash.
Daniel Dunbare326f9b2011-01-31 22:00:42 +0000669 if (RemoveFileOnSignal)
Rafael Espindola18556de2013-06-13 21:02:40 +0000670 llvm::sys::RemoveFileOnSignal(OSFile);
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000671
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000672 if (ResultPathName)
673 *ResultPathName = OutFile;
Argyrios Kyrtzidisd0599972010-09-17 17:38:48 +0000674 if (TempPathName)
675 *TempPathName = TempFile;
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000676
NAKAMURA Takumi69f35282014-08-11 06:53:11 +0000677 return OS.release();
Daniel Dunbar420b0f12009-11-13 18:32:08 +0000678}
Daniel Dunbar409e8902009-11-14 07:53:04 +0000679
680// Initialization Utilities
681
Argyrios Kyrtzidis1b3240b2012-11-09 19:40:33 +0000682bool CompilerInstance::InitializeSourceManager(const FrontendInputFile &Input){
683 return InitializeSourceManager(Input, getDiagnostics(),
Douglas Gregora686e1b2012-01-27 19:52:33 +0000684 getFileManager(), getSourceManager(),
685 getFrontendOpts());
Daniel Dunbar409e8902009-11-14 07:53:04 +0000686}
687
Argyrios Kyrtzidis1b3240b2012-11-09 19:40:33 +0000688bool CompilerInstance::InitializeSourceManager(const FrontendInputFile &Input,
David Blaikie9c902b52011-09-25 23:23:43 +0000689 DiagnosticsEngine &Diags,
Daniel Dunbar409e8902009-11-14 07:53:04 +0000690 FileManager &FileMgr,
691 SourceManager &SourceMgr,
692 const FrontendOptions &Opts) {
Argyrios Kyrtzidis1b3240b2012-11-09 19:40:33 +0000693 SrcMgr::CharacteristicKind
Argyrios Kyrtzidis873c8582012-11-09 19:40:39 +0000694 Kind = Input.isSystem() ? SrcMgr::C_System : SrcMgr::C_User;
Argyrios Kyrtzidis1b3240b2012-11-09 19:40:33 +0000695
Argyrios Kyrtzidis6566e232012-11-09 19:40:45 +0000696 if (Input.isBuffer()) {
David Blaikie50a5f972014-08-29 07:59:55 +0000697 SourceMgr.setMainFileID(SourceMgr.createFileID(
698 std::unique_ptr<llvm::MemoryBuffer>(Input.getBuffer()), Kind));
Argyrios Kyrtzidis6566e232012-11-09 19:40:45 +0000699 assert(!SourceMgr.getMainFileID().isInvalid() &&
700 "Couldn't establish MainFileID!");
701 return true;
702 }
703
704 StringRef InputFile = Input.getFile();
705
Argyrios Kyrtzidis7c06d862011-09-19 20:40:35 +0000706 // Figure out where to get and map in the main file.
707 if (InputFile != "-") {
Benjamin Kramer3841fa32013-08-12 13:46:52 +0000708 const FileEntry *File = FileMgr.getFile(InputFile, /*OpenFile=*/true);
Dan Gohman52765212010-10-26 21:13:51 +0000709 if (!File) {
Daniel Dunbar409e8902009-11-14 07:53:04 +0000710 Diags.Report(diag::err_fe_error_reading) << InputFile;
711 return false;
712 }
Daniel Dunbare2951f42012-11-05 22:53:33 +0000713
714 // The natural SourceManager infrastructure can't currently handle named
715 // pipes, but we would at least like to accept them for the main
Benjamin Kramer3841fa32013-08-12 13:46:52 +0000716 // file. Detect them here, read them with the volatile flag so FileMgr will
717 // pick up the correct size, and simply override their contents as we do for
718 // STDIN.
Daniel Dunbare2951f42012-11-05 22:53:33 +0000719 if (File->isNamedPipe()) {
Benjamin Kramera8857962014-10-26 22:44:13 +0000720 auto MB = FileMgr.getBufferForFile(File, /*isVolatile=*/true);
721 if (MB) {
Benjamin Kramer3841fa32013-08-12 13:46:52 +0000722 // Create a new virtual file that will have the correct size.
Benjamin Kramera8857962014-10-26 22:44:13 +0000723 File = FileMgr.getVirtualFile(InputFile, (*MB)->getBufferSize(), 0);
724 SourceMgr.overrideFileContents(File, std::move(*MB));
Benjamin Kramer3841fa32013-08-12 13:46:52 +0000725 } else {
Benjamin Kramera8857962014-10-26 22:44:13 +0000726 Diags.Report(diag::err_cannot_open_file) << InputFile
727 << MB.getError().message();
Daniel Dunbare2951f42012-11-05 22:53:33 +0000728 return false;
729 }
Daniel Dunbare2951f42012-11-05 22:53:33 +0000730 }
Daniel Dunbardb0745a2012-11-27 00:04:16 +0000731
Alp Tokerb671e342014-05-21 01:12:41 +0000732 SourceMgr.setMainFileID(
733 SourceMgr.createFileID(File, SourceLocation(), Kind));
Daniel Dunbar409e8902009-11-14 07:53:04 +0000734 } else {
Rafael Espindola2d2b4202014-07-06 17:43:24 +0000735 llvm::ErrorOr<std::unique_ptr<llvm::MemoryBuffer>> SBOrErr =
736 llvm::MemoryBuffer::getSTDIN();
737 if (std::error_code EC = SBOrErr.getError()) {
738 Diags.Report(diag::err_fe_error_reading_stdin) << EC.message();
Daniel Dunbar409e8902009-11-14 07:53:04 +0000739 return false;
740 }
Rafael Espindola2d2b4202014-07-06 17:43:24 +0000741 std::unique_ptr<llvm::MemoryBuffer> SB = std::move(SBOrErr.get());
742
Dan Gohman2f76cd72010-10-26 23:21:25 +0000743 const FileEntry *File = FileMgr.getVirtualFile(SB->getBufferIdentifier(),
Chris Lattner5159f612010-11-23 08:35:12 +0000744 SB->getBufferSize(), 0);
Alp Tokerb671e342014-05-21 01:12:41 +0000745 SourceMgr.setMainFileID(
746 SourceMgr.createFileID(File, SourceLocation(), Kind));
David Blaikie49cc3182014-08-27 20:54:45 +0000747 SourceMgr.overrideFileContents(File, std::move(SB));
Daniel Dunbar409e8902009-11-14 07:53:04 +0000748 }
749
Dan Gohman52765212010-10-26 21:13:51 +0000750 assert(!SourceMgr.getMainFileID().isInvalid() &&
751 "Couldn't establish MainFileID!");
Daniel Dunbar409e8902009-11-14 07:53:04 +0000752 return true;
753}
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000754
755// High-Level Operations
756
757bool CompilerInstance::ExecuteAction(FrontendAction &Act) {
758 assert(hasDiagnostics() && "Diagnostics engine is not initialized!");
759 assert(!getFrontendOpts().ShowHelp && "Client must handle '-help'!");
760 assert(!getFrontendOpts().ShowVersion && "Client must handle '-version'!");
761
762 // FIXME: Take this as an argument, once all the APIs we used have moved to
763 // taking it as an input instead of hard-coding llvm::errs.
Chris Lattner0e62c1c2011-07-23 10:55:15 +0000764 raw_ostream &OS = llvm::errs();
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000765
766 // Create the target instance.
Alp Toker80758082014-07-06 05:26:44 +0000767 setTarget(TargetInfo::CreateTargetInfo(getDiagnostics(),
768 getInvocation().TargetOpts));
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000769 if (!hasTarget())
770 return false;
771
772 // Inform the target of the language options.
773 //
774 // FIXME: We shouldn't need to do this, the target should be immutable once
775 // created. This complexity should be lifted elsewhere.
Alp Toker74437972014-07-06 05:14:24 +0000776 getTarget().adjust(getLangOpts());
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000777
Fariborz Jahanian29898f42012-04-16 21:03:30 +0000778 // rewriter project will change target built-in bool type from its default.
779 if (getFrontendOpts().ProgramAction == frontend::RewriteObjC)
780 getTarget().noSignedCharForObjCBool();
781
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000782 // Validate/process some options.
783 if (getHeaderSearchOpts().Verbose)
784 OS << "clang -cc1 version " CLANG_VERSION_STRING
Alp Tokerf988d002014-06-06 10:36:22 +0000785 << " based upon " << BACKEND_PACKAGE_STRING
Sebastian Pop8188c8a2011-11-01 21:33:06 +0000786 << " default target " << llvm::sys::getDefaultTargetTriple() << "\n";
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000787
788 if (getFrontendOpts().ShowTimers)
789 createFrontendTimer();
790
Douglas Gregor171b7802010-03-30 17:33:59 +0000791 if (getFrontendOpts().ShowStats)
792 llvm::EnableStatistics();
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000793
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000794 for (unsigned i = 0, e = getFrontendOpts().Inputs.size(); i != e; ++i) {
Ted Kremenekeeccb302014-08-27 15:14:15 +0000795 // Reset the ID tables if we are reusing the SourceManager and parsing
796 // regular files.
797 if (hasSourceManager() && !Act.isModelParsingAction())
Daniel Dunbaraed46fc2010-06-07 23:23:50 +0000798 getSourceManager().clearIDTables();
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000799
Douglas Gregor32fbe312012-01-20 16:28:04 +0000800 if (Act.BeginSourceFile(*this, getFrontendOpts().Inputs[i])) {
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000801 Act.Execute();
802 Act.EndSourceFile();
803 }
804 }
805
Argyrios Kyrtzidis7910d7b2011-12-07 05:52:12 +0000806 // Notify the diagnostic client that all files were processed.
807 getDiagnostics().getClient()->finish();
808
Chris Lattner198cb4d2010-04-07 18:47:42 +0000809 if (getDiagnosticOpts().ShowCarets) {
Argyrios Kyrtzidisc79346a2010-11-18 20:06:46 +0000810 // We can have multiple diagnostics sharing one diagnostic client.
811 // Get the total number of warnings/errors from the client.
812 unsigned NumWarnings = getDiagnostics().getClient()->getNumWarnings();
813 unsigned NumErrors = getDiagnostics().getClient()->getNumErrors();
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000814
Chris Lattner198cb4d2010-04-07 18:47:42 +0000815 if (NumWarnings)
816 OS << NumWarnings << " warning" << (NumWarnings == 1 ? "" : "s");
817 if (NumWarnings && NumErrors)
818 OS << " and ";
819 if (NumErrors)
820 OS << NumErrors << " error" << (NumErrors == 1 ? "" : "s");
821 if (NumWarnings || NumErrors)
822 OS << " generated.\n";
823 }
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000824
Daniel Dunbaraed46fc2010-06-07 23:23:50 +0000825 if (getFrontendOpts().ShowStats && hasFileManager()) {
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000826 getFileManager().PrintStats();
827 OS << "\n";
828 }
829
Argyrios Kyrtzidisbc467932010-11-18 21:13:57 +0000830 return !getDiagnostics().getClient()->getNumErrors();
Daniel Dunbar4f2bc552010-01-13 00:48:06 +0000831}
832
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000833/// \brief Determine the appropriate source input kind based on language
834/// options.
835static InputKind getSourceInputKindFromOptions(const LangOptions &LangOpts) {
836 if (LangOpts.OpenCL)
837 return IK_OpenCL;
838 if (LangOpts.CUDA)
839 return IK_CUDA;
840 if (LangOpts.ObjC1)
841 return LangOpts.CPlusPlus? IK_ObjCXX : IK_ObjC;
842 return LangOpts.CPlusPlus? IK_CXX : IK_C;
843}
844
Douglas Gregor514b6362011-11-29 19:06:37 +0000845/// \brief Compile a module file for the given module, using the options
Ben Langmuirb797d592014-07-19 16:29:28 +0000846/// provided by the importing compiler instance. Returns true if the module
847/// was built without errors.
848static bool compileModuleImpl(CompilerInstance &ImportingInstance,
849 SourceLocation ImportLoc,
850 Module *Module,
851 StringRef ModuleFileName) {
Douglas Gregor514b6362011-11-29 19:06:37 +0000852 ModuleMap &ModMap
853 = ImportingInstance.getPreprocessor().getHeaderSearchInfo().getModuleMap();
854
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000855 // Construct a compiler invocation for creating this module.
Dylan Noblesmithc95d8192012-02-20 14:00:23 +0000856 IntrusiveRefCntPtr<CompilerInvocation> Invocation
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000857 (new CompilerInvocation(ImportingInstance.getInvocation()));
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000858
Douglas Gregorf545f672011-11-29 21:59:16 +0000859 PreprocessorOptions &PPOpts = Invocation->getPreprocessorOpts();
860
Douglas Gregor44bf68d2011-09-15 20:53:28 +0000861 // For any options that aren't intended to affect how a module is built,
862 // reset them to their default values.
Ted Kremenek8cf47df2011-11-17 23:01:24 +0000863 Invocation->getLangOpts()->resetNonModularOptions();
Douglas Gregorf545f672011-11-29 21:59:16 +0000864 PPOpts.resetNonModularOptions();
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000865
Douglas Gregor5dc38992013-02-07 00:21:12 +0000866 // Remove any macro definitions that are explicitly ignored by the module.
867 // They aren't supposed to affect how the module is built anyway.
868 const HeaderSearchOptions &HSOpts = Invocation->getHeaderSearchOpts();
Benjamin Kramerbbdd7642014-03-01 14:48:57 +0000869 PPOpts.Macros.erase(
870 std::remove_if(PPOpts.Macros.begin(), PPOpts.Macros.end(),
871 [&HSOpts](const std::pair<std::string, bool> &def) {
872 StringRef MacroDef = def.first;
873 return HSOpts.ModulesIgnoreMacros.count(MacroDef.split('=').first) > 0;
874 }),
875 PPOpts.Macros.end());
Douglas Gregor5dc38992013-02-07 00:21:12 +0000876
Douglas Gregor7d106e42011-11-15 19:35:01 +0000877 // Note the name of the module we're building.
Douglas Gregor6dc57922011-11-29 18:31:39 +0000878 Invocation->getLangOpts()->CurrentModule = Module->getTopLevelModuleName();
Douglas Gregor7d106e42011-11-15 19:35:01 +0000879
Douglas Gregor7a626572012-11-29 23:55:25 +0000880 // Make sure that the failed-module structure has been allocated in
881 // the importing instance, and propagate the pointer to the newly-created
882 // instance.
883 PreprocessorOptions &ImportingPPOpts
884 = ImportingInstance.getInvocation().getPreprocessorOpts();
885 if (!ImportingPPOpts.FailedModules)
886 ImportingPPOpts.FailedModules = new PreprocessorOptions::FailedModulesSet;
887 PPOpts.FailedModules = ImportingPPOpts.FailedModules;
888
Douglas Gregorf545f672011-11-29 21:59:16 +0000889 // If there is a module map file, build the module using the module map.
Douglas Gregor44bf68d2011-09-15 20:53:28 +0000890 // Set up the inputs/outputs so that we build the module from its umbrella
891 // header.
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000892 FrontendOptions &FrontendOpts = Invocation->getFrontendOpts();
Douglas Gregor1735f4e2011-09-13 23:15:45 +0000893 FrontendOpts.OutputFile = ModuleFileName.str();
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000894 FrontendOpts.DisableFree = false;
Douglas Gregorc1bbec82013-01-25 00:45:27 +0000895 FrontendOpts.GenerateGlobalModuleIndex = false;
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000896 FrontendOpts.Inputs.clear();
Douglas Gregorf545f672011-11-29 21:59:16 +0000897 InputKind IK = getSourceInputKindFromOptions(*Invocation->getLangOpts());
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000898
Douglas Gregorf545f672011-11-29 21:59:16 +0000899 // Don't free the remapped file buffers; they are owned by our caller.
900 PPOpts.RetainRemappedFileBuffers = true;
901
Douglas Gregor2b9b4642011-09-13 01:26:44 +0000902 Invocation->getDiagnosticOpts().VerifyDiagnostics = 0;
Douglas Gregor3728ea72011-09-13 23:20:27 +0000903 assert(ImportingInstance.getInvocation().getModuleHash() ==
Douglas Gregorf545f672011-11-29 21:59:16 +0000904 Invocation->getModuleHash() && "Module hash mismatch!");
905
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000906 // Construct a compiler instance that will be used to actually create the
907 // module.
John Thompson2255f2c2014-04-23 12:57:01 +0000908 CompilerInstance Instance(/*BuildingModule=*/true);
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000909 Instance.setInvocation(&*Invocation);
Douglas Gregor6b930962013-05-03 22:58:43 +0000910
911 Instance.createDiagnostics(new ForwardingDiagnosticConsumer(
912 ImportingInstance.getDiagnosticClient()),
Douglas Gregor30071cea2013-05-03 23:07:45 +0000913 /*ShouldOwnClient=*/true);
Douglas Gregoraf8f0262012-11-30 18:38:50 +0000914
Ben Langmuirc8130a72014-02-20 21:59:23 +0000915 Instance.setVirtualFileSystem(&ImportingInstance.getVirtualFileSystem());
916
Douglas Gregor63365432012-11-30 22:11:57 +0000917 // Note that this module is part of the module build stack, so that we
Douglas Gregoraf8f0262012-11-30 18:38:50 +0000918 // can detect cycles in the module graph.
Ben Langmuird066d4c2014-02-28 21:16:07 +0000919 Instance.setFileManager(&ImportingInstance.getFileManager());
Douglas Gregoraf8f0262012-11-30 18:38:50 +0000920 Instance.createSourceManager(Instance.getFileManager());
921 SourceManager &SourceMgr = Instance.getSourceManager();
Douglas Gregor63365432012-11-30 22:11:57 +0000922 SourceMgr.setModuleBuildStack(
923 ImportingInstance.getSourceManager().getModuleBuildStack());
924 SourceMgr.pushModuleBuildStack(Module->getTopLevelModuleName(),
Douglas Gregoraf8f0262012-11-30 18:38:50 +0000925 FullSourceLoc(ImportLoc, ImportingInstance.getSourceManager()));
926
Justin Bogner86d12592014-06-19 19:36:03 +0000927 // If we're collecting module dependencies, we need to share a collector
928 // between all of the module CompilerInstances.
929 Instance.setModuleDepCollector(ImportingInstance.getModuleDepCollector());
930
Manuel Klimek1f76c4e2013-10-24 07:51:24 +0000931 // Get or create the module map that we'll use to build this module.
932 std::string InferredModuleMapContent;
933 if (const FileEntry *ModuleMapFile =
934 ModMap.getContainingModuleMapFile(Module)) {
935 // Use the module map where this module resides.
936 FrontendOpts.Inputs.push_back(
937 FrontendInputFile(ModuleMapFile->getName(), IK));
938 } else {
939 llvm::raw_string_ostream OS(InferredModuleMapContent);
940 Module->print(OS);
941 OS.flush();
942 FrontendOpts.Inputs.push_back(
943 FrontendInputFile("__inferred_module.map", IK));
944
Rafael Espindolad87f8d72014-08-27 20:03:29 +0000945 std::unique_ptr<llvm::MemoryBuffer> ModuleMapBuffer =
Manuel Klimek1f76c4e2013-10-24 07:51:24 +0000946 llvm::MemoryBuffer::getMemBuffer(InferredModuleMapContent);
947 ModuleMapFile = Instance.getFileManager().getVirtualFile(
948 "__inferred_module.map", InferredModuleMapContent.size(), 0);
David Blaikie49cc3182014-08-27 20:54:45 +0000949 SourceMgr.overrideFileContents(ModuleMapFile, std::move(ModuleMapBuffer));
Manuel Klimek1f76c4e2013-10-24 07:51:24 +0000950 }
Douglas Gregoraf8f0262012-11-30 18:38:50 +0000951
Ben Langmuir9d6448b2014-08-09 00:57:23 +0000952 // Construct a module-generating action. Passing through the module map is
Ben Langmuirbeee15e2014-04-14 18:00:01 +0000953 // safe because the FileManager is shared between the compiler instances.
Ben Langmuir9d6448b2014-08-09 00:57:23 +0000954 GenerateModuleAction CreateModuleAction(
955 ModMap.getModuleMapFileForUniquing(Module), Module->IsSystem);
Richard Smith99891da2014-10-14 02:08:30 +0000956
957 ImportingInstance.getDiagnostics().Report(ImportLoc,
958 diag::remark_module_build)
959 << Module->Name << ModuleFileName;
960
Douglas Gregor51e0b542011-10-04 00:21:21 +0000961 // Execute the action to actually build the module in-place. Use a separate
962 // thread so that we get a stack large enough.
963 const unsigned ThreadStackSize = 8 << 20;
964 llvm::CrashRecoveryContext CRC;
Richard Smith841f1c72014-03-04 21:50:01 +0000965 CRC.RunSafelyOnThread([&]() { Instance.ExecuteAction(CreateModuleAction); },
966 ThreadStackSize);
Douglas Gregor6b930962013-05-03 22:58:43 +0000967
Richard Smith99891da2014-10-14 02:08:30 +0000968 ImportingInstance.getDiagnostics().Report(ImportLoc,
969 diag::remark_module_build_done)
970 << Module->Name;
971
Douglas Gregorf545f672011-11-29 21:59:16 +0000972 // Delete the temporary module map file.
973 // FIXME: Even though we're executing under crash protection, it would still
974 // be nice to do this with RemoveFileOnSignal when we can. However, that
975 // doesn't make sense for all clients, so clean this up manually.
Benjamin Kramer13afbf42012-10-14 19:50:53 +0000976 Instance.clearOutputFiles(/*EraseFiles=*/true);
Douglas Gregor5e306b12013-01-23 22:38:11 +0000977
978 // We've rebuilt a module. If we're allowed to generate or update the global
979 // module index, record that fact in the importing compiler instance.
Douglas Gregorc1bbec82013-01-25 00:45:27 +0000980 if (ImportingInstance.getFrontendOpts().GenerateGlobalModuleIndex) {
Douglas Gregor5e306b12013-01-23 22:38:11 +0000981 ImportingInstance.setBuildGlobalModuleIndex(true);
982 }
Ben Langmuirb797d592014-07-19 16:29:28 +0000983
984 return !Instance.getDiagnostics().hasErrorOccurred();
NAKAMURA Takumi82a35112011-10-08 11:31:46 +0000985}
Douglas Gregorfaeb1d42011-09-12 23:31:24 +0000986
Ben Langmuirdbdc0362014-06-17 22:35:27 +0000987static bool compileAndLoadModule(CompilerInstance &ImportingInstance,
988 SourceLocation ImportLoc,
Ben Langmuirb797d592014-07-19 16:29:28 +0000989 SourceLocation ModuleNameLoc, Module *Module,
Ben Langmuirdbdc0362014-06-17 22:35:27 +0000990 StringRef ModuleFileName) {
Ben Langmuird213aab2014-09-26 22:42:23 +0000991 DiagnosticsEngine &Diags = ImportingInstance.getDiagnostics();
992
Ben Langmuirb797d592014-07-19 16:29:28 +0000993 auto diagnoseBuildFailure = [&] {
Ben Langmuird213aab2014-09-26 22:42:23 +0000994 Diags.Report(ModuleNameLoc, diag::err_module_not_built)
Ben Langmuirb797d592014-07-19 16:29:28 +0000995 << Module->Name << SourceRange(ImportLoc, ModuleNameLoc);
996 };
997
Argyrios Kyrtzidis4382fe72014-04-06 03:21:44 +0000998 // FIXME: have LockFileManager return an error_code so that we can
999 // avoid the mkdir when the directory already exists.
1000 StringRef Dir = llvm::sys::path::parent_path(ModuleFileName);
1001 llvm::sys::fs::create_directories(Dir);
1002
1003 while (1) {
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001004 unsigned ModuleLoadCapabilities = ASTReader::ARR_Missing;
Argyrios Kyrtzidis4382fe72014-04-06 03:21:44 +00001005 llvm::LockFileManager Locked(ModuleFileName);
1006 switch (Locked) {
1007 case llvm::LockFileManager::LFS_Error:
Ben Langmuird213aab2014-09-26 22:42:23 +00001008 Diags.Report(ModuleNameLoc, diag::err_module_lock_failure)
1009 << Module->Name;
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001010 return false;
Argyrios Kyrtzidis4382fe72014-04-06 03:21:44 +00001011
1012 case llvm::LockFileManager::LFS_Owned:
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001013 // We're responsible for building the module ourselves.
Ben Langmuirb797d592014-07-19 16:29:28 +00001014 if (!compileModuleImpl(ImportingInstance, ModuleNameLoc, Module,
1015 ModuleFileName)) {
1016 diagnoseBuildFailure();
1017 return false;
1018 }
Argyrios Kyrtzidis4382fe72014-04-06 03:21:44 +00001019 break;
1020
1021 case llvm::LockFileManager::LFS_Shared:
1022 // Someone else is responsible for building the module. Wait for them to
1023 // finish.
1024 if (Locked.waitForUnlock() == llvm::LockFileManager::Res_OwnerDied)
1025 continue; // try again to get the lock.
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001026 ModuleLoadCapabilities |= ASTReader::ARR_OutOfDate;
1027 break;
Argyrios Kyrtzidis4382fe72014-04-06 03:21:44 +00001028 }
1029
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001030 // Try to read the module file, now that we've compiled it.
1031 ASTReader::ASTReadResult ReadResult =
1032 ImportingInstance.getModuleManager()->ReadAST(
Richard Smithe842a472014-10-22 02:05:46 +00001033 ModuleFileName, serialization::MK_ImplicitModule, ImportLoc,
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001034 ModuleLoadCapabilities);
1035
1036 if (ReadResult == ASTReader::OutOfDate &&
1037 Locked == llvm::LockFileManager::LFS_Shared) {
1038 // The module may be out of date in the presence of file system races,
1039 // or if one of its imports depends on header search paths that are not
1040 // consistent with this ImportingInstance. Try again...
1041 continue;
1042 } else if (ReadResult == ASTReader::Missing) {
Ben Langmuirb797d592014-07-19 16:29:28 +00001043 diagnoseBuildFailure();
Ben Langmuird213aab2014-09-26 22:42:23 +00001044 } else if (ReadResult != ASTReader::Success &&
1045 !Diags.hasErrorOccurred()) {
1046 // The ASTReader didn't diagnose the error, so conservatively report it.
1047 diagnoseBuildFailure();
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001048 }
1049 return ReadResult == ASTReader::Success;
Argyrios Kyrtzidis4382fe72014-04-06 03:21:44 +00001050 }
1051}
1052
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001053/// \brief Diagnose differences between the current definition of the given
1054/// configuration macro and the definition provided on the command line.
1055static void checkConfigMacro(Preprocessor &PP, StringRef ConfigMacro,
1056 Module *Mod, SourceLocation ImportLoc) {
1057 IdentifierInfo *Id = PP.getIdentifierInfo(ConfigMacro);
1058 SourceManager &SourceMgr = PP.getSourceManager();
1059
1060 // If this identifier has never had a macro definition, then it could
1061 // not have changed.
1062 if (!Id->hadMacroDefinition())
1063 return;
1064
1065 // If this identifier does not currently have a macro definition,
1066 // check whether it had one on the command line.
1067 if (!Id->hasMacroDefinition()) {
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001068 MacroDirective::DefInfo LatestDef =
1069 PP.getMacroDirectiveHistory(Id)->getDefinition();
1070 for (MacroDirective::DefInfo Def = LatestDef; Def;
1071 Def = Def.getPreviousDefinition()) {
1072 FileID FID = SourceMgr.getFileID(Def.getLocation());
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001073 if (FID.isInvalid())
1074 continue;
1075
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001076 // We only care about the predefines buffer.
Douglas Gregor05ba2a02013-04-03 03:16:36 +00001077 if (FID != PP.getPredefinesFileID())
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001078 continue;
1079
1080 // This macro was defined on the command line, then #undef'd later.
1081 // Complain.
1082 PP.Diag(ImportLoc, diag::warn_module_config_macro_undef)
1083 << true << ConfigMacro << Mod->getFullModuleName();
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001084 if (LatestDef.isUndefined())
1085 PP.Diag(LatestDef.getUndefLocation(), diag::note_module_def_undef_here)
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001086 << true;
1087 return;
1088 }
1089
1090 // Okay: no definition in the predefines buffer.
1091 return;
1092 }
1093
1094 // This identifier has a macro definition. Check whether we had a definition
1095 // on the command line.
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001096 MacroDirective::DefInfo LatestDef =
1097 PP.getMacroDirectiveHistory(Id)->getDefinition();
1098 MacroDirective::DefInfo PredefinedDef;
1099 for (MacroDirective::DefInfo Def = LatestDef; Def;
1100 Def = Def.getPreviousDefinition()) {
1101 FileID FID = SourceMgr.getFileID(Def.getLocation());
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001102 if (FID.isInvalid())
1103 continue;
1104
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001105 // We only care about the predefines buffer.
Douglas Gregor05ba2a02013-04-03 03:16:36 +00001106 if (FID != PP.getPredefinesFileID())
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001107 continue;
1108
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001109 PredefinedDef = Def;
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001110 break;
1111 }
1112
1113 // If there was no definition for this macro in the predefines buffer,
1114 // complain.
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001115 if (!PredefinedDef ||
1116 (!PredefinedDef.getLocation().isValid() &&
1117 PredefinedDef.getUndefLocation().isValid())) {
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001118 PP.Diag(ImportLoc, diag::warn_module_config_macro_undef)
1119 << false << ConfigMacro << Mod->getFullModuleName();
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001120 PP.Diag(LatestDef.getLocation(), diag::note_module_def_undef_here)
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001121 << false;
1122 return;
1123 }
1124
1125 // If the current macro definition is the same as the predefined macro
1126 // definition, it's okay.
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001127 if (LatestDef.getMacroInfo() == PredefinedDef.getMacroInfo() ||
Argyrios Kyrtzidis0c2f30b2013-04-03 17:39:30 +00001128 LatestDef.getMacroInfo()->isIdenticalTo(*PredefinedDef.getMacroInfo(),PP,
1129 /*Syntactically=*/true))
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001130 return;
1131
1132 // The macro definitions differ.
1133 PP.Diag(ImportLoc, diag::warn_module_config_macro_undef)
1134 << false << ConfigMacro << Mod->getFullModuleName();
Argyrios Kyrtzidisb6210df2013-03-26 17:17:01 +00001135 PP.Diag(LatestDef.getLocation(), diag::note_module_def_undef_here)
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001136 << false;
1137}
1138
Douglas Gregor527b1c92013-03-25 21:19:16 +00001139/// \brief Write a new timestamp file with the given path.
1140static void writeTimestampFile(StringRef TimestampFile) {
Rafael Espindoladae941a2014-08-25 18:17:04 +00001141 std::error_code EC;
1142 llvm::raw_fd_ostream Out(TimestampFile.str(), EC, llvm::sys::fs::F_None);
Douglas Gregor527b1c92013-03-25 21:19:16 +00001143}
1144
1145/// \brief Prune the module cache of modules that haven't been accessed in
1146/// a long time.
1147static void pruneModuleCache(const HeaderSearchOptions &HSOpts) {
1148 struct stat StatBuf;
1149 llvm::SmallString<128> TimestampFile;
1150 TimestampFile = HSOpts.ModuleCachePath;
1151 llvm::sys::path::append(TimestampFile, "modules.timestamp");
1152
1153 // Try to stat() the timestamp file.
1154 if (::stat(TimestampFile.c_str(), &StatBuf)) {
1155 // If the timestamp file wasn't there, create one now.
1156 if (errno == ENOENT) {
1157 writeTimestampFile(TimestampFile);
1158 }
1159 return;
1160 }
1161
1162 // Check whether the time stamp is older than our pruning interval.
1163 // If not, do nothing.
1164 time_t TimeStampModTime = StatBuf.st_mtime;
Craig Topper49a27902014-05-22 04:46:25 +00001165 time_t CurrentTime = time(nullptr);
Benjamin Kramerdbcf5032013-03-29 17:39:43 +00001166 if (CurrentTime - TimeStampModTime <= time_t(HSOpts.ModuleCachePruneInterval))
Douglas Gregor527b1c92013-03-25 21:19:16 +00001167 return;
Douglas Gregor527b1c92013-03-25 21:19:16 +00001168
1169 // Write a new timestamp file so that nobody else attempts to prune.
1170 // There is a benign race condition here, if two Clang instances happen to
1171 // notice at the same time that the timestamp is out-of-date.
1172 writeTimestampFile(TimestampFile);
1173
1174 // Walk the entire module cache, looking for unused module files and module
1175 // indices.
Rafael Espindolac0809172014-06-12 14:02:15 +00001176 std::error_code EC;
Douglas Gregor527b1c92013-03-25 21:19:16 +00001177 SmallString<128> ModuleCachePathNative;
1178 llvm::sys::path::native(HSOpts.ModuleCachePath, ModuleCachePathNative);
1179 for (llvm::sys::fs::directory_iterator
1180 Dir(ModuleCachePathNative.str(), EC), DirEnd;
1181 Dir != DirEnd && !EC; Dir.increment(EC)) {
1182 // If we don't have a directory, there's nothing to look into.
Rafael Espindolaa07f7202013-07-17 04:23:07 +00001183 if (!llvm::sys::fs::is_directory(Dir->path()))
Douglas Gregor527b1c92013-03-25 21:19:16 +00001184 continue;
1185
1186 // Walk all of the files within this directory.
Douglas Gregor527b1c92013-03-25 21:19:16 +00001187 for (llvm::sys::fs::directory_iterator File(Dir->path(), EC), FileEnd;
1188 File != FileEnd && !EC; File.increment(EC)) {
1189 // We only care about module and global module index files.
Dmitri Gribenkof430da42014-02-12 10:33:14 +00001190 StringRef Extension = llvm::sys::path::extension(File->path());
1191 if (Extension != ".pcm" && Extension != ".timestamp" &&
1192 llvm::sys::path::filename(File->path()) != "modules.idx")
Douglas Gregor527b1c92013-03-25 21:19:16 +00001193 continue;
Douglas Gregor527b1c92013-03-25 21:19:16 +00001194
1195 // Look at this file. If we can't stat it, there's nothing interesting
1196 // there.
Dmitri Gribenkof430da42014-02-12 10:33:14 +00001197 if (::stat(File->path().c_str(), &StatBuf))
Douglas Gregor527b1c92013-03-25 21:19:16 +00001198 continue;
Douglas Gregor527b1c92013-03-25 21:19:16 +00001199
1200 // If the file has been used recently enough, leave it there.
1201 time_t FileAccessTime = StatBuf.st_atime;
Benjamin Kramerdbcf5032013-03-29 17:39:43 +00001202 if (CurrentTime - FileAccessTime <=
1203 time_t(HSOpts.ModuleCachePruneAfter)) {
Douglas Gregor527b1c92013-03-25 21:19:16 +00001204 continue;
1205 }
1206
1207 // Remove the file.
Dmitri Gribenkof430da42014-02-12 10:33:14 +00001208 llvm::sys::fs::remove(File->path());
1209
1210 // Remove the timestamp file.
1211 std::string TimpestampFilename = File->path() + ".timestamp";
1212 llvm::sys::fs::remove(TimpestampFilename);
Douglas Gregor527b1c92013-03-25 21:19:16 +00001213 }
1214
1215 // If we removed all of the files in the directory, remove the directory
1216 // itself.
Dmitri Gribenkof430da42014-02-12 10:33:14 +00001217 if (llvm::sys::fs::directory_iterator(Dir->path(), EC) ==
1218 llvm::sys::fs::directory_iterator() && !EC)
Rafael Espindola2a008782014-01-10 21:32:14 +00001219 llvm::sys::fs::remove(Dir->path());
Douglas Gregor527b1c92013-03-25 21:19:16 +00001220 }
1221}
1222
John Thompson2255f2c2014-04-23 12:57:01 +00001223void CompilerInstance::createModuleManager() {
1224 if (!ModuleManager) {
1225 if (!hasASTContext())
1226 createASTContext();
1227
1228 // If we're not recursively building a module, check whether we
1229 // need to prune the module cache.
1230 if (getSourceManager().getModuleBuildStack().empty() &&
1231 getHeaderSearchOpts().ModuleCachePruneInterval > 0 &&
1232 getHeaderSearchOpts().ModuleCachePruneAfter > 0) {
1233 pruneModuleCache(getHeaderSearchOpts());
1234 }
1235
1236 HeaderSearchOptions &HSOpts = getHeaderSearchOpts();
1237 std::string Sysroot = HSOpts.Sysroot;
1238 const PreprocessorOptions &PPOpts = getPreprocessorOpts();
1239 ModuleManager = new ASTReader(getPreprocessor(), *Context,
1240 Sysroot.empty() ? "" : Sysroot.c_str(),
1241 PPOpts.DisablePCHValidation,
1242 /*AllowASTWithCompilerErrors=*/false,
1243 /*AllowConfigurationMismatch=*/false,
1244 HSOpts.ModulesValidateSystemHeaders,
1245 getFrontendOpts().UseGlobalModuleIndex);
1246 if (hasASTConsumer()) {
1247 ModuleManager->setDeserializationListener(
1248 getASTConsumer().GetASTDeserializationListener());
1249 getASTContext().setASTMutationListener(
1250 getASTConsumer().GetASTMutationListener());
1251 }
1252 getASTContext().setExternalSource(ModuleManager);
1253 if (hasSema())
1254 ModuleManager->InitializeSema(getSema());
1255 if (hasASTConsumer())
1256 ModuleManager->StartTranslationUnit(&getASTConsumer());
1257 }
1258}
1259
Douglas Gregor7a626572012-11-29 23:55:25 +00001260ModuleLoadResult
Richard Smithe842a472014-10-22 02:05:46 +00001261CompilerInstance::loadModuleFile(StringRef FileName, SourceLocation Loc) {
1262 if (!ModuleManager)
1263 createModuleManager();
1264 if (!ModuleManager)
1265 return ModuleLoadResult();
1266
1267 // Load the module if this is the first time we've been told about this file.
1268 auto *MF = ModuleManager->getModuleManager().lookup(FileName);
1269 if (!MF) {
1270 struct ReadModuleNameListener : ASTReaderListener {
1271 std::function<void(StringRef)> OnRead;
1272 ReadModuleNameListener(std::function<void(StringRef)> F) : OnRead(F) {}
1273 void ReadModuleName(StringRef ModuleName) override { OnRead(ModuleName); }
1274 };
1275
1276 // Register listener to track the modules that are loaded by explicitly
1277 // loading a module file. We suppress any attempts to implicitly load
1278 // module files for any such module.
1279 ASTReader::ListenerScope OnReadModuleName(
1280 *ModuleManager,
1281 llvm::make_unique<ReadModuleNameListener>([&](StringRef ModuleName) {
1282 auto &PP = getPreprocessor();
1283 auto *NameII = PP.getIdentifierInfo(ModuleName);
1284 auto *Module = PP.getHeaderSearchInfo().lookupModule(ModuleName, false);
1285 if (!KnownModules.insert(std::make_pair(NameII, Module)).second)
1286 getDiagnostics().Report(Loc, diag::err_module_already_loaded)
1287 << ModuleName << FileName;
1288 }));
1289
1290 if (ModuleManager->ReadAST(FileName, serialization::MK_ExplicitModule, Loc,
1291 ASTReader::ARR_None) != ASTReader::Success)
1292 return ModuleLoadResult();
1293
1294 MF = ModuleManager->getModuleManager().lookup(FileName);
1295 assert(MF && "unexpectedly failed to load module file");
1296 }
1297
1298 if (MF->ModuleName.empty()) {
1299 getDiagnostics().Report(Loc, diag::err_module_file_not_module)
1300 << FileName;
1301 return ModuleLoadResult();
1302 }
1303 auto *Module = PP->getHeaderSearchInfo().lookupModule(MF->ModuleName, false);
1304 return ModuleLoadResult(Module, false);
1305}
1306
1307ModuleLoadResult
Douglas Gregor7a626572012-11-29 23:55:25 +00001308CompilerInstance::loadModule(SourceLocation ImportLoc,
1309 ModuleIdPath Path,
1310 Module::NameVisibilityKind Visibility,
1311 bool IsInclusionDirective) {
Richard Smith92304e02013-10-18 22:48:20 +00001312 // Determine what file we're searching from.
1313 StringRef ModuleName = Path[0].first->getName();
1314 SourceLocation ModuleNameLoc = Path[0].second;
1315
Douglas Gregor1805b8a2011-11-30 04:26:53 +00001316 // If we've already handled this import, just return the cached result.
1317 // This one-element cache is important to eliminate redundant diagnostics
1318 // when both the preprocessor and parser see the same import declaration.
Douglas Gregorff2be532011-12-01 17:11:21 +00001319 if (!ImportLoc.isInvalid() && LastModuleImportLoc == ImportLoc) {
1320 // Make the named module visible.
Ben Langmuirb537a3a2014-07-23 15:30:23 +00001321 if (LastModuleImportResult && ModuleName != getLangOpts().CurrentModule &&
1322 ModuleName != getLangOpts().ImplementationOfModule)
Argyrios Kyrtzidis125df052013-02-01 16:36:12 +00001323 ModuleManager->makeModuleVisible(LastModuleImportResult, Visibility,
Douglas Gregorfb912652013-03-20 21:10:35 +00001324 ImportLoc, /*Complain=*/false);
Douglas Gregor69021972011-11-30 17:33:56 +00001325 return LastModuleImportResult;
Douglas Gregorff2be532011-12-01 17:11:21 +00001326 }
Douglas Gregor5196bc62011-11-30 04:03:44 +00001327
Craig Topper49a27902014-05-22 04:46:25 +00001328 clang::Module *Module = nullptr;
Richard Smith92304e02013-10-18 22:48:20 +00001329
Douglas Gregor5196bc62011-11-30 04:03:44 +00001330 // If we don't already have information on this module, load the module now.
Douglas Gregorde3ef502011-11-30 23:21:26 +00001331 llvm::DenseMap<const IdentifierInfo *, clang::Module *>::iterator Known
Douglas Gregor69021972011-11-30 17:33:56 +00001332 = KnownModules.find(Path[0].first);
Douglas Gregor2537a362011-12-08 17:01:29 +00001333 if (Known != KnownModules.end()) {
1334 // Retrieve the cached top-level module.
1335 Module = Known->second;
Ben Langmuirb537a3a2014-07-23 15:30:23 +00001336 } else if (ModuleName == getLangOpts().CurrentModule ||
1337 ModuleName == getLangOpts().ImplementationOfModule) {
Douglas Gregor2537a362011-12-08 17:01:29 +00001338 // This is the module we're building.
Ben Langmuir527040e2014-05-05 05:31:33 +00001339 Module = PP->getHeaderSearchInfo().lookupModule(ModuleName);
Douglas Gregor2537a362011-12-08 17:01:29 +00001340 Known = KnownModules.insert(std::make_pair(Path[0].first, Module)).first;
1341 } else {
Douglas Gregor5196bc62011-11-30 04:03:44 +00001342 // Search for a module with the given name.
Douglas Gregor279a6c32012-01-29 17:08:11 +00001343 Module = PP->getHeaderSearchInfo().lookupModule(ModuleName);
Ben Langmuir9eb229b2014-01-22 23:19:39 +00001344 if (!Module) {
1345 getDiagnostics().Report(ModuleNameLoc, diag::err_module_not_found)
1346 << ModuleName
1347 << SourceRange(ImportLoc, ModuleNameLoc);
1348 ModuleBuildFailed = true;
1349 return ModuleLoadResult();
1350 }
1351
Justin Bognerf24d9c92014-04-28 20:58:58 +00001352 std::string ModuleFileName =
1353 PP->getHeaderSearchInfo().getModuleFileName(Module);
Douglas Gregor7a626572012-11-29 23:55:25 +00001354
Douglas Gregor5196bc62011-11-30 04:03:44 +00001355 // If we don't already have an ASTReader, create one now.
John Thompson2255f2c2014-04-23 12:57:01 +00001356 if (!ModuleManager)
1357 createModuleManager();
Douglas Gregor5196bc62011-11-30 04:03:44 +00001358
Ben Langmuircb69b572014-03-07 06:40:32 +00001359 if (TheDependencyFileGenerator)
1360 TheDependencyFileGenerator->AttachToASTReader(*ModuleManager);
1361
Justin Bogner86d12592014-06-19 19:36:03 +00001362 if (ModuleDepCollector)
1363 ModuleDepCollector->attachToASTReader(*ModuleManager);
1364
Ben Langmuir33c80902014-06-30 20:04:14 +00001365 for (auto &Listener : DependencyCollectors)
1366 Listener->attachToASTReader(*ModuleManager);
1367
Douglas Gregor7029ce12013-03-19 00:28:20 +00001368 // Try to load the module file.
1369 unsigned ARRFlags = ASTReader::ARR_OutOfDate | ASTReader::ARR_Missing;
Richard Smithe842a472014-10-22 02:05:46 +00001370 switch (ModuleManager->ReadAST(ModuleFileName,
1371 serialization::MK_ImplicitModule, ImportLoc,
1372 ARRFlags)) {
Douglas Gregor5196bc62011-11-30 04:03:44 +00001373 case ASTReader::Success:
1374 break;
1375
Eli Friedman963ff2c2013-09-17 00:51:29 +00001376 case ASTReader::OutOfDate:
Douglas Gregor7029ce12013-03-19 00:28:20 +00001377 case ASTReader::Missing: {
Eli Friedman963ff2c2013-09-17 00:51:29 +00001378 // The module file is missing or out-of-date. Build it.
Ben Langmuir9eb229b2014-01-22 23:19:39 +00001379 assert(Module && "missing module file");
Douglas Gregor7029ce12013-03-19 00:28:20 +00001380 // Check whether there is a cycle in the module graph.
1381 ModuleBuildStack ModPath = getSourceManager().getModuleBuildStack();
1382 ModuleBuildStack::iterator Pos = ModPath.begin(), PosEnd = ModPath.end();
1383 for (; Pos != PosEnd; ++Pos) {
1384 if (Pos->first == ModuleName)
1385 break;
1386 }
1387
1388 if (Pos != PosEnd) {
1389 SmallString<256> CyclePath;
1390 for (; Pos != PosEnd; ++Pos) {
1391 CyclePath += Pos->first;
1392 CyclePath += " -> ";
1393 }
1394 CyclePath += ModuleName;
1395
1396 getDiagnostics().Report(ModuleNameLoc, diag::err_module_cycle)
1397 << ModuleName << CyclePath;
1398 return ModuleLoadResult();
1399 }
Douglas Gregor7a626572012-11-29 23:55:25 +00001400
1401 // Check whether we have already attempted to build this module (but
1402 // failed).
1403 if (getPreprocessorOpts().FailedModules &&
1404 getPreprocessorOpts().FailedModules->hasAlreadyFailed(ModuleName)) {
1405 getDiagnostics().Report(ModuleNameLoc, diag::err_module_not_built)
1406 << ModuleName
1407 << SourceRange(ImportLoc, ModuleNameLoc);
Douglas Gregorc1bbec82013-01-25 00:45:27 +00001408 ModuleBuildFailed = true;
Douglas Gregor7a626572012-11-29 23:55:25 +00001409 return ModuleLoadResult();
1410 }
1411
Ben Langmuirdbdc0362014-06-17 22:35:27 +00001412 // Try to compile and then load the module.
1413 if (!compileAndLoadModule(*this, ImportLoc, ModuleNameLoc, Module,
1414 ModuleFileName)) {
Ben Langmuird213aab2014-09-26 22:42:23 +00001415 assert(getDiagnostics().hasErrorOccurred() &&
1416 "undiagnosed error in compileAndLoadModule");
Douglas Gregor0f2b4632013-01-10 02:04:18 +00001417 if (getPreprocessorOpts().FailedModules)
1418 getPreprocessorOpts().FailedModules->addFailed(ModuleName);
Craig Topper49a27902014-05-22 04:46:25 +00001419 KnownModules[Path[0].first] = nullptr;
Douglas Gregorc1bbec82013-01-25 00:45:27 +00001420 ModuleBuildFailed = true;
Douglas Gregor7a626572012-11-29 23:55:25 +00001421 return ModuleLoadResult();
Douglas Gregor188dbef2012-11-07 17:46:15 +00001422 }
1423
1424 // Okay, we've rebuilt and now loaded the module.
1425 break;
1426 }
1427
Douglas Gregorc9ad5fb2012-10-22 22:50:17 +00001428 case ASTReader::VersionMismatch:
1429 case ASTReader::ConfigurationMismatch:
1430 case ASTReader::HadErrors:
Argyrios Kyrtzidisdc9fdaf2013-05-24 05:44:08 +00001431 ModuleLoader::HadFatalFailure = true;
Douglas Gregor5196bc62011-11-30 04:03:44 +00001432 // FIXME: The ASTReader will already have complained, but can we showhorn
1433 // that diagnostic information into a more useful form?
Craig Topper49a27902014-05-22 04:46:25 +00001434 KnownModules[Path[0].first] = nullptr;
Douglas Gregor7a626572012-11-29 23:55:25 +00001435 return ModuleLoadResult();
Douglas Gregor5196bc62011-11-30 04:03:44 +00001436
1437 case ASTReader::Failure:
Argyrios Kyrtzidisdc9fdaf2013-05-24 05:44:08 +00001438 ModuleLoader::HadFatalFailure = true;
Douglas Gregor69021972011-11-30 17:33:56 +00001439 // Already complained, but note now that we failed.
Craig Topper49a27902014-05-22 04:46:25 +00001440 KnownModules[Path[0].first] = nullptr;
Douglas Gregorc1bbec82013-01-25 00:45:27 +00001441 ModuleBuildFailed = true;
Douglas Gregor7a626572012-11-29 23:55:25 +00001442 return ModuleLoadResult();
Douglas Gregor5196bc62011-11-30 04:03:44 +00001443 }
Argyrios Kyrtzidis43af5132012-09-29 01:06:04 +00001444
Douglas Gregor69021972011-11-30 17:33:56 +00001445 // Cache the result of this top-level module lookup for later.
1446 Known = KnownModules.insert(std::make_pair(Path[0].first, Module)).first;
Douglas Gregor08142532011-08-26 23:56:07 +00001447 }
Douglas Gregor5196bc62011-11-30 04:03:44 +00001448
Douglas Gregor69021972011-11-30 17:33:56 +00001449 // If we never found the module, fail.
1450 if (!Module)
Douglas Gregor7a626572012-11-29 23:55:25 +00001451 return ModuleLoadResult();
Douglas Gregor69021972011-11-30 17:33:56 +00001452
Douglas Gregor5196bc62011-11-30 04:03:44 +00001453 // Verify that the rest of the module path actually corresponds to
1454 // a submodule.
Douglas Gregor69021972011-11-30 17:33:56 +00001455 if (Path.size() > 1) {
Douglas Gregor5196bc62011-11-30 04:03:44 +00001456 for (unsigned I = 1, N = Path.size(); I != N; ++I) {
1457 StringRef Name = Path[I].first->getName();
Douglas Gregoreb90e832012-01-04 23:32:19 +00001458 clang::Module *Sub = Module->findSubmodule(Name);
Douglas Gregor5196bc62011-11-30 04:03:44 +00001459
Douglas Gregoreb90e832012-01-04 23:32:19 +00001460 if (!Sub) {
Douglas Gregor5196bc62011-11-30 04:03:44 +00001461 // Attempt to perform typo correction to find a module name that works.
Dmitri Gribenkof8579502013-01-12 19:30:44 +00001462 SmallVector<StringRef, 2> Best;
Douglas Gregor5196bc62011-11-30 04:03:44 +00001463 unsigned BestEditDistance = (std::numeric_limits<unsigned>::max)();
1464
Douglas Gregoreb90e832012-01-04 23:32:19 +00001465 for (clang::Module::submodule_iterator J = Module->submodule_begin(),
1466 JEnd = Module->submodule_end();
Matt Beaumont-Gayeb44eda2011-11-30 19:41:21 +00001467 J != JEnd; ++J) {
Douglas Gregoreb90e832012-01-04 23:32:19 +00001468 unsigned ED = Name.edit_distance((*J)->Name,
Douglas Gregor5196bc62011-11-30 04:03:44 +00001469 /*AllowReplacements=*/true,
1470 BestEditDistance);
1471 if (ED <= BestEditDistance) {
Douglas Gregoreb90e832012-01-04 23:32:19 +00001472 if (ED < BestEditDistance) {
Douglas Gregor5196bc62011-11-30 04:03:44 +00001473 Best.clear();
Douglas Gregoreb90e832012-01-04 23:32:19 +00001474 BestEditDistance = ED;
1475 }
1476
1477 Best.push_back((*J)->Name);
Douglas Gregor5196bc62011-11-30 04:03:44 +00001478 }
1479 }
1480
1481 // If there was a clear winner, user it.
1482 if (Best.size() == 1) {
1483 getDiagnostics().Report(Path[I].second,
1484 diag::err_no_submodule_suggest)
Douglas Gregor69021972011-11-30 17:33:56 +00001485 << Path[I].first << Module->getFullModuleName() << Best[0]
Douglas Gregor5196bc62011-11-30 04:03:44 +00001486 << SourceRange(Path[0].second, Path[I-1].second)
1487 << FixItHint::CreateReplacement(SourceRange(Path[I].second),
1488 Best[0]);
Douglas Gregoreb90e832012-01-04 23:32:19 +00001489
1490 Sub = Module->findSubmodule(Best[0]);
Douglas Gregor5196bc62011-11-30 04:03:44 +00001491 }
1492 }
1493
Douglas Gregoreb90e832012-01-04 23:32:19 +00001494 if (!Sub) {
Douglas Gregor5196bc62011-11-30 04:03:44 +00001495 // No submodule by this name. Complain, and don't look for further
1496 // submodules.
1497 getDiagnostics().Report(Path[I].second, diag::err_no_submodule)
Douglas Gregor69021972011-11-30 17:33:56 +00001498 << Path[I].first << Module->getFullModuleName()
Douglas Gregor5196bc62011-11-30 04:03:44 +00001499 << SourceRange(Path[0].second, Path[I-1].second);
1500 break;
1501 }
1502
Douglas Gregoreb90e832012-01-04 23:32:19 +00001503 Module = Sub;
Douglas Gregor5196bc62011-11-30 04:03:44 +00001504 }
Douglas Gregor08142532011-08-26 23:56:07 +00001505 }
Ben Langmuirb537a3a2014-07-23 15:30:23 +00001506
1507 // Don't make the module visible if we are in the implementation.
1508 if (ModuleName == getLangOpts().ImplementationOfModule)
1509 return ModuleLoadResult(Module, false);
Douglas Gregor5196bc62011-11-30 04:03:44 +00001510
Douglas Gregor2537a362011-12-08 17:01:29 +00001511 // Make the named module visible, if it's not already part of the module
1512 // we are parsing.
Douglas Gregor98a52db2011-12-20 00:28:52 +00001513 if (ModuleName != getLangOpts().CurrentModule) {
1514 if (!Module->IsFromModuleFile) {
1515 // We have an umbrella header or directory that doesn't actually include
1516 // all of the headers within the directory it covers. Complain about
1517 // this missing submodule and recover by forgetting that we ever saw
1518 // this submodule.
1519 // FIXME: Should we detect this at module load time? It seems fairly
1520 // expensive (and rare).
1521 getDiagnostics().Report(ImportLoc, diag::warn_missing_submodule)
1522 << Module->getFullModuleName()
1523 << SourceRange(Path.front().second, Path.back().second);
Craig Topper49a27902014-05-22 04:46:25 +00001524
1525 return ModuleLoadResult(nullptr, true);
Douglas Gregor98a52db2011-12-20 00:28:52 +00001526 }
Douglas Gregor1fb5c3a2011-12-31 04:05:44 +00001527
1528 // Check whether this module is available.
Richard Smitha3feee22013-10-28 22:18:19 +00001529 clang::Module::Requirement Requirement;
Daniel Jasper0761a8a2013-12-17 10:31:37 +00001530 clang::Module::HeaderDirective MissingHeader;
1531 if (!Module->isAvailable(getLangOpts(), getTarget(), Requirement,
1532 MissingHeader)) {
1533 if (MissingHeader.FileNameLoc.isValid()) {
1534 getDiagnostics().Report(MissingHeader.FileNameLoc,
1535 diag::err_module_header_missing)
1536 << MissingHeader.IsUmbrella << MissingHeader.FileName;
1537 } else {
1538 getDiagnostics().Report(ImportLoc, diag::err_module_unavailable)
1539 << Module->getFullModuleName()
1540 << Requirement.second << Requirement.first
1541 << SourceRange(Path.front().second, Path.back().second);
1542 }
Douglas Gregor1fb5c3a2011-12-31 04:05:44 +00001543 LastModuleImportLoc = ImportLoc;
Douglas Gregor7a626572012-11-29 23:55:25 +00001544 LastModuleImportResult = ModuleLoadResult();
1545 return ModuleLoadResult();
Douglas Gregor1fb5c3a2011-12-31 04:05:44 +00001546 }
1547
Douglas Gregorfb912652013-03-20 21:10:35 +00001548 ModuleManager->makeModuleVisible(Module, Visibility, ImportLoc,
1549 /*Complain=*/true);
Douglas Gregor98a52db2011-12-20 00:28:52 +00001550 }
Douglas Gregor35b13ec2013-03-20 00:22:05 +00001551
1552 // Check for any configuration macros that have changed.
1553 clang::Module *TopModule = Module->getTopLevelModule();
1554 for (unsigned I = 0, N = TopModule->ConfigMacros.size(); I != N; ++I) {
1555 checkConfigMacro(getPreprocessor(), TopModule->ConfigMacros[I],
1556 Module, ImportLoc);
1557 }
1558
Douglas Gregorbcfc7d02011-12-02 23:42:12 +00001559 // If this module import was due to an inclusion directive, create an
1560 // implicit import declaration to capture it in the AST.
1561 if (IsInclusionDirective && hasASTContext()) {
1562 TranslationUnitDecl *TU = getASTContext().getTranslationUnitDecl();
Argyrios Kyrtzidis72d1aa32012-10-03 01:58:37 +00001563 ImportDecl *ImportD = ImportDecl::CreateImplicit(getASTContext(), TU,
1564 ImportLoc, Module,
1565 Path.back().second);
1566 TU->addDecl(ImportD);
1567 if (Consumer)
1568 Consumer->HandleImplicitImportDecl(ImportD);
Douglas Gregorbcfc7d02011-12-02 23:42:12 +00001569 }
Douglas Gregor5196bc62011-11-30 04:03:44 +00001570
Douglas Gregor1805b8a2011-11-30 04:26:53 +00001571 LastModuleImportLoc = ImportLoc;
Douglas Gregor7a626572012-11-29 23:55:25 +00001572 LastModuleImportResult = ModuleLoadResult(Module, false);
1573 return LastModuleImportResult;
Douglas Gregor08142532011-08-26 23:56:07 +00001574}
Douglas Gregorc147b0b2013-01-12 01:29:50 +00001575
1576void CompilerInstance::makeModuleVisible(Module *Mod,
Argyrios Kyrtzidis125df052013-02-01 16:36:12 +00001577 Module::NameVisibilityKind Visibility,
Douglas Gregorfb912652013-03-20 21:10:35 +00001578 SourceLocation ImportLoc,
1579 bool Complain){
1580 ModuleManager->makeModuleVisible(Mod, Visibility, ImportLoc, Complain);
Douglas Gregorc147b0b2013-01-12 01:29:50 +00001581}
1582
John Thompson2255f2c2014-04-23 12:57:01 +00001583GlobalModuleIndex *CompilerInstance::loadGlobalModuleIndex(
1584 SourceLocation TriggerLoc) {
1585 if (!ModuleManager)
1586 createModuleManager();
1587 // Can't do anything if we don't have the module manager.
1588 if (!ModuleManager)
Craig Topper49a27902014-05-22 04:46:25 +00001589 return nullptr;
John Thompson2255f2c2014-04-23 12:57:01 +00001590 // Get an existing global index. This loads it if not already
1591 // loaded.
1592 ModuleManager->loadGlobalIndex();
1593 GlobalModuleIndex *GlobalIndex = ModuleManager->getGlobalIndex();
1594 // If the global index doesn't exist, create it.
1595 if (!GlobalIndex && shouldBuildGlobalModuleIndex() && hasFileManager() &&
1596 hasPreprocessor()) {
1597 llvm::sys::fs::create_directories(
1598 getPreprocessor().getHeaderSearchInfo().getModuleCachePath());
1599 GlobalModuleIndex::writeIndex(
1600 getFileManager(),
1601 getPreprocessor().getHeaderSearchInfo().getModuleCachePath());
1602 ModuleManager->resetForReload();
1603 ModuleManager->loadGlobalIndex();
1604 GlobalIndex = ModuleManager->getGlobalIndex();
1605 }
1606 // For finding modules needing to be imported for fixit messages,
1607 // we need to make the global index cover all modules, so we do that here.
1608 if (!HaveFullGlobalModuleIndex && GlobalIndex && !buildingModule()) {
1609 ModuleMap &MMap = getPreprocessor().getHeaderSearchInfo().getModuleMap();
1610 bool RecreateIndex = false;
1611 for (ModuleMap::module_iterator I = MMap.module_begin(),
1612 E = MMap.module_end(); I != E; ++I) {
1613 Module *TheModule = I->second;
1614 const FileEntry *Entry = TheModule->getASTFile();
1615 if (!Entry) {
1616 SmallVector<std::pair<IdentifierInfo *, SourceLocation>, 2> Path;
1617 Path.push_back(std::make_pair(
1618 getPreprocessor().getIdentifierInfo(TheModule->Name), TriggerLoc));
1619 std::reverse(Path.begin(), Path.end());
1620 // Load a module as hidden. This also adds it to the global index.
John Thompsone0a5afe2014-04-23 13:45:44 +00001621 loadModule(TheModule->DefinitionLoc, Path,
John Thompson2255f2c2014-04-23 12:57:01 +00001622 Module::Hidden, false);
1623 RecreateIndex = true;
1624 }
1625 }
1626 if (RecreateIndex) {
1627 GlobalModuleIndex::writeIndex(
1628 getFileManager(),
1629 getPreprocessor().getHeaderSearchInfo().getModuleCachePath());
1630 ModuleManager->resetForReload();
1631 ModuleManager->loadGlobalIndex();
1632 GlobalIndex = ModuleManager->getGlobalIndex();
1633 }
1634 HaveFullGlobalModuleIndex = true;
1635 }
1636 return GlobalIndex;
1637}
John Thompson2d94bbb2014-04-23 19:04:32 +00001638
1639// Check global module index for missing imports.
1640bool
1641CompilerInstance::lookupMissingImports(StringRef Name,
1642 SourceLocation TriggerLoc) {
1643 // Look for the symbol in non-imported modules, but only if an error
1644 // actually occurred.
1645 if (!buildingModule()) {
1646 // Load global module index, or retrieve a previously loaded one.
1647 GlobalModuleIndex *GlobalIndex = loadGlobalModuleIndex(
1648 TriggerLoc);
1649
1650 // Only if we have a global index.
1651 if (GlobalIndex) {
1652 GlobalModuleIndex::HitSet FoundModules;
1653
1654 // Find the modules that reference the identifier.
1655 // Note that this only finds top-level modules.
1656 // We'll let diagnoseTypo find the actual declaration module.
1657 if (GlobalIndex->lookupIdentifier(Name, FoundModules))
1658 return true;
1659 }
1660 }
1661
1662 return false;
1663}
David Blaikiea97eaa12014-08-29 16:53:14 +00001664void CompilerInstance::resetAndLeakSema() { BuryPointer(takeSema()); }