|
@@ -72,6 +72,18 @@ void cmFindLibraryCommand::AddArchitecturePaths(const char* suffix)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+static bool cmLibDirsLinked(std::string const& l, std::string const& r)
|
|
|
+{
|
|
|
+ // Compare the real paths of the two directories.
|
|
|
+ // Since our caller only changed the trailing component of each
|
|
|
+ // directory, the real paths can be the same only if at least one of
|
|
|
+ // the trailing components is a symlink. Use this as an optimization
|
|
|
+ // to avoid excessive realpath calls.
|
|
|
+ return (cmSystemTools::FileIsSymlink(l) ||
|
|
|
+ cmSystemTools::FileIsSymlink(r)) &&
|
|
|
+ cmSystemTools::GetRealPath(l) == cmSystemTools::GetRealPath(r);
|
|
|
+}
|
|
|
+
|
|
|
void cmFindLibraryCommand::AddArchitecturePath(
|
|
|
std::string const& dir, std::string::size_type start_pos, const char* suffix,
|
|
|
bool fresh)
|
|
@@ -87,6 +99,11 @@ void cmFindLibraryCommand::AddArchitecturePath(
|
|
|
std::string libX = lib + suffix;
|
|
|
bool use_libX = cmSystemTools::FileIsDirectory(libX);
|
|
|
|
|
|
+ // Avoid copies of the same directory due to symlinks.
|
|
|
+ if (use_libX && use_lib && cmLibDirsLinked(libX, lib)) {
|
|
|
+ use_libX = false;
|
|
|
+ }
|
|
|
+
|
|
|
if (use_libX) {
|
|
|
libX += dir.substr(pos + 3);
|
|
|
std::string::size_type libX_pos = pos + 3 + strlen(suffix) + 1;
|
|
@@ -106,6 +123,11 @@ void cmFindLibraryCommand::AddArchitecturePath(
|
|
|
std::string dirX = dir + suffix;
|
|
|
bool use_dirX = cmSystemTools::FileIsDirectory(dirX);
|
|
|
|
|
|
+ // Avoid copies of the same directory due to symlinks.
|
|
|
+ if (use_dirX && use_dir && cmLibDirsLinked(dirX, dir)) {
|
|
|
+ use_dirX = false;
|
|
|
+ }
|
|
|
+
|
|
|
if (use_dirX) {
|
|
|
dirX += "/";
|
|
|
this->SearchPaths.push_back(dirX);
|