diff options
author | Brad King <brad.king@kitware.com> | 2004-10-15 13:24:44 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2004-10-15 13:24:44 (GMT) |
commit | 6bc6466be352aafe052ca6d5f0a2a03784322353 (patch) | |
tree | 39c72523ee56a7def0a66c377dc2cf13f0cf776b | |
parent | b4176dcab91df1d7f28ee41e1f52eb6ae9accbf4 (diff) | |
download | CMake-6bc6466be352aafe052ca6d5f0a2a03784322353.zip CMake-6bc6466be352aafe052ca6d5f0a2a03784322353.tar.gz CMake-6bc6466be352aafe052ca6d5f0a2a03784322353.tar.bz2 |
ENH: Added --check-rerun option to allow a runtime check of whether a new generate should really be done.
-rw-r--r-- | Source/cmake.cxx | 72 | ||||
-rw-r--r-- | Source/cmake.h | 2 |
2 files changed, 74 insertions, 0 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx index dda4acd..c56c740 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -323,6 +323,10 @@ void cmake::SetArgs(const std::vector<std::string>& args) cmSystemTools::ConvertToUnixSlashes(path); this->SetHomeOutputDirectory(path.c_str()); } + else if((i < args.size()-1) && (arg.find("--check-rerun",0) == 0)) + { + m_CheckRerun = args[++i]; + } else if(arg.find("-V",0) == 0) { m_Verbose = true; @@ -1258,6 +1262,12 @@ int cmake::Run(const std::vector<std::string>& args, bool noconfigure) if(m_ScriptMode || !m_Local || !this->CacheVersionMatches() || !cmSystemTools::FileExists(systemFile.c_str()) ) { + // Check whether we should really do a generate. + if(!this->CheckRerun()) + { + return 0; + } + // If we are doing global generate, we better set start and start // output directory to the root of the project. std::string oldstartdir = this->GetStartDirectory(); @@ -1551,3 +1561,65 @@ void cmake::UpdateConversionPathTable() } } } + +int cmake::CheckRerun() +{ + // If no file is provided for the check, we have to rerun. + if(m_CheckRerun.size() == 0) + { + return 1; + } + + // If the file provided does not exist, we have to rerun. + if(!cmSystemTools::FileExists(m_CheckRerun.c_str())) + { + return 1; + } + + // Read the rerun check file and use it to decide whether to do the + // global generate. + cmake cm; + cmGlobalGenerator gg; + gg.SetCMakeInstance(&cm); + std::auto_ptr<cmLocalGenerator> lg(gg.CreateLocalGenerator()); + lg->SetGlobalGenerator(&gg); + cmMakefile* mf = lg->GetMakefile(); + if(!mf->ReadListFile(0, m_CheckRerun.c_str()) || + cmSystemTools::GetErrorOccuredFlag()) + { + // There was an error reading the file. Just rerun. + return 1; + } + + // Get the set of dependencies and outputs. + const char* dependsStr = mf->GetDefinition("CMAKE_MAKEFILE_DEPENDS"); + const char* outputsStr = mf->GetDefinition("CMAKE_MAKEFILE_OUTPUTS"); + if(!dependsStr || !outputsStr) + { + // Not enough information was provided to do the test. Just rerun. + return 1; + } + std::vector<std::string> depends; + std::vector<std::string> outputs; + cmSystemTools::ExpandListArgument(dependsStr, depends); + cmSystemTools::ExpandListArgument(outputsStr, outputs); + + // If any output is older than any dependency then rerun. + for(std::vector<std::string>::iterator dep = depends.begin(); + dep != depends.end(); ++dep) + { + for(std::vector<std::string>::iterator out = outputs.begin(); + out != outputs.end(); ++out) + { + int result = 0; + if(!cmSystemTools::FileTimeCompare(out->c_str(), dep->c_str(), &result) || + result < 0) + { + return 1; + } + } + } + + // No need to rerun. + return 0; +} diff --git a/Source/cmake.h b/Source/cmake.h index 168d690..edeb723 100644 --- a/Source/cmake.h +++ b/Source/cmake.h @@ -289,6 +289,7 @@ protected: ///! used by Run int LocalGenerate(); + int CheckRerun(); /** * Generate CMAKE_ROOT and CMAKE_COMMAND cache entries @@ -309,6 +310,7 @@ private: std::string m_CMakeCommand; std::string m_CXXEnvironment; std::string m_CCEnvironment; + std::string m_CheckRerun; bool m_DebugTryCompile; void UpdateConversionPathTable(); |