ENH: Remove memory leak and remember global generator for next time
This commit is contained in:
parent
4e49c3bf6e
commit
0842958977
|
@ -21,6 +21,24 @@
|
||||||
#include "cmake.h"
|
#include "cmake.h"
|
||||||
#include "cmGlobalGenerator.h"
|
#include "cmGlobalGenerator.h"
|
||||||
|
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
cmCTestBuildCommand::cmCTestBuildCommand()
|
||||||
|
{
|
||||||
|
m_GlobalGenerator = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
cmCTestBuildCommand::~cmCTestBuildCommand()
|
||||||
|
{
|
||||||
|
if ( m_GlobalGenerator )
|
||||||
|
{
|
||||||
|
delete m_GlobalGenerator;
|
||||||
|
m_GlobalGenerator = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
bool cmCTestBuildCommand::InitialPass(
|
bool cmCTestBuildCommand::InitialPass(
|
||||||
std::vector<std::string> const& args)
|
std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
|
@ -97,13 +115,24 @@ bool cmCTestBuildCommand::InitialPass(
|
||||||
{
|
{
|
||||||
cmakeBuildConfiguration = "Release";
|
cmakeBuildConfiguration = "Release";
|
||||||
}
|
}
|
||||||
cmGlobalGenerator* gen =
|
if ( m_GlobalGenerator )
|
||||||
m_Makefile->GetCMakeInstance()->CreateGlobalGenerator(cmakeGeneratorName);
|
{
|
||||||
gen->FindMakeProgram(m_Makefile);
|
if ( strcmp(m_GlobalGenerator->GetName(), cmakeGeneratorName) != 0 )
|
||||||
|
{
|
||||||
|
delete m_GlobalGenerator;
|
||||||
|
m_GlobalGenerator = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if ( !m_GlobalGenerator )
|
||||||
|
{
|
||||||
|
m_GlobalGenerator =
|
||||||
|
m_Makefile->GetCMakeInstance()->CreateGlobalGenerator(cmakeGeneratorName);
|
||||||
|
}
|
||||||
|
m_GlobalGenerator->FindMakeProgram(m_Makefile);
|
||||||
const char* cmakeMakeProgram = m_Makefile->GetDefinition("CMAKE_MAKE_PROGRAM");
|
const char* cmakeMakeProgram = m_Makefile->GetDefinition("CMAKE_MAKE_PROGRAM");
|
||||||
std::string buildCommand = gen->GenerateBuildCommand(cmakeMakeProgram, cmakeProjectName,
|
std::string buildCommand
|
||||||
0, cmakeBuildConfiguration, true);
|
= m_GlobalGenerator->GenerateBuildCommand(cmakeMakeProgram, cmakeProjectName,
|
||||||
|
0, cmakeBuildConfiguration, true);
|
||||||
m_CTest->SetCTestConfiguration("MakeCommand", buildCommand.c_str());
|
m_CTest->SetCTestConfiguration("MakeCommand", buildCommand.c_str());
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -19,6 +19,8 @@
|
||||||
|
|
||||||
#include "cmCTestCommand.h"
|
#include "cmCTestCommand.h"
|
||||||
|
|
||||||
|
class cmGlobalGenerator;
|
||||||
|
|
||||||
/** \class cmCTestBuild
|
/** \class cmCTestBuild
|
||||||
* \brief Run a ctest script
|
* \brief Run a ctest script
|
||||||
*
|
*
|
||||||
|
@ -28,7 +30,8 @@ class cmCTestBuildCommand : public cmCTestCommand
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
cmCTestBuildCommand() {}
|
cmCTestBuildCommand();
|
||||||
|
~cmCTestBuildCommand();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is a virtual constructor for the command.
|
* This is a virtual constructor for the command.
|
||||||
|
@ -71,6 +74,8 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
cmTypeMacro(cmCTestBuildCommand, cmCTestCommand);
|
cmTypeMacro(cmCTestBuildCommand, cmCTestCommand);
|
||||||
|
|
||||||
|
cmGlobalGenerator* m_GlobalGenerator;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue