summaryrefslogtreecommitdiffstats
path: root/Source/cmake.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmake.cxx')
-rw-r--r--Source/cmake.cxx105
1 files changed, 29 insertions, 76 deletions
diff --git a/Source/cmake.cxx b/Source/cmake.cxx
index bfb6281..e09dca8 100644
--- a/Source/cmake.cxx
+++ b/Source/cmake.cxx
@@ -115,7 +115,6 @@ cmake::cmake()
cmSystemTools::PutEnv("MAKEFLAGS=");
}
- m_Local = false;
m_Verbose = false;
m_InTryCompile = false;
m_CacheManager = new cmCacheManager;
@@ -275,7 +274,6 @@ void cmake::ReadListFile(const char *path)
// Parse the args
void cmake::SetArgs(const std::vector<std::string>& args)
{
- m_Local = false;
bool directoriesSet = false;
for(unsigned int i=1; i < args.size(); ++i)
{
@@ -363,11 +361,9 @@ void cmake::SetArgs(const std::vector<std::string>& args)
this->SetStartDirectory
(cmSystemTools::GetCurrentWorkingDirectory().c_str());
}
- if (!m_Local)
- {
- this->SetStartDirectory(this->GetHomeDirectory());
- this->SetStartOutputDirectory(this->GetHomeOutputDirectory());
- }
+
+ this->SetStartDirectory(this->GetHomeDirectory());
+ this->SetStartOutputDirectory(this->GetHomeOutputDirectory());
}
//----------------------------------------------------------------------------
@@ -1282,49 +1278,36 @@ int cmake::Run(const std::vector<std::string>& args, bool noconfigure)
}
int ret = 0;
- // if not local or the cmake version has changed since the last run
- // of cmake, or CMakeSystem.cmake file is not in the root binary
- // directory, run a global generate
- if(m_ScriptMode || !m_Local || !this->CacheVersionMatches() ||
- !cmSystemTools::FileExists(systemFile.c_str()) )
- {
- // Check the state of the build system to see if we need to regenerate.
- if(!this->CheckBuildSystem())
- {
- 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();
- std::string oldstartoutputdir = this->GetStartOutputDirectory();
- this->SetStartDirectory(this->GetHomeDirectory());
- this->SetStartOutputDirectory(this->GetHomeOutputDirectory());
- bool saveLocalFlag = m_Local;
- m_Local = false;
- ret = this->Configure();
- if (ret || m_ScriptMode)
- {
- return ret;
- }
- ret = this->Generate();
- std::string message = "Build files have been written to: ";
- message += this->GetHomeOutputDirectory();
- this->UpdateProgress(message.c_str(), -1);
- if(ret)
- {
- return ret;
- }
- m_Local = saveLocalFlag;
- this->SetStartDirectory(oldstartdir.c_str());
- this->SetStartOutputDirectory(oldstartoutputdir.c_str());
+ // now run the global generate
+ // Check the state of the build system to see if we need to regenerate.
+ if(!this->CheckBuildSystem())
+ {
+ return 0;
}
-
- // if we are local do the local thing
- if (m_Local)
+
+ // 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();
+ std::string oldstartoutputdir = this->GetStartOutputDirectory();
+ this->SetStartDirectory(this->GetHomeDirectory());
+ this->SetStartOutputDirectory(this->GetHomeOutputDirectory());
+ ret = this->Configure();
+ if (ret || m_ScriptMode)
{
- ret = this->LocalGenerate();
+ return ret;
}
+ ret = this->Generate();
+ std::string message = "Build files have been written to: ";
+ message += this->GetHomeOutputDirectory();
+ this->UpdateProgress(message.c_str(), -1);
+ if(ret)
+ {
+ return ret;
+ }
+ this->SetStartDirectory(oldstartdir.c_str());
+ this->SetStartOutputDirectory(oldstartoutputdir.c_str());
+
return ret;
}
@@ -1342,36 +1325,6 @@ int cmake::Generate()
return 0;
}
-int cmake::LocalGenerate()
-{
- // Read in the cache
- m_CacheManager->LoadCache(this->GetHomeOutputDirectory());
-
- // create the generator based on the cache if it isn't already there
- const char* genName = m_CacheManager->GetCacheValue("CMAKE_GENERATOR");
- if(genName)
- {
- m_GlobalGenerator = this->CreateGlobalGenerator(genName);
- // set the global flag for unix style paths on cmSystemTools as
- // soon as the generator is set. This allows gmake to be used
- // on windows.
- cmSystemTools::SetForceUnixPaths(m_GlobalGenerator->GetForceUnixPaths());
- }
- else
- {
- cmSystemTools::Error("Could local Generate called without the GENERATOR being specified in the CMakeCache");
- return -1;
- }
-
- // do the local generate
- m_GlobalGenerator->LocalGenerate();
- if(cmSystemTools::GetErrorOccuredFlag())
- {
- return -1;
- }
- return 0;
-}
-
unsigned int cmake::GetMajorVersion()
{
return cmMakefile::GetMajorVersion();