diff options
author | Alex Neundorf <neundorf@kde.org> | 2011-06-16 19:11:06 (GMT) |
---|---|---|
committer | Alex Neundorf <neundorf@kde.org> | 2011-06-21 19:18:23 (GMT) |
commit | 6e1d3edb4d1e1b491df879a2764d8a24442795dc (patch) | |
tree | 4bf936866974aeff11d09c8e94a4347a39267f45 /Source | |
parent | 0751106f2fbfd1a5eb8c4572f60209cc9b22f841 (diff) | |
download | CMake-6e1d3edb4d1e1b491df879a2764d8a24442795dc.zip CMake-6e1d3edb4d1e1b491df879a2764d8a24442795dc.tar.gz CMake-6e1d3edb4d1e1b491df879a2764d8a24442795dc.tar.bz2 |
Add a switch to disable a find_package() call completely
As discussed, this adds a switch CMAKE_DISABLE_FIND_PACKAGE_<name>,
which, when set to TRUE, keeps the find_package() command from executing.
When the package is REQUIRED at the same time, an error is generated.
Alex
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmFindPackageCommand.cxx | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/Source/cmFindPackageCommand.cxx b/Source/cmFindPackageCommand.cxx index 5f106bc..554601d 100644 --- a/Source/cmFindPackageCommand.cxx +++ b/Source/cmFindPackageCommand.cxx @@ -607,6 +607,24 @@ bool cmFindPackageCommand } } + std::string disableFindPackageVar = "CMAKE_DISABLE_FIND_PACKAGE_"; + disableFindPackageVar += this->Name; + if(this->Makefile->IsOn(disableFindPackageVar.c_str())) + { + if (this->Required) + { + cmOStringStream e; + e << "for module " << this->Name << " called with REQUIRED, but " + << disableFindPackageVar + << " is enabled. A REQUIRED package cannot be disabled."; + this->SetError(e.str().c_str()); + return false; + } + + return true; + } + + this->SetModuleVariables(components); // See if there is a Find<package>.cmake module. |