| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694 | /* Distributed under the OSI-approved BSD 3-Clause License.  See accompanying   file Copyright.txt or https://cmake.org/licensing for details.  */#include "cmGlobalVisualStudio7Generator.h"#include "cmGeneratedFileStream.h"#include "cmGeneratorTarget.h"#include "cmLocalVisualStudio7Generator.h"#include "cmMakefile.h"#include "cmMessageType.h"#include "cmState.h"#include "cmUuid.h"#include "cmake.h"#include "cmsys/Encoding.hxx"#include <assert.h>#include <vector>#include <windows.h>static cmVS7FlagTable cmVS7ExtraFlagTable[] = {  // Precompiled header and related options.  Note that the  // UsePrecompiledHeader entries are marked as "Continue" so that the  // corresponding PrecompiledHeaderThrough entry can be found.  { "UsePrecompiledHeader", "YX", "Automatically Generate", "2",    cmVS7FlagTable::UserValueIgnored | cmVS7FlagTable::Continue },  { "PrecompiledHeaderThrough", "YX", "Precompiled Header Name", "",    cmVS7FlagTable::UserValueRequired },  { "UsePrecompiledHeader", "Yu", "Use Precompiled Header", "3",    cmVS7FlagTable::UserValueIgnored | cmVS7FlagTable::Continue },  { "PrecompiledHeaderThrough", "Yu", "Precompiled Header Name", "",    cmVS7FlagTable::UserValueRequired },  { "WholeProgramOptimization", "LTCG", "WholeProgramOptimization", "true",    0 },  // Exception handling mode.  If no entries match, it will be FALSE.  { "ExceptionHandling", "GX", "enable c++ exceptions", "true", 0 },  { "ExceptionHandling", "EHsc", "enable c++ exceptions", "true", 0 },  // The EHa option does not have an IDE setting.  Let it go to false,  // and have EHa passed on the command line by leaving out the table  // entry.  { "", "", "", "", 0 }};cmGlobalVisualStudio7Generator::cmGlobalVisualStudio7Generator(  cmake* cm, std::string const& platformInGeneratorName)  : cmGlobalVisualStudioGenerator(cm, platformInGeneratorName){  this->IntelProjectVersion = 0;  this->DevEnvCommandInitialized = false;  this->MasmEnabled = false;  this->NasmEnabled = false;  this->ExtraFlagTable = cmVS7ExtraFlagTable;}cmGlobalVisualStudio7Generator::~cmGlobalVisualStudio7Generator(){  free(this->IntelProjectVersion);}// Package GUID of Intel Visual Fortran plugin to VS IDE#define CM_INTEL_PLUGIN_GUID "{B68A201D-CB9B-47AF-A52F-7EEC72E217E4}"const char* cmGlobalVisualStudio7Generator::GetIntelProjectVersion(){  if (!this->IntelProjectVersion) {    // Compute the version of the Intel plugin to the VS IDE.    // If the key does not exist then use a default guess.    std::string intelVersion;    std::string vskey = this->GetRegistryBase();    vskey += "\\Packages\\" CM_INTEL_PLUGIN_GUID ";ProductVersion";    cmSystemTools::ReadRegistryValue(vskey.c_str(), intelVersion,                                     cmSystemTools::KeyWOW64_32);    unsigned int intelVersionNumber = ~0u;    sscanf(intelVersion.c_str(), "%u", &intelVersionNumber);    if (intelVersionNumber >= 11) {      // Default to latest known project file version.      intelVersion = "11.0";    } else if (intelVersionNumber == 10) {      // Version 10.x actually uses 9.10 in project files!      intelVersion = "9.10";    } else {      // Version <= 9: use ProductVersion from registry.    }    this->IntelProjectVersion = strdup(intelVersion.c_str());  }  return this->IntelProjectVersion;}void cmGlobalVisualStudio7Generator::EnableLanguage(  std::vector<std::string> const& lang, cmMakefile* mf, bool optional){  mf->AddDefinition("CMAKE_GENERATOR_RC", "rc");  mf->AddDefinition("CMAKE_GENERATOR_NO_COMPILER_ENV", "1");  if (!mf->GetDefinition("CMAKE_CONFIGURATION_TYPES")) {    mf->AddCacheDefinition(      "CMAKE_CONFIGURATION_TYPES", "Debug;Release;MinSizeRel;RelWithDebInfo",      "Semicolon separated list of supported configuration types, "      "only supports Debug, Release, MinSizeRel, and RelWithDebInfo, "      "anything else will be ignored.",      cmStateEnums::STRING);  }  // Create list of configurations requested by user's cache, if any.  this->cmGlobalVisualStudioGenerator::EnableLanguage(lang, mf, optional);  // if this environment variable is set, then copy it to  // a static cache entry.  It will be used by  // cmLocalGenerator::ConstructScript, to add an extra PATH  // to all custom commands.   This is because the VS IDE  // does not use the environment it is run in, and this allows  // for running commands and using dll's that the IDE environment  // does not know about.  std::string extraPath;  if (cmSystemTools::GetEnv("CMAKE_MSVCIDE_RUN_PATH", extraPath)) {    mf->AddCacheDefinition("CMAKE_MSVCIDE_RUN_PATH", extraPath.c_str(),                           "Saved environment variable CMAKE_MSVCIDE_RUN_PATH",                           cmStateEnums::STATIC);  }}bool cmGlobalVisualStudio7Generator::FindMakeProgram(cmMakefile* mf){  if (!this->cmGlobalVisualStudioGenerator::FindMakeProgram(mf)) {    return false;  }  mf->AddDefinition("CMAKE_VS_DEVENV_COMMAND",                    this->GetDevEnvCommand().c_str());  return true;}std::string const& cmGlobalVisualStudio7Generator::GetDevEnvCommand(){  if (!this->DevEnvCommandInitialized) {    this->DevEnvCommandInitialized = true;    this->DevEnvCommand = this->FindDevEnvCommand();  }  return this->DevEnvCommand;}std::string cmGlobalVisualStudio7Generator::FindDevEnvCommand(){  std::string vscmd;  std::string vskey;  // Search in standard location.  vskey = this->GetRegistryBase() + ";InstallDir";  if (cmSystemTools::ReadRegistryValue(vskey.c_str(), vscmd,                                       cmSystemTools::KeyWOW64_32)) {    cmSystemTools::ConvertToUnixSlashes(vscmd);    vscmd += "/devenv.com";    if (cmSystemTools::FileExists(vscmd, true)) {      return vscmd;    }  }  // Search where VS15Preview places it.  vskey = "HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\VisualStudio\\SxS\\VS7;";  vskey += this->GetIDEVersion();  if (cmSystemTools::ReadRegistryValue(vskey.c_str(), vscmd,                                       cmSystemTools::KeyWOW64_32)) {    cmSystemTools::ConvertToUnixSlashes(vscmd);    vscmd += "/Common7/IDE/devenv.com";    if (cmSystemTools::FileExists(vscmd, true)) {      return vscmd;    }  }  vscmd = "devenv.com";  return vscmd;}const char* cmGlobalVisualStudio7Generator::ExternalProjectType(  const char* location){  std::string extension = cmSystemTools::GetFilenameLastExtension(location);  if (extension == ".vbproj") {    return "F184B08F-C81C-45F6-A57F-5ABD9991F28F";  } else if (extension == ".csproj") {    return "FAE04EC0-301F-11D3-BF4B-00C04F79EFBC";  } else if (extension == ".fsproj") {    return "F2A71F9B-5D33-465A-A702-920D77279786";  } else if (extension == ".vdproj") {    return "54435603-DBB4-11D2-8724-00A0C9A8B90C";  } else if (extension == ".dbproj") {    return "C8D11400-126E-41CD-887F-60BD40844F9E";  } else if (extension == ".wixproj") {    return "930C7802-8A8C-48F9-8165-68863BCCD9DD";  } else if (extension == ".pyproj") {    return "888888A0-9F3D-457C-B088-3A5042F75D52";  }  return "8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942";}void cmGlobalVisualStudio7Generator::GenerateBuildCommand(  GeneratedMakeCommand& makeCommand, const std::string& makeProgram,  const std::string& projectName, const std::string& /*projectDir*/,  const std::string& targetName, const std::string& config, bool /*fast*/,  int /*jobs*/, bool /*verbose*/, std::vector<std::string> const& makeOptions){  // Select the caller- or user-preferred make program, else devenv.  std::string makeProgramSelected =    this->SelectMakeProgram(makeProgram, this->GetDevEnvCommand());  // Ignore the above preference if it is msbuild.  // Assume any other value is either a devenv or  // command-line compatible with devenv.  std::string makeProgramLower = makeProgramSelected;  cmSystemTools::LowerCase(makeProgramLower);  if (makeProgramLower.find("msbuild") != std::string::npos) {    makeProgramSelected = this->GetDevEnvCommand();  }  // Workaround to convince VCExpress.exe to produce output.  makeCommand.RequiresOutputForward =    (makeProgramLower.find("vcexpress") != std::string::npos);  makeCommand.add(makeProgramSelected);  makeCommand.add(std::string(projectName) + ".sln");  std::string realTarget = targetName;  bool clean = false;  if (realTarget == "clean") {    clean = true;    realTarget = "ALL_BUILD";  }  makeCommand.add((clean ? "/clean" : "/build"));  makeCommand.add((config.empty() ? "Debug" : config));  makeCommand.add("/project");  makeCommand.add((realTarget.empty() ? "ALL_BUILD" : realTarget));  makeCommand.add(makeOptions.begin(), makeOptions.end());}///! Create a local generator appropriate to this Global GeneratorcmLocalGenerator* cmGlobalVisualStudio7Generator::CreateLocalGenerator(  cmMakefile* mf){  cmLocalVisualStudio7Generator* lg =    new cmLocalVisualStudio7Generator(this, mf);  return lg;}#if defined(CMAKE_BUILD_WITH_CMAKE)Json::Value cmGlobalVisualStudio7Generator::GetJson() const{  Json::Value generator = this->cmGlobalVisualStudioGenerator::GetJson();  generator["platform"] = this->GetPlatformName();  return generator;}#endifbool cmGlobalVisualStudio7Generator::SetSystemName(std::string const& s,                                                   cmMakefile* mf){  mf->AddDefinition("CMAKE_VS_INTEL_Fortran_PROJECT_VERSION",                    this->GetIntelProjectVersion());  return this->cmGlobalVisualStudioGenerator::SetSystemName(s, mf);}void cmGlobalVisualStudio7Generator::Generate(){  // first do the superclass method  this->cmGlobalVisualStudioGenerator::Generate();  // Now write out the DSW  this->OutputSLNFile();  // If any solution or project files changed during the generation,  // tell Visual Studio to reload them...  if (!cmSystemTools::GetErrorOccuredFlag()) {    this->CallVisualStudioMacro(MacroReload);  }}void cmGlobalVisualStudio7Generator::OutputSLNFile(  cmLocalGenerator* root, std::vector<cmLocalGenerator*>& generators){  if (generators.empty()) {    return;  }  this->CurrentProject = root->GetProjectName();  std::string fname = root->GetCurrentBinaryDirectory();  fname += "/";  fname += root->GetProjectName();  fname += ".sln";  cmGeneratedFileStream fout(fname.c_str());  fout.SetCopyIfDifferent(true);  if (!fout) {    return;  }  this->WriteSLNFile(fout, root, generators);  if (fout.Close()) {    this->FileReplacedDuringGenerate(fname);  }}// output the SLN filevoid cmGlobalVisualStudio7Generator::OutputSLNFile(){  for (auto& it : this->ProjectMap) {    this->OutputSLNFile(it.second[0], it.second);  }}void cmGlobalVisualStudio7Generator::WriteTargetConfigurations(  std::ostream& fout, std::vector<std::string> const& configs,  OrderedTargetDependSet const& projectTargets){  // loop over again and write out configurations for each target  // in the solution  for (cmGeneratorTarget const* target : projectTargets) {    if (target->GetType() == cmStateEnums::INTERFACE_LIBRARY) {      continue;    }    const char* expath = target->GetProperty("EXTERNAL_MSPROJECT");    if (expath) {      std::set<std::string> allConfigurations(configs.begin(), configs.end());      const char* mapping = target->GetProperty("VS_PLATFORM_MAPPING");      this->WriteProjectConfigurations(fout, target->GetName().c_str(),                                       *target, configs, allConfigurations,                                       mapping ? mapping : "");    } else {      const std::set<std::string>& configsPartOfDefaultBuild =        this->IsPartOfDefaultBuild(configs, projectTargets, target);      const char* vcprojName = target->GetProperty("GENERATOR_FILE_NAME");      if (vcprojName) {        this->WriteProjectConfigurations(fout, vcprojName, *target, configs,                                         configsPartOfDefaultBuild);      }    }  }}void cmGlobalVisualStudio7Generator::WriteTargetsToSolution(  std::ostream& fout, cmLocalGenerator* root,  OrderedTargetDependSet const& projectTargets){  VisualStudioFolders.clear();  std::string rootBinaryDir = root->GetCurrentBinaryDirectory();  for (cmGeneratorTarget const* target : projectTargets) {    if (target->GetType() == cmStateEnums::INTERFACE_LIBRARY) {      continue;    }    bool written = false;    // handle external vc project files    const char* expath = target->GetProperty("EXTERNAL_MSPROJECT");    if (expath) {      std::string project = target->GetName();      std::string location = expath;      this->WriteExternalProject(fout, project.c_str(), location.c_str(),                                 target->GetProperty("VS_PROJECT_TYPE"),                                 target->GetUtilities());      written = true;    } else {      const char* vcprojName = target->GetProperty("GENERATOR_FILE_NAME");      if (vcprojName) {        cmLocalGenerator* lg = target->GetLocalGenerator();        std::string dir = lg->GetCurrentBinaryDirectory();        dir = root->MaybeConvertToRelativePath(rootBinaryDir, dir.c_str());        if (dir == ".") {          dir.clear(); // msbuild cannot handle ".\" prefix        }        this->WriteProject(fout, vcprojName, dir.c_str(), target);        written = true;      }    }    // Create "solution folder" information from FOLDER target property    //    if (written && this->UseFolderProperty()) {      const std::string targetFolder = target->GetEffectiveFolderName();      if (!targetFolder.empty()) {        std::vector<std::string> tokens =          cmSystemTools::SplitString(targetFolder, '/', false);        std::string cumulativePath;        for (std::string const& iter : tokens) {          if (!iter.size()) {            continue;          }          if (cumulativePath.empty()) {            cumulativePath = "CMAKE_FOLDER_GUID_" + iter;          } else {            VisualStudioFolders[cumulativePath].insert(cumulativePath + "/" +                                                       iter);            cumulativePath = cumulativePath + "/" + iter;          }        }        if (!cumulativePath.empty()) {          VisualStudioFolders[cumulativePath].insert(target->GetName());        }      }    }  }}void cmGlobalVisualStudio7Generator::WriteTargetDepends(  std::ostream& fout, OrderedTargetDependSet const& projectTargets){  for (cmGeneratorTarget const* target : projectTargets) {    if (target->GetType() == cmStateEnums::INTERFACE_LIBRARY) {      continue;    }    const char* vcprojName = target->GetProperty("GENERATOR_FILE_NAME");    if (vcprojName) {      std::string dir =        target->GetLocalGenerator()->GetCurrentSourceDirectory();      this->WriteProjectDepends(fout, vcprojName, dir.c_str(), target);    }  }}void cmGlobalVisualStudio7Generator::WriteFolders(std::ostream& fout){  const char* prefix = "CMAKE_FOLDER_GUID_";  const std::string::size_type skip_prefix = strlen(prefix);  std::string guidProjectTypeFolder = "2150E333-8FDC-42A3-9474-1A3956D46DE8";  for (auto const& iter : VisualStudioFolders) {    std::string fullName = iter.first;    std::string guid = this->GetGUID(fullName);    std::replace(fullName.begin(), fullName.end(), '/', '\\');    if (cmSystemTools::StringStartsWith(fullName.c_str(), prefix)) {      fullName = fullName.substr(skip_prefix);    }    std::string nameOnly = cmSystemTools::GetFilenameName(fullName);    fout << "Project(\"{" << guidProjectTypeFolder << "}\") = \"" << nameOnly         << "\", \"" << fullName << "\", \"{" << guid << "}\"\nEndProject\n";  }}void cmGlobalVisualStudio7Generator::WriteFoldersContent(std::ostream& fout){  for (auto const& iter : VisualStudioFolders) {    std::string key(iter.first);    std::string guidParent(this->GetGUID(key));    for (std::string const& it : iter.second) {      std::string value(it);      std::string guid(this->GetGUID(value));      fout << "\t\t{" << guid << "} = {" << guidParent << "}\n";    }  }}std::string cmGlobalVisualStudio7Generator::ConvertToSolutionPath(  const char* path){  // Convert to backslashes.  Do not use ConvertToOutputPath because  // we will add quoting ourselves, and we know these projects always  // use windows slashes.  std::string d = path;  std::string::size_type pos = 0;  while ((pos = d.find('/', pos)) != d.npos) {    d[pos++] = '\\';  }  return d;}void cmGlobalVisualStudio7Generator::WriteSLNGlobalSections(  std::ostream& fout, cmLocalGenerator* root){  std::string const guid = this->GetGUID(root->GetProjectName() + ".sln");  bool extensibilityGlobalsOverridden = false;  bool extensibilityAddInsOverridden = false;  const std::vector<std::string> propKeys =    root->GetMakefile()->GetPropertyKeys();  for (std::string const& it : propKeys) {    if (it.find("VS_GLOBAL_SECTION_") == 0) {      std::string sectionType;      std::string name = it.substr(18);      if (name.find("PRE_") == 0) {        name = name.substr(4);        sectionType = "preSolution";      } else if (name.find("POST_") == 0) {        name = name.substr(5);        sectionType = "postSolution";      } else        continue;      if (!name.empty()) {        bool addGuid = false;        if (name == "ExtensibilityGlobals" && sectionType == "postSolution") {          addGuid = true;          extensibilityGlobalsOverridden = true;        } else if (name == "ExtensibilityAddIns" &&                   sectionType == "postSolution") {          extensibilityAddInsOverridden = true;        }        fout << "\tGlobalSection(" << name << ") = " << sectionType << "\n";        std::vector<std::string> keyValuePairs;        cmSystemTools::ExpandListArgument(root->GetMakefile()->GetProperty(it),                                          keyValuePairs);        for (std::string const& itPair : keyValuePairs) {          const std::string::size_type posEqual = itPair.find('=');          if (posEqual != std::string::npos) {            const std::string key =              cmSystemTools::TrimWhitespace(itPair.substr(0, posEqual));            const std::string value =              cmSystemTools::TrimWhitespace(itPair.substr(posEqual + 1));            fout << "\t\t" << key << " = " << value << "\n";            if (key == "SolutionGuid") {              addGuid = false;            }          }        }        if (addGuid) {          fout << "\t\tSolutionGuid = {" << guid << "}\n";        }        fout << "\tEndGlobalSection\n";      }    }  }  if (!extensibilityGlobalsOverridden) {    fout << "\tGlobalSection(ExtensibilityGlobals) = postSolution\n"         << "\t\tSolutionGuid = {" << guid << "}\n"         << "\tEndGlobalSection\n";  }  if (!extensibilityAddInsOverridden)    fout << "\tGlobalSection(ExtensibilityAddIns) = postSolution\n"         << "\tEndGlobalSection\n";}// Standard end of dsw filevoid cmGlobalVisualStudio7Generator::WriteSLNFooter(std::ostream& fout){  fout << "EndGlobal\n";}std::string cmGlobalVisualStudio7Generator::WriteUtilityDepend(  cmGeneratorTarget const* target){  std::vector<std::string> configs;  target->Target->GetMakefile()->GetConfigurations(configs);  std::string pname = target->GetName();  pname += "_UTILITY";  std::string fname = target->GetLocalGenerator()->GetCurrentBinaryDirectory();  fname += "/";  fname += pname;  fname += ".vcproj";  cmGeneratedFileStream fout(fname.c_str());  fout.SetCopyIfDifferent(true);  std::string guid = this->GetGUID(pname.c_str());  /* clang-format off */  fout <<    "<?xml version=\"1.0\" encoding = \""    << this->Encoding() << "\"?>\n"    "<VisualStudioProject\n"    "\tProjectType=\"Visual C++\"\n"    "\tVersion=\"" << this->GetIDEVersion() << "0\"\n"    "\tName=\"" << pname << "\"\n"    "\tProjectGUID=\"{" << guid << "}\"\n"    "\tKeyword=\"Win32Proj\">\n"    "\t<Platforms><Platform Name=\"Win32\"/></Platforms>\n"    "\t<Configurations>\n"    ;  /* clang-format on */  for (std::string const& i : configs) {    /* clang-format off */    fout <<      "\t\t<Configuration\n"      "\t\t\tName=\"" << i << "|Win32\"\n"      "\t\t\tOutputDirectory=\"" << i << "\"\n"      "\t\t\tIntermediateDirectory=\"" << pname << ".dir\\" << i << "\"\n"      "\t\t\tConfigurationType=\"10\"\n"      "\t\t\tUseOfMFC=\"0\"\n"      "\t\t\tATLMinimizesCRunTimeLibraryUsage=\"FALSE\"\n"      "\t\t\tCharacterSet=\"2\">\n"      "\t\t</Configuration>\n"      ;    /* clang-format on */  }  /* clang-format off */  fout <<    "\t</Configurations>\n"    "\t<Files></Files>\n"    "\t<Globals></Globals>\n"    "</VisualStudioProject>\n"    ;  /* clang-format on */  if (fout.Close()) {    this->FileReplacedDuringGenerate(fname);  }  return pname;}std::string cmGlobalVisualStudio7Generator::GetGUID(std::string const& name){  std::string const& guidStoreName = name + "_GUID_CMAKE";  if (const char* storedGUID =        this->CMakeInstance->GetCacheDefinition(guidStoreName.c_str())) {    return std::string(storedGUID);  }  // Compute a GUID that is deterministic but unique to the build tree.  std::string input = this->CMakeInstance->GetState()->GetBinaryDirectory();  input += "|";  input += name;  cmUuid uuidGenerator;  std::vector<unsigned char> uuidNamespace;  uuidGenerator.StringToBinary("ee30c4be-5192-4fb0-b335-722a2dffe760",                               uuidNamespace);  std::string guid = uuidGenerator.FromMd5(uuidNamespace, input);  return cmSystemTools::UpperCase(guid);}void cmGlobalVisualStudio7Generator::AppendDirectoryForConfig(  const std::string& prefix, const std::string& config,  const std::string& suffix, std::string& dir){  if (!config.empty()) {    dir += prefix;    dir += config;    dir += suffix;  }}std::set<std::string> cmGlobalVisualStudio7Generator::IsPartOfDefaultBuild(  std::vector<std::string> const& configs,  OrderedTargetDependSet const& projectTargets,  cmGeneratorTarget const* target){  std::set<std::string> activeConfigs;  // if it is a utilitiy target then only make it part of the  // default build if another target depends on it  int type = target->GetType();  if (type == cmStateEnums::GLOBAL_TARGET) {    std::vector<std::string> targetNames;    targetNames.push_back("INSTALL");    targetNames.push_back("PACKAGE");    for (std::string const& t : targetNames) {      // check if target <t> is part of default build      if (target->GetName() == t) {        const std::string propertyName =          "CMAKE_VS_INCLUDE_" + t + "_TO_DEFAULT_BUILD";        // inspect CMAKE_VS_INCLUDE_<t>_TO_DEFAULT_BUILD properties        for (std::string const& i : configs) {          const char* propertyValue =            target->Target->GetMakefile()->GetDefinition(propertyName);          cmGeneratorExpression ge;          std::unique_ptr<cmCompiledGeneratorExpression> cge =            ge.Parse(propertyValue);          if (cmSystemTools::IsOn(                cge->Evaluate(target->GetLocalGenerator(), i))) {            activeConfigs.insert(i);          }        }      }    }    return activeConfigs;  }  if (type == cmStateEnums::UTILITY &&      !this->IsDependedOn(projectTargets, target)) {    return activeConfigs;  }  // inspect EXCLUDE_FROM_DEFAULT_BUILD[_<CONFIG>] properties  for (std::string const& i : configs) {    const char* propertyValue =      target->GetFeature("EXCLUDE_FROM_DEFAULT_BUILD", i);    if (cmSystemTools::IsOff(propertyValue)) {      activeConfigs.insert(i);    }  }  return activeConfigs;}bool cmGlobalVisualStudio7Generator::IsDependedOn(  OrderedTargetDependSet const& projectTargets, cmGeneratorTarget const* gtIn){  for (cmTargetDepend const& l : projectTargets) {    TargetDependSet const& tgtdeps = this->GetTargetDirectDepends(l);    if (tgtdeps.count(gtIn)) {      return true;    }  }  return false;}std::string cmGlobalVisualStudio7Generator::Encoding(){  return "UTF-8";}
 |