From ea762b046017664e38b149e6cdba88b943bb30c0 Mon Sep 17 00:00:00 2001 From: Jordan Rose Date: Fri, 10 Aug 2012 01:06:08 +0000 Subject: Make sure to call EndSourceFile even if we can't continue compiling. Patch by Andy Gibbs! llvm-svn: 161649 --- clang/lib/Frontend/FrontendAction.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'clang/lib/Frontend/FrontendAction.cpp') diff --git a/clang/lib/Frontend/FrontendAction.cpp b/clang/lib/Frontend/FrontendAction.cpp index fb53c71..a4321e7 100644 --- a/clang/lib/Frontend/FrontendAction.cpp +++ b/clang/lib/Frontend/FrontendAction.cpp @@ -162,6 +162,7 @@ bool FrontendAction::BeginSourceFile(CompilerInstance &CI, setCurrentInput(Input); setCompilerInstance(&CI); + bool HasBegunSourceFile = false; if (!BeginInvocation(CI)) goto failure; @@ -214,6 +215,7 @@ bool FrontendAction::BeginSourceFile(CompilerInstance &CI, // Inform the diagnostic client we are processing a source file. CI.getDiagnosticClient().BeginSourceFile(CI.getLangOpts(), 0); + HasBegunSourceFile = true; // Initialize the action. if (!BeginSourceFileAction(CI, Input.File)) @@ -228,6 +230,7 @@ bool FrontendAction::BeginSourceFile(CompilerInstance &CI, // Inform the diagnostic client we are processing a source file. CI.getDiagnosticClient().BeginSourceFile(CI.getLangOpts(), &CI.getPreprocessor()); + HasBegunSourceFile = true; // Initialize the action. if (!BeginSourceFileAction(CI, Input.File)) @@ -309,7 +312,8 @@ bool FrontendAction::BeginSourceFile(CompilerInstance &CI, CI.setFileManager(0); } - CI.getDiagnosticClient().EndSourceFile(); + if (HasBegunSourceFile) + CI.getDiagnosticClient().EndSourceFile(); setCurrentInput(FrontendInputFile()); setCompilerInstance(0); return false; -- cgit v1.1