From: Richard Trieu Date: Tue, 30 Aug 2016 21:12:48 +0000 (+0000) Subject: Fix memory leak by storing returned pointer in std::unique_ptr X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7c5e085fb61f7d0fce7a08be2ca09e17dc0b0263;p=clang Fix memory leak by storing returned pointer in std::unique_ptr git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@280157 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Tooling/Tooling.cpp b/lib/Tooling/Tooling.cpp index 162a4914de..529c47ef1e 100644 --- a/lib/Tooling/Tooling.cpp +++ b/lib/Tooling/Tooling.cpp @@ -244,10 +244,9 @@ bool ToolInvocation::run() { const char *const BinaryName = Argv[0]; IntrusiveRefCntPtr DiagOpts = new DiagnosticOptions(); unsigned MissingArgIndex, MissingArgCount; - llvm::opt::InputArgList ParsedArgs = - driver::createDriverOptTable()->ParseArgs( - ArrayRef(Argv).slice(1), MissingArgIndex, - MissingArgCount); + std::unique_ptr Opts(driver::createDriverOptTable()); + llvm::opt::InputArgList ParsedArgs = Opts->ParseArgs( + ArrayRef(Argv).slice(1), MissingArgIndex, MissingArgCount); ParseDiagnosticArgs(*DiagOpts, ParsedArgs); TextDiagnosticPrinter DiagnosticPrinter( llvm::errs(), &*DiagOpts);