|
|
@@ -5,21 +5,20 @@
|
|
|
#include "cmsys/RegularExpression.hxx"
|
|
|
#include <algorithm>
|
|
|
|
|
|
+#include "cmExecutionStatus.h"
|
|
|
#include "cmMakefile.h"
|
|
|
#include "cmStateTypes.h"
|
|
|
#include "cmSystemTools.h"
|
|
|
|
|
|
-class cmExecutionStatus;
|
|
|
-
|
|
|
-// cmBuildNameCommand
|
|
|
-bool cmBuildNameCommand::InitialPass(std::vector<std::string> const& args,
|
|
|
- cmExecutionStatus&)
|
|
|
+bool cmBuildNameCommand(std::vector<std::string> const& args,
|
|
|
+ cmExecutionStatus& status)
|
|
|
{
|
|
|
if (args.empty()) {
|
|
|
- this->SetError("called with incorrect number of arguments");
|
|
|
+ status.SetError("called with incorrect number of arguments");
|
|
|
return false;
|
|
|
}
|
|
|
- const char* cacheValue = this->Makefile->GetDefinition(args[0]);
|
|
|
+ cmMakefile& mf = status.GetMakefile();
|
|
|
+ const char* cacheValue = mf.GetDefinition(args[0]);
|
|
|
if (cacheValue) {
|
|
|
// do we need to correct the value?
|
|
|
cmsys::RegularExpression reg("[()/]");
|
|
|
@@ -28,14 +27,14 @@ bool cmBuildNameCommand::InitialPass(std::vector<std::string> const& args,
|
|
|
std::replace(cv.begin(), cv.end(), '/', '_');
|
|
|
std::replace(cv.begin(), cv.end(), '(', '_');
|
|
|
std::replace(cv.begin(), cv.end(), ')', '_');
|
|
|
- this->Makefile->AddCacheDefinition(args[0], cv.c_str(), "Name of build.",
|
|
|
- cmStateEnums::STRING);
|
|
|
+ mf.AddCacheDefinition(args[0], cv.c_str(), "Name of build.",
|
|
|
+ cmStateEnums::STRING);
|
|
|
}
|
|
|
return true;
|
|
|
}
|
|
|
|
|
|
std::string buildname = "WinNT";
|
|
|
- if (this->Makefile->GetDefinition("UNIX")) {
|
|
|
+ if (mf.GetDefinition("UNIX")) {
|
|
|
buildname.clear();
|
|
|
cmSystemTools::RunSingleCommand("uname -a", &buildname, &buildname);
|
|
|
if (!buildname.empty()) {
|
|
|
@@ -47,14 +46,14 @@ bool cmBuildNameCommand::InitialPass(std::vector<std::string> const& args,
|
|
|
}
|
|
|
}
|
|
|
std::string compiler = "${CMAKE_CXX_COMPILER}";
|
|
|
- this->Makefile->ExpandVariablesInString(compiler);
|
|
|
+ mf.ExpandVariablesInString(compiler);
|
|
|
buildname += "-";
|
|
|
buildname += cmSystemTools::GetFilenameName(compiler);
|
|
|
std::replace(buildname.begin(), buildname.end(), '/', '_');
|
|
|
std::replace(buildname.begin(), buildname.end(), '(', '_');
|
|
|
std::replace(buildname.begin(), buildname.end(), ')', '_');
|
|
|
|
|
|
- this->Makefile->AddCacheDefinition(args[0], buildname.c_str(),
|
|
|
- "Name of build.", cmStateEnums::STRING);
|
|
|
+ mf.AddCacheDefinition(args[0], buildname.c_str(), "Name of build.",
|
|
|
+ cmStateEnums::STRING);
|
|
|
return true;
|
|
|
}
|