diff options
author | Brad King <brad.king@kitware.com> | 2006-03-16 19:14:15 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2006-03-16 19:14:15 (GMT) |
commit | 180a45c8c752c01ee81b8f7ac6aaaf8053f57d0e (patch) | |
tree | 26780708545f6917aa6d9828d096ec3ec2bc2549 | |
parent | 3b43c29a30b154cedd3f983b34bb5e1461832349 (diff) | |
download | CMake-180a45c8c752c01ee81b8f7ac6aaaf8053f57d0e.zip CMake-180a45c8c752c01ee81b8f7ac6aaaf8053f57d0e.tar.gz CMake-180a45c8c752c01ee81b8f7ac6aaaf8053f57d0e.tar.bz2 |
BUG: Do not leak the ofstream object in append mode. Just use an auto_ptr for both cases.
-rw-r--r-- | Source/cmExportLibraryDependencies.cxx | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/Source/cmExportLibraryDependencies.cxx b/Source/cmExportLibraryDependencies.cxx index 3f39920..7dab940 100644 --- a/Source/cmExportLibraryDependencies.cxx +++ b/Source/cmExportLibraryDependencies.cxx @@ -57,21 +57,19 @@ void cmExportLibraryDependenciesCommand::FinalPass() } // Use copy-if-different if not appending. - std::ostream* foutPtr; - std::auto_ptr<cmGeneratedFileStream> foutNew; + std::auto_ptr<std::ofstream> foutPtr; if(append) { - foutPtr = new std::ofstream(fname.c_str(), std::ios::app); + foutPtr.reset(new std::ofstream(fname.c_str(), std::ios::app)); } else { std::auto_ptr<cmGeneratedFileStream> ap( new cmGeneratedFileStream(fname.c_str(), true)); ap->SetCopyIfDifferent(true); - foutNew = ap; - foutPtr = foutNew.get(); + foutPtr.reset(ap.release()); } - std::ostream& fout = *foutPtr; + std::ostream& fout = *foutPtr.get(); if (!fout) { |