aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Frontend/PrintPreprocessedOutput.cpp
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2010-02-27 18:02:51 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2010-02-27 18:02:51 +0000
commit718f7222712f58979ad94471cd5b0e608604cbce (patch)
tree307fb214c5ac392926fd307551669a22bcc10cca /clang/lib/Frontend/PrintPreprocessedOutput.cpp
parenta197fb67314ad0b7a1aab58b62bc82e523613094 (diff)
downloadllvm-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.cpp32
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;