diff options
| author | Douglas Gregor <dgregor@apple.com> | 2010-11-11 00:39:14 +0000 |
|---|---|---|
| committer | Douglas Gregor <dgregor@apple.com> | 2010-11-11 00:39:14 +0000 |
| commit | 44c6ee77293ac396b3f4737951e4fd44834b85e9 (patch) | |
| tree | 5d86b8b57286f6f894b0b6920a6d26c6a6578d35 /clang/lib/Frontend/CompilerInstance.cpp | |
| parent | 8bf3d832e5044bace8722894f691ff6badc95d61 (diff) | |
| download | llvm-44c6ee77293ac396b3f4737951e4fd44834b85e9.zip llvm-44c6ee77293ac396b3f4737951e4fd44834b85e9.tar.gz llvm-44c6ee77293ac396b3f4737951e4fd44834b85e9.tar.bz2 | |
Improve ASTUnit's capture of diagnostics so that the
diagnostic-capturing client lives as long as the ASTUnit itself
does. Otherwise, we can end up with crashes when we get a diagnostic
outside of parsing/code completion. The circumstances under which this
happen are really hard to reproduce, because a file needs to change
from under us.
llvm-svn: 118751
Diffstat (limited to 'clang/lib/Frontend/CompilerInstance.cpp')
| -rw-r--r-- | clang/lib/Frontend/CompilerInstance.cpp | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/clang/lib/Frontend/CompilerInstance.cpp b/clang/lib/Frontend/CompilerInstance.cpp index c5e5d7f..7cfcd1c 100644 --- a/clang/lib/Frontend/CompilerInstance.cpp +++ b/clang/lib/Frontend/CompilerInstance.cpp @@ -113,19 +113,23 @@ static void SetUpBuildDumpLog(const DiagnosticOptions &DiagOpts, Diags.setClient(new ChainedDiagnosticClient(Diags.takeClient(), Logger)); } -void CompilerInstance::createDiagnostics(int Argc, const char* const *Argv) { - Diagnostics = createDiagnostics(getDiagnosticOpts(), Argc, Argv); +void CompilerInstance::createDiagnostics(int Argc, const char* const *Argv, + DiagnosticClient *Client) { + Diagnostics = createDiagnostics(getDiagnosticOpts(), Argc, Argv, Client); } llvm::IntrusiveRefCntPtr<Diagnostic> CompilerInstance::createDiagnostics(const DiagnosticOptions &Opts, - int Argc, const char* const *Argv) { + int Argc, const char* const *Argv, + DiagnosticClient *Client) { llvm::IntrusiveRefCntPtr<Diagnostic> Diags(new Diagnostic()); // Create the diagnostic client for reporting errors or for // implementing -verify. - llvm::OwningPtr<DiagnosticClient> DiagClient; - Diags->setClient(new TextDiagnosticPrinter(llvm::errs(), Opts)); + if (Client) + Diags->setClient(Client); + else + Diags->setClient(new TextDiagnosticPrinter(llvm::errs(), Opts)); // Chain in -verify checker, if requested. if (Opts.VerifyDiagnostics) |
