]> granicus.if.org Git - clang/commitdiff
Simplify.
authorDaniel Dunbar <daniel@zuster.org>
Thu, 12 Nov 2009 02:53:34 +0000 (02:53 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Thu, 12 Nov 2009 02:53:34 +0000 (02:53 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@86938 91177308-0d34-0410-b5e6-96231b3b80d8

tools/clang-cc/clang-cc.cpp

index 0d056c046e7d0e33222f61bb2a1b00417c6f0115..403eddb1959b5d46de817727195834a84a8701d6 100644 (file)
@@ -821,12 +821,12 @@ static void ProcessInputFile(const CompilerInvocation &CompOpts,
       return;
 
     // Run the preprocessor actions.
+    llvm::TimeRegion Timer(ClangFrontendTimer);
     switch (PA) {
     default:
       assert(0 && "unexpected program action");
 
     case DumpRawTokens: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
       SourceManager &SM = PP.getSourceManager();
       // Start lexing the specified input file.
       Lexer RawLex(SM.getMainFileID(), SM, PP.getLangOptions());
@@ -839,12 +839,10 @@ static void ProcessInputFile(const CompilerInvocation &CompOpts,
         fprintf(stderr, "\n");
         RawLex.LexFromRawLexer(RawTok);
       }
-      ClearSourceMgr = true;
       break;
     }
 
     case DumpTokens: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
       Token Tok;
       // Start preprocessing the specified input file.
       PP.EnterMainSourceFile();
@@ -853,66 +851,46 @@ static void ProcessInputFile(const CompilerInvocation &CompOpts,
         PP.DumpToken(Tok, true);
         fprintf(stderr, "\n");
       } while (Tok.isNot(tok::eof));
-      ClearSourceMgr = true;
       break;
     }
 
-    case GeneratePTH: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
+    case GeneratePTH:
       CacheTokens(PP, static_cast<llvm::raw_fd_ostream*>(OS.get()));
-      ClearSourceMgr = true;
       break;
-    }
 
-    case ParseNoop: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
+    case ParseNoop:
       ParseFile(PP, new MinimalAction(PP));
-      ClearSourceMgr = true;
       break;
-    }
 
-    case ParsePrintCallbacks: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
+    case ParsePrintCallbacks:
       ParseFile(PP, CreatePrintParserActionsAction(PP, OS.get()));
-      ClearSourceMgr = true;
       break;
-    }
 
-    case PrintPreprocessedInput: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
+    case PrintPreprocessedInput:
       DoPrintPreprocessedInput(PP, OS.get(),
                                CompOpts.getPreprocessorOutputOpts());
-      ClearSourceMgr = true;
       break;
-    }
 
-    case RewriteMacros: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
+    case RewriteMacros:
       RewriteMacrosInInput(PP, OS.get());
-      ClearSourceMgr = true;
       break;
-    }
 
-    case RewriteTest: {
-      llvm::TimeRegion Timer(ClangFrontendTimer);
+    case RewriteTest:
       DoRewriteTest(PP, OS.get());
-      ClearSourceMgr = true;
       break;
-    }
 
     case RunPreprocessorOnly: {    // Just lex as fast as we can, no output.
-      llvm::TimeRegion Timer(ClangFrontendTimer);
       Token Tok;
       // Start parsing the specified input file.
       PP.EnterMainSourceFile();
       do {
         PP.Lex(Tok);
       } while (Tok.isNot(tok::eof));
-      ClearSourceMgr = true;
       break;
     }
-
     }
+
+    ClearSourceMgr = true;
   }
 
   if (FixItRewrite)