diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2008-10-07 20:23:20 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2008-10-07 20:23:20 (GMT) |
commit | 637418a8355cf2bc0aa0796c4bd99a65f793c1ed (patch) | |
tree | 5b0300cff579f4cce1564ec3dff7c4d35926ee53 | |
parent | db0e1fd6756fc5da5ec046e00ce736fc5e93c094 (diff) | |
download | CMake-637418a8355cf2bc0aa0796c4bd99a65f793c1ed.zip CMake-637418a8355cf2bc0aa0796c4bd99a65f793c1ed.tar.gz CMake-637418a8355cf2bc0aa0796c4bd99a65f793c1ed.tar.bz2 |
BUG: fix for 4524, add support for target properties to set vs source code control information
-rw-r--r-- | Source/cmLocalVisualStudio7Generator.cxx | 32 | ||||
-rw-r--r-- | Source/cmSetTargetPropertiesCommand.h | 3 |
2 files changed, 32 insertions, 3 deletions
diff --git a/Source/cmLocalVisualStudio7Generator.cxx b/Source/cmLocalVisualStudio7Generator.cxx index faeb620..ce603b6 100644 --- a/Source/cmLocalVisualStudio7Generator.cxx +++ b/Source/cmLocalVisualStudio7Generator.cxx @@ -1832,6 +1832,26 @@ cmLocalVisualStudio7Generator::WriteProjectStart(std::ostream& fout, { keyword = "Win32Proj"; } + const char* vsProjectname = target.GetProperty("VS_SCC_PROJECTNAME"); + if (!vsProjectname) + { + vsProjectname = ""; + } + const char* vsLocalpath = target.GetProperty("VS_SCC_LOCALPATH"); + if (!vsLocalpath) + { + vsLocalpath = ""; + } + const char* vsProvider = target.GetProperty("VS_SCC_PROVIDER"); + std::string providerString; + if (!vsProvider) + { + providerString = ""; + } + else + { + providerString = "\tSccProvider=\"" + std::string(vsProvider) + "\"\n"; + } cmGlobalVisualStudio7Generator* gg = static_cast<cmGlobalVisualStudio7Generator *>(this->GlobalGenerator); fout << "\tName=\"" << projLabel << "\"\n"; @@ -1839,9 +1859,15 @@ cmLocalVisualStudio7Generator::WriteProjectStart(std::ostream& fout, { fout << "\tProjectGUID=\"{" << gg->GetGUID(libName) << "}\"\n"; } - fout << "\tSccProjectName=\"\"\n" - << "\tSccLocalPath=\"\"\n" - << "\tKeyword=\"" << keyword << "\">\n" + // if we have all the required Source code control tags + // then add that to the project + if(vsProvider && vsLocalpath && vsProjectname) + { + fout << "\tSccProjectName=\"" << vsProjectname << "\"\n" + << "\tSccLocalPath=\"" << vsLocalpath << "\"\n" + << "\tSccProvider=\"" << providerString << "\"\n"; + } + fout << "\tKeyword=\"" << keyword << "\">\n" << "\t<Platforms>\n" << "\t\t<Platform\n\t\t\tName=\"" << this->PlatformName << "\"/>\n" << "\t</Platforms>\n"; diff --git a/Source/cmSetTargetPropertiesCommand.h b/Source/cmSetTargetPropertiesCommand.h index e9ff1ce..78429d2 100644 --- a/Source/cmSetTargetPropertiesCommand.h +++ b/Source/cmSetTargetPropertiesCommand.h @@ -145,6 +145,9 @@ public: "the target in an IDE like visual studio. VS_KEYWORD can be set " "to change the visual studio keyword, for example QT integration " "works better if this is set to Qt4VSv1.0.\n" + "VS_SCC_PROJECTNAME, VS_SCC_LOCALPATH, VS_SCC_PROVIDER can be set " + "to add support for source control bindings in a Visual Studio " + "project file.\n" "When a library is built CMake by default generates code to remove " "any existing library using all possible names. This is needed " "to support libraries that switch between STATIC and SHARED by " |