diff options
author | Alexander Neundorf <neundorf@kde.org> | 2009-01-08 22:57:52 (GMT) |
---|---|---|
committer | Alexander Neundorf <neundorf@kde.org> | 2009-01-08 22:57:52 (GMT) |
commit | ef3e48c3d566a8d0d547a2a65bf18281a0aef664 (patch) | |
tree | 8ed49d007f0ffaab2d508ced35b9b997d6a21b0d /Source | |
parent | 206c09c4f66fff69ea35f3434834c98a9e4a8fa9 (diff) | |
download | CMake-ef3e48c3d566a8d0d547a2a65bf18281a0aef664.zip CMake-ef3e48c3d566a8d0d547a2a65bf18281a0aef664.tar.gz CMake-ef3e48c3d566a8d0d547a2a65bf18281a0aef664.tar.bz2 |
ENH: when trying to find a FooConfig.cmake file, if in the directory pointed
to by the Foo_DIR variable there is no FooConfig.cmake file, then instead of
abort and complain that the user should set or clear the Foo_DIR variables,
just search for the file and discard the old Foo_DIR contents
The tests succeed, ok by Brad.
Alex
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmFindPackageCommand.cxx | 93 | ||||
-rw-r--r-- | Source/cmFindPackageCommand.h | 1 |
2 files changed, 36 insertions, 58 deletions
diff --git a/Source/cmFindPackageCommand.cxx b/Source/cmFindPackageCommand.cxx index 9577b42..7432c84 100644 --- a/Source/cmFindPackageCommand.cxx +++ b/Source/cmFindPackageCommand.cxx @@ -710,17 +710,8 @@ bool cmFindPackageCommand::HandlePackageMode() } } - // Search for the config file if it is not already found. - if(cmSystemTools::IsOff(def)) - { - this->FindConfig(); - def = this->Makefile->GetDefinition(this->Variable.c_str()); - } - - // If the config file was found, load it. - std::string file; - bool result = true; - bool found = false; + // Try to load the config file if the directory is known + bool cachedDirectoryOk = false; if(!cmSystemTools::IsOff(def)) { // Get the directory from the variable value. @@ -733,38 +724,44 @@ bool cmFindPackageCommand::HandlePackageMode() dir = "/" + dir; dir = this->Makefile->GetCurrentDirectory() + dir; } - - // Find the configuration file. - if(this->FindConfigFileToLoad(dir, file)) + // The file location was cached. Look for the correct file. + std::string file; + if (this->FindConfigFile(dir, file)) { - // Set the version variables before loading the config file. - // It may override them. - this->StoreVersionFound(); + this->FileFound = file; + cachedDirectoryOk = true; + } + def = this->Makefile->GetDefinition(this->Variable.c_str()); + } - // Parse the configuration file. - if(this->ReadListFile(file.c_str())) - { - // The package has been found. - found = true; - } - else - { - // The configuration file is invalid. - result = false; - } + // Search for the config file if it is not already found. + if(cmSystemTools::IsOff(def) || !cachedDirectoryOk) + { + this->FindConfig(); + def = this->Makefile->GetDefinition(this->Variable.c_str()); + } + + // If the directory for the config file was found, try to read the file. + bool result = true; + bool found = false; + // in the following test FileFound should never be empty if def is valid + // but I don't want to put an assert() in there now, in case this still + // makes it into 2.6.3 + if(!cmSystemTools::IsOff(def) && (!this->FileFound.empty())) + { + // Set the version variables before loading the config file. + // It may override them. + this->StoreVersionFound(); + + // Parse the configuration file. + if(this->ReadListFile(this->FileFound.c_str())) + { + // The package has been found. + found = true; } else { - // The variable setting is wrong. - cmOStringStream e; - e << "cannot find package " << this->Name << " because " - << this->Variable << " is set to \"" << def << "\" " - << "which is not a directory containing a package configuration " - << "file (or it is not for the requested version). " - << "Please set the cache entry " << this->Variable << " " - << "to the correct directory, or delete it to ask CMake " - << "to search."; - this->SetError(e.str().c_str()); + // The configuration file is invalid. result = false; } } @@ -816,7 +813,7 @@ bool cmFindPackageCommand::HandlePackageMode() fileVar += "_CONFIG"; if(found) { - this->Makefile->AddDefinition(fileVar.c_str(), file.c_str()); + this->Makefile->AddDefinition(fileVar.c_str(), this->FileFound.c_str()); } else { @@ -1245,24 +1242,6 @@ bool cmFindPackageCommand::FindConfigFile(std::string const& dir, } //---------------------------------------------------------------------------- -bool cmFindPackageCommand::FindConfigFileToLoad(std::string const& dir, - std::string& file) -{ - if(this->FileFound.empty()) - { - // The file location was cached. Look for the correct file. - return this->FindConfigFile(dir, file); - } - else - { - // The file location was just found during this call. - // Use the file found without searching again. - file = this->FileFound; - return true; - } -} - -//---------------------------------------------------------------------------- bool cmFindPackageCommand::CheckVersion(std::string const& config_file) { // Get the filename without the .cmake extension. diff --git a/Source/cmFindPackageCommand.h b/Source/cmFindPackageCommand.h index 1bfb2af..3fc8f65 100644 --- a/Source/cmFindPackageCommand.h +++ b/Source/cmFindPackageCommand.h @@ -97,7 +97,6 @@ private: bool SearchDirectory(std::string const& dir); bool CheckDirectory(std::string const& dir); bool FindConfigFile(std::string const& dir, std::string& file); - bool FindConfigFileToLoad(std::string const& dir, std::string& file); bool CheckVersion(std::string const& config_file); bool CheckVersionFile(std::string const& version_file); bool SearchPrefix(std::string const& prefix); |