mirror of
https://github.com/intel/llvm.git
synced 2026-02-02 10:08:59 +08:00
Arrange for the preprocessor to be passed down into the PCH writer.
llvm-svn: 68790
This commit is contained in:
@@ -29,8 +29,9 @@ namespace llvm {
|
||||
|
||||
namespace clang {
|
||||
|
||||
class ASTContext;
|
||||
class SourceManager;
|
||||
class Preprocessor;
|
||||
class ASTContext;
|
||||
|
||||
/// \brief Writes a precompiled header containing the contents of a
|
||||
/// translation unit.
|
||||
@@ -76,6 +77,7 @@ class PCHWriter {
|
||||
unsigned NextTypeID;
|
||||
|
||||
void WriteSourceManagerBlock(SourceManager &SourceMgr);
|
||||
void WritePreprocessor(Preprocessor &PP);
|
||||
void WriteType(const Type *T);
|
||||
void WriteTypesBlock(ASTContext &Context);
|
||||
uint64_t WriteDeclContextLexicalBlock(ASTContext &Context, DeclContext *DC);
|
||||
@@ -90,7 +92,7 @@ public:
|
||||
PCHWriter(llvm::BitstreamWriter &S);
|
||||
|
||||
/// \brief Write a precompiled header for the given AST context.
|
||||
void WritePCH(ASTContext &Context);
|
||||
void WritePCH(ASTContext &Context, Preprocessor &PP);
|
||||
|
||||
/// \brief Emit a source location.
|
||||
void AddSourceLocation(SourceLocation Loc, RecordData &Record);
|
||||
|
||||
@@ -474,6 +474,13 @@ void PCHWriter::WriteSourceManagerBlock(SourceManager &SourceMgr) {
|
||||
S.ExitBlock();
|
||||
}
|
||||
|
||||
/// \brief Writes the block containing the serialized form of the
|
||||
/// preprocessor.
|
||||
///
|
||||
void PCHWriter::WritePreprocessor(Preprocessor &PP) {
|
||||
}
|
||||
|
||||
|
||||
/// \brief Write the representation of a type to the PCH stream.
|
||||
void PCHWriter::WriteType(const Type *T) {
|
||||
pch::ID &ID = TypeIDs[T];
|
||||
@@ -659,7 +666,7 @@ void PCHWriter::WriteDeclsBlock(ASTContext &Context) {
|
||||
PCHWriter::PCHWriter(llvm::BitstreamWriter &S)
|
||||
: S(S), NextTypeID(pch::NUM_PREDEF_TYPE_IDS) { }
|
||||
|
||||
void PCHWriter::WritePCH(ASTContext &Context) {
|
||||
void PCHWriter::WritePCH(ASTContext &Context, Preprocessor &PP) {
|
||||
// Emit the file header.
|
||||
S.Emit((unsigned)'C', 8);
|
||||
S.Emit((unsigned)'P', 8);
|
||||
@@ -673,6 +680,7 @@ void PCHWriter::WritePCH(ASTContext &Context) {
|
||||
// Write the remaining PCH contents.
|
||||
S.EnterSubblock(pch::PCH_BLOCK_ID, 2);
|
||||
WriteSourceManagerBlock(Context.getSourceManager());
|
||||
WritePreprocessor(PP);
|
||||
WriteTypesBlock(Context);
|
||||
WriteDeclsBlock(Context);
|
||||
S.ExitBlock();
|
||||
|
||||
@@ -55,35 +55,33 @@ ASTConsumer *CreateBackendConsumer(BackendAction Action,
|
||||
Diagnostic &Diags,
|
||||
const LangOptions &Features,
|
||||
const CompileOptions &CompileOpts,
|
||||
const std::string& InFile,
|
||||
const std::string& OutFile);
|
||||
const std::string &InFile,
|
||||
const std::string &OutFile);
|
||||
|
||||
ASTConsumer* CreateHTMLPrinter(const std::string &OutFile, Diagnostic &D,
|
||||
Preprocessor *PP, PreprocessorFactory* PPF);
|
||||
Preprocessor *PP, PreprocessorFactory *PPF);
|
||||
|
||||
ASTConsumer *CreateSerializationTest(Diagnostic &Diags,
|
||||
FileManager& FMgr);
|
||||
FileManager &FMgr);
|
||||
|
||||
ASTConsumer *CreateASTSerializer(const std::string& InFile,
|
||||
const std::string& EmitDir,
|
||||
ASTConsumer *CreateASTSerializer(const std::string &InFile,
|
||||
const std::string &EmitDir,
|
||||
Diagnostic &Diags);
|
||||
|
||||
ASTConsumer *CreatePCHGenerator(Diagnostic &Diags,
|
||||
const LangOptions &Features,
|
||||
const std::string& InFile,
|
||||
const std::string& OutFile);
|
||||
ASTConsumer *CreatePCHGenerator(Preprocessor &PP,
|
||||
const std::string &OutFile);
|
||||
|
||||
ASTConsumer *CreateBlockRewriter(const std::string& InFile,
|
||||
const std::string& OutFile,
|
||||
ASTConsumer *CreateBlockRewriter(const std::string &InFile,
|
||||
const std::string &OutFile,
|
||||
Diagnostic &Diags,
|
||||
const LangOptions &LangOpts);
|
||||
|
||||
ASTConsumer *CreateInheritanceViewer(const std::string& clsname);
|
||||
|
||||
ASTConsumer* CreateAnalysisConsumer(Diagnostic &diags, Preprocessor* pp,
|
||||
PreprocessorFactory* ppf,
|
||||
const LangOptions& lopts,
|
||||
const std::string& output);
|
||||
ASTConsumer* CreateAnalysisConsumer(Diagnostic &diags, Preprocessor *pp,
|
||||
PreprocessorFactory *ppf,
|
||||
const LangOptions &lopts,
|
||||
const std::string &output);
|
||||
|
||||
} // end clang namespace
|
||||
|
||||
|
||||
@@ -12,9 +12,11 @@
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "ASTConsumers.h"
|
||||
#include "clang/Frontend/PCHWriter.h"
|
||||
#include "clang/AST/ASTContext.h"
|
||||
#include "clang/AST/ASTConsumer.h"
|
||||
#include "clang/Lex/Preprocessor.h"
|
||||
#include "llvm/Bitcode/BitstreamWriter.h"
|
||||
#include "llvm/System/Path.h"
|
||||
#include "llvm/Support/Compiler.h"
|
||||
@@ -27,19 +29,19 @@ using namespace llvm;
|
||||
|
||||
namespace {
|
||||
class VISIBILITY_HIDDEN PCHGenerator : public ASTConsumer {
|
||||
Diagnostic &Diags;
|
||||
Preprocessor &PP;
|
||||
std::string OutFile;
|
||||
|
||||
public:
|
||||
explicit PCHGenerator(Diagnostic &Diags, const std::string &OutFile)
|
||||
: Diags(Diags), OutFile(OutFile) { }
|
||||
explicit PCHGenerator(Preprocessor &PP, const std::string &OutFile)
|
||||
: PP(PP), OutFile(OutFile) { }
|
||||
|
||||
virtual void HandleTranslationUnit(ASTContext &Ctx);
|
||||
};
|
||||
}
|
||||
|
||||
void PCHGenerator::HandleTranslationUnit(ASTContext &Ctx) {
|
||||
if (Diags.hasErrorOccurred())
|
||||
if (PP.getDiagnostics().hasErrorOccurred())
|
||||
return;
|
||||
|
||||
// Write the PCH contents into a buffer
|
||||
@@ -48,7 +50,7 @@ void PCHGenerator::HandleTranslationUnit(ASTContext &Ctx) {
|
||||
PCHWriter Writer(Stream);
|
||||
|
||||
// Emit the PCH file
|
||||
Writer.WritePCH(Ctx);
|
||||
Writer.WritePCH(Ctx, PP);
|
||||
|
||||
// Open up the PCH file.
|
||||
std::string ErrMsg;
|
||||
@@ -66,13 +68,7 @@ void PCHGenerator::HandleTranslationUnit(ASTContext &Ctx) {
|
||||
Out.flush();
|
||||
}
|
||||
|
||||
namespace clang {
|
||||
|
||||
ASTConsumer *CreatePCHGenerator(Diagnostic &Diags,
|
||||
const LangOptions &Features,
|
||||
const std::string& InFile,
|
||||
const std::string& OutFile) {
|
||||
return new PCHGenerator(Diags, OutFile);
|
||||
}
|
||||
|
||||
ASTConsumer *clang::CreatePCHGenerator(Preprocessor &PP,
|
||||
const std::string &OutFile) {
|
||||
return new PCHGenerator(PP, OutFile);
|
||||
}
|
||||
|
||||
@@ -1529,7 +1529,8 @@ static ASTConsumer *CreateASTConsumer(const std::string& InFile,
|
||||
return CreateASTSerializer(InFile, OutputFile, Diag);
|
||||
|
||||
case GeneratePCH:
|
||||
return CreatePCHGenerator(Diag, LangOpts, InFile, OutputFile);
|
||||
assert(PP && "Generate PCH doesn't work from serialized file yet");
|
||||
return CreatePCHGenerator(*PP, OutputFile);
|
||||
|
||||
case RewriteObjC:
|
||||
return CreateCodeRewriterTest(InFile, OutputFile, Diag, LangOpts);
|
||||
|
||||
Reference in New Issue
Block a user