Arrange for the preprocessor to be passed down into the PCH writer.

llvm-svn: 68790
This commit is contained in:
Chris Lattner
2009-04-10 17:15:23 +00:00
parent 5f122a644a
commit eeffaef7b9
5 changed files with 39 additions and 34 deletions

View File

@@ -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);

View File

@@ -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();

View File

@@ -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

View File

@@ -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);
}

View File

@@ -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);