diff options
author | Ben Boeckel <ben.boeckel@kitware.com> | 2016-06-13 15:10:59 (GMT) |
---|---|---|
committer | Ben Boeckel <ben.boeckel@kitware.com> | 2016-06-13 15:16:12 (GMT) |
commit | 919db25c3b54f0303a19abb4a9e4f16056a3c1b6 (patch) | |
tree | efac4b1898fa5fbe07a117fd8a20fce2284e5513 | |
parent | ebf18df58083c90d4ba06ab896dfad8df9fe6ade (diff) | |
download | CMake-919db25c3b54f0303a19abb4a9e4f16056a3c1b6.zip CMake-919db25c3b54f0303a19abb4a9e4f16056a3c1b6.tar.gz CMake-919db25c3b54f0303a19abb4a9e4f16056a3c1b6.tar.bz2 |
cmFindPackageCommand: remove duplicate paths from error message
Fixes #15252.
-rw-r--r-- | Source/cmFindPackageCommand.cxx | 4 | ||||
-rw-r--r-- | Source/cmFindPackageCommand.h | 15 |
2 files changed, 18 insertions, 1 deletions
diff --git a/Source/cmFindPackageCommand.cxx b/Source/cmFindPackageCommand.cxx index 4ab7a72..1945c44 100644 --- a/Source/cmFindPackageCommand.cxx +++ b/Source/cmFindPackageCommand.cxx @@ -664,6 +664,8 @@ bool cmFindPackageCommand::HandlePackageMode() // If there are files in ConsideredConfigs, it means that FooConfig.cmake // have been found, but they didn't have appropriate versions. else if (!this->ConsideredConfigs.empty()) { + std::vector<ConfigFileInfo>::const_iterator duplicate_end = + cmRemoveDuplicates(this->ConsideredConfigs); e << "Could not find a configuration file for package \"" << this->Name << "\" that " << (this->VersionExact ? "exactly matches" : "is compatible with") @@ -672,7 +674,7 @@ bool cmFindPackageCommand::HandlePackageMode() "accepted:\n"; for (std::vector<ConfigFileInfo>::const_iterator i = this->ConsideredConfigs.begin(); - i != this->ConsideredConfigs.end(); ++i) { + i != duplicate_end; ++i) { e << " " << i->filename << ", version: " << i->version << "\n"; } } else { diff --git a/Source/cmFindPackageCommand.h b/Source/cmFindPackageCommand.h index eff6b80..00db22b 100644 --- a/Source/cmFindPackageCommand.h +++ b/Source/cmFindPackageCommand.h @@ -159,6 +159,21 @@ private: { std::string filename; std::string version; + + bool operator<(ConfigFileInfo const& rhs) const + { + return this->filename < rhs.filename; + } + + bool operator==(ConfigFileInfo const& rhs) const + { + return this->filename == rhs.filename; + } + + bool operator!=(ConfigFileInfo const& rhs) const + { + return !(*this == rhs); + } }; std::vector<ConfigFileInfo> ConsideredConfigs; }; |