Merge topic 'vs-external-project-type'

a79cbdc VS: Teach include_external_msproject about non-C++ projects (#14661)
This commit is contained in:
Brad King 2013-12-23 10:19:10 -05:00 committed by CMake Topic Stage
commit 11ddaa51ea
3 changed files with 39 additions and 2 deletions

View File

@ -240,7 +240,7 @@ void cmGlobalVisualStudio71Generator
const std::set<cmStdString>& depends)
{
fout << "Project(\"{"
<< (typeGuid ? typeGuid : "8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942")
<< (typeGuid ? typeGuid : this->ExternalProjectType(location))
<< "}\") = \""
<< name << "\", \""
<< this->ConvertToSolutionPath(location) << "\", \"{"

View File

@ -145,6 +145,41 @@ std::string cmGlobalVisualStudio7Generator::FindDevEnvCommand()
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(
std::vector<std::string>& makeCommand,
@ -730,7 +765,7 @@ void cmGlobalVisualStudio7Generator::WriteExternalProject(std::ostream& fout,
std::string d = cmSystemTools::ConvertToOutputPath(location);
fout << "Project("
<< "\"{"
<< (typeGuid ? typeGuid : "8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942")
<< (typeGuid ? typeGuid : this->ExternalProjectType(location))
<< "}\") = \""
<< name << "\", \""
<< this->ConvertToSolutionPath(location) << "\", \"{"

View File

@ -115,6 +115,8 @@ protected:
std::string const& GetDevEnvCommand();
virtual std::string FindDevEnvCommand();
static const char* ExternalProjectType(const char* location);
static cmIDEFlagTable const* GetExtraFlagTableVS7();
virtual void OutputSLNFile(cmLocalGenerator* root,
std::vector<cmLocalGenerator*>& generators);