]> granicus.if.org Git - clang/commitdiff
Fix memory leak by storing returned pointer in std::unique_ptr
authorRichard Trieu <rtrieu@google.com>
Tue, 30 Aug 2016 21:12:48 +0000 (21:12 +0000)
committerRichard Trieu <rtrieu@google.com>
Tue, 30 Aug 2016 21:12:48 +0000 (21:12 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@280157 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Tooling/Tooling.cpp

index 162a4914dec420d81d7b8e8ca62f5c7dfc297cc9..529c47ef1e7a840b5c6f9d36310b9c45f598b663 100644 (file)
@@ -244,10 +244,9 @@ bool ToolInvocation::run() {
   const char *const BinaryName = Argv[0];
   IntrusiveRefCntPtr<DiagnosticOptions> DiagOpts = new DiagnosticOptions();
   unsigned MissingArgIndex, MissingArgCount;
-  llvm::opt::InputArgList ParsedArgs =
-      driver::createDriverOptTable()->ParseArgs(
-          ArrayRef<const char *>(Argv).slice(1), MissingArgIndex,
-          MissingArgCount);
+  std::unique_ptr<llvm::opt::OptTable> Opts(driver::createDriverOptTable());
+  llvm::opt::InputArgList ParsedArgs = Opts->ParseArgs(
+      ArrayRef<const char *>(Argv).slice(1), MissingArgIndex, MissingArgCount);
   ParseDiagnosticArgs(*DiagOpts, ParsedArgs);
   TextDiagnosticPrinter DiagnosticPrinter(
       llvm::errs(), &*DiagOpts);