Wrap clang module files in a Mach-O, ELF, or COFF container.
This is a necessary prerequisite for debugging with modules. The .pcm files become containers that hold the serialized AST which allows us to store debug information in the module file that can be shared by all object files that were built importing the module. This reapplies r230044 with a fixed configure+make build and updated dependencies and testcase requirements. Over the last iteration this version adds - missing target requirements for testcases that specify an x86 triple, - a missing clangCodeGen.a dependency to libClang.a in the make build. rdar://problem/19104245 llvm-svn: 230423
This commit is contained in:
@@ -10,10 +10,13 @@
|
||||
#include "clang/Frontend/FrontendActions.h"
|
||||
#include "clang/AST/ASTConsumer.h"
|
||||
#include "clang/Basic/FileManager.h"
|
||||
#include "clang/Basic/TargetInfo.h"
|
||||
#include "clang/CodeGen/CodeGenModuleContainer.h"
|
||||
#include "clang/Frontend/ASTConsumers.h"
|
||||
#include "clang/Frontend/ASTUnit.h"
|
||||
#include "clang/Frontend/CompilerInstance.h"
|
||||
#include "clang/Frontend/FrontendDiagnostic.h"
|
||||
#include "clang/Frontend/MultiplexConsumer.h"
|
||||
#include "clang/Frontend/Utils.h"
|
||||
#include "clang/Lex/HeaderSearch.h"
|
||||
#include "clang/Lex/Pragma.h"
|
||||
@@ -85,8 +88,23 @@ GeneratePCHAction::CreateASTConsumer(CompilerInstance &CI, StringRef InFile) {
|
||||
|
||||
if (!CI.getFrontendOpts().RelocatablePCH)
|
||||
Sysroot.clear();
|
||||
return llvm::make_unique<PCHGenerator>(CI.getPreprocessor(), OutputFile,
|
||||
nullptr, Sysroot, OS);
|
||||
|
||||
std::vector<std::unique_ptr<ASTConsumer>> Consumers;
|
||||
Consumers.push_back(llvm::make_unique<PCHGenerator>(CI.getPreprocessor(),
|
||||
OutputFile, nullptr,
|
||||
Sysroot));
|
||||
|
||||
auto CGOpts = CI.getCodeGenOpts();
|
||||
// The debug info emitted by ModuleContainerGenerator is not affected by the
|
||||
// optimization level.
|
||||
CGOpts.OptimizationLevel = 0;
|
||||
CGOpts.setDebugInfo(CodeGenOptions::LimitedDebugInfo);
|
||||
Consumers.push_back(std::unique_ptr<ASTConsumer>(
|
||||
CreateModuleContainerGenerator(CI.getDiagnostics(), "PCH", CGOpts,
|
||||
CI.getTargetOpts(), CI.getLangOpts(), OS,
|
||||
cast<PCHGenerator>(Consumers[0].get()))));
|
||||
|
||||
return llvm::make_unique<MultiplexConsumer>(std::move(Consumers));
|
||||
}
|
||||
|
||||
bool GeneratePCHAction::ComputeASTConsumerArguments(CompilerInstance &CI,
|
||||
@@ -122,8 +140,22 @@ GenerateModuleAction::CreateASTConsumer(CompilerInstance &CI,
|
||||
if (ComputeASTConsumerArguments(CI, InFile, Sysroot, OutputFile, OS))
|
||||
return nullptr;
|
||||
|
||||
return llvm::make_unique<PCHGenerator>(CI.getPreprocessor(), OutputFile,
|
||||
Module, Sysroot, OS);
|
||||
std::vector<std::unique_ptr<ASTConsumer>> Consumers;
|
||||
Consumers.push_back(llvm::make_unique<PCHGenerator>(CI.getPreprocessor(),
|
||||
OutputFile, Module,
|
||||
Sysroot));
|
||||
|
||||
auto CGOpts = CI.getCodeGenOpts();
|
||||
// The debug info emitted by ModuleContainerGenerator is not affected by the
|
||||
// optimization level.
|
||||
CGOpts.OptimizationLevel = 0;
|
||||
CGOpts.setDebugInfo(CodeGenOptions::LimitedDebugInfo);
|
||||
Consumers.push_back(
|
||||
std::unique_ptr<ASTConsumer>(CreateModuleContainerGenerator(
|
||||
CI.getDiagnostics(), Module->getFullModuleName(), CGOpts,
|
||||
CI.getTargetOpts(), CI.getLangOpts(), OS,
|
||||
cast<PCHGenerator>(Consumers[0].get()))));
|
||||
return llvm::make_unique<MultiplexConsumer>(std::move(Consumers));
|
||||
}
|
||||
|
||||
static SmallVectorImpl<char> &
|
||||
|
||||
Reference in New Issue
Block a user