diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2010-02-27 18:02:51 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2010-02-27 18:02:51 +0000 |
commit | 718f7222712f58979ad94471cd5b0e608604cbce (patch) | |
tree | 307fb214c5ac392926fd307551669a22bcc10cca /clang/lib/Frontend/PrintPreprocessedOutput.cpp | |
parent | a197fb67314ad0b7a1aab58b62bc82e523613094 (diff) | |
download | llvm-718f7222712f58979ad94471cd5b0e608604cbce.zip llvm-718f7222712f58979ad94471cd5b0e608604cbce.tar.gz llvm-718f7222712f58979ad94471cd5b0e608604cbce.tar.bz2 |
Revert 97324. Chris says this cleanup could hurt -E performance.
llvm-svn: 97331
Diffstat (limited to 'clang/lib/Frontend/PrintPreprocessedOutput.cpp')
-rw-r--r-- | clang/lib/Frontend/PrintPreprocessedOutput.cpp | 32 |
1 files changed, 24 insertions, 8 deletions
diff --git a/clang/lib/Frontend/PrintPreprocessedOutput.cpp b/clang/lib/Frontend/PrintPreprocessedOutput.cpp index beba260..774372c 100644 --- a/clang/lib/Frontend/PrintPreprocessedOutput.cpp +++ b/clang/lib/Frontend/PrintPreprocessedOutput.cpp @@ -390,7 +390,7 @@ struct UnknownPragmaHandler : public PragmaHandler { static void PrintPreprocessedTokens(Preprocessor &PP, Token &Tok, PrintPPOutputPPCallbacks *Callbacks, llvm::raw_ostream &OS) { - llvm::SmallString<256> Buffer; + char Buffer[256]; Token PrevTok; while (1) { @@ -406,13 +406,29 @@ static void PrintPreprocessedTokens(Preprocessor &PP, Token &Tok, OS << ' '; } - llvm::StringRef Str = PP.getSpelling(Tok, Buffer); - OS << Str; - // Tokens that can contain embedded newlines need to adjust our current - // line number. - if (Tok.getKind() == tok::comment) - Callbacks->HandleNewlinesInToken(Str.data(), Str.size()); - + if (IdentifierInfo *II = Tok.getIdentifierInfo()) { + OS << II->getName(); + } else if (Tok.isLiteral() && !Tok.needsCleaning() && + Tok.getLiteralData()) { + OS.write(Tok.getLiteralData(), Tok.getLength()); + } else if (Tok.getLength() < 256) { + const char *TokPtr = Buffer; + unsigned Len = PP.getSpelling(Tok, TokPtr); + OS.write(TokPtr, Len); + + // Tokens that can contain embedded newlines need to adjust our current + // line number. + if (Tok.getKind() == tok::comment) + Callbacks->HandleNewlinesInToken(TokPtr, Len); + } else { + std::string S = PP.getSpelling(Tok); + OS.write(&S[0], S.size()); + + // Tokens that can contain embedded newlines need to adjust our current + // line number. + if (Tok.getKind() == tok::comment) + Callbacks->HandleNewlinesInToken(&S[0], S.size()); + } Callbacks->SetEmittedTokensOnThisLine(); if (Tok.is(tok::eof)) break; |