ENH: Improve syntax
This commit is contained in:
parent
082b3b44d7
commit
9619d54003
|
@ -24,16 +24,55 @@
|
||||||
bool cmCTestBuildCommand::InitialPass(
|
bool cmCTestBuildCommand::InitialPass(
|
||||||
std::vector<std::string> const& args)
|
std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
if (args.size() != 2)
|
const char* build_dir = 0;
|
||||||
|
const char* res_var = 0;
|
||||||
|
|
||||||
|
bool havereturn_variable = false;
|
||||||
|
bool havesource = false;
|
||||||
|
for(size_t i=0; i < args.size(); ++i)
|
||||||
{
|
{
|
||||||
this->SetError("called with incorrect number of arguments");
|
if ( havereturn_variable )
|
||||||
|
{
|
||||||
|
res_var = args[i].c_str();
|
||||||
|
havereturn_variable = false;
|
||||||
|
}
|
||||||
|
else if ( havesource )
|
||||||
|
{
|
||||||
|
build_dir = args[i].c_str();
|
||||||
|
havesource = false;
|
||||||
|
}
|
||||||
|
else if(args[i] == "RETURN_VALUE")
|
||||||
|
{
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. RETURN_VALUE specified twice.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
havereturn_variable = true;
|
||||||
|
}
|
||||||
|
else if(args[i] == "BUILD")
|
||||||
|
{
|
||||||
|
if ( build_dir )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. BUILD specified twice.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
havesource = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cmOStringStream str;
|
||||||
|
str << "called with incorrect number of arguments. Extra argument is: " << args[i].c_str() << ".";
|
||||||
|
this->SetError(str.str().c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const char* build_dir = args[0].c_str();
|
if ( build_dir )
|
||||||
const char* res_var = args[1].c_str();
|
{
|
||||||
|
|
||||||
m_CTest->SetCTestConfiguration("BuildDirectory", build_dir);
|
m_CTest->SetCTestConfiguration("BuildDirectory", build_dir);
|
||||||
|
}
|
||||||
|
|
||||||
cmCTestGenericHandler* handler = m_CTest->GetHandler("build");
|
cmCTestGenericHandler* handler = m_CTest->GetHandler("build");
|
||||||
if ( !handler )
|
if ( !handler )
|
||||||
{
|
{
|
||||||
|
@ -62,7 +101,6 @@ bool cmCTestBuildCommand::InitialPass(
|
||||||
m_Makefile->GetCMakeInstance()->CreateGlobalGenerator(cmakeGeneratorName);
|
m_Makefile->GetCMakeInstance()->CreateGlobalGenerator(cmakeGeneratorName);
|
||||||
gen->FindMakeProgram(m_Makefile);
|
gen->FindMakeProgram(m_Makefile);
|
||||||
const char* cmakeMakeProgram = m_Makefile->GetDefinition("CMAKE_MAKE_PROGRAM");
|
const char* cmakeMakeProgram = m_Makefile->GetDefinition("CMAKE_MAKE_PROGRAM");
|
||||||
std::cout << "CMake Make program is: " << cmakeMakeProgram << std::endl;
|
|
||||||
std::string buildCommand = gen->GenerateBuildCommand(cmakeMakeProgram, cmakeProjectName,
|
std::string buildCommand = gen->GenerateBuildCommand(cmakeMakeProgram, cmakeProjectName,
|
||||||
0, cmakeBuildConfiguration, true);
|
0, cmakeBuildConfiguration, true);
|
||||||
|
|
||||||
|
@ -78,9 +116,12 @@ bool cmCTestBuildCommand::InitialPass(
|
||||||
}
|
}
|
||||||
|
|
||||||
int res = handler->ProcessHandler();
|
int res = handler->ProcessHandler();
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
cmOStringStream str;
|
cmOStringStream str;
|
||||||
str << res;
|
str << res;
|
||||||
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ public:
|
||||||
virtual const char* GetFullDocumentation()
|
virtual const char* GetFullDocumentation()
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
" CTEST_BUILD(build_dir res)\n"
|
" CTEST_BUILD([BUILD build_dir] [RETURN_VALUE res])\n"
|
||||||
"Builds the given build directory and stores results in Build.xml.";
|
"Builds the given build directory and stores results in Build.xml.";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,17 +22,56 @@
|
||||||
bool cmCTestConfigureCommand::InitialPass(
|
bool cmCTestConfigureCommand::InitialPass(
|
||||||
std::vector<std::string> const& args)
|
std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
if (args.size() != 2)
|
const char* build_dir = 0;
|
||||||
|
const char* res_var = 0;
|
||||||
|
|
||||||
|
bool havereturn_variable = false;
|
||||||
|
bool havesource = false;
|
||||||
|
for(size_t i=0; i < args.size(); ++i)
|
||||||
{
|
{
|
||||||
this->SetError("called with incorrect number of arguments");
|
if ( havereturn_variable )
|
||||||
|
{
|
||||||
|
res_var = args[i].c_str();
|
||||||
|
havereturn_variable = false;
|
||||||
|
}
|
||||||
|
else if ( havesource )
|
||||||
|
{
|
||||||
|
build_dir = args[i].c_str();
|
||||||
|
havesource = false;
|
||||||
|
}
|
||||||
|
else if(args[i] == "RETURN_VALUE")
|
||||||
|
{
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. RETURN_VALUE specified twice.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
havereturn_variable = true;
|
||||||
const char* build_dir = args[0].c_str();
|
}
|
||||||
const char* res_var = args[1].c_str();
|
else if(args[i] == "BUILD")
|
||||||
|
{
|
||||||
|
if ( build_dir )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. BUILD specified twice.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
havesource = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cmOStringStream str;
|
||||||
|
str << "called with incorrect number of arguments. Extra argument is: " << args[i].c_str() << ".";
|
||||||
|
this->SetError(str.str().c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "ConfigureCommand", "CTEST_CONFIGURE_COMMAND");
|
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "ConfigureCommand", "CTEST_CONFIGURE_COMMAND");
|
||||||
|
|
||||||
|
if ( build_dir )
|
||||||
|
{
|
||||||
m_CTest->SetCTestConfiguration("BuildDirectory", build_dir);
|
m_CTest->SetCTestConfiguration("BuildDirectory", build_dir);
|
||||||
|
}
|
||||||
|
|
||||||
cmCTestGenericHandler* handler = m_CTest->GetHandler("configure");
|
cmCTestGenericHandler* handler = m_CTest->GetHandler("configure");
|
||||||
if ( !handler )
|
if ( !handler )
|
||||||
|
@ -41,9 +80,12 @@ bool cmCTestConfigureCommand::InitialPass(
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
int res = handler->ProcessHandler();
|
int res = handler->ProcessHandler();
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
cmOStringStream str;
|
cmOStringStream str;
|
||||||
str << res;
|
str << res;
|
||||||
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ public:
|
||||||
virtual const char* GetFullDocumentation()
|
virtual const char* GetFullDocumentation()
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
" CTEST_CONFIGURE(build_dir res)\n"
|
" CTEST_CONFIGURE(BUILD build_dir RETURN_VALUE res)\n"
|
||||||
"Configures the given build directory and stores results in Configure.xml. The "
|
"Configures the given build directory and stores results in Configure.xml. The "
|
||||||
"second argument is a variable that will hold return value.";
|
"second argument is a variable that will hold return value.";
|
||||||
}
|
}
|
||||||
|
|
|
@ -165,8 +165,8 @@ int cmCTestCoverageHandler::ProcessHandler()
|
||||||
cmSystemTools::ConvertToUnixSlashes(sourceDir);
|
cmSystemTools::ConvertToUnixSlashes(sourceDir);
|
||||||
cmSystemTools::ConvertToUnixSlashes(binaryDir);
|
cmSystemTools::ConvertToUnixSlashes(binaryDir);
|
||||||
|
|
||||||
std::string asfGlob = sourceDir + "/*";
|
//std::string asfGlob = sourceDir + "/*";
|
||||||
std::string abfGlob = binaryDir + "/*";
|
//std::string abfGlob = binaryDir + "/*";
|
||||||
std::string daGlob = binaryDir + "/*.da";
|
std::string daGlob = binaryDir + "/*.da";
|
||||||
std::string gcovOutputRex = "[0-9]+\\.[0-9]+% of [0-9]+ (source |)lines executed in file (.*)$";
|
std::string gcovOutputRex = "[0-9]+\\.[0-9]+% of [0-9]+ (source |)lines executed in file (.*)$";
|
||||||
std::string gcovOutputRex2 = "^Creating (.*\\.gcov)\\.";
|
std::string gcovOutputRex2 = "^Creating (.*\\.gcov)\\.";
|
||||||
|
@ -347,8 +347,8 @@ int cmCTestCoverageHandler::ProcessHandler()
|
||||||
int cnt = 0;
|
int cnt = 0;
|
||||||
long total_tested = 0;
|
long total_tested = 0;
|
||||||
long total_untested = 0;
|
long total_untested = 0;
|
||||||
std::string fullSourceDir = sourceDir + "/";
|
//std::string fullSourceDir = sourceDir + "/";
|
||||||
std::string fullBinaryDir = binaryDir + "/";
|
//std::string fullBinaryDir = binaryDir + "/";
|
||||||
for ( fileIterator = totalCoverage.begin();
|
for ( fileIterator = totalCoverage.begin();
|
||||||
fileIterator != totalCoverage.end();
|
fileIterator != totalCoverage.end();
|
||||||
++fileIterator )
|
++fileIterator )
|
||||||
|
|
|
@ -22,13 +22,33 @@
|
||||||
bool cmCTestSubmitCommand::InitialPass(
|
bool cmCTestSubmitCommand::InitialPass(
|
||||||
std::vector<std::string> const& args)
|
std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
if (args.size() != 1)
|
const char* res_var = 0;
|
||||||
|
|
||||||
|
bool havereturn_variable = false;
|
||||||
|
for(size_t i=0; i < args.size(); ++i)
|
||||||
{
|
{
|
||||||
this->SetError("called with incorrect number of arguments");
|
if ( havereturn_variable )
|
||||||
|
{
|
||||||
|
res_var = args[i].c_str();
|
||||||
|
havereturn_variable = false;
|
||||||
|
}
|
||||||
|
else if(args[i] == "RETURN_VALUE")
|
||||||
|
{
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. RETURN_VALUE specified twice.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
havereturn_variable = true;
|
||||||
const char* res_var = args[0].c_str();
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cmOStringStream str;
|
||||||
|
str << "called with incorrect number of arguments. Extra argument is: " << args[i].c_str() << ".";
|
||||||
|
this->SetError(str.str().c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "DropMethod", "CTEST_DROP_METHOD");
|
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "DropMethod", "CTEST_DROP_METHOD");
|
||||||
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "DropSite", "CTEST_DROP_SITE");
|
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "DropSite", "CTEST_DROP_SITE");
|
||||||
|
@ -45,9 +65,12 @@ bool cmCTestSubmitCommand::InitialPass(
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
int res = handler->ProcessHandler();
|
int res = handler->ProcessHandler();
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
cmOStringStream str;
|
cmOStringStream str;
|
||||||
str << res;
|
str << res;
|
||||||
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ public:
|
||||||
virtual const char* GetFullDocumentation()
|
virtual const char* GetFullDocumentation()
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
" CTEST_SUBMIT(res)\n"
|
" CTEST_SUBMIT([RETURN_VALUE res])\n"
|
||||||
"Submits the test results for the project.";
|
"Submits the test results for the project.";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,16 +22,54 @@
|
||||||
bool cmCTestTestCommand::InitialPass(
|
bool cmCTestTestCommand::InitialPass(
|
||||||
std::vector<std::string> const& args)
|
std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
if (args.size() != 2)
|
const char* build_dir = 0;
|
||||||
|
const char* res_var = 0;
|
||||||
|
|
||||||
|
bool havereturn_variable = false;
|
||||||
|
bool havesource = false;
|
||||||
|
for(size_t i=0; i < args.size(); ++i)
|
||||||
{
|
{
|
||||||
this->SetError("called with incorrect number of arguments");
|
if ( havereturn_variable )
|
||||||
|
{
|
||||||
|
res_var = args[i].c_str();
|
||||||
|
havereturn_variable = false;
|
||||||
|
}
|
||||||
|
else if ( havesource )
|
||||||
|
{
|
||||||
|
build_dir = args[i].c_str();
|
||||||
|
havesource = false;
|
||||||
|
}
|
||||||
|
else if(args[i] == "RETURN_VALUE")
|
||||||
|
{
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. RETURN_VALUE specified twice.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
havereturn_variable = true;
|
||||||
|
}
|
||||||
|
else if(args[i] == "BUILD")
|
||||||
|
{
|
||||||
|
if ( build_dir )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. BUILD specified twice.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
havesource = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cmOStringStream str;
|
||||||
|
str << "called with incorrect number of arguments. Extra argument is: " << args[i].c_str() << ".";
|
||||||
|
this->SetError(str.str().c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const char* build_dir = args[0].c_str();
|
if ( build_dir )
|
||||||
const char* res_var = args[1].c_str();
|
{
|
||||||
|
|
||||||
m_CTest->SetCTestConfiguration("BuildDirectory", build_dir);
|
m_CTest->SetCTestConfiguration("BuildDirectory", build_dir);
|
||||||
|
}
|
||||||
|
|
||||||
cmCTestGenericHandler* handler = m_CTest->GetHandler("test");
|
cmCTestGenericHandler* handler = m_CTest->GetHandler("test");
|
||||||
if ( !handler )
|
if ( !handler )
|
||||||
|
@ -40,12 +78,15 @@ bool cmCTestTestCommand::InitialPass(
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
std::string current_dir = cmSystemTools::GetCurrentWorkingDirectory();
|
std::string current_dir = cmSystemTools::GetCurrentWorkingDirectory();
|
||||||
cmSystemTools::ChangeDirectory(build_dir);
|
cmSystemTools::ChangeDirectory(m_CTest->GetCTestConfiguration("BuildDirectory").c_str());
|
||||||
int res = handler->ProcessHandler();
|
int res = handler->ProcessHandler();
|
||||||
cmSystemTools::ChangeDirectory(current_dir.c_str());
|
if ( res_var )
|
||||||
|
{
|
||||||
cmOStringStream str;
|
cmOStringStream str;
|
||||||
str << res;
|
str << res;
|
||||||
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
||||||
|
}
|
||||||
|
cmSystemTools::ChangeDirectory(current_dir.c_str());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ public:
|
||||||
virtual const char* GetFullDocumentation()
|
virtual const char* GetFullDocumentation()
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
" CTEST_TEST(build_dir res)\n"
|
" CTEST_TEST([BUILD build_dir] [RETURN_VALUE res])\n"
|
||||||
"Tests the given build directory and stores results in Test.xml. The "
|
"Tests the given build directory and stores results in Test.xml. The "
|
||||||
"second argument is a variable that will hold value.";
|
"second argument is a variable that will hold value.";
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,14 +22,49 @@
|
||||||
bool cmCTestUpdateCommand::InitialPass(
|
bool cmCTestUpdateCommand::InitialPass(
|
||||||
std::vector<std::string> const& args)
|
std::vector<std::string> const& args)
|
||||||
{
|
{
|
||||||
if (args.size() != 2)
|
const char* source_dir = 0;
|
||||||
|
const char* res_var = 0;
|
||||||
|
|
||||||
|
bool havereturn_variable = false;
|
||||||
|
bool havesource = false;
|
||||||
|
for(size_t i=0; i < args.size(); ++i)
|
||||||
{
|
{
|
||||||
this->SetError("called with incorrect number of arguments");
|
if ( havereturn_variable )
|
||||||
|
{
|
||||||
|
res_var = args[i].c_str();
|
||||||
|
havereturn_variable = false;
|
||||||
|
}
|
||||||
|
else if ( havesource )
|
||||||
|
{
|
||||||
|
source_dir = args[i].c_str();
|
||||||
|
havesource = false;
|
||||||
|
}
|
||||||
|
else if(args[i] == "RETURN_VALUE")
|
||||||
|
{
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. RETURN_VALUE specified twice.");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
havereturn_variable = true;
|
||||||
const char* source_dir = args[0].c_str();
|
}
|
||||||
const char* res_var = args[1].c_str();
|
else if(args[i] == "SOURCE")
|
||||||
|
{
|
||||||
|
if ( source_dir )
|
||||||
|
{
|
||||||
|
this->SetError("called with incorrect number of arguments. SOURCE specified twice.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
havesource = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
cmOStringStream str;
|
||||||
|
str << "called with incorrect number of arguments. Extra argument is: " << args[i].c_str() << ".";
|
||||||
|
this->SetError(str.str().c_str());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "CVSCommand", "CTEST_CVS_COMMAND");
|
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "CVSCommand", "CTEST_CVS_COMMAND");
|
||||||
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "SVNCommand", "CTEST_SVN_COMMAND");
|
m_CTest->SetCTestConfigurationFromCMakeVariable(m_Makefile, "SVNCommand", "CTEST_SVN_COMMAND");
|
||||||
|
@ -40,11 +75,17 @@ bool cmCTestUpdateCommand::InitialPass(
|
||||||
this->SetError("internal CTest error. Cannot instantiate update handler");
|
this->SetError("internal CTest error. Cannot instantiate update handler");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
if ( source_dir )
|
||||||
|
{
|
||||||
handler->SetOption("SourceDirectory", source_dir);
|
handler->SetOption("SourceDirectory", source_dir);
|
||||||
|
}
|
||||||
int res = handler->ProcessHandler();
|
int res = handler->ProcessHandler();
|
||||||
|
if ( res_var )
|
||||||
|
{
|
||||||
cmOStringStream str;
|
cmOStringStream str;
|
||||||
str << res;
|
str << res;
|
||||||
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
m_Makefile->AddDefinition(res_var, str.str().c_str());
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -66,7 +66,7 @@ public:
|
||||||
virtual const char* GetFullDocumentation()
|
virtual const char* GetFullDocumentation()
|
||||||
{
|
{
|
||||||
return
|
return
|
||||||
" CTEST_UPDATE(source res)\n"
|
" CTEST_UPDATE([SOURCE source] [RETURN_VALUE res])\n"
|
||||||
"Updates the given source directory and stores results in Update.xml. The "
|
"Updates the given source directory and stores results in Update.xml. The "
|
||||||
"second argument is a variable that will hold the number of files "
|
"second argument is a variable that will hold the number of files "
|
||||||
"modified. If there is a problem, the variable will be -1.";
|
"modified. If there is a problem, the variable will be -1.";
|
||||||
|
|
Loading…
Reference in New Issue