summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndy Cedilnik <andy.cedilnik@kitware.com>2004-05-05 14:13:19 (GMT)
committerAndy Cedilnik <andy.cedilnik@kitware.com>2004-05-05 14:13:19 (GMT)
commit23798f8a220093598270ef272dc1b1845c5729f4 (patch)
treefa11caf4592d1cb1f317479096bf26ee004bc3da
parent22de04fab9d440126e2b215291ae4ae3a6d91639 (diff)
downloadCMake-23798f8a220093598270ef272dc1b1845c5729f4.zip
CMake-23798f8a220093598270ef272dc1b1845c5729f4.tar.gz
CMake-23798f8a220093598270ef272dc1b1845c5729f4.tar.bz2
ENH: Remove memory leak
-rw-r--r--Source/cmCTest.cxx8
-rw-r--r--Source/cmake.cxx10
2 files changed, 13 insertions, 5 deletions
diff --git a/Source/cmCTest.cxx b/Source/cmCTest.cxx
index 821a346..377e688 100644
--- a/Source/cmCTest.cxx
+++ b/Source/cmCTest.cxx
@@ -21,6 +21,7 @@
#include "cmGlobalGenerator.h"
#include <cmsys/Directory.hxx>
#include "cmGlob.h"
+#include "cmDynamicLoader.h"
#include "cmCTestSubmit.h"
#include "curl/curl.h"
@@ -33,7 +34,8 @@
#include <time.h>
#include <math.h>
#include <float.h>
-#include "cmDynamicLoader.h"
+
+#include <memory> // auto_ptr
#define SAFEDIV(x,y) (((y)!=0)?((x)/(y)):(0))
#define DEBUGOUT std::cout << __LINE__ << " "; std::cout
@@ -3499,7 +3501,7 @@ int cmCTest::RunConfigurationScript(const std::string& total_script_arg)
gg.SetCMakeInstance(&cm);
// read in the list file to fill the cache
- cmLocalGenerator *lg = gg.CreateLocalGenerator();
+ std::auto_ptr<cmLocalGenerator> lg(gg.CreateLocalGenerator());
lg->SetGlobalGenerator(&gg);
// set a variable with the path to the current script
@@ -4930,7 +4932,7 @@ int cmCTest::ReadCustomConfigurationFileTree(const char* dir)
cmake cm;
cmGlobalGenerator gg;
gg.SetCMakeInstance(&cm);
- cmLocalGenerator *lg = gg.CreateLocalGenerator();
+ std::auto_ptr<cmLocalGenerator> lg(gg.CreateLocalGenerator());
lg->SetGlobalGenerator(&gg);
cmMakefile *mf = lg->GetMakefile();
diff --git a/Source/cmake.cxx b/Source/cmake.cxx
index b3fc121..5c0dd75 100644
--- a/Source/cmake.cxx
+++ b/Source/cmake.cxx
@@ -49,6 +49,7 @@
#endif
#endif
+#include <memory> // auto_ptr
void cmNeedBackwardsCompatibility(const std::string& variable,
int access_type, void* )
@@ -57,7 +58,12 @@ void cmNeedBackwardsCompatibility(const std::string& variable,
{
std::string message = "An attempt was made to access a variable: ";
message += variable;
- message += " that has not been defined. Some variables were always defined by CMake in versions prior to 1.6. To fix this you might need to set the cache value of CMAKE_BACKWARDS_COMPATIBILITY to 1.4 or less. If you are writing a CMakeList file, (or have already set CMAKE_BACKWARDS_COMPATABILITY to 1.4 or less) then you probably need to include a CMake module to test for the feature this variable defines.";
+ message += " that has not been defined. Some variables were always defined "
+ "by CMake in versions prior to 1.6. To fix this you might need to set the "
+ "cache value of CMAKE_BACKWARDS_COMPATIBILITY to 1.4 or less. If you are "
+ "writing a CMakeList file, (or have already set "
+ "CMAKE_BACKWARDS_COMPATABILITY to 1.4 or less) then you probably need to "
+ "include a CMake module to test for the feature this variable defines.";
cmSystemTools::Error(message.c_str());
}
}
@@ -248,7 +254,7 @@ void cmake::ReadListFile(const char *path)
// read in the list file to fill the cache
if(path)
{
- cmLocalGenerator *lg = gg->CreateLocalGenerator();
+ std::auto_ptr<cmLocalGenerator> lg(gg->CreateLocalGenerator());
lg->SetGlobalGenerator(gg);
if (!lg->GetMakefile()->ReadListFile(0, path))
{