Răsfoiți Sursa

Merge topic 'getsafedef-stdstring'

f4ff60a803 cmMakefile: Make GetSafeDefinition return std::string const&

Acked-by: Kitware Robot <[email protected]>
Merge-request: !2350
Brad King 7 ani în urmă
părinte
comite
a8f628c0a4

+ 2 - 2
Source/CTest/cmCTestHandlerCommand.cxx

@@ -151,9 +151,9 @@ bool cmCTestHandlerCommand::InitialPass(std::vector<std::string> const& args,
       cmSystemTools::CollapseFullPath(this->Values[ct_BUILD]).c_str(),
       cmSystemTools::CollapseFullPath(this->Values[ct_BUILD]).c_str(),
       this->Quiet);
       this->Quiet);
   } else {
   } else {
-    const char* bdir =
+    std::string const& bdir =
       this->Makefile->GetSafeDefinition("CTEST_BINARY_DIRECTORY");
       this->Makefile->GetSafeDefinition("CTEST_BINARY_DIRECTORY");
-    if (bdir) {
+    if (!bdir.empty()) {
       this->CTest->SetCTestConfiguration(
       this->CTest->SetCTestConfiguration(
         "BuildDirectory", cmSystemTools::CollapseFullPath(bdir).c_str(),
         "BuildDirectory", cmSystemTools::CollapseFullPath(bdir).c_str(),
         this->Quiet);
         this->Quiet);

+ 1 - 1
Source/cmComputeLinkInformation.cxx

@@ -1725,7 +1725,7 @@ void cmComputeLinkInformation::GetRPath(std::vector<std::string>& runtimeDirs,
     }
     }
     const char* stagePath =
     const char* stagePath =
       this->Makefile->GetDefinition("CMAKE_STAGING_PREFIX");
       this->Makefile->GetDefinition("CMAKE_STAGING_PREFIX");
-    const char* installPrefix =
+    std::string const& installPrefix =
       this->Makefile->GetSafeDefinition("CMAKE_INSTALL_PREFIX");
       this->Makefile->GetSafeDefinition("CMAKE_INSTALL_PREFIX");
     cmSystemTools::ConvertToUnixSlashes(rootPath);
     cmSystemTools::ConvertToUnixSlashes(rootPath);
     std::vector<std::string> const& rdirs = this->GetRuntimeSearchPath();
     std::vector<std::string> const& rdirs = this->GetRuntimeSearchPath();

+ 1 - 1
Source/cmDepends.cxx

@@ -36,7 +36,7 @@ bool cmDepends::Write(std::ostream& makeDepends, std::ostream& internalDepends)
   std::string srcLang = "CMAKE_DEPENDS_CHECK_";
   std::string srcLang = "CMAKE_DEPENDS_CHECK_";
   srcLang += this->Language;
   srcLang += this->Language;
   cmMakefile* mf = this->LocalGenerator->GetMakefile();
   cmMakefile* mf = this->LocalGenerator->GetMakefile();
-  const char* srcStr = mf->GetSafeDefinition(srcLang);
+  std::string const& srcStr = mf->GetSafeDefinition(srcLang);
   std::vector<std::string> pairs;
   std::vector<std::string> pairs;
   cmSystemTools::ExpandListArgument(srcStr, pairs);
   cmSystemTools::ExpandListArgument(srcStr, pairs);
 
 

+ 1 - 1
Source/cmExportFileGenerator.cxx

@@ -195,7 +195,7 @@ static bool checkInterfaceDirs(const std::string& prepro,
                                cmGeneratorTarget* target,
                                cmGeneratorTarget* target,
                                const std::string& prop)
                                const std::string& prop)
 {
 {
-  const char* installDir =
+  std::string const& installDir =
     target->Makefile->GetSafeDefinition("CMAKE_INSTALL_PREFIX");
     target->Makefile->GetSafeDefinition("CMAKE_INSTALL_PREFIX");
   std::string const& topSourceDir =
   std::string const& topSourceDir =
     target->GetLocalGenerator()->GetSourceDirectory();
     target->GetLocalGenerator()->GetSourceDirectory();

+ 1 - 1
Source/cmExtraCodeBlocksGenerator.cxx

@@ -666,7 +666,7 @@ std::string cmExtraCodeBlocksGenerator::GetCBCompilerId(const cmMakefile* mf)
     pureFortran = true;
     pureFortran = true;
   }
   }
 
 
-  std::string compilerId = mf->GetSafeDefinition(compilerIdVar);
+  std::string const& compilerId = mf->GetSafeDefinition(compilerIdVar);
   std::string compiler = "gcc"; // default to gcc
   std::string compiler = "gcc"; // default to gcc
   if (compilerId == "MSVC") {
   if (compilerId == "MSVC") {
     if (mf->IsDefinitionSet("MSVC10")) {
     if (mf->IsDefinitionSet("MSVC10")) {

+ 1 - 1
Source/cmExtraCodeLiteGenerator.cxx

@@ -599,7 +599,7 @@ std::string cmExtraCodeLiteGenerator::GetCodeLiteCompilerName(
     compilerIdVar = "CMAKE_C_COMPILER_ID";
     compilerIdVar = "CMAKE_C_COMPILER_ID";
   }
   }
 
 
-  std::string compilerId = mf->GetSafeDefinition(compilerIdVar);
+  std::string const& compilerId = mf->GetSafeDefinition(compilerIdVar);
   std::string compiler = "gnu g++"; // default to g++
   std::string compiler = "gnu g++"; // default to g++
 
 
   // Since we need the compiler for parsing purposes only
   // Since we need the compiler for parsing purposes only

+ 16 - 14
Source/cmGeneratorExpressionNode.cxx

@@ -580,10 +580,11 @@ struct CompilerIdNode : public cmGeneratorExpressionNode
                                    cmGeneratorExpressionDAGChecker* /*unused*/,
                                    cmGeneratorExpressionDAGChecker* /*unused*/,
                                    const std::string& lang) const
                                    const std::string& lang) const
   {
   {
-    const char* compilerId = context->LG->GetMakefile()->GetSafeDefinition(
-      "CMAKE_" + lang + "_COMPILER_ID");
+    std::string const& compilerId =
+      context->LG->GetMakefile()->GetSafeDefinition("CMAKE_" + lang +
+                                                    "_COMPILER_ID");
     if (parameters.empty()) {
     if (parameters.empty()) {
-      return compilerId ? compilerId : "";
+      return compilerId;
     }
     }
     static cmsys::RegularExpression compilerIdValidator("^[A-Za-z0-9_]*$");
     static cmsys::RegularExpression compilerIdValidator("^[A-Za-z0-9_]*$");
     if (!compilerIdValidator.find(*parameters.begin())) {
     if (!compilerIdValidator.find(*parameters.begin())) {
@@ -591,15 +592,16 @@ struct CompilerIdNode : public cmGeneratorExpressionNode
                   "Expression syntax not recognized.");
                   "Expression syntax not recognized.");
       return std::string();
       return std::string();
     }
     }
-    if (!compilerId) {
+    if (compilerId.empty()) {
       return parameters.front().empty() ? "1" : "0";
       return parameters.front().empty() ? "1" : "0";
     }
     }
 
 
-    if (strcmp(parameters.begin()->c_str(), compilerId) == 0) {
+    if (strcmp(parameters.begin()->c_str(), compilerId.c_str()) == 0) {
       return "1";
       return "1";
     }
     }
 
 
-    if (cmsysString_strcasecmp(parameters.begin()->c_str(), compilerId) == 0) {
+    if (cmsysString_strcasecmp(parameters.begin()->c_str(),
+                               compilerId.c_str()) == 0) {
       switch (context->LG->GetPolicyStatus(cmPolicies::CMP0044)) {
       switch (context->LG->GetPolicyStatus(cmPolicies::CMP0044)) {
         case cmPolicies::WARN: {
         case cmPolicies::WARN: {
           std::ostringstream e;
           std::ostringstream e;
@@ -676,11 +678,11 @@ struct CompilerVersionNode : public cmGeneratorExpressionNode
                                    cmGeneratorExpressionDAGChecker* /*unused*/,
                                    cmGeneratorExpressionDAGChecker* /*unused*/,
                                    const std::string& lang) const
                                    const std::string& lang) const
   {
   {
-    const char* compilerVersion =
+    std::string const& compilerVersion =
       context->LG->GetMakefile()->GetSafeDefinition("CMAKE_" + lang +
       context->LG->GetMakefile()->GetSafeDefinition("CMAKE_" + lang +
                                                     "_COMPILER_VERSION");
                                                     "_COMPILER_VERSION");
     if (parameters.empty()) {
     if (parameters.empty()) {
-      return compilerVersion ? compilerVersion : "";
+      return compilerVersion;
     }
     }
 
 
     static cmsys::RegularExpression compilerIdValidator("^[0-9\\.]*$");
     static cmsys::RegularExpression compilerIdValidator("^[0-9\\.]*$");
@@ -689,13 +691,13 @@ struct CompilerVersionNode : public cmGeneratorExpressionNode
                   "Expression syntax not recognized.");
                   "Expression syntax not recognized.");
       return std::string();
       return std::string();
     }
     }
-    if (!compilerVersion) {
+    if (compilerVersion.empty()) {
       return parameters.front().empty() ? "1" : "0";
       return parameters.front().empty() ? "1" : "0";
     }
     }
 
 
     return cmSystemTools::VersionCompare(cmSystemTools::OP_EQUAL,
     return cmSystemTools::VersionCompare(cmSystemTools::OP_EQUAL,
                                          parameters.begin()->c_str(),
                                          parameters.begin()->c_str(),
-                                         compilerVersion)
+                                         compilerVersion.c_str())
       ? "1"
       ? "1"
       : "0";
       : "0";
   }
   }
@@ -757,17 +759,17 @@ struct PlatformIdNode : public cmGeneratorExpressionNode
     const GeneratorExpressionContent* /*content*/,
     const GeneratorExpressionContent* /*content*/,
     cmGeneratorExpressionDAGChecker* /*dagChecker*/) const override
     cmGeneratorExpressionDAGChecker* /*dagChecker*/) const override
   {
   {
-    const char* platformId =
+    std::string const& platformId =
       context->LG->GetMakefile()->GetSafeDefinition("CMAKE_SYSTEM_NAME");
       context->LG->GetMakefile()->GetSafeDefinition("CMAKE_SYSTEM_NAME");
     if (parameters.empty()) {
     if (parameters.empty()) {
-      return platformId ? platformId : "";
+      return platformId;
     }
     }
 
 
-    if (!platformId) {
+    if (platformId.empty()) {
       return parameters.front().empty() ? "1" : "0";
       return parameters.front().empty() ? "1" : "0";
     }
     }
 
 
-    if (strcmp(parameters.begin()->c_str(), platformId) == 0) {
+    if (*parameters.begin() == platformId) {
       return "1";
       return "1";
     }
     }
     return "0";
     return "0";

+ 10 - 10
Source/cmGeneratorTarget.cxx

@@ -138,8 +138,7 @@ cmGeneratorTarget::cmGeneratorTarget(cmTarget* t, cmLocalGenerator* lg)
                                      this->SourceEntries, true);
                                      this->SourceEntries, true);
 
 
   this->DLLPlatform =
   this->DLLPlatform =
-    strcmp(this->Makefile->GetSafeDefinition("CMAKE_IMPORT_LIBRARY_SUFFIX"),
-           "") != 0;
+    !this->Makefile->GetSafeDefinition("CMAKE_IMPORT_LIBRARY_SUFFIX").empty();
 
 
   this->PolicyMap = t->PolicyMap;
   this->PolicyMap = t->PolicyMap;
 }
 }
@@ -3495,12 +3494,13 @@ void cmGeneratorTarget::GetFullNameInternal(
   }
   }
 
 
   // if there is no prefix on the target use the cmake definition
   // if there is no prefix on the target use the cmake definition
+  std::string targetPrefix2, targetSuffix2;
   if (!targetPrefix && prefixVar) {
   if (!targetPrefix && prefixVar) {
-    targetPrefix = this->Makefile->GetSafeDefinition(prefixVar);
+    targetPrefix2 = this->Makefile->GetSafeDefinition(prefixVar);
   }
   }
   // if there is no suffix on the target use the cmake definition
   // if there is no suffix on the target use the cmake definition
   if (!targetSuffix && suffixVar) {
   if (!targetSuffix && suffixVar) {
-    targetSuffix = this->Makefile->GetSafeDefinition(suffixVar);
+    targetSuffix2 = this->Makefile->GetSafeDefinition(suffixVar);
   }
   }
 
 
   // frameworks have directory prefix but no suffix
   // frameworks have directory prefix but no suffix
@@ -3508,19 +3508,19 @@ void cmGeneratorTarget::GetFullNameInternal(
   if (this->IsFrameworkOnApple()) {
   if (this->IsFrameworkOnApple()) {
     fw_prefix = this->GetFrameworkDirectory(config, ContentLevel);
     fw_prefix = this->GetFrameworkDirectory(config, ContentLevel);
     fw_prefix += "/";
     fw_prefix += "/";
-    targetPrefix = fw_prefix.c_str();
-    targetSuffix = nullptr;
+    targetPrefix2 = fw_prefix;
+    targetSuffix2.clear();
   }
   }
 
 
   if (this->IsCFBundleOnApple()) {
   if (this->IsCFBundleOnApple()) {
     fw_prefix = this->GetCFBundleDirectory(config, FullLevel);
     fw_prefix = this->GetCFBundleDirectory(config, FullLevel);
     fw_prefix += "/";
     fw_prefix += "/";
-    targetPrefix = fw_prefix.c_str();
-    targetSuffix = nullptr;
+    targetPrefix2 = fw_prefix;
+    targetSuffix2.clear();
   }
   }
 
 
   // Begin the final name with the prefix.
   // Begin the final name with the prefix.
-  outPrefix = targetPrefix ? targetPrefix : "";
+  outPrefix = targetPrefix2;
 
 
   // Append the target name or property-specified name.
   // Append the target name or property-specified name.
   outBase += this->GetOutputName(config, artifact);
   outBase += this->GetOutputName(config, artifact);
@@ -3539,7 +3539,7 @@ void cmGeneratorTarget::GetFullNameInternal(
   }
   }
 
 
   // Append the suffix.
   // Append the suffix.
-  outSuffix = targetSuffix ? targetSuffix : "";
+  outSuffix = targetSuffix2;
 }
 }
 
 
 std::string cmGeneratorTarget::GetLinkerLanguage(
 std::string cmGeneratorTarget::GetLinkerLanguage(

+ 1 - 1
Source/cmGetDirectoryPropertyCommand.cxx

@@ -65,7 +65,7 @@ bool cmGetDirectoryPropertyCommand::InitialPass(
                      "providing the name of the variable to get.");
                      "providing the name of the variable to get.");
       return false;
       return false;
     }
     }
-    std::string output = dir->GetSafeDefinition(*i);
+    std::string const& output = dir->GetSafeDefinition(*i);
     this->Makefile->AddDefinition(variable, output.c_str());
     this->Makefile->AddDefinition(variable, output.c_str());
     return true;
     return true;
   }
   }

+ 6 - 5
Source/cmGlobalGenerator.cxx

@@ -828,8 +828,9 @@ void cmGlobalGenerator::EnableLanguage(
     std::string sharedLibFlagsVar = "CMAKE_SHARED_LIBRARY_";
     std::string sharedLibFlagsVar = "CMAKE_SHARED_LIBRARY_";
     sharedLibFlagsVar += lang;
     sharedLibFlagsVar += lang;
     sharedLibFlagsVar += "_FLAGS";
     sharedLibFlagsVar += "_FLAGS";
-    const char* sharedLibFlags = mf->GetSafeDefinition(sharedLibFlagsVar);
-    if (sharedLibFlags) {
+    std::string const& sharedLibFlags =
+      mf->GetSafeDefinition(sharedLibFlagsVar);
+    if (!sharedLibFlags.empty()) {
       this->LanguageToOriginalSharedLibFlags[lang] = sharedLibFlags;
       this->LanguageToOriginalSharedLibFlags[lang] = sharedLibFlags;
     }
     }
 
 
@@ -1092,7 +1093,7 @@ void cmGlobalGenerator::FillExtensionToLanguageMap(const std::string& l,
 {
 {
   std::string extensionsVar = std::string("CMAKE_") + std::string(l) +
   std::string extensionsVar = std::string("CMAKE_") + std::string(l) +
     std::string("_SOURCE_FILE_EXTENSIONS");
     std::string("_SOURCE_FILE_EXTENSIONS");
-  std::string exts = mf->GetSafeDefinition(extensionsVar);
+  const std::string& exts = mf->GetSafeDefinition(extensionsVar);
   std::vector<std::string> extensionList;
   std::vector<std::string> extensionList;
   cmSystemTools::ExpandListArgument(exts, extensionList);
   cmSystemTools::ExpandListArgument(exts, extensionList);
   for (std::string const& i : extensionList) {
   for (std::string const& i : extensionList) {
@@ -1112,7 +1113,7 @@ bool cmGlobalGenerator::GlobalSettingIsOn(std::string const& name) const
   return this->Makefiles[0]->IsOn(name);
   return this->Makefiles[0]->IsOn(name);
 }
 }
 
 
-const char* cmGlobalGenerator::GetSafeGlobalSetting(
+std::string cmGlobalGenerator::GetSafeGlobalSetting(
   std::string const& name) const
   std::string const& name) const
 {
 {
   assert(!this->Makefiles.empty());
   assert(!this->Makefiles.empty());
@@ -1596,7 +1597,7 @@ void cmGlobalGenerator::FinalizeTargetCompileInfo()
     for (std::string const& li : langs) {
     for (std::string const& li : langs) {
       std::string const standardIncludesVar =
       std::string const standardIncludesVar =
         "CMAKE_" + li + "_STANDARD_INCLUDE_DIRECTORIES";
         "CMAKE_" + li + "_STANDARD_INCLUDE_DIRECTORIES";
-      std::string const standardIncludesStr =
+      std::string const& standardIncludesStr =
         mf->GetSafeDefinition(standardIncludesVar);
         mf->GetSafeDefinition(standardIncludesVar);
       std::vector<std::string> standardIncludesVec;
       std::vector<std::string> standardIncludesVec;
       cmSystemTools::ExpandListArgument(standardIncludesStr,
       cmSystemTools::ExpandListArgument(standardIncludesStr,

+ 1 - 1
Source/cmGlobalGenerator.h

@@ -233,7 +233,7 @@ public:
 
 
   const char* GetGlobalSetting(std::string const& name) const;
   const char* GetGlobalSetting(std::string const& name) const;
   bool GlobalSettingIsOn(std::string const& name) const;
   bool GlobalSettingIsOn(std::string const& name) const;
-  const char* GetSafeGlobalSetting(std::string const& name) const;
+  std::string GetSafeGlobalSetting(std::string const& name) const;
 
 
   /** Add a file to the manifest of generated targets for a configuration.  */
   /** Add a file to the manifest of generated targets for a configuration.  */
   void AddToManifest(std::string const& f);
   void AddToManifest(std::string const& f);

+ 6 - 6
Source/cmGlobalNinjaGenerator.cxx

@@ -651,13 +651,13 @@ void cmGlobalNinjaGenerator::EnableLanguage(
     this->ResolveLanguageCompiler(l, mf, optional);
     this->ResolveLanguageCompiler(l, mf, optional);
   }
   }
 #ifdef _WIN32
 #ifdef _WIN32
-  if (strcmp(mf->GetSafeDefinition("CMAKE_C_SIMULATE_ID"), "MSVC") != 0 &&
-      strcmp(mf->GetSafeDefinition("CMAKE_CXX_SIMULATE_ID"), "MSVC") != 0 &&
+  if ((mf->GetSafeDefinition("CMAKE_C_SIMULATE_ID") != "MSVC") &&
+      (mf->GetSafeDefinition("CMAKE_CXX_SIMULATE_ID") != "MSVC") &&
       (mf->IsOn("CMAKE_COMPILER_IS_MINGW") ||
       (mf->IsOn("CMAKE_COMPILER_IS_MINGW") ||
-       strcmp(mf->GetSafeDefinition("CMAKE_C_COMPILER_ID"), "GNU") == 0 ||
-       strcmp(mf->GetSafeDefinition("CMAKE_CXX_COMPILER_ID"), "GNU") == 0 ||
-       strcmp(mf->GetSafeDefinition("CMAKE_C_COMPILER_ID"), "Clang") == 0 ||
-       strcmp(mf->GetSafeDefinition("CMAKE_CXX_COMPILER_ID"), "Clang") == 0)) {
+       (mf->GetSafeDefinition("CMAKE_C_COMPILER_ID") == "GNU") ||
+       (mf->GetSafeDefinition("CMAKE_CXX_COMPILER_ID") == "GNU") ||
+       (mf->GetSafeDefinition("CMAKE_C_COMPILER_ID") == "Clang") ||
+       (mf->GetSafeDefinition("CMAKE_CXX_COMPILER_ID") == "Clang"))) {
     this->UsingGCCOnWindows = true;
     this->UsingGCCOnWindows = true;
   }
   }
 #endif
 #endif

+ 1 - 3
Source/cmInstallCommand.cxx

@@ -5,7 +5,6 @@
 #include "cmsys/Glob.hxx"
 #include "cmsys/Glob.hxx"
 #include <sstream>
 #include <sstream>
 #include <stddef.h>
 #include <stddef.h>
-#include <string.h>
 #include <utility>
 #include <utility>
 
 
 #include "cmAlgorithms.h"
 #include "cmAlgorithms.h"
@@ -350,8 +349,7 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
 
 
   // Check whether this is a DLL platform.
   // Check whether this is a DLL platform.
   bool dll_platform =
   bool dll_platform =
-    strcmp(this->Makefile->GetSafeDefinition("CMAKE_IMPORT_LIBRARY_SUFFIX"),
-           "") != 0;
+    !this->Makefile->GetSafeDefinition("CMAKE_IMPORT_LIBRARY_SUFFIX").empty();
 
 
   for (std::string const& tgt : targetList.GetVector()) {
   for (std::string const& tgt : targetList.GetVector()) {
 
 

+ 6 - 6
Source/cmLocalGenerator.cxx

@@ -683,7 +683,7 @@ std::string cmLocalGenerator::GetIncludeFlags(
 
 
   std::string flagVar = "CMAKE_INCLUDE_FLAG_";
   std::string flagVar = "CMAKE_INCLUDE_FLAG_";
   flagVar += lang;
   flagVar += lang;
-  const char* includeFlag = this->Makefile->GetSafeDefinition(flagVar);
+  std::string const& includeFlag = this->Makefile->GetSafeDefinition(flagVar);
   flagVar = "CMAKE_INCLUDE_FLAG_SEP_";
   flagVar = "CMAKE_INCLUDE_FLAG_SEP_";
   flagVar += lang;
   flagVar += lang;
   const char* sep = this->Makefile->GetDefinition(flagVar);
   const char* sep = this->Makefile->GetDefinition(flagVar);
@@ -1824,9 +1824,9 @@ bool cmLocalGenerator::GetShouldUseOldFlags(bool shared,
     std::string flagsVar = "CMAKE_SHARED_LIBRARY_";
     std::string flagsVar = "CMAKE_SHARED_LIBRARY_";
     flagsVar += lang;
     flagsVar += lang;
     flagsVar += "_FLAGS";
     flagsVar += "_FLAGS";
-    const char* flags = this->Makefile->GetSafeDefinition(flagsVar);
+    std::string const& flags = this->Makefile->GetSafeDefinition(flagsVar);
 
 
-    if (flags && flags != originalFlags) {
+    if (!flags.empty() && flags != originalFlags) {
       switch (this->GetPolicyStatus(cmPolicies::CMP0018)) {
       switch (this->GetPolicyStatus(cmPolicies::CMP0018)) {
         case cmPolicies::WARN: {
         case cmPolicies::WARN: {
           std::ostringstream e;
           std::ostringstream e;
@@ -1859,7 +1859,7 @@ void cmLocalGenerator::AddPositionIndependentFlags(std::string& flags,
                                                    std::string const& lang,
                                                    std::string const& lang,
                                                    int targetType)
                                                    int targetType)
 {
 {
-  const char* picFlags = nullptr;
+  std::string picFlags;
 
 
   if (targetType == cmStateEnums::EXECUTABLE) {
   if (targetType == cmStateEnums::EXECUTABLE) {
     std::string flagsVar = "CMAKE_";
     std::string flagsVar = "CMAKE_";
@@ -1867,13 +1867,13 @@ void cmLocalGenerator::AddPositionIndependentFlags(std::string& flags,
     flagsVar += "_COMPILE_OPTIONS_PIE";
     flagsVar += "_COMPILE_OPTIONS_PIE";
     picFlags = this->Makefile->GetSafeDefinition(flagsVar);
     picFlags = this->Makefile->GetSafeDefinition(flagsVar);
   }
   }
-  if (!picFlags) {
+  if (picFlags.empty()) {
     std::string flagsVar = "CMAKE_";
     std::string flagsVar = "CMAKE_";
     flagsVar += lang;
     flagsVar += lang;
     flagsVar += "_COMPILE_OPTIONS_PIC";
     flagsVar += "_COMPILE_OPTIONS_PIC";
     picFlags = this->Makefile->GetSafeDefinition(flagsVar);
     picFlags = this->Makefile->GetSafeDefinition(flagsVar);
   }
   }
-  if (picFlags) {
+  if (!picFlags.empty()) {
     std::vector<std::string> options;
     std::vector<std::string> options;
     cmSystemTools::ExpandListArgument(picFlags, options);
     cmSystemTools::ExpandListArgument(picFlags, options);
     for (std::string const& o : options) {
     for (std::string const& o : options) {

+ 2 - 1
Source/cmLocalUnixMakefileGenerator3.cxx

@@ -1422,7 +1422,8 @@ bool cmLocalUnixMakefileGenerator3::ScanDependencies(
   this->WriteDisclaimer(internalRuleFileStream);
   this->WriteDisclaimer(internalRuleFileStream);
 
 
   // for each language we need to scan, scan it
   // for each language we need to scan, scan it
-  const char* langStr = mf->GetSafeDefinition("CMAKE_DEPENDS_LANGUAGES");
+  std::string const& langStr =
+    mf->GetSafeDefinition("CMAKE_DEPENDS_LANGUAGES");
   std::vector<std::string> langs;
   std::vector<std::string> langs;
   cmSystemTools::ExpandListArgument(langStr, langs);
   cmSystemTools::ExpandListArgument(langStr, langs);
   for (std::string const& lang : langs) {
   for (std::string const& lang : langs) {

+ 2 - 2
Source/cmLocalVisualStudio7Generator.cxx

@@ -1082,7 +1082,7 @@ void cmLocalVisualStudio7Generator::OutputBuildTool(
       // Use the NOINHERIT macro to avoid getting VS project default
       // Use the NOINHERIT macro to avoid getting VS project default
       // libraries which may be set by the user to something bad.
       // libraries which may be set by the user to something bad.
       fout << "\t\t\t\tAdditionalDependencies=\"$(NOINHERIT) "
       fout << "\t\t\t\tAdditionalDependencies=\"$(NOINHERIT) "
-           << this->Makefile->GetSafeDefinition(standardLibsVar.c_str());
+           << this->Makefile->GetSafeDefinition(standardLibsVar);
       if (this->FortranProject) {
       if (this->FortranProject) {
         this->Internal->OutputObjects(fout, target, configName, " ");
         this->Internal->OutputObjects(fout, target, configName, " ");
       }
       }
@@ -1167,7 +1167,7 @@ void cmLocalVisualStudio7Generator::OutputBuildTool(
       // Use the NOINHERIT macro to avoid getting VS project default
       // Use the NOINHERIT macro to avoid getting VS project default
       // libraries which may be set by the user to something bad.
       // libraries which may be set by the user to something bad.
       fout << "\t\t\t\tAdditionalDependencies=\"$(NOINHERIT) "
       fout << "\t\t\t\tAdditionalDependencies=\"$(NOINHERIT) "
-           << this->Makefile->GetSafeDefinition(standardLibsVar.c_str());
+           << this->Makefile->GetSafeDefinition(standardLibsVar);
       if (this->FortranProject) {
       if (this->FortranProject) {
         this->Internal->OutputObjects(fout, target, configName, " ");
         this->Internal->OutputObjects(fout, target, configName, " ");
       }
       }

+ 17 - 7
Source/cmMakefile.cxx

@@ -2401,7 +2401,7 @@ bool cmMakefile::IsDefinitionSet(const std::string& name) const
   return def != nullptr;
   return def != nullptr;
 }
 }
 
 
-const char* cmMakefile::GetDefinition(const std::string& name) const
+const std::string* cmMakefile::GetDef(const std::string& name) const
 {
 {
   const std::string* def = this->StateSnapshot.GetDefinition(name);
   const std::string* def = this->StateSnapshot.GetDefinition(name);
   if (!def) {
   if (!def) {
@@ -2427,16 +2427,26 @@ const char* cmMakefile::GetDefinition(const std::string& name) const
     }
     }
   }
   }
 #endif
 #endif
-  return (def ? def->c_str() : nullptr);
+  return def;
 }
 }
 
 
-const char* cmMakefile::GetSafeDefinition(const std::string& def) const
+const char* cmMakefile::GetDefinition(const std::string& name) const
 {
 {
-  const char* ret = this->GetDefinition(def);
-  if (!ret) {
-    return "";
+  const std::string* def = GetDef(name);
+  if (!def) {
+    return nullptr;
   }
   }
-  return ret;
+  return def->c_str();
+}
+
+const std::string& cmMakefile::GetSafeDefinition(const std::string& name) const
+{
+  static std::string const empty;
+  const std::string* def = GetDef(name);
+  if (!def) {
+    return empty;
+  }
+  return *def;
 }
 }
 
 
 std::vector<std::string> cmMakefile::GetDefinitions() const
 std::vector<std::string> cmMakefile::GetDefinitions() const

+ 2 - 1
Source/cmMakefile.h

@@ -432,7 +432,8 @@ public:
    * cache is then queried.
    * cache is then queried.
    */
    */
   const char* GetDefinition(const std::string&) const;
   const char* GetDefinition(const std::string&) const;
-  const char* GetSafeDefinition(const std::string&) const;
+  const std::string* GetDef(const std::string&) const;
+  const std::string& GetSafeDefinition(const std::string&) const;
   std::string GetRequiredDefinition(const std::string& name) const;
   std::string GetRequiredDefinition(const std::string& name) const;
   bool IsDefinitionSet(const std::string&) const;
   bool IsDefinitionSet(const std::string&) const;
   /**
   /**

+ 2 - 4
Source/cmNinjaTargetGenerator.cxx

@@ -10,7 +10,6 @@
 #include <map>
 #include <map>
 #include <memory> // IWYU pragma: keep
 #include <memory> // IWYU pragma: keep
 #include <sstream>
 #include <sstream>
-#include <string.h>
 
 
 #include "cmAlgorithms.h"
 #include "cmAlgorithms.h"
 #include "cmComputeLinkInformation.h"
 #include "cmComputeLinkInformation.h"
@@ -174,9 +173,8 @@ void cmNinjaTargetGenerator::AddIncludeFlags(std::string& languageFlags,
 
 
 bool cmNinjaTargetGenerator::NeedDepTypeMSVC(const std::string& lang) const
 bool cmNinjaTargetGenerator::NeedDepTypeMSVC(const std::string& lang) const
 {
 {
-  return strcmp(this->GetMakefile()->GetSafeDefinition("CMAKE_NINJA_DEPTYPE_" +
-                                                       lang),
-                "msvc") == 0;
+  return (this->GetMakefile()->GetSafeDefinition("CMAKE_NINJA_DEPTYPE_" +
+                                                 lang) == "msvc");
 }
 }
 
 
 // TODO: Refactor with
 // TODO: Refactor with

+ 1 - 1
Source/cmPolicies.cxx

@@ -135,7 +135,7 @@ static bool GetPolicyDefault(cmMakefile* mf, std::string const& policy,
                              cmPolicies::PolicyStatus* defaultSetting)
                              cmPolicies::PolicyStatus* defaultSetting)
 {
 {
   std::string defaultVar = "CMAKE_POLICY_DEFAULT_" + policy;
   std::string defaultVar = "CMAKE_POLICY_DEFAULT_" + policy;
-  std::string defaultValue = mf->GetSafeDefinition(defaultVar);
+  std::string const& defaultValue = mf->GetSafeDefinition(defaultVar);
   if (defaultValue == "NEW") {
   if (defaultValue == "NEW") {
     *defaultSetting = cmPolicies::NEW;
     *defaultSetting = cmPolicies::NEW;
   } else if (defaultValue == "OLD") {
   } else if (defaultValue == "OLD") {

+ 1 - 1
Source/cmQtAutoGenInitializer.cxx

@@ -1126,7 +1126,7 @@ bool cmQtAutoGenInitializer::SetupWriteAutogenInfo()
       }
       }
     };
     };
     auto MfDef = [makefile](const char* key) {
     auto MfDef = [makefile](const char* key) {
-      return std::string(makefile->GetSafeDefinition(key));
+      return makefile->GetSafeDefinition(key);
     };
     };
 
 
     // Write
     // Write

+ 4 - 3
Source/cmQtAutoGeneratorMocUic.cxx

@@ -1204,7 +1204,7 @@ bool cmQtAutoGeneratorMocUic::Init(cmMakefile* makefile)
       valueConf = makefile->GetDefinition(keyConf);
       valueConf = makefile->GetDefinition(keyConf);
     }
     }
     if (valueConf == nullptr) {
     if (valueConf == nullptr) {
-      valueConf = makefile->GetSafeDefinition(key);
+      return makefile->GetSafeDefinition(key);
     }
     }
     return std::string(valueConf);
     return std::string(valueConf);
   };
   };
@@ -1226,7 +1226,7 @@ bool cmQtAutoGeneratorMocUic::Init(cmMakefile* makefile)
   Base_.MultiConfig = InfoGetBool("AM_MULTI_CONFIG");
   Base_.MultiConfig = InfoGetBool("AM_MULTI_CONFIG");
   {
   {
     unsigned long num = Base_.NumThreads;
     unsigned long num = Base_.NumThreads;
-    if (cmSystemTools::StringToULong(InfoGet("AM_PARALLEL"), &num)) {
+    if (cmSystemTools::StringToULong(InfoGet("AM_PARALLEL").c_str(), &num)) {
       num = std::max<unsigned long>(num, 1);
       num = std::max<unsigned long>(num, 1);
       num = std::min<unsigned long>(num, ParallelMax);
       num = std::min<unsigned long>(num, ParallelMax);
       Base_.NumThreads = static_cast<unsigned int>(num);
       Base_.NumThreads = static_cast<unsigned int>(num);
@@ -1264,7 +1264,8 @@ bool cmQtAutoGeneratorMocUic::Init(cmMakefile* makefile)
   // - Qt environment
   // - Qt environment
   {
   {
     unsigned long qtv = Base_.QtVersionMajor;
     unsigned long qtv = Base_.QtVersionMajor;
-    if (cmSystemTools::StringToULong(InfoGet("AM_QT_VERSION_MAJOR"), &qtv)) {
+    if (cmSystemTools::StringToULong(InfoGet("AM_QT_VERSION_MAJOR").c_str(),
+                                     &qtv)) {
       Base_.QtVersionMajor = static_cast<unsigned int>(qtv);
       Base_.QtVersionMajor = static_cast<unsigned int>(qtv);
     }
     }
   }
   }

+ 1 - 1
Source/cmQtAutoGeneratorRcc.cxx

@@ -52,7 +52,7 @@ bool cmQtAutoGeneratorRcc::Init(cmMakefile* makefile)
       valueConf = makefile->GetDefinition(keyConf);
       valueConf = makefile->GetDefinition(keyConf);
     }
     }
     if (valueConf == nullptr) {
     if (valueConf == nullptr) {
-      valueConf = makefile->GetSafeDefinition(key);
+      return makefile->GetSafeDefinition(key);
     }
     }
     return std::string(valueConf);
     return std::string(valueConf);
   };
   };

+ 2 - 4
Source/cmTarget.cxx

@@ -190,13 +190,11 @@ cmTarget::cmTarget(std::string const& name, cmStateEnums::TargetType type,
 
 
   // Check whether this is a DLL platform.
   // Check whether this is a DLL platform.
   this->DLLPlatform =
   this->DLLPlatform =
-    strcmp(this->Makefile->GetSafeDefinition("CMAKE_IMPORT_LIBRARY_SUFFIX"),
-           "") != 0;
+    !this->Makefile->GetSafeDefinition("CMAKE_IMPORT_LIBRARY_SUFFIX").empty();
 
 
   // Check whether we are targeting an Android platform.
   // Check whether we are targeting an Android platform.
   this->IsAndroid =
   this->IsAndroid =
-    strcmp(this->Makefile->GetSafeDefinition("CMAKE_SYSTEM_NAME"),
-           "Android") == 0;
+    (this->Makefile->GetSafeDefinition("CMAKE_SYSTEM_NAME") == "Android");
 
 
   // Setup default property values.
   // Setup default property values.
   if (this->GetType() != cmStateEnums::INTERFACE_LIBRARY &&
   if (this->GetType() != cmStateEnums::INTERFACE_LIBRARY &&

+ 11 - 19
Source/cmVisualStudio10TargetGenerator.cxx

@@ -2699,11 +2699,9 @@ bool cmVisualStudio10TargetGenerator::ComputeRcOptions(
   Options& rcOptions = *pOptions;
   Options& rcOptions = *pOptions;
 
 
   std::string CONFIG = cmSystemTools::UpperCase(configName);
   std::string CONFIG = cmSystemTools::UpperCase(configName);
-  std::string rcConfigFlagsVar = std::string("CMAKE_RC_FLAGS_") + CONFIG;
-  std::string flags =
-    std::string(this->Makefile->GetSafeDefinition("CMAKE_RC_FLAGS")) +
-    std::string(" ") +
-    std::string(this->Makefile->GetSafeDefinition(rcConfigFlagsVar));
+  std::string rcConfigFlagsVar = "CMAKE_RC_FLAGS_" + CONFIG;
+  std::string flags = this->Makefile->GetSafeDefinition("CMAKE_RC_FLAGS") +
+    " " + this->Makefile->GetSafeDefinition(rcConfigFlagsVar);
 
 
   rcOptions.Parse(flags);
   rcOptions.Parse(flags);
 
 
@@ -2757,10 +2755,8 @@ bool cmVisualStudio10TargetGenerator::ComputeCudaOptions(
   // Get compile flags for CUDA in this directory.
   // Get compile flags for CUDA in this directory.
   std::string CONFIG = cmSystemTools::UpperCase(configName);
   std::string CONFIG = cmSystemTools::UpperCase(configName);
   std::string configFlagsVar = std::string("CMAKE_CUDA_FLAGS_") + CONFIG;
   std::string configFlagsVar = std::string("CMAKE_CUDA_FLAGS_") + CONFIG;
-  std::string flags =
-    std::string(this->Makefile->GetSafeDefinition("CMAKE_CUDA_FLAGS")) +
-    std::string(" ") +
-    std::string(this->Makefile->GetSafeDefinition(configFlagsVar));
+  std::string flags = this->Makefile->GetSafeDefinition("CMAKE_CUDA_FLAGS") +
+    " " + this->Makefile->GetSafeDefinition(configFlagsVar);
   this->LocalGenerator->AddCompileOptions(flags, this->GeneratorTarget, "CUDA",
   this->LocalGenerator->AddCompileOptions(flags, this->GeneratorTarget, "CUDA",
                                           configName);
                                           configName);
 
 
@@ -2971,9 +2967,8 @@ bool cmVisualStudio10TargetGenerator::ComputeMasmOptions(
   std::string CONFIG = cmSystemTools::UpperCase(configName);
   std::string CONFIG = cmSystemTools::UpperCase(configName);
   std::string configFlagsVar = std::string("CMAKE_ASM_MASM_FLAGS_") + CONFIG;
   std::string configFlagsVar = std::string("CMAKE_ASM_MASM_FLAGS_") + CONFIG;
   std::string flags =
   std::string flags =
-    std::string(this->Makefile->GetSafeDefinition("CMAKE_ASM_MASM_FLAGS")) +
-    std::string(" ") +
-    std::string(this->Makefile->GetSafeDefinition(configFlagsVar));
+    this->Makefile->GetSafeDefinition("CMAKE_ASM_MASM_FLAGS") + " " +
+    this->Makefile->GetSafeDefinition(configFlagsVar);
 
 
   masmOptions.Parse(flags);
   masmOptions.Parse(flags);
 
 
@@ -3024,14 +3019,11 @@ bool cmVisualStudio10TargetGenerator::ComputeNasmOptions(
   Options& nasmOptions = *pOptions;
   Options& nasmOptions = *pOptions;
 
 
   std::string CONFIG = cmSystemTools::UpperCase(configName);
   std::string CONFIG = cmSystemTools::UpperCase(configName);
-  std::string configFlagsVar = std::string("CMAKE_ASM_NASM_FLAGS_") + CONFIG;
+  std::string configFlagsVar = "CMAKE_ASM_NASM_FLAGS_" + CONFIG;
   std::string flags =
   std::string flags =
-    std::string(this->Makefile->GetSafeDefinition("CMAKE_ASM_NASM_FLAGS")) +
-    std::string(" -f") +
-    std::string(
-      this->Makefile->GetSafeDefinition("CMAKE_ASM_NASM_OBJECT_FORMAT")) +
-    std::string(" ") +
-    std::string(this->Makefile->GetSafeDefinition(configFlagsVar));
+    this->Makefile->GetSafeDefinition("CMAKE_ASM_NASM_FLAGS") + " -f" +
+    this->Makefile->GetSafeDefinition("CMAKE_ASM_NASM_OBJECT_FORMAT") + " " +
+    this->Makefile->GetSafeDefinition(configFlagsVar);
   nasmOptions.Parse(flags);
   nasmOptions.Parse(flags);
 
 
   // Get includes for this target
   // Get includes for this target