summaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2008-08-12 23:01:04 (GMT)
committerBrad King <brad.king@kitware.com>2008-08-12 23:01:04 (GMT)
commit2b96e0edab9f255ff049b93f4fa17a3a444c8338 (patch)
treeb0f494bae65177f4dbf3dec1d962515835165acb /Source
parent1712cd0a9874914f04514f5d35a204e9d30a8dea (diff)
downloadCMake-2b96e0edab9f255ff049b93f4fa17a3a444c8338.zip
CMake-2b96e0edab9f255ff049b93f4fa17a3a444c8338.tar.gz
CMake-2b96e0edab9f255ff049b93f4fa17a3a444c8338.tar.bz2
ENH: Teach find_package about lib64 paths
When find_package is about to look in <prefix>/lib, search first in <prefix>/lib64 in cases that find_library would use lib64 paths.
Diffstat (limited to 'Source')
-rw-r--r--Source/cmFindPackageCommand.cxx36
-rw-r--r--Source/cmFindPackageCommand.h1
2 files changed, 28 insertions, 9 deletions
diff --git a/Source/cmFindPackageCommand.cxx b/Source/cmFindPackageCommand.cxx
index f4e36e0..f130ba2 100644
--- a/Source/cmFindPackageCommand.cxx
+++ b/Source/cmFindPackageCommand.cxx
@@ -63,6 +63,7 @@ cmFindPackageCommand::cmFindPackageCommand()
this->NoBuilds = false;
this->NoModule = false;
this->DebugMode = false;
+ this->UseLib64Paths = false;
this->VersionMajor = 0;
this->VersionMinor = 0;
this->VersionPatch = 0;
@@ -298,6 +299,18 @@ bool cmFindPackageCommand
// Check for debug mode.
this->DebugMode = this->Makefile->IsOn("CMAKE_FIND_DEBUG_MODE");
+ // Lookup whether lib64 paths should be used.
+ if(const char* sizeof_dptr =
+ this->Makefile->GetDefinition("CMAKE_SIZEOF_VOID_P"))
+ {
+ if(atoi(sizeof_dptr) == 8 &&
+ this->Makefile->GetCMakeInstance()
+ ->GetPropertyAsBool("FIND_LIBRARY_USE_LIB64_PATHS"))
+ {
+ this->UseLib64Paths = true;
+ }
+ }
+
// Find the current root path mode.
this->SelectDefaultRootPathMode();
@@ -1457,16 +1470,12 @@ private:
class cmFileListGeneratorEnumerate: public cmFileListGeneratorBase
{
public:
- cmFileListGeneratorEnumerate(const char* p1, const char* p2):
- cmFileListGeneratorBase()
- {
- this->Vector.push_back(p1);
- this->Vector.push_back(p2);
- }
+ cmFileListGeneratorEnumerate(std::vector<std::string> const& v):
+ cmFileListGeneratorBase(), Vector(v) {}
cmFileListGeneratorEnumerate(cmFileListGeneratorEnumerate const& r):
cmFileListGeneratorBase(), Vector(r.Vector) {}
private:
- std::vector<std::string> Vector;
+ std::vector<std::string> const& Vector;
virtual bool Search(std::string const& parent, cmFileList& lister)
{
for(std::vector<std::string>::const_iterator i = this->Vector.begin();
@@ -1716,12 +1725,21 @@ bool cmFindPackageCommand::SearchPrefix(std::string const& prefix_in)
}
}
+ // Construct list of common install locations (lib and share).
+ std::vector<std::string> common;
+ if(this->UseLib64Paths)
+ {
+ common.push_back("lib64");
+ }
+ common.push_back("lib");
+ common.push_back("share");
+
// PREFIX/(share|lib)/(Foo|foo|FOO).*/
{
cmFindPackageFileList lister(this);
lister
/ cmFileListGeneratorFixed(prefix)
- / cmFileListGeneratorEnumerate("lib", "share")
+ / cmFileListGeneratorEnumerate(common)
/ cmFileListGeneratorProject(this->Names);
if(lister.Search())
{
@@ -1734,7 +1752,7 @@ bool cmFindPackageCommand::SearchPrefix(std::string const& prefix_in)
cmFindPackageFileList lister(this);
lister
/ cmFileListGeneratorFixed(prefix)
- / cmFileListGeneratorEnumerate("lib", "share")
+ / cmFileListGeneratorEnumerate(common)
/ cmFileListGeneratorProject(this->Names)
/ cmFileListGeneratorCaseInsensitive("cmake");
if(lister.Search())
diff --git a/Source/cmFindPackageCommand.h b/Source/cmFindPackageCommand.h
index 9f3a59f..d5fe703 100644
--- a/Source/cmFindPackageCommand.h
+++ b/Source/cmFindPackageCommand.h
@@ -124,6 +124,7 @@ private:
bool NoModule;
bool NoBuilds;
bool DebugMode;
+ bool UseLib64Paths;
std::vector<std::string> Names;
std::vector<std::string> Configs;
};