mirror of
https://github.com/reactos/CMake.git
synced 2024-12-15 23:57:44 +00:00
4878c00905
"imported" executable target. This can then be used e.g. with ADD_CUSTOM_COMMAND() to generate stuff. It adds a second container for "imported" targets, and FindTarget() now takes an additional argument bool useImportedTargets to specify whether you also want to search in the imported targets or only in the "normal" targets. Alex
818 lines
25 KiB
C++
818 lines
25 KiB
C++
/*=========================================================================
|
|
|
|
Program: CMake - Cross-Platform Makefile Generator
|
|
Module: $RCSfile$
|
|
Language: C++
|
|
Date: $Date$
|
|
Version: $Revision$
|
|
|
|
Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
|
|
See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even
|
|
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
PURPOSE. See the above copyright notices for more information.
|
|
|
|
=========================================================================*/
|
|
#include "windows.h" // this must be first to define GetCurrentDirectory
|
|
#include "cmGlobalVisualStudio7Generator.h"
|
|
#include "cmLocalVisualStudio7Generator.h"
|
|
#include "cmGeneratedFileStream.h"
|
|
#include "cmMakefile.h"
|
|
#include "cmake.h"
|
|
|
|
cmGlobalVisualStudio7Generator::cmGlobalVisualStudio7Generator()
|
|
{
|
|
this->FindMakeProgramFile = "CMakeVS7FindMake.cmake";
|
|
}
|
|
|
|
|
|
void cmGlobalVisualStudio7Generator
|
|
::EnableLanguage(std::vector<std::string>const & lang,
|
|
cmMakefile *mf)
|
|
{
|
|
mf->AddDefinition("CMAKE_GENERATOR_CC", "cl");
|
|
mf->AddDefinition("CMAKE_GENERATOR_CXX", "cl");
|
|
mf->AddDefinition("CMAKE_GENERATOR_RC", "rc");
|
|
mf->AddDefinition("CMAKE_GENERATOR_NO_COMPILER_ENV", "1");
|
|
mf->AddDefinition("CMAKE_GENERATOR_Fortran", "ifort");
|
|
|
|
this->AddPlatformDefinitions(mf);
|
|
|
|
// Create list of configurations requested by user's cache, if any.
|
|
this->cmGlobalGenerator::EnableLanguage(lang, mf);
|
|
this->GenerateConfigurations(mf);
|
|
|
|
// 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.
|
|
const char* extraPath = cmSystemTools::GetEnv("CMAKE_MSVCIDE_RUN_PATH");
|
|
if(extraPath)
|
|
{
|
|
mf->AddCacheDefinition
|
|
("CMAKE_MSVCIDE_RUN_PATH", extraPath,
|
|
"Saved environment variable CMAKE_MSVCIDE_RUN_PATH",
|
|
cmCacheManager::STATIC);
|
|
}
|
|
|
|
}
|
|
|
|
void cmGlobalVisualStudio7Generator::AddPlatformDefinitions(cmMakefile* mf)
|
|
{
|
|
mf->AddDefinition("MSVC70", "1");
|
|
}
|
|
|
|
std::string cmGlobalVisualStudio7Generator
|
|
::GenerateBuildCommand(const char* makeProgram,
|
|
const char *projectName,
|
|
const char* additionalOptions, const char *targetName,
|
|
const char* config, bool ignoreErrors, bool)
|
|
{
|
|
// Ingoring errors is not implemented in visual studio 6
|
|
(void) ignoreErrors;
|
|
|
|
// now build the test
|
|
std::string makeCommand =
|
|
cmSystemTools::ConvertToOutputPath(makeProgram);
|
|
std::string lowerCaseCommand = makeCommand;
|
|
cmSystemTools::LowerCase(lowerCaseCommand);
|
|
|
|
// if there are spaces in the makeCommand, assume a full path
|
|
// and convert it to a path with no spaces in it as the
|
|
// RunSingleCommand does not like spaces
|
|
#if defined(_WIN32) && !defined(__CYGWIN__)
|
|
if(makeCommand.find(' ') != std::string::npos)
|
|
{
|
|
cmSystemTools::GetShortPath(makeCommand.c_str(), makeCommand);
|
|
}
|
|
#endif
|
|
makeCommand += " ";
|
|
makeCommand += projectName;
|
|
makeCommand += ".sln ";
|
|
bool clean = false;
|
|
if ( targetName && strcmp(targetName, "clean") == 0 )
|
|
{
|
|
clean = true;
|
|
targetName = "ALL_BUILD";
|
|
}
|
|
if(clean)
|
|
{
|
|
makeCommand += "/clean ";
|
|
}
|
|
else
|
|
{
|
|
makeCommand += "/build ";
|
|
}
|
|
|
|
if(config && strlen(config))
|
|
{
|
|
makeCommand += config;
|
|
}
|
|
else
|
|
{
|
|
makeCommand += "Debug";
|
|
}
|
|
makeCommand += " /project ";
|
|
|
|
if (targetName && strlen(targetName))
|
|
{
|
|
makeCommand += targetName;
|
|
}
|
|
else
|
|
{
|
|
makeCommand += "ALL_BUILD";
|
|
}
|
|
if ( additionalOptions )
|
|
{
|
|
makeCommand += " ";
|
|
makeCommand += additionalOptions;
|
|
}
|
|
return makeCommand;
|
|
}
|
|
|
|
///! Create a local generator appropriate to this Global Generator
|
|
cmLocalGenerator *cmGlobalVisualStudio7Generator::CreateLocalGenerator()
|
|
{
|
|
cmLocalVisualStudio7Generator *lg = new cmLocalVisualStudio7Generator;
|
|
lg->SetExtraFlagTable(this->GetExtraFlagTableVS7());
|
|
lg->SetGlobalGenerator(this);
|
|
return lg;
|
|
}
|
|
|
|
void cmGlobalVisualStudio7Generator::GenerateConfigurations(cmMakefile* mf)
|
|
{
|
|
// process the configurations
|
|
const char* ct
|
|
= this->CMakeInstance->GetCacheDefinition("CMAKE_CONFIGURATION_TYPES");
|
|
if ( ct )
|
|
{
|
|
std::string configTypes = ct;
|
|
|
|
std::string::size_type start = 0;
|
|
std::string::size_type endpos = 0;
|
|
while(endpos != std::string::npos)
|
|
{
|
|
endpos = configTypes.find_first_of(" ;", start);
|
|
std::string config;
|
|
std::string::size_type len;
|
|
if(endpos != std::string::npos)
|
|
{
|
|
len = endpos - start;
|
|
}
|
|
else
|
|
{
|
|
len = configTypes.size() - start;
|
|
}
|
|
config = configTypes.substr(start, len);
|
|
if(config == "Debug" || config == "Release" ||
|
|
config == "MinSizeRel" || config == "RelWithDebInfo")
|
|
{
|
|
// only add unique configurations
|
|
if(std::find(this->Configurations.begin(),
|
|
this->Configurations.end(),
|
|
config) == this->Configurations.end())
|
|
{
|
|
this->Configurations.push_back(config);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
cmSystemTools::Error(
|
|
"Invalid configuration type in CMAKE_CONFIGURATION_TYPES: ",
|
|
config.c_str(),
|
|
" (Valid types are Debug,Release,MinSizeRel,RelWithDebInfo)");
|
|
}
|
|
start = endpos+1;
|
|
}
|
|
}
|
|
if(this->Configurations.size() == 0)
|
|
{
|
|
this->Configurations.push_back("Debug");
|
|
this->Configurations.push_back("Release");
|
|
}
|
|
|
|
// Reset the entry to have a semi-colon separated list.
|
|
std::string configs = this->Configurations[0];
|
|
for(unsigned int i=1; i < this->Configurations.size(); ++i)
|
|
{
|
|
configs += ";";
|
|
configs += this->Configurations[i];
|
|
}
|
|
|
|
mf->AddCacheDefinition(
|
|
"CMAKE_CONFIGURATION_TYPES",
|
|
configs.c_str(),
|
|
"Semicolon separated list of supported configuration types, "
|
|
"only supports Debug, Release, MinSizeRel, and RelWithDebInfo, "
|
|
"anything else will be ignored.",
|
|
cmCacheManager::STRING);
|
|
}
|
|
|
|
void cmGlobalVisualStudio7Generator::Generate()
|
|
{
|
|
// first do the superclass method
|
|
this->cmGlobalVisualStudioGenerator::Generate();
|
|
|
|
// Now write out the DSW
|
|
this->OutputSLNFile();
|
|
}
|
|
|
|
void cmGlobalVisualStudio7Generator
|
|
::OutputSLNFile(cmLocalGenerator* root,
|
|
std::vector<cmLocalGenerator*>& generators)
|
|
{
|
|
if(generators.size() == 0)
|
|
{
|
|
return;
|
|
}
|
|
this->CurrentProject = root->GetMakefile()->GetProjectName();
|
|
std::string fname = root->GetMakefile()->GetStartOutputDirectory();
|
|
fname += "/";
|
|
fname += root->GetMakefile()->GetProjectName();
|
|
fname += ".sln";
|
|
cmGeneratedFileStream fout(fname.c_str());
|
|
fout.SetCopyIfDifferent(true);
|
|
if(!fout)
|
|
{
|
|
return;
|
|
}
|
|
this->WriteSLNFile(fout, root, generators);
|
|
}
|
|
|
|
// output the SLN file
|
|
void cmGlobalVisualStudio7Generator::OutputSLNFile()
|
|
{
|
|
std::map<cmStdString, std::vector<cmLocalGenerator*> >::iterator it;
|
|
for(it = this->ProjectMap.begin(); it!= this->ProjectMap.end(); ++it)
|
|
{
|
|
this->OutputSLNFile(it->second[0], it->second);
|
|
}
|
|
}
|
|
|
|
|
|
// Write a SLN file to the stream
|
|
void cmGlobalVisualStudio7Generator
|
|
::WriteSLNFile(std::ostream& fout,
|
|
cmLocalGenerator* root,
|
|
std::vector<cmLocalGenerator*>& generators)
|
|
{
|
|
// Write out the header for a SLN file
|
|
this->WriteSLNHeader(fout);
|
|
|
|
// Get the start directory with the trailing slash
|
|
std::string rootdir = root->GetMakefile()->GetStartOutputDirectory();
|
|
rootdir += "/";
|
|
bool doneAllBuild = false;
|
|
bool doneRunTests = false;
|
|
bool doneInstall = false;
|
|
bool doneEditCache = false;
|
|
bool doneRebuildCache = false;
|
|
bool donePackage = false;
|
|
|
|
// For each cmMakefile, create a VCProj for it, and
|
|
// add it to this SLN file
|
|
unsigned int i;
|
|
for(i = 0; i < generators.size(); ++i)
|
|
{
|
|
if(this->IsExcluded(root, generators[i]))
|
|
{
|
|
continue;
|
|
}
|
|
cmMakefile* mf = generators[i]->GetMakefile();
|
|
|
|
// Get the source directory from the makefile
|
|
std::string dir = mf->GetStartOutputDirectory();
|
|
// remove the home directory and / from the source directory
|
|
// this gives a relative path
|
|
cmSystemTools::ReplaceString(dir, rootdir.c_str(), "");
|
|
|
|
// Get the list of create dsp files names from the cmVCProjWriter, more
|
|
// than one dsp could have been created per input CMakeLists.txt file
|
|
// for each target
|
|
cmTargets &tgts = generators[i]->GetMakefile()->GetTargets();
|
|
for (cmTargets::iterator l = tgts.begin(); l != tgts.end(); ++l)
|
|
{
|
|
// special handling for the current makefile
|
|
if(mf == generators[0]->GetMakefile())
|
|
{
|
|
dir = "."; // no subdirectory for project generated
|
|
// if this is the special ALL_BUILD utility, then
|
|
// make it depend on every other non UTILITY project.
|
|
// This is done by adding the names to the GetUtilities
|
|
// vector on the makefile
|
|
if(l->first == "ALL_BUILD" && !doneAllBuild)
|
|
{
|
|
unsigned int j;
|
|
for(j = 0; j < generators.size(); ++j)
|
|
{
|
|
cmTargets &atgts = generators[j]->GetMakefile()->GetTargets();
|
|
for(cmTargets::iterator al = atgts.begin();
|
|
al != atgts.end(); ++al)
|
|
{
|
|
if (!al->second.GetPropertyAsBool("EXCLUDE_FROM_ALL"))
|
|
{
|
|
if (al->second.GetType() == cmTarget::UTILITY ||
|
|
al->second.GetType() == cmTarget::GLOBAL_TARGET)
|
|
{
|
|
l->second.AddUtility(al->first.c_str());
|
|
}
|
|
else
|
|
{
|
|
l->second.AddLinkLibrary(al->first,cmTarget::GENERAL);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
// Write the project into the SLN file
|
|
if (strncmp(l->first.c_str(), "INCLUDE_EXTERNAL_MSPROJECT", 26) == 0)
|
|
{
|
|
cmCustomCommand cc = l->second.GetPostBuildCommands()[0];
|
|
const cmCustomCommandLines& cmds = cc.GetCommandLines();
|
|
std::string project = cmds[0][0];
|
|
std::string location = cmds[0][1];
|
|
this->WriteExternalProject(fout, project.c_str(),
|
|
location.c_str(), cc.GetDepends());
|
|
}
|
|
else
|
|
{
|
|
if ((l->second.GetType() != cmTarget::INSTALL_FILES)
|
|
&& (l->second.GetType() != cmTarget::INSTALL_PROGRAMS))
|
|
{
|
|
bool skip = false;
|
|
if(l->first == "ALL_BUILD" )
|
|
{
|
|
if(doneAllBuild)
|
|
{
|
|
skip = true;
|
|
}
|
|
else
|
|
{
|
|
doneAllBuild = true;
|
|
}
|
|
}
|
|
if(l->first == "INSTALL")
|
|
{
|
|
if(doneInstall)
|
|
{
|
|
skip = true;
|
|
}
|
|
else
|
|
{
|
|
doneInstall = true;
|
|
}
|
|
}
|
|
if(l->first == "RUN_TESTS")
|
|
{
|
|
if(doneRunTests)
|
|
{
|
|
skip = true;
|
|
}
|
|
else
|
|
{
|
|
doneRunTests = true;
|
|
}
|
|
}
|
|
if(l->first == "EDIT_CACHE")
|
|
{
|
|
if(doneEditCache)
|
|
{
|
|
skip = true;
|
|
}
|
|
else
|
|
{
|
|
doneEditCache = true;
|
|
}
|
|
}
|
|
if(l->first == "REBUILD_CACHE")
|
|
{
|
|
if(doneRebuildCache)
|
|
{
|
|
skip = true;
|
|
}
|
|
else
|
|
{
|
|
doneRebuildCache = true;
|
|
}
|
|
}
|
|
if(l->first == "PACKAGE")
|
|
{
|
|
if(donePackage)
|
|
{
|
|
skip = true;
|
|
}
|
|
else
|
|
{
|
|
donePackage = true;
|
|
}
|
|
}
|
|
if(!skip)
|
|
{
|
|
const char *dspname =
|
|
l->second.GetProperty("GENERATOR_FILE_NAME");
|
|
if (dspname)
|
|
{
|
|
this->WriteProject(fout, dspname, dir.c_str(),l->second);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
fout << "Global\n"
|
|
<< "\tGlobalSection(SolutionConfiguration) = preSolution\n";
|
|
|
|
int c = 0;
|
|
for(std::vector<std::string>::iterator i = this->Configurations.begin();
|
|
i != this->Configurations.end(); ++i)
|
|
{
|
|
fout << "\t\tConfigName." << c << " = " << *i << "\n";
|
|
c++;
|
|
}
|
|
fout << "\tEndGlobalSection\n"
|
|
<< "\tGlobalSection(ProjectDependencies) = postSolution\n";
|
|
|
|
// loop over again and compute the depends
|
|
for(i = 0; i < generators.size(); ++i)
|
|
{
|
|
cmMakefile* mf = generators[i]->GetMakefile();
|
|
cmLocalVisualStudio7Generator* pg =
|
|
static_cast<cmLocalVisualStudio7Generator*>(generators[i]);
|
|
// Get the list of create dsp files names from the cmVCProjWriter, more
|
|
// than one dsp could have been created per input CMakeLists.txt file
|
|
// for each target
|
|
cmTargets &tgts = pg->GetMakefile()->GetTargets();
|
|
cmTargets::iterator l = tgts.begin();
|
|
std::string dir = mf->GetStartDirectory();
|
|
for(; l != tgts.end(); ++l)
|
|
{
|
|
if (strncmp(l->first.c_str(), "INCLUDE_EXTERNAL_MSPROJECT", 26) == 0)
|
|
{
|
|
cmCustomCommand cc = l->second.GetPostBuildCommands()[0];
|
|
const cmCustomCommandLines& cmds = cc.GetCommandLines();
|
|
std::string name = cmds[0][0];
|
|
std::vector<std::string> depends = cc.GetDepends();
|
|
std::vector<std::string>::iterator iter;
|
|
int depcount = 0;
|
|
for(iter = depends.begin(); iter != depends.end(); ++iter)
|
|
{
|
|
std::string guid = this->GetGUID(iter->c_str());
|
|
if(guid.size() == 0)
|
|
{
|
|
std::string m = "Target: ";
|
|
m += l->first;
|
|
m += " depends on unknown target: ";
|
|
m += iter->c_str();
|
|
cmSystemTools::Error(m.c_str());
|
|
}
|
|
|
|
fout << "\t\t{" << this->GetGUID(name.c_str())
|
|
<< "}." << depcount << " = {" << guid.c_str() << "}\n";
|
|
depcount++;
|
|
}
|
|
}
|
|
else if ((l->second.GetType() != cmTarget::INSTALL_FILES)
|
|
&& (l->second.GetType() != cmTarget::INSTALL_PROGRAMS))
|
|
{
|
|
const char *dspname =
|
|
l->second.GetProperty("GENERATOR_FILE_NAME");
|
|
if (dspname)
|
|
{
|
|
this->WriteProjectDepends(fout, dspname,
|
|
dir.c_str(), l->second);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
fout << "\tEndGlobalSection\n";
|
|
fout << "\tGlobalSection(ProjectConfiguration) = postSolution\n";
|
|
// loop over again and compute the depends
|
|
for(i = 0; i < generators.size(); ++i)
|
|
{
|
|
cmMakefile* mf = generators[i]->GetMakefile();
|
|
cmLocalVisualStudio7Generator* pg =
|
|
static_cast<cmLocalVisualStudio7Generator*>(generators[i]);
|
|
// Get the list of create dsp files names from the cmVCProjWriter, more
|
|
// than one dsp could have been created per input CMakeLists.txt file
|
|
// for each target
|
|
cmTargets &tgts = pg->GetMakefile()->GetTargets();
|
|
cmTargets::iterator l = tgts.begin();
|
|
std::string dir = mf->GetStartDirectory();
|
|
for(; l != tgts.end(); ++l)
|
|
{
|
|
if(strncmp(l->first.c_str(), "INCLUDE_EXTERNAL_MSPROJECT", 26) == 0)
|
|
{
|
|
cmCustomCommand cc = l->second.GetPostBuildCommands()[0];
|
|
const cmCustomCommandLines& cmds = cc.GetCommandLines();
|
|
std::string name = cmds[0][0];
|
|
this->WriteProjectConfigurations(fout, name.c_str(),
|
|
true);
|
|
}
|
|
else if ((l->second.GetType() != cmTarget::INSTALL_FILES)
|
|
&& (l->second.GetType() != cmTarget::INSTALL_PROGRAMS))
|
|
{
|
|
bool partOfDefaultBuild = this->IsPartOfDefaultBuild(
|
|
root->GetMakefile()->GetProjectName(),
|
|
&l->second);
|
|
const char *dspname =
|
|
l->second.GetProperty("GENERATOR_FILE_NAME");
|
|
if (dspname)
|
|
{
|
|
this->WriteProjectConfigurations(fout, dspname,
|
|
partOfDefaultBuild);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
fout << "\tEndGlobalSection\n";
|
|
|
|
// Write the footer for the SLN file
|
|
this->WriteSLNFooter(fout);
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
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;
|
|
}
|
|
|
|
// Write a dsp file into the SLN file,
|
|
// Note, that dependencies from executables to
|
|
// the libraries it uses are also done here
|
|
void cmGlobalVisualStudio7Generator::WriteProject(std::ostream& fout,
|
|
const char* dspname,
|
|
const char* dir, cmTarget&)
|
|
{
|
|
fout << "Project(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \""
|
|
<< dspname << "\", \""
|
|
<< this->ConvertToSolutionPath(dir)
|
|
<< "\\" << dspname << ".vcproj\", \"{"
|
|
<< this->GetGUID(dspname) << "}\"\nEndProject\n";
|
|
}
|
|
|
|
|
|
|
|
// Write a dsp file into the SLN file,
|
|
// Note, that dependencies from executables to
|
|
// the libraries it uses are also done here
|
|
void
|
|
cmGlobalVisualStudio7Generator
|
|
::WriteProjectDepends(std::ostream& fout,
|
|
const char* dspname,
|
|
const char*, cmTarget& target)
|
|
{
|
|
int depcount = 0;
|
|
// insert Begin Project Dependency Project_Dep_Name project stuff here
|
|
if (target.GetType() != cmTarget::STATIC_LIBRARY)
|
|
{
|
|
cmTarget::LinkLibraryVectorType::const_iterator j, jend;
|
|
j = target.GetLinkLibraries().begin();
|
|
jend = target.GetLinkLibraries().end();
|
|
for(;j!= jend; ++j)
|
|
{
|
|
if(j->first != dspname)
|
|
{
|
|
// is the library part of this SLN ? If so add dependency
|
|
if(this->FindTarget(this->CurrentProject.c_str(),
|
|
j->first.c_str()),
|
|
false)
|
|
{
|
|
std::string guid = this->GetGUID(j->first.c_str());
|
|
if(guid.size() == 0)
|
|
{
|
|
std::string m = "Target: ";
|
|
m += dspname;
|
|
m += " depends on unknown target: ";
|
|
m += j->first.c_str();
|
|
cmSystemTools::Error(m.c_str());
|
|
}
|
|
fout << "\t\t{" << this->GetGUID(dspname) << "}."
|
|
<< depcount << " = {" << guid << "}\n";
|
|
depcount++;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
std::set<cmStdString>::const_iterator i, end;
|
|
// write utility dependencies.
|
|
i = target.GetUtilities().begin();
|
|
end = target.GetUtilities().end();
|
|
for(;i!= end; ++i)
|
|
{
|
|
if(*i != dspname)
|
|
{
|
|
std::string name = this->GetUtilityForTarget(target, i->c_str());
|
|
std::string guid = this->GetGUID(name.c_str());
|
|
if(guid.size() == 0)
|
|
{
|
|
std::string m = "Target: ";
|
|
m += dspname;
|
|
m += " depends on unknown target: ";
|
|
m += name.c_str();
|
|
cmSystemTools::Error(m.c_str());
|
|
}
|
|
|
|
fout << "\t\t{" << this->GetGUID(dspname) << "}." << depcount << " = {"
|
|
<< guid << "}\n";
|
|
depcount++;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
// Write a dsp file into the SLN file, Note, that dependencies from
|
|
// executables to the libraries it uses are also done here
|
|
void cmGlobalVisualStudio7Generator
|
|
::WriteProjectConfigurations(std::ostream& fout, const char* name,
|
|
bool partOfDefaultBuild)
|
|
{
|
|
std::string guid = this->GetGUID(name);
|
|
for(std::vector<std::string>::iterator i = this->Configurations.begin();
|
|
i != this->Configurations.end(); ++i)
|
|
{
|
|
fout << "\t\t{" << guid << "}." << *i
|
|
<< ".ActiveCfg = " << *i << "|Win32\n";
|
|
if(partOfDefaultBuild)
|
|
{
|
|
fout << "\t\t{" << guid << "}." << *i
|
|
<< ".Build.0 = " << *i << "|Win32\n";
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// Write a dsp file into the SLN file,
|
|
// Note, that dependencies from executables to
|
|
// the libraries it uses are also done here
|
|
void cmGlobalVisualStudio7Generator::WriteExternalProject(std::ostream& fout,
|
|
const char* name,
|
|
const char* location,
|
|
const std::vector<std::string>&)
|
|
{
|
|
std::string d = cmSystemTools::ConvertToOutputPath(location);
|
|
fout << "Project(\"{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}\") = \""
|
|
<< name << "\", \""
|
|
<< this->ConvertToSolutionPath(location) << "\", \"{"
|
|
<< this->GetGUID(name)
|
|
<< "}\"\n";
|
|
fout << "EndProject\n";
|
|
}
|
|
|
|
|
|
|
|
// Standard end of dsw file
|
|
void cmGlobalVisualStudio7Generator::WriteSLNFooter(std::ostream& fout)
|
|
{
|
|
fout << "\tGlobalSection(ExtensibilityGlobals) = postSolution\n"
|
|
<< "\tEndGlobalSection\n"
|
|
<< "\tGlobalSection(ExtensibilityAddIns) = postSolution\n"
|
|
<< "\tEndGlobalSection\n"
|
|
<< "EndGlobal\n";
|
|
}
|
|
|
|
|
|
// ouput standard header for dsw file
|
|
void cmGlobalVisualStudio7Generator::WriteSLNHeader(std::ostream& fout)
|
|
{
|
|
fout << "Microsoft Visual Studio Solution File, Format Version 7.00\n";
|
|
}
|
|
|
|
std::string cmGlobalVisualStudio7Generator::GetGUID(const char* name)
|
|
{
|
|
std::string guidStoreName = name;
|
|
guidStoreName += "_GUID_CMAKE";
|
|
const char* storedGUID =
|
|
this->CMakeInstance->GetCacheDefinition(guidStoreName.c_str());
|
|
if(storedGUID)
|
|
{
|
|
return std::string(storedGUID);
|
|
}
|
|
cmSystemTools::Error("Unknown Target referenced : ",
|
|
name);
|
|
return "";
|
|
}
|
|
|
|
|
|
void cmGlobalVisualStudio7Generator::CreateGUID(const char* name)
|
|
{
|
|
std::string guidStoreName = name;
|
|
guidStoreName += "_GUID_CMAKE";
|
|
if(this->CMakeInstance->GetCacheDefinition(guidStoreName.c_str()))
|
|
{
|
|
return;
|
|
}
|
|
std::string ret;
|
|
UUID uid;
|
|
unsigned char *uidstr;
|
|
UuidCreate(&uid);
|
|
UuidToString(&uid,&uidstr);
|
|
ret = reinterpret_cast<char*>(uidstr);
|
|
RpcStringFree(&uidstr);
|
|
ret = cmSystemTools::UpperCase(ret);
|
|
this->CMakeInstance->AddCacheEntry(guidStoreName.c_str(),
|
|
ret.c_str(), "Stored GUID",
|
|
cmCacheManager::INTERNAL);
|
|
}
|
|
|
|
std::vector<std::string> *cmGlobalVisualStudio7Generator::GetConfigurations()
|
|
{
|
|
return &this->Configurations;
|
|
};
|
|
|
|
//----------------------------------------------------------------------------
|
|
void cmGlobalVisualStudio7Generator
|
|
::GetDocumentation(cmDocumentationEntry& entry) const
|
|
{
|
|
entry.name = this->GetName();
|
|
entry.brief = "Generates Visual Studio .NET 2002 project files.";
|
|
entry.full = "";
|
|
}
|
|
|
|
// make sure "special" targets have GUID's
|
|
void cmGlobalVisualStudio7Generator::Configure()
|
|
{
|
|
cmGlobalGenerator::Configure();
|
|
this->CreateGUID("ALL_BUILD");
|
|
this->CreateGUID("INSTALL");
|
|
this->CreateGUID("RUN_TESTS");
|
|
this->CreateGUID("EDIT_CACHE");
|
|
this->CreateGUID("REBUILD_CACHE");
|
|
this->CreateGUID("PACKAGE");
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
void
|
|
cmGlobalVisualStudio7Generator
|
|
::AppendDirectoryForConfig(const char* prefix,
|
|
const char* config,
|
|
const char* suffix,
|
|
std::string& dir)
|
|
{
|
|
if(config)
|
|
{
|
|
dir += prefix;
|
|
dir += config;
|
|
dir += suffix;
|
|
}
|
|
}
|
|
|
|
bool cmGlobalVisualStudio7Generator::IsPartOfDefaultBuild(const char* project,
|
|
cmTarget* target)
|
|
{
|
|
if(target->GetPropertyAsBool("EXCLUDE_FROM_DEFAULT_BUILD"))
|
|
{
|
|
return false;
|
|
}
|
|
// 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 == cmTarget::GLOBAL_TARGET)
|
|
{
|
|
return false;
|
|
}
|
|
if(type == cmTarget::UTILITY)
|
|
{
|
|
return this->IsDependedOn(project, target);
|
|
}
|
|
// default is to be part of the build
|
|
return true;
|
|
}
|
|
|
|
//----------------------------------------------------------------------------
|
|
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},
|
|
{0,0,0,0,0}
|
|
};
|
|
cmVS7FlagTable const* cmGlobalVisualStudio7Generator::GetExtraFlagTableVS7()
|
|
{
|
|
return cmVS7ExtraFlagTable;
|
|
}
|