diff options
author | Brad King <brad.king@kitware.com> | 2009-09-03 12:26:31 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2009-09-03 12:26:31 (GMT) |
commit | a6890a1673aec8e3bf6afa7daa8d738ff4d32868 (patch) | |
tree | 036ad85d69a2c9263bf71244c4ee0948f7905f4c /Source | |
parent | 2ea28107377b83852a9bdff83ab1bf19653600ee (diff) | |
download | CMake-a6890a1673aec8e3bf6afa7daa8d738ff4d32868.zip CMake-a6890a1673aec8e3bf6afa7daa8d738ff4d32868.tar.gz CMake-a6890a1673aec8e3bf6afa7daa8d738ff4d32868.tar.bz2 |
Manage current local generator with automatic var
The cmLocalGenerator::Configure method sets its cmLocalGenerator
instance as the global generator's current local generator during
configuration. This commit refactors management of the current local
generator to use an automatic variable. This will allow early returns
from the method.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmLocalGenerator.cxx | 27 |
1 files changed, 22 insertions, 5 deletions
diff --git a/Source/cmLocalGenerator.cxx b/Source/cmLocalGenerator.cxx index cac52b2..c051e0b 100644 --- a/Source/cmLocalGenerator.cxx +++ b/Source/cmLocalGenerator.cxx @@ -68,11 +68,30 @@ cmLocalGenerator::~cmLocalGenerator() delete this->Makefile; } +//---------------------------------------------------------------------------- +class cmLocalGeneratorCurrent +{ + cmGlobalGenerator* GG; + cmLocalGenerator* LG; +public: + cmLocalGeneratorCurrent(cmLocalGenerator* lg) + { + this->GG = lg->GetGlobalGenerator(); + this->LG = this->GG->GetCurrentLocalGenerator(); + this->GG->SetCurrentLocalGenerator(lg); + } + ~cmLocalGeneratorCurrent() + { + this->GG->SetCurrentLocalGenerator(this->LG); + } +}; + +//---------------------------------------------------------------------------- void cmLocalGenerator::Configure() { - cmLocalGenerator* previousLg = - this->GetGlobalGenerator()->GetCurrentLocalGenerator(); - this->GetGlobalGenerator()->SetCurrentLocalGenerator(this); + // Manage the global generator's current local generator. + cmLocalGeneratorCurrent clg(this); + static_cast<void>(clg); // make sure the CMakeFiles dir is there std::string filesDir = this->Makefile->GetStartOutputDirectory(); @@ -141,8 +160,6 @@ void cmLocalGenerator::Configure() } this->Configured = true; - - this->GetGlobalGenerator()->SetCurrentLocalGenerator(previousLg); } void cmLocalGenerator::SetupPathConversions() |