diff options
author | Bill Hoffman <bill.hoffman@kitware.com> | 2001-02-23 00:24:43 (GMT) |
---|---|---|
committer | Bill Hoffman <bill.hoffman@kitware.com> | 2001-02-23 00:24:43 (GMT) |
commit | 0b0d1b1d436c6e59ed9ea5c25e1f454fc0ae7827 (patch) | |
tree | ed4c5e1e8bc331799cba8c2a797de8228f9f1f97 /Source/CMakeBuildTargets.cxx | |
parent | 5d903c6b0f5622a149e0aeda1053ce82b39d2807 (diff) | |
download | CMake-0b0d1b1d436c6e59ed9ea5c25e1f454fc0ae7827.zip CMake-0b0d1b1d436c6e59ed9ea5c25e1f454fc0ae7827.tar.gz CMake-0b0d1b1d436c6e59ed9ea5c25e1f454fc0ae7827.tar.bz2 |
ENH: add CMakeCache.txt support
Diffstat (limited to 'Source/CMakeBuildTargets.cxx')
-rw-r--r-- | Source/CMakeBuildTargets.cxx | 33 |
1 files changed, 31 insertions, 2 deletions
diff --git a/Source/CMakeBuildTargets.cxx b/Source/CMakeBuildTargets.cxx index 243cac0..8b6adba 100644 --- a/Source/CMakeBuildTargets.cxx +++ b/Source/CMakeBuildTargets.cxx @@ -43,6 +43,7 @@ int main(int ac, char** av) // Create a makefile cmMakefile mf; mf.AddDefinition("UNIX", "1"); + bool makeCache = false; // Parse the command line if(ac > 2) { @@ -50,6 +51,11 @@ int main(int ac, char** av) { std::string arg = av[i]; // Set the start source directory with a -S dir options + if(arg.find("-MakeCache",0) == 0) + { + makeCache = true; + } + // Set the start source directory with a -S dir options if(arg.find("-S",0) == 0) { std::string path = arg.substr(2); @@ -75,7 +81,12 @@ int main(int ac, char** av) } } } - mf.SetMakefileGenerator(new cmUnixMakefileGenerator); + // Only generate makefiles if not trying to make the cache + if(!makeCache) + { + mf.SetMakefileGenerator(new cmUnixMakefileGenerator); + } + // Read and parse the input makefile mf.MakeStartDirectoriesCurrent(); @@ -85,6 +96,24 @@ int main(int ac, char** av) Usage(av[0]); return -1; } - mf.GenerateMakefile(); + if(makeCache) + { + mf.GenerateCacheOnly(); + } + else + { + mf.GenerateMakefile(); + } cmCacheManager::GetInstance()->SaveCache(&mf); + if(makeCache) + { + cmCacheManager::GetInstance()->PrintCache(cout); + } + + if(cmSystemTools::GetErrorOccuredFlag()) + { + return -1; + } + return 0; } + |