diff options
Diffstat (limited to 'Source/cmake.cxx')
-rw-r--r-- | Source/cmake.cxx | 50 |
1 files changed, 29 insertions, 21 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx index 2c86c4d..9042b4a 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -625,15 +625,8 @@ void cmake::SetGlobalGenerator(cmGlobalGenerator *gg) gg->SetCMakeInstance(this); } -int cmake::Configure(const char *arg0, const std::vector<std::string>* args) +int cmake::Configure() { - // Read in the cache, but not for a try compile - // because there will be no cache - if (!m_InTryCompile) - { - m_CacheManager->LoadCache(this->GetHomeOutputDirectory()); - } - // do a sanity check on some values if(m_CacheManager->GetCacheValue("CMAKE_HOME_DIRECTORY")) { @@ -661,18 +654,6 @@ int cmake::Configure(const char *arg0, const std::vector<std::string>* args) cmCacheManager::INTERNAL); } - // extract command line arguments that might add cache entries - if (args) - { - this->SetCacheArgs(*args); - } - - // setup CMAKE_ROOT and CMAKE_COMMAND - if(!this->AddCMakePaths(arg0)) - { - return -3; - } - // no generator specified on the command line if(!m_GlobalGenerator) { @@ -785,6 +766,15 @@ int cmake::Run(const std::vector<std::string>& args) // Process the arguments this->SetArgs(args); + // set the cmake command + m_CMakeCommand = args[0]; + + // load the cache + this->LoadCache(); + + // Add any cache args + this->SetCacheArgs(args); + // if we are local do the local thing, otherwise do global if (m_Local) { @@ -792,7 +782,7 @@ int cmake::Run(const std::vector<std::string>& args) } // otherwise global - int ret = this->Configure(args[0].c_str(),&args); + int ret = this->Configure(); if (ret) { return ret; @@ -892,3 +882,21 @@ void cmake::AddDefaultCommands() } } +int cmake::LoadCache() +{ + m_CacheManager->LoadCache(this->GetHomeOutputDirectory()); + + if (m_CMakeCommand.size() < 2) + { + cmSystemTools::Error("cmake command was not specified prior to loading the cache in cmake.cxx"); + return -1; + } + + // setup CMAKE_ROOT and CMAKE_COMMAND + if(!this->AddCMakePaths(m_CMakeCommand.c_str())) + { + return -3; + } + return 0; +} + |