diff options
| author | Ted Kremenek <kremenek@apple.com> | 2009-03-19 22:10:38 +0000 |
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2009-03-19 22:10:38 +0000 |
| commit | 7040b57c9fd10a95f6ce7a321b091cd364a748d5 (patch) | |
| tree | 499ff97dca150a1e63eabf1393b4d7bf7d7a5f01 /clang/Driver | |
| parent | 308fdf6ee9e6ee7adbdb22115c468cdea082d199 (diff) | |
| download | bcm5719-llvm-7040b57c9fd10a95f6ce7a321b091cd364a748d5.tar.gz bcm5719-llvm-7040b57c9fd10a95f6ce7a321b091cd364a748d5.zip | |
Store the name of the original file used to generate the PTH file in the PTH
file itself.
llvm-svn: 67340
Diffstat (limited to 'clang/Driver')
| -rw-r--r-- | clang/Driver/CacheTokens.cpp | 34 |
1 files changed, 29 insertions, 5 deletions
diff --git a/clang/Driver/CacheTokens.cpp b/clang/Driver/CacheTokens.cpp index cf1ec5ac1a3..4ca350e6fb0 100644 --- a/clang/Driver/CacheTokens.cpp +++ b/clang/Driver/CacheTokens.cpp @@ -406,7 +406,7 @@ public: PTHWriter(llvm::raw_fd_ostream& out, Preprocessor& pp) : Out(out), PP(pp), idcount(0), CurStrOffset(0) {} - void GeneratePTH(); + void GeneratePTH(const std::string *MainFile = 0); StatSysCallCache *createStatListener() { return new StatListener(PM); @@ -632,7 +632,7 @@ Offset PTHWriter::EmitCachedSpellings() { return SpellingsOff; } -void PTHWriter::GeneratePTH() { +void PTHWriter::GeneratePTH(const std::string *MainFile) { // Generate the prologue. Out << "cfe-pth"; Emit32(PTHManager::Version); @@ -640,6 +640,17 @@ void PTHWriter::GeneratePTH() { // Leave 4 words for the prologue. Offset PrologueOffset = Out.tell(); for (unsigned i = 0; i < 4 * sizeof(uint32_t); ++i) Emit8(0); + + // Write the name of the MainFile. + if (MainFile && MainFile->length() > 0) { + Emit16(MainFile->length()); + EmitBuf(&((*MainFile)[0]), &((*MainFile)[0]) + MainFile->length()); + } + else { + // String with 0 bytes. + Emit16(0); + } + Emit8(0); // Iterate over all the files in SourceManager. Create a lexer // for each file and cache the tokens. @@ -690,6 +701,21 @@ void clang::CacheTokens(Preprocessor& PP, const std::string& OutFile) { llvm::errs() << "PTH error: " << ErrMsg << "\n"; return; } + + // Get the name of the main file. + const SourceManager &SrcMgr = PP.getSourceManager(); + const FileEntry *MainFile = SrcMgr.getFileEntryForID(SrcMgr.getMainFileID()); + llvm::sys::Path MainFilePath(MainFile->getName()); + std::string MainFileName; + + if (!MainFilePath.isAbsolute()) { + llvm::sys::Path P = llvm::sys::Path::GetCurrentDirectory(); + P.appendComponent(MainFilePath.toString()); + MainFileName = P.toString(); + } + else { + MainFileName = MainFilePath.toString(); + } // Create the PTHWriter. PTHWriter PW(Out, PP); @@ -703,11 +729,9 @@ void clang::CacheTokens(Preprocessor& PP, const std::string& OutFile) { PP.EnterMainSourceFile(); do { PP.Lex(Tok); } while (Tok.isNot(tok::eof)); - - // Generate the PTH file. PP.getFileManager().setStatCache(0); - PW.GeneratePTH(); + PW.GeneratePTH(&MainFileName); } //===----------------------------------------------------------------------===// |

