Use better KWSys SystemTools::GetEnv and HasEnv signatures

This commit is contained in:
Dāvis Mosāns 2016-07-08 00:54:05 +03:00 committed by Brad King
parent 03407040d4
commit b1f87a50b3
24 changed files with 134 additions and 110 deletions

View File

@ -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 {

View File

@ -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",

View File

@ -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;
} }
} }
} }

View File

@ -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.

View File

@ -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 =

View File

@ -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,

View File

@ -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);
} }
} }

View File

@ -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;

View File

@ -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());
} }

View File

@ -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;

View File

@ -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 {

View File

@ -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];

View File

@ -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,

View File

@ -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);
} }

View File

@ -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);

View File

@ -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));
} }

View File

@ -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)

View File

@ -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;

View File

@ -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");
} }

View File

@ -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;
} }

View File

@ -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

26
Source/cmUtils.hxx Normal file
View File

@ -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

View File

@ -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

View File

@ -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) {