Use better KWSys SystemTools::GetEnv and HasEnv signatures
This commit is contained in:
parent
03407040d4
commit
b1f87a50b3
|
@ -1074,11 +1074,11 @@ const char* cmCPackGenerator::GetInstallPath()
|
||||||
return this->InstallPath.c_str();
|
return this->InstallPath.c_str();
|
||||||
}
|
}
|
||||||
#if defined(_WIN32) && !defined(__CYGWIN__)
|
#if defined(_WIN32) && !defined(__CYGWIN__)
|
||||||
const char* prgfiles = cmsys::SystemTools::GetEnv("ProgramFiles");
|
std::string prgfiles;
|
||||||
const char* sysDrive = cmsys::SystemTools::GetEnv("SystemDrive");
|
std::string sysDrive;
|
||||||
if (prgfiles) {
|
if (cmsys::SystemTools::GetEnv("ProgramFiles", prgfiles)) {
|
||||||
this->InstallPath = prgfiles;
|
this->InstallPath = prgfiles;
|
||||||
} else if (sysDrive) {
|
} else if (cmsys::SystemTools::GetEnv("SystemDrive", sysDrive)) {
|
||||||
this->InstallPath = sysDrive;
|
this->InstallPath = sysDrive;
|
||||||
this->InstallPath += "/Program Files";
|
this->InstallPath += "/Program Files";
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -727,10 +727,8 @@ int cmCTestCoverageHandler::HandleCoberturaCoverage(
|
||||||
// if it doesn't exist or is empty, assume the
|
// if it doesn't exist or is empty, assume the
|
||||||
// binary directory is used.
|
// binary directory is used.
|
||||||
std::string coverageXMLFile;
|
std::string coverageXMLFile;
|
||||||
const char* covDir = cmSystemTools::GetEnv("COBERTURADIR");
|
if (!cmSystemTools::GetEnv("COBERTURADIR", coverageXMLFile) ||
|
||||||
if (covDir && strlen(covDir) != 0) {
|
coverageXMLFile.empty()) {
|
||||||
coverageXMLFile = std::string(covDir);
|
|
||||||
} else {
|
|
||||||
coverageXMLFile = this->CTest->GetBinaryDir();
|
coverageXMLFile = this->CTest->GetBinaryDir();
|
||||||
}
|
}
|
||||||
// build the find file string with the directory from above
|
// build the find file string with the directory from above
|
||||||
|
@ -791,7 +789,8 @@ struct cmCTestCoverageHandlerLocale
|
||||||
{
|
{
|
||||||
cmCTestCoverageHandlerLocale()
|
cmCTestCoverageHandlerLocale()
|
||||||
{
|
{
|
||||||
if (const char* l = cmSystemTools::GetEnv("LC_ALL")) {
|
std::string l;
|
||||||
|
if (cmSystemTools::GetEnv("LC_ALL", l)) {
|
||||||
lc_all = l;
|
lc_all = l;
|
||||||
}
|
}
|
||||||
if (lc_all != "C") {
|
if (lc_all != "C") {
|
||||||
|
@ -2121,8 +2120,8 @@ int cmCTestCoverageHandler::RunBullseyeSourceSummary(
|
||||||
int cmCTestCoverageHandler::HandleBullseyeCoverage(
|
int cmCTestCoverageHandler::HandleBullseyeCoverage(
|
||||||
cmCTestCoverageHandlerContainer* cont)
|
cmCTestCoverageHandlerContainer* cont)
|
||||||
{
|
{
|
||||||
const char* covfile = cmSystemTools::GetEnv("COVFILE");
|
std::string covfile;
|
||||||
if (!covfile || strlen(covfile) == 0) {
|
if (!cmSystemTools::GetEnv("COVFILE", covfile) || covfile.empty()) {
|
||||||
cmCTestOptionalLog(this->CTest, HANDLER_VERBOSE_OUTPUT,
|
cmCTestOptionalLog(this->CTest, HANDLER_VERBOSE_OUTPUT,
|
||||||
" COVFILE environment variable not found, not running "
|
" COVFILE environment variable not found, not running "
|
||||||
" bullseye\n",
|
" bullseye\n",
|
||||||
|
|
|
@ -219,16 +219,18 @@ bool cmCTestCurl::HttpRequest(std::string const& url,
|
||||||
|
|
||||||
void cmCTestCurl::SetProxyType()
|
void cmCTestCurl::SetProxyType()
|
||||||
{
|
{
|
||||||
if (cmSystemTools::GetEnv("HTTP_PROXY")) {
|
this->HTTPProxy = "";
|
||||||
this->HTTPProxy = cmSystemTools::GetEnv("HTTP_PROXY");
|
|
||||||
if (cmSystemTools::GetEnv("HTTP_PROXY_PORT")) {
|
|
||||||
this->HTTPProxy += ":";
|
|
||||||
this->HTTPProxy += cmSystemTools::GetEnv("HTTP_PROXY_PORT");
|
|
||||||
}
|
|
||||||
if (cmSystemTools::GetEnv("HTTP_PROXY_TYPE")) {
|
|
||||||
// this is the default
|
// this is the default
|
||||||
this->HTTPProxyType = CURLPROXY_HTTP;
|
this->HTTPProxyType = CURLPROXY_HTTP;
|
||||||
std::string type = cmSystemTools::GetEnv("HTTP_PROXY_TYPE");
|
this->HTTPProxyAuth = "";
|
||||||
|
if (cmSystemTools::GetEnv("HTTP_PROXY", this->HTTPProxy)) {
|
||||||
|
std::string port;
|
||||||
|
if (cmSystemTools::GetEnv("HTTP_PROXY_PORT", port)) {
|
||||||
|
this->HTTPProxy += ":";
|
||||||
|
this->HTTPProxy += port;
|
||||||
|
}
|
||||||
|
std::string type;
|
||||||
|
if (cmSystemTools::GetEnv("HTTP_PROXY_TYPE", type)) {
|
||||||
// HTTP/SOCKS4/SOCKS5
|
// HTTP/SOCKS4/SOCKS5
|
||||||
if (type == "HTTP") {
|
if (type == "HTTP") {
|
||||||
this->HTTPProxyType = CURLPROXY_HTTP;
|
this->HTTPProxyType = CURLPROXY_HTTP;
|
||||||
|
@ -238,12 +240,11 @@ void cmCTestCurl::SetProxyType()
|
||||||
this->HTTPProxyType = CURLPROXY_SOCKS5;
|
this->HTTPProxyType = CURLPROXY_SOCKS5;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (cmSystemTools::GetEnv("HTTP_PROXY_USER")) {
|
cmSystemTools::GetEnv("HTTP_PROXY_USER", this->HTTPProxyAuth);
|
||||||
this->HTTPProxyAuth = cmSystemTools::GetEnv("HTTP_PROXY_USER");
|
std::string passwd;
|
||||||
}
|
if (cmSystemTools::GetEnv("HTTP_PROXY_PASSWD", passwd)) {
|
||||||
if (cmSystemTools::GetEnv("HTTP_PROXY_PASSWD")) {
|
|
||||||
this->HTTPProxyAuth += ":";
|
this->HTTPProxyAuth += ":";
|
||||||
this->HTTPProxyAuth += cmSystemTools::GetEnv("HTTP_PROXY_PASSWD");
|
this->HTTPProxyAuth += passwd;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -261,12 +261,14 @@ void cmCTestMultiProcessHandler::StartNextTests()
|
||||||
allTestsFailedTestLoadCheck = true;
|
allTestsFailedTestLoadCheck = true;
|
||||||
|
|
||||||
// Check for a fake load average value used in testing.
|
// Check for a fake load average value used in testing.
|
||||||
if (const char* fake_load_value =
|
std::string fake_load_value;
|
||||||
cmSystemTools::GetEnv("__CTEST_FAKE_LOAD_AVERAGE_FOR_TESTING")) {
|
if (cmSystemTools::GetEnv("__CTEST_FAKE_LOAD_AVERAGE_FOR_TESTING",
|
||||||
|
fake_load_value)) {
|
||||||
usedFakeLoadForTesting = true;
|
usedFakeLoadForTesting = true;
|
||||||
if (!cmSystemTools::StringToULong(fake_load_value, &systemLoad)) {
|
if (!cmSystemTools::StringToULong(fake_load_value.c_str(),
|
||||||
|
&systemLoad)) {
|
||||||
cmSystemTools::Error("Failed to parse fake load value: ",
|
cmSystemTools::Error("Failed to parse fake load value: ",
|
||||||
fake_load_value);
|
fake_load_value.c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// If it's not set, look up the true load average.
|
// If it's not set, look up the true load average.
|
||||||
|
|
|
@ -36,8 +36,8 @@ bool cmBuildCommand::MainSignature(std::vector<std::string> const& args)
|
||||||
const char* variable = args[0].c_str();
|
const char* variable = args[0].c_str();
|
||||||
|
|
||||||
// Parse remaining arguments.
|
// Parse remaining arguments.
|
||||||
const char* configuration = CM_NULLPTR;
|
std::string configuration;
|
||||||
const char* project_name = CM_NULLPTR;
|
std::string project_name;
|
||||||
std::string target;
|
std::string target;
|
||||||
enum Doing
|
enum Doing
|
||||||
{
|
{
|
||||||
|
@ -56,10 +56,10 @@ bool cmBuildCommand::MainSignature(std::vector<std::string> const& args)
|
||||||
doing = DoingTarget;
|
doing = DoingTarget;
|
||||||
} else if (doing == DoingConfiguration) {
|
} else if (doing == DoingConfiguration) {
|
||||||
doing = DoingNone;
|
doing = DoingNone;
|
||||||
configuration = args[i].c_str();
|
configuration = args[i];
|
||||||
} else if (doing == DoingProjectName) {
|
} else if (doing == DoingProjectName) {
|
||||||
doing = DoingNone;
|
doing = DoingNone;
|
||||||
project_name = args[i].c_str();
|
project_name = args[i];
|
||||||
} else if (doing == DoingTarget) {
|
} else if (doing == DoingTarget) {
|
||||||
doing = DoingNone;
|
doing = DoingNone;
|
||||||
target = args[i];
|
target = args[i];
|
||||||
|
@ -76,14 +76,14 @@ bool cmBuildCommand::MainSignature(std::vector<std::string> const& args)
|
||||||
// so we put this code here to end up with the same default configuration
|
// so we put this code here to end up with the same default configuration
|
||||||
// as the original 2-arg build_command signature:
|
// as the original 2-arg build_command signature:
|
||||||
//
|
//
|
||||||
if (!configuration || !*configuration) {
|
if (configuration.empty()) {
|
||||||
configuration = getenv("CMAKE_CONFIG_TYPE");
|
cmSystemTools::GetEnv("CMAKE_CONFIG_TYPE", configuration);
|
||||||
}
|
}
|
||||||
if (!configuration || !*configuration) {
|
if (configuration.empty()) {
|
||||||
configuration = "Release";
|
configuration = "Release";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (project_name && *project_name) {
|
if (!project_name.empty()) {
|
||||||
this->Makefile->IssueMessage(
|
this->Makefile->IssueMessage(
|
||||||
cmake::AUTHOR_WARNING,
|
cmake::AUTHOR_WARNING,
|
||||||
"Ignoring PROJECT_NAME option because it has no effect.");
|
"Ignoring PROJECT_NAME option because it has no effect.");
|
||||||
|
@ -91,7 +91,8 @@ bool cmBuildCommand::MainSignature(std::vector<std::string> const& args)
|
||||||
|
|
||||||
std::string makecommand =
|
std::string makecommand =
|
||||||
this->Makefile->GetGlobalGenerator()->GenerateCMakeBuildCommand(
|
this->Makefile->GetGlobalGenerator()->GenerateCMakeBuildCommand(
|
||||||
target, configuration, "", this->Makefile->IgnoreErrorsCMP0061());
|
target, configuration.c_str(), "",
|
||||||
|
this->Makefile->IgnoreErrorsCMP0061());
|
||||||
|
|
||||||
this->Makefile->AddDefinition(variable, makecommand.c_str());
|
this->Makefile->AddDefinition(variable, makecommand.c_str());
|
||||||
|
|
||||||
|
@ -108,10 +109,10 @@ bool cmBuildCommand::TwoArgsSignature(std::vector<std::string> const& args)
|
||||||
const char* define = args[0].c_str();
|
const char* define = args[0].c_str();
|
||||||
const char* cacheValue = this->Makefile->GetDefinition(define);
|
const char* cacheValue = this->Makefile->GetDefinition(define);
|
||||||
|
|
||||||
std::string configType = "Release";
|
std::string configType;
|
||||||
const char* cfg = getenv("CMAKE_CONFIG_TYPE");
|
if (!cmSystemTools::GetEnv("CMAKE_CONFIG_TYPE", configType) ||
|
||||||
if (cfg && *cfg) {
|
configType.empty()) {
|
||||||
configType = cfg;
|
configType = "Release";
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string makecommand =
|
std::string makecommand =
|
||||||
|
|
|
@ -31,8 +31,9 @@ cmCLocaleEnvironmentScope::cmCLocaleEnvironmentScope()
|
||||||
|
|
||||||
std::string cmCLocaleEnvironmentScope::GetEnv(std::string const& key)
|
std::string cmCLocaleEnvironmentScope::GetEnv(std::string const& key)
|
||||||
{
|
{
|
||||||
const char* value = cmSystemTools::GetEnv(key);
|
std::string value;
|
||||||
return value ? value : std::string();
|
cmSystemTools::GetEnv(key, value);
|
||||||
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmCLocaleEnvironmentScope::SetEnv(std::string const& key,
|
void cmCLocaleEnvironmentScope::SetEnv(std::string const& key,
|
||||||
|
|
|
@ -298,9 +298,10 @@ cmCTest::cmCTest()
|
||||||
this->ComputedCompressMemCheckOutput = false;
|
this->ComputedCompressMemCheckOutput = false;
|
||||||
this->RepeatTests = 1; // default to run each test once
|
this->RepeatTests = 1; // default to run each test once
|
||||||
this->RepeatUntilFail = false;
|
this->RepeatUntilFail = false;
|
||||||
if (const char* outOnFail =
|
std::string outOnFail;
|
||||||
cmSystemTools::GetEnv("CTEST_OUTPUT_ON_FAILURE")) {
|
if (cmSystemTools::GetEnv("CTEST_OUTPUT_ON_FAILURE", outOnFail)) {
|
||||||
this->OutputTestOutputOnTestFailure = !cmSystemTools::IsOff(outOnFail);
|
this->OutputTestOutputOnTestFailure =
|
||||||
|
!cmSystemTools::IsOff(outOnFail.c_str());
|
||||||
}
|
}
|
||||||
this->InitStreams();
|
this->InitStreams();
|
||||||
|
|
||||||
|
@ -2091,8 +2092,9 @@ int cmCTest::Run(std::vector<std::string>& args, std::string* output)
|
||||||
|
|
||||||
// handle CTEST_PARALLEL_LEVEL environment variable
|
// handle CTEST_PARALLEL_LEVEL environment variable
|
||||||
if (!this->ParallelLevelSetInCli) {
|
if (!this->ParallelLevelSetInCli) {
|
||||||
if (const char* parallel = cmSystemTools::GetEnv("CTEST_PARALLEL_LEVEL")) {
|
std::string parallel;
|
||||||
int plevel = atoi(parallel);
|
if (cmSystemTools::GetEnv("CTEST_PARALLEL_LEVEL", parallel)) {
|
||||||
|
int plevel = atoi(parallel.c_str());
|
||||||
this->SetParallelLevel(plevel);
|
this->SetParallelLevel(plevel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,12 +71,12 @@ char* cmCommandArgumentParserHelper::ExpandSpecialVariable(const char* key,
|
||||||
return this->EmptyVariable;
|
return this->EmptyVariable;
|
||||||
}
|
}
|
||||||
if (strcmp(key, "ENV") == 0) {
|
if (strcmp(key, "ENV") == 0) {
|
||||||
char* ptr = getenv(var);
|
std::string str;
|
||||||
if (ptr) {
|
if (cmSystemTools::GetEnv(var, str)) {
|
||||||
if (this->EscapeQuotes) {
|
if (this->EscapeQuotes) {
|
||||||
return this->AddString(cmSystemTools::EscapeQuotes(ptr));
|
return this->AddString(cmSystemTools::EscapeQuotes(str.c_str()));
|
||||||
} else {
|
} else {
|
||||||
return ptr;
|
return this->AddString(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return this->EmptyVariable;
|
return this->EmptyVariable;
|
||||||
|
|
|
@ -486,7 +486,7 @@ bool cmConditionEvaluator::HandleLevel1(cmArgumentList& newArgs, std::string&,
|
||||||
if (argP1len > 4 && argP1->GetValue().substr(0, 4) == "ENV{" &&
|
if (argP1len > 4 && argP1->GetValue().substr(0, 4) == "ENV{" &&
|
||||||
argP1->GetValue().operator[](argP1len - 1) == '}') {
|
argP1->GetValue().operator[](argP1len - 1) == '}') {
|
||||||
std::string env = argP1->GetValue().substr(4, argP1len - 5);
|
std::string env = argP1->GetValue().substr(4, argP1len - 5);
|
||||||
bdef = cmSystemTools::GetEnv(env.c_str()) ? true : false;
|
bdef = cmSystemTools::HasEnv(env.c_str());
|
||||||
} else {
|
} else {
|
||||||
bdef = this->Makefile.IsDefinitionSet(argP1->GetValue());
|
bdef = this->Makefile.IsDefinitionSet(argP1->GetValue());
|
||||||
}
|
}
|
||||||
|
|
|
@ -327,11 +327,10 @@ void cmExportCommand::StorePackageRegistryDir(std::string const& package,
|
||||||
fname += "/cmake/packages/";
|
fname += "/cmake/packages/";
|
||||||
fname += package;
|
fname += package;
|
||||||
#else
|
#else
|
||||||
const char* home = cmSystemTools::GetEnv("HOME");
|
std::string fname;
|
||||||
if (!home) {
|
if (!cmSystemTools::GetEnv("HOME", fname)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
std::string fname = home;
|
|
||||||
cmSystemTools::ConvertToUnixSlashes(fname);
|
cmSystemTools::ConvertToUnixSlashes(fname);
|
||||||
fname += "/.cmake/packages/";
|
fname += "/.cmake/packages/";
|
||||||
fname += package;
|
fname += package;
|
||||||
|
|
|
@ -208,7 +208,8 @@ void cmExtraEclipseCDT4Generator::AddEnvVar(std::ostream& out,
|
||||||
// get the variables from the environment and from the cache and then
|
// get the variables from the environment and from the cache and then
|
||||||
// figure out which one to use:
|
// figure out which one to use:
|
||||||
|
|
||||||
const char* envVarValue = getenv(envVar);
|
std::string envVarValue;
|
||||||
|
const bool envVarSet = cmSystemTools::GetEnv(envVar, envVarValue);
|
||||||
|
|
||||||
std::string cacheEntryName = "CMAKE_ECLIPSE_ENVVAR_";
|
std::string cacheEntryName = "CMAKE_ECLIPSE_ENVVAR_";
|
||||||
cacheEntryName += envVar;
|
cacheEntryName += envVar;
|
||||||
|
@ -217,17 +218,17 @@ void cmExtraEclipseCDT4Generator::AddEnvVar(std::ostream& out,
|
||||||
|
|
||||||
// now we have both, decide which one to use
|
// now we have both, decide which one to use
|
||||||
std::string valueToUse;
|
std::string valueToUse;
|
||||||
if (envVarValue == CM_NULLPTR && cacheValue == CM_NULLPTR) {
|
if (!envVarSet && cacheValue == CM_NULLPTR) {
|
||||||
// nothing known, do nothing
|
// nothing known, do nothing
|
||||||
valueToUse = "";
|
valueToUse = "";
|
||||||
} else if (envVarValue != CM_NULLPTR && cacheValue == CM_NULLPTR) {
|
} else if (envVarSet && cacheValue == CM_NULLPTR) {
|
||||||
// The variable is in the env, but not in the cache. Use it and put it
|
// The variable is in the env, but not in the cache. Use it and put it
|
||||||
// in the cache
|
// in the cache
|
||||||
valueToUse = envVarValue;
|
valueToUse = envVarValue;
|
||||||
mf->AddCacheDefinition(cacheEntryName, valueToUse.c_str(),
|
mf->AddCacheDefinition(cacheEntryName, valueToUse.c_str(),
|
||||||
cacheEntryName.c_str(), cmState::STRING, true);
|
cacheEntryName.c_str(), cmState::STRING, true);
|
||||||
mf->GetCMakeInstance()->SaveCache(lg->GetBinaryDirectory());
|
mf->GetCMakeInstance()->SaveCache(lg->GetBinaryDirectory());
|
||||||
} else if (envVarValue == CM_NULLPTR && cacheValue != CM_NULLPTR) {
|
} else if (!envVarSet && cacheValue != CM_NULLPTR) {
|
||||||
// It is already in the cache, but not in the env, so use it from the cache
|
// It is already in the cache, but not in the env, so use it from the cache
|
||||||
valueToUse = cacheValue;
|
valueToUse = cacheValue;
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -1609,8 +1609,10 @@ struct cmFileInstaller : public cmFileCopier
|
||||||
// Installation does not use source permissions by default.
|
// Installation does not use source permissions by default.
|
||||||
this->UseSourcePermissions = false;
|
this->UseSourcePermissions = false;
|
||||||
// Check whether to copy files always or only if they have changed.
|
// Check whether to copy files always or only if they have changed.
|
||||||
this->Always =
|
std::string install_always;
|
||||||
cmSystemTools::IsOn(cmSystemTools::GetEnv("CMAKE_INSTALL_ALWAYS"));
|
if (cmSystemTools::GetEnv("CMAKE_INSTALL_ALWAYS", install_always)) {
|
||||||
|
this->Always = cmSystemTools::IsOn(install_always.c_str());
|
||||||
|
}
|
||||||
// Get the current manifest.
|
// Get the current manifest.
|
||||||
this->Manifest =
|
this->Manifest =
|
||||||
this->Makefile->GetSafeDefinition("CMAKE_INSTALL_MANIFEST_FILES");
|
this->Makefile->GetSafeDefinition("CMAKE_INSTALL_MANIFEST_FILES");
|
||||||
|
@ -1869,9 +1871,8 @@ bool cmFileInstaller::HandleInstallDestination()
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* destdir = cmSystemTools::GetEnv("DESTDIR");
|
std::string sdestdir;
|
||||||
if (destdir && *destdir) {
|
if (cmSystemTools::GetEnv("DESTDIR", sdestdir) && !sdestdir.empty()) {
|
||||||
std::string sdestdir = destdir;
|
|
||||||
cmSystemTools::ConvertToUnixSlashes(sdestdir);
|
cmSystemTools::ConvertToUnixSlashes(sdestdir);
|
||||||
char ch1 = destination[0];
|
char ch1 = destination[0];
|
||||||
char ch2 = destination[1];
|
char ch2 = destination[1];
|
||||||
|
|
|
@ -1077,8 +1077,8 @@ void cmFindPackageCommand::FillPrefixesUserRegistry()
|
||||||
this->LabeledPaths[PathLabel::UserRegistry]);
|
this->LabeledPaths[PathLabel::UserRegistry]);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if (const char* home = cmSystemTools::GetEnv("HOME")) {
|
std::string dir;
|
||||||
std::string dir = home;
|
if (cmSystemTools::GetEnv("HOME", dir)) {
|
||||||
dir += "/.cmake/packages/";
|
dir += "/.cmake/packages/";
|
||||||
dir += this->Name;
|
dir += this->Name;
|
||||||
this->LoadPackageRegistryDir(dir,
|
this->LoadPackageRegistryDir(dir,
|
||||||
|
|
|
@ -122,9 +122,9 @@ void cmGlobalVisualStudio7Generator::EnableLanguage(
|
||||||
// does not use the environment it is run in, and this allows
|
// does not use the environment it is run in, and this allows
|
||||||
// for running commands and using dll's that the IDE environment
|
// for running commands and using dll's that the IDE environment
|
||||||
// does not know about.
|
// does not know about.
|
||||||
const char* extraPath = cmSystemTools::GetEnv("CMAKE_MSVCIDE_RUN_PATH");
|
std::string extraPath;
|
||||||
if (extraPath) {
|
if (cmSystemTools::GetEnv("CMAKE_MSVCIDE_RUN_PATH", extraPath)) {
|
||||||
mf->AddCacheDefinition("CMAKE_MSVCIDE_RUN_PATH", extraPath,
|
mf->AddCacheDefinition("CMAKE_MSVCIDE_RUN_PATH", extraPath.c_str(),
|
||||||
"Saved environment variable CMAKE_MSVCIDE_RUN_PATH",
|
"Saved environment variable CMAKE_MSVCIDE_RUN_PATH",
|
||||||
cmState::STATIC);
|
cmState::STATIC);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2572,6 +2572,7 @@ cmake::MessageType cmMakefile::ExpandVariablesInStringNew(
|
||||||
std::string const& lookup = result.substr(var.loc);
|
std::string const& lookup = result.substr(var.loc);
|
||||||
const char* value = CM_NULLPTR;
|
const char* value = CM_NULLPTR;
|
||||||
std::string varresult;
|
std::string varresult;
|
||||||
|
std::string svalue;
|
||||||
static const std::string lineVar = "CMAKE_CURRENT_LIST_LINE";
|
static const std::string lineVar = "CMAKE_CURRENT_LIST_LINE";
|
||||||
switch (var.domain) {
|
switch (var.domain) {
|
||||||
case NORMAL:
|
case NORMAL:
|
||||||
|
@ -2584,7 +2585,9 @@ cmake::MessageType cmMakefile::ExpandVariablesInStringNew(
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case ENVIRONMENT:
|
case ENVIRONMENT:
|
||||||
value = cmSystemTools::GetEnv(lookup.c_str());
|
if (cmSystemTools::GetEnv(lookup, svalue)) {
|
||||||
|
value = svalue.c_str();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case CACHE:
|
case CACHE:
|
||||||
value = state->GetCacheEntryValue(lookup);
|
value = state->GetCacheEntryValue(lookup);
|
||||||
|
|
|
@ -741,5 +741,5 @@ bool cmNinjaTargetGenerator::ForceResponseFile()
|
||||||
{
|
{
|
||||||
static std::string const forceRspFile = "CMAKE_NINJA_FORCE_RESPONSE_FILE";
|
static std::string const forceRspFile = "CMAKE_NINJA_FORCE_RESPONSE_FILE";
|
||||||
return (this->GetMakefile()->IsDefinitionSet(forceRspFile) ||
|
return (this->GetMakefile()->IsDefinitionSet(forceRspFile) ||
|
||||||
cmSystemTools::GetEnv(forceRspFile) != CM_NULLPTR);
|
cmSystemTools::HasEnv(forceRspFile));
|
||||||
}
|
}
|
||||||
|
|
|
@ -88,7 +88,7 @@ static std::string extractSubDir(const std::string& absPath,
|
||||||
}
|
}
|
||||||
|
|
||||||
cmQtAutoGenerators::cmQtAutoGenerators()
|
cmQtAutoGenerators::cmQtAutoGenerators()
|
||||||
: Verbose(cmsys::SystemTools::GetEnv("VERBOSE") != CM_NULLPTR)
|
: Verbose(cmsys::SystemTools::HasEnv("VERBOSE"))
|
||||||
, ColorOutput(true)
|
, ColorOutput(true)
|
||||||
, RunMocFailed(false)
|
, RunMocFailed(false)
|
||||||
, RunUicFailed(false)
|
, RunUicFailed(false)
|
||||||
|
|
|
@ -31,13 +31,14 @@ bool cmSetCommand::InitialPass(std::vector<std::string> const& args,
|
||||||
putEnvArg += "=";
|
putEnvArg += "=";
|
||||||
|
|
||||||
// what is the current value if any
|
// what is the current value if any
|
||||||
const char* currValue = getenv(varName);
|
std::string currValue;
|
||||||
|
const bool currValueSet = cmSystemTools::GetEnv(varName, currValue);
|
||||||
delete[] varName;
|
delete[] varName;
|
||||||
|
|
||||||
// will it be set to something, then set it
|
// will it be set to something, then set it
|
||||||
if (args.size() > 1 && !args[1].empty()) {
|
if (args.size() > 1 && !args[1].empty()) {
|
||||||
// but only if it is different from current value
|
// but only if it is different from current value
|
||||||
if (!currValue || strcmp(currValue, args[1].c_str())) {
|
if (!currValueSet || currValue != args[1]) {
|
||||||
putEnvArg += args[1];
|
putEnvArg += args[1];
|
||||||
cmSystemTools::PutEnv(putEnvArg);
|
cmSystemTools::PutEnv(putEnvArg);
|
||||||
}
|
}
|
||||||
|
@ -45,7 +46,7 @@ bool cmSetCommand::InitialPass(std::vector<std::string> const& args,
|
||||||
}
|
}
|
||||||
|
|
||||||
// if it will be cleared, then clear it if it isn't already clear
|
// if it will be cleared, then clear it if it isn't already clear
|
||||||
if (currValue) {
|
if (currValueSet) {
|
||||||
cmSystemTools::PutEnv(putEnvArg);
|
cmSystemTools::PutEnv(putEnvArg);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -1286,8 +1286,9 @@ void cmState::Snapshot::SetDefaultDefinitions()
|
||||||
this->SetDefinition("CMAKE_HOST_UNIX", "1");
|
this->SetDefinition("CMAKE_HOST_UNIX", "1");
|
||||||
#endif
|
#endif
|
||||||
#if defined(__CYGWIN__)
|
#if defined(__CYGWIN__)
|
||||||
if (cmSystemTools::IsOn(
|
std::string legacy;
|
||||||
cmSystemTools::GetEnv("CMAKE_LEGACY_CYGWIN_WIN32"))) {
|
if (cmSystemTools::GetEnv("CMAKE_LEGACY_CYGWIN_WIN32", legacy) &&
|
||||||
|
cmSystemTools::IsOn(legacy.c_str())) {
|
||||||
this->SetDefinition("WIN32", "1");
|
this->SetDefinition("WIN32", "1");
|
||||||
this->SetDefinition("CMAKE_HOST_WIN32", "1");
|
this->SetDefinition("CMAKE_HOST_WIN32", "1");
|
||||||
}
|
}
|
||||||
|
|
|
@ -2069,9 +2069,9 @@ void cmSystemTools::MakefileColorEcho(int color, const char* message,
|
||||||
// However, we can test for some situations when the answer is most
|
// However, we can test for some situations when the answer is most
|
||||||
// likely no.
|
// likely no.
|
||||||
int assumeTTY = cmsysTerminal_Color_AssumeTTY;
|
int assumeTTY = cmsysTerminal_Color_AssumeTTY;
|
||||||
if (cmSystemTools::GetEnv("DART_TEST_FROM_DART") ||
|
if (cmSystemTools::HasEnv("DART_TEST_FROM_DART") ||
|
||||||
cmSystemTools::GetEnv("DASHBOARD_TEST_FROM_CTEST") ||
|
cmSystemTools::HasEnv("DASHBOARD_TEST_FROM_CTEST") ||
|
||||||
cmSystemTools::GetEnv("CTEST_INTERACTIVE_DEBUG_MODE")) {
|
cmSystemTools::HasEnv("CTEST_INTERACTIVE_DEBUG_MODE")) {
|
||||||
// Avoid printing color escapes during dashboard builds.
|
// Avoid printing color escapes during dashboard builds.
|
||||||
assumeTTY = 0;
|
assumeTTY = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -93,10 +93,9 @@ time_t cmTimestamp::CreateUtcTimeTFromTm(struct tm& tm) const
|
||||||
#else
|
#else
|
||||||
// From Linux timegm() manpage.
|
// From Linux timegm() manpage.
|
||||||
|
|
||||||
std::string tz_old = "TZ=";
|
std::string tz_old = "";
|
||||||
if (const char* tz = cmSystemTools::GetEnv("TZ")) {
|
cmSystemTools::GetEnv("TZ", tz_old);
|
||||||
tz_old += tz;
|
tz_old = "TZ=" + tz_old;
|
||||||
}
|
|
||||||
|
|
||||||
// The standard says that "TZ=" or "TZ=[UNRECOGNIZED_TZ]" means UTC.
|
// The standard says that "TZ=" or "TZ=[UNRECOGNIZED_TZ]" means UTC.
|
||||||
// It seems that "TZ=" does NOT work, at least under Windows
|
// It seems that "TZ=" does NOT work, at least under Windows
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
/*============================================================================
|
||||||
|
CMake - Cross Platform Makefile Generator
|
||||||
|
Copyright 2000-2016 Kitware, Inc., Insight Software Consortium
|
||||||
|
|
||||||
|
Distributed under the OSI-approved BSD License (the "License");
|
||||||
|
see accompanying file Copyright.txt for details.
|
||||||
|
|
||||||
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
||||||
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
See the License for more information.
|
||||||
|
============================================================================*/
|
||||||
|
#ifndef cmUtils_hxx
|
||||||
|
#define cmUtils_hxx
|
||||||
|
|
||||||
|
#include <cmsys/SystemTools.hxx>
|
||||||
|
|
||||||
|
// Use the make system's VERBOSE environment variable to enable
|
||||||
|
// verbose output. This can be skipped by also setting CMAKE_NO_VERBOSE
|
||||||
|
// (which is set by the Eclipse and KDevelop generators).
|
||||||
|
inline bool isCMakeVerbose()
|
||||||
|
{
|
||||||
|
return (cmSystemTools::HasEnv("VERBOSE") &&
|
||||||
|
!cmSystemTools::HasEnv("CMAKE_NO_VERBOSE"));
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
|
@ -22,6 +22,7 @@
|
||||||
#include "cmSourceFile.h"
|
#include "cmSourceFile.h"
|
||||||
#include "cmState.h"
|
#include "cmState.h"
|
||||||
#include "cmTest.h"
|
#include "cmTest.h"
|
||||||
|
#include "cmUtils.hxx"
|
||||||
|
|
||||||
#if defined(CMAKE_BUILD_WITH_CMAKE)
|
#if defined(CMAKE_BUILD_WITH_CMAKE)
|
||||||
#include "cmGraphVizWriter.h"
|
#include "cmGraphVizWriter.h"
|
||||||
|
@ -957,16 +958,10 @@ void cmake::SetGlobalGenerator(cmGlobalGenerator* gg)
|
||||||
cmSystemTools::SetForceUnixPaths(this->GlobalGenerator->GetForceUnixPaths());
|
cmSystemTools::SetForceUnixPaths(this->GlobalGenerator->GetForceUnixPaths());
|
||||||
|
|
||||||
// Save the environment variables CXX and CC
|
// Save the environment variables CXX and CC
|
||||||
const char* cxx = getenv("CXX");
|
if (!cmSystemTools::GetEnv("CXX", this->CXXEnvironment)) {
|
||||||
const char* cc = getenv("CC");
|
|
||||||
if (cxx) {
|
|
||||||
this->CXXEnvironment = cxx;
|
|
||||||
} else {
|
|
||||||
this->CXXEnvironment = "";
|
this->CXXEnvironment = "";
|
||||||
}
|
}
|
||||||
if (cc) {
|
if (!cmSystemTools::GetEnv("CC", this->CCEnvironment)) {
|
||||||
this->CCEnvironment = cc;
|
|
||||||
} else {
|
|
||||||
this->CCEnvironment = "";
|
this->CCEnvironment = "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1431,7 +1426,7 @@ int cmake::Run(const std::vector<std::string>& args, bool noconfigure)
|
||||||
// should fail (if "-i" is an option). We cannot simply test
|
// should fail (if "-i" is an option). We cannot simply test
|
||||||
// whether "-i" is given and remove it because some make programs
|
// whether "-i" is given and remove it because some make programs
|
||||||
// encode the MAKEFLAGS variable in a strange way.
|
// encode the MAKEFLAGS variable in a strange way.
|
||||||
if (getenv("MAKEFLAGS")) {
|
if (cmSystemTools::HasEnv("MAKEFLAGS")) {
|
||||||
cmSystemTools::PutEnv("MAKEFLAGS=");
|
cmSystemTools::PutEnv("MAKEFLAGS=");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1706,12 +1701,8 @@ void cmake::UpdateConversionPathTable()
|
||||||
|
|
||||||
int cmake::CheckBuildSystem()
|
int cmake::CheckBuildSystem()
|
||||||
{
|
{
|
||||||
// We do not need to rerun CMake. Check dependency integrity. Use
|
// We do not need to rerun CMake. Check dependency integrity.
|
||||||
// the make system's VERBOSE environment variable to enable verbose
|
const bool verbose = isCMakeVerbose();
|
||||||
// output. This can be skipped by setting CMAKE_NO_VERBOSE (which is set
|
|
||||||
// by the Eclipse and KDevelop generators).
|
|
||||||
bool verbose = ((cmSystemTools::GetEnv("VERBOSE") != CM_NULLPTR) &&
|
|
||||||
(cmSystemTools::GetEnv("CMAKE_NO_VERBOSE") == CM_NULLPTR));
|
|
||||||
|
|
||||||
// This method will check the integrity of the build system if the
|
// This method will check the integrity of the build system if the
|
||||||
// option was given on the command line. It reads the given file to
|
// option was given on the command line. It reads the given file to
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
#include "cmLocalGenerator.h"
|
#include "cmLocalGenerator.h"
|
||||||
#include "cmMakefile.h"
|
#include "cmMakefile.h"
|
||||||
#include "cmQtAutoGenerators.h"
|
#include "cmQtAutoGenerators.h"
|
||||||
|
#include "cmUtils.hxx"
|
||||||
#include "cmVersion.h"
|
#include "cmVersion.h"
|
||||||
|
|
||||||
#if defined(CMAKE_BUILD_WITH_CMAKE)
|
#if defined(CMAKE_BUILD_WITH_CMAKE)
|
||||||
|
@ -673,12 +674,7 @@ int cmcmd::ExecuteCMakeCommand(std::vector<std::string>& args)
|
||||||
|
|
||||||
// Internal CMake dependency scanning support.
|
// Internal CMake dependency scanning support.
|
||||||
else if (args[1] == "cmake_depends" && args.size() >= 6) {
|
else if (args[1] == "cmake_depends" && args.size() >= 6) {
|
||||||
// Use the make system's VERBOSE environment variable to enable
|
const bool verbose = isCMakeVerbose();
|
||||||
// verbose output. This can be skipped by also setting CMAKE_NO_VERBOSE
|
|
||||||
// (which is set by the Eclipse and KDevelop generators).
|
|
||||||
bool verbose =
|
|
||||||
((cmSystemTools::GetEnv("VERBOSE") != CM_NULLPTR) &&
|
|
||||||
(cmSystemTools::GetEnv("CMAKE_NO_VERBOSE") == CM_NULLPTR));
|
|
||||||
|
|
||||||
// Create a cmake object instance to process dependencies.
|
// Create a cmake object instance to process dependencies.
|
||||||
cmake cm;
|
cmake cm;
|
||||||
|
@ -876,9 +872,9 @@ int cmcmd::ExecuteCMakeCommand(std::vector<std::string>& args)
|
||||||
// 1/10th of a second after the untar. If CMAKE_UNTAR_DELAY
|
// 1/10th of a second after the untar. If CMAKE_UNTAR_DELAY
|
||||||
// is set in the env, its value will be used instead of 100.
|
// is set in the env, its value will be used instead of 100.
|
||||||
int delay = 100;
|
int delay = 100;
|
||||||
const char* delayVar = cmSystemTools::GetEnv("CMAKE_UNTAR_DELAY");
|
std::string delayVar;
|
||||||
if (delayVar) {
|
if (cmSystemTools::GetEnv("CMAKE_UNTAR_DELAY", delayVar)) {
|
||||||
delay = atoi(delayVar);
|
delay = atoi(delayVar.c_str());
|
||||||
}
|
}
|
||||||
if (delay) {
|
if (delay) {
|
||||||
cmSystemTools::Delay(delay);
|
cmSystemTools::Delay(delay);
|
||||||
|
@ -1230,7 +1226,7 @@ int cmcmd::VisualStudioLink(std::vector<std::string>& args, int type)
|
||||||
if (args.size() < 2) {
|
if (args.size() < 2) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
bool verbose = cmSystemTools::GetEnv("VERBOSE") != CM_NULLPTR;
|
const bool verbose = cmSystemTools::HasEnv("VERBOSE");
|
||||||
std::vector<std::string> expandedArgs;
|
std::vector<std::string> expandedArgs;
|
||||||
for (std::vector<std::string>::iterator i = args.begin(); i != args.end();
|
for (std::vector<std::string>::iterator i = args.begin(); i != args.end();
|
||||||
++i) {
|
++i) {
|
||||||
|
|
Loading…
Reference in New Issue