aboutsummaryrefslogtreecommitdiff
path: root/lib/Frontend/PrintPreprocessedOutput.cpp
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2010-02-27 14:22:08 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2010-02-27 14:22:08 +0000
commit8caa6c56b1c0047deb690f764265a35800572d50 (patch)
tree0271b012bfce8535c2e88ad9371aa0aa625c549d /lib/Frontend/PrintPreprocessedOutput.cpp
parenta15e7eaea9e63f58d1a7e72ed167cbb244da438a (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.cpp32
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;