diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2010-02-27 14:22:08 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2010-02-27 14:22:08 +0000 |
commit | 8caa6c56b1c0047deb690f764265a35800572d50 (patch) | |
tree | 0271b012bfce8535c2e88ad9371aa0aa625c549d /lib/Frontend/PrintPreprocessedOutput.cpp | |
parent | a15e7eaea9e63f58d1a7e72ed167cbb244da438a (diff) |
Simplify code.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@97324 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Frontend/PrintPreprocessedOutput.cpp')
-rw-r--r-- | lib/Frontend/PrintPreprocessedOutput.cpp | 32 |
1 files changed, 8 insertions, 24 deletions
diff --git a/lib/Frontend/PrintPreprocessedOutput.cpp b/lib/Frontend/PrintPreprocessedOutput.cpp index 774372c869..beba26013e 100644 --- a/lib/Frontend/PrintPreprocessedOutput.cpp +++ b/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) { - char Buffer[256]; + llvm::SmallString<256> Buffer; Token PrevTok; while (1) { @@ -406,29 +406,13 @@ static void PrintPreprocessedTokens(Preprocessor &PP, Token &Tok, OS << ' '; } - 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()); - } + 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()); + Callbacks->SetEmittedTokensOnThisLine(); if (Tok.is(tok::eof)) break; |