From 518ec2ea1f6ad48471e78cb6cfd56ac04767aadb Mon Sep 17 00:00:00 2001 From: Reid Spencer Date: Mon, 13 Dec 2004 03:22:31 +0000 Subject: Make sure the Archive gets deleted if there's an error. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18869 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Bytecode/Archive/ArchiveReader.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'lib/Bytecode/Archive') diff --git a/lib/Bytecode/Archive/ArchiveReader.cpp b/lib/Bytecode/Archive/ArchiveReader.cpp index a813371..d4a4921 100644 --- a/lib/Bytecode/Archive/ArchiveReader.cpp +++ b/lib/Bytecode/Archive/ArchiveReader.cpp @@ -282,9 +282,9 @@ Archive::loadArchive() { Archive* Archive::OpenAndLoad(const sys::Path& file, std::string* ErrorMessage) { try { - Archive* result = new Archive(file, true); + std::auto_ptr result ( new Archive(file, true)); result->loadArchive(); - return result; + return result.release(); } catch (const std::string& msg) { if (ErrorMessage) { *ErrorMessage = msg; @@ -377,9 +377,9 @@ Archive::loadSymbolTable() { Archive* Archive::OpenAndLoadSymbols(const sys::Path& file, std::string* ErrorMessage) { try { - Archive* result = new Archive(file, true); + std::auto_ptr result ( new Archive(file, true) ); result->loadSymbolTable(); - return result; + return result.release(); } catch (const std::string& msg) { if (ErrorMessage) { *ErrorMessage = msg; -- cgit v1.1