diff options
author | Brad King <brad.king@kitware.com> | 2007-11-09 17:05:03 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2007-11-09 17:05:03 (GMT) |
commit | f9322d188bf8f441a2511ae060bd2a56439deec7 (patch) | |
tree | 081e96171ce8d4683ef4368eb739c2548980b672 | |
parent | c5b01a7daff1657063b938b60ee67bc710e07d6c (diff) | |
download | CMake-f9322d188bf8f441a2511ae060bd2a56439deec7.zip CMake-f9322d188bf8f441a2511ae060bd2a56439deec7.tar.gz CMake-f9322d188bf8f441a2511ae060bd2a56439deec7.tar.bz2 |
ENH: Converted vcproj file generation to use cmGeneratedFileStream for atomic replacement. Replaced the vcproj.cmake copy of the file with a simple vcproj.stamp timestamp file to preserve previous rerun-without-reload behavior.
-rw-r--r-- | Source/cmGlobalVisualStudio8Generator.cxx | 13 | ||||
-rw-r--r-- | Source/cmLocalVisualStudio7Generator.cxx | 44 |
2 files changed, 33 insertions, 24 deletions
diff --git a/Source/cmGlobalVisualStudio8Generator.cxx b/Source/cmGlobalVisualStudio8Generator.cxx index 335dd4c..c7c5fff 100644 --- a/Source/cmGlobalVisualStudio8Generator.cxx +++ b/Source/cmGlobalVisualStudio8Generator.cxx @@ -146,20 +146,21 @@ void cmGlobalVisualStudio8Generator::Generate() // target. const char* no_main_dependency = 0; const char* no_working_directory = 0; + std::string stampName = cmake::GetCMakeFilesDirectoryPostSlash(); + stampName += CMAKE_CHECK_BUILD_SYSTEM_TARGET ".vcproj.stamp"; mf->AddCustomCommandToOutput( - CMAKE_CHECK_BUILD_SYSTEM_TARGET ".vcproj.cmake", listFiles, + stampName.c_str(), listFiles, no_main_dependency, commandLines, "Checking Build System", no_working_directory, true); - if(cmSourceFile* file = mf->GetSource(CMAKE_CHECK_BUILD_SYSTEM_TARGET - ".vcproj.cmake.rule")) + std::string ruleName = stampName; + ruleName += ".rule"; + if(cmSourceFile* file = mf->GetSource(ruleName.c_str())) { tgt->AddSourceFile(file); } else { - cmSystemTools::Error("Error adding rule for " - CMAKE_CHECK_BUILD_SYSTEM_TARGET - ".vcproj.cmake"); + cmSystemTools::Error("Error adding rule for ", stampName.c_str()); } } } diff --git a/Source/cmLocalVisualStudio7Generator.cxx b/Source/cmLocalVisualStudio7Generator.cxx index d7de459..6af5fa8 100644 --- a/Source/cmLocalVisualStudio7Generator.cxx +++ b/Source/cmLocalVisualStudio7Generator.cxx @@ -24,6 +24,8 @@ #include "cmCacheManager.h" #include "cmake.h" +#include "cmGeneratedFileStream.h" + #include <cmsys/System.h> #include <ctype.h> // for isspace @@ -152,25 +154,35 @@ void cmLocalVisualStudio7Generator fname += "/"; fname += lname; fname += ".vcproj"; - // save the name of the real dsp file - std::string realVCProj = fname; - fname += ".cmake"; - std::ofstream fout(fname.c_str()); - if(!fout) - { - cmSystemTools::Error("Error Writing ", fname.c_str()); - } + + // Generate the project file and replace it atomically with + // copy-if-different. We use a separate timestamp so that the IDE + // does not reload project files unnecessarily. + { + cmGeneratedFileStream fout(fname.c_str()); + fout.SetCopyIfDifferent(true); this->WriteVCProjFile(fout,lname,target); - fout.close(); - // if the dsp file has changed, then write it. - cmSystemTools::CopyFileIfDifferent(fname.c_str(), realVCProj.c_str()); + } + + // Touch a timestamp file used to determine when the project file is + // out of date. + std::string stampName; + stampName = this->Makefile->GetStartOutputDirectory(); + stampName += cmake::GetCMakeFilesDirectory(); + cmSystemTools::MakeDirectory(stampName.c_str()); + stampName += "/"; + stampName += lname; + stampName += ".vcproj.stamp"; + std::ofstream stamp(stampName.c_str()); + stamp << "# CMake timestamp for " << lname << ".vcproj" << std::endl; } void cmLocalVisualStudio7Generator::AddVCProjBuildRule(cmTarget& tgt) { - std::string dspname = tgt.GetName(); - dspname += ".vcproj.cmake"; + std::string stampName = cmake::GetCMakeFilesDirectoryPostSlash(); + stampName += tgt.GetName(); + stampName += ".vcproj.stamp"; const char* dsprule = this->Makefile->GetRequiredDefinition("CMAKE_COMMAND"); cmCustomCommandLine commandLine; @@ -213,7 +225,7 @@ void cmLocalVisualStudio7Generator::AddVCProjBuildRule(cmTarget& tgt) cmCustomCommandLines commandLines; commandLines.push_back(commandLine); const char* no_working_directory = 0; - this->Makefile->AddCustomCommandToOutput(dspname.c_str(), listFiles, + this->Makefile->AddCustomCommandToOutput(stampName.c_str(), listFiles, makefileIn.c_str(), commandLines, comment.c_str(), no_working_directory, true); @@ -959,10 +971,6 @@ void cmLocalVisualStudio7Generator::WriteVCProjFile(std::ostream& fout, static_cast<cmGlobalVisualStudio7Generator *> (this->GlobalGenerator)->GetConfigurations(); - // trace the visual studio dependencies - std::string name = libName; - name += ".vcproj.cmake"; - // We may be modifying the source groups temporarily, so make a copy. std::vector<cmSourceGroup> sourceGroups = this->Makefile->GetSourceGroups(); |