summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Support/CommandLine.cpp
diff options
context:
space:
mode:
authorAlexander Kornienko <alexfh@google.com>2014-02-07 17:42:30 +0000
committerAlexander Kornienko <alexfh@google.com>2014-02-07 17:42:30 +0000
commitd772d7214074f49a778c426cba9fe06ec8749022 (patch)
tree2a9fa5173ec6cc1bcd99983cdd802d3c4f4bb36c /llvm/lib/Support/CommandLine.cpp
parentc7d0acaf348df72507ac755a3bdfd23b357f58bd (diff)
downloadbcm5719-llvm-d772d7214074f49a778c426cba9fe06ec8749022.tar.gz
bcm5719-llvm-d772d7214074f49a778c426cba9fe06ec8749022.zip
Fix an invalid check for duplicate option categories.
An intermediate solution until the problems with analyzer plugins linking with llvm/Support and causing assertions due to duplicate GeneralCategory are solved. llvm-svn: 200981
Diffstat (limited to 'llvm/lib/Support/CommandLine.cpp')
-rw-r--r--llvm/lib/Support/CommandLine.cpp14
1 files changed, 10 insertions, 4 deletions
diff --git a/llvm/lib/Support/CommandLine.cpp b/llvm/lib/Support/CommandLine.cpp
index 16db4d63960..7b2a4d0270f 100644
--- a/llvm/lib/Support/CommandLine.cpp
+++ b/llvm/lib/Support/CommandLine.cpp
@@ -36,6 +36,7 @@
#include <cerrno>
#include <cstdlib>
#include <map>
+#include <set>
using namespace llvm;
using namespace cl;
@@ -1495,9 +1496,7 @@ public:
// It shall return true if A's name should be lexographically
// ordered before B's name. It returns false otherwise.
static bool OptionCategoryCompare(OptionCategory *A, OptionCategory *B) {
- int Length = strcmp(A->getName(), B->getName());
- assert(Length != 0 && "Duplicate option categories");
- return Length < 0;
+ return strcmp(A->getName(), B->getName()) < 0;
}
// Make sure we inherit our base class's operator=()
@@ -1507,13 +1506,20 @@ protected:
virtual void printOptions(StrOptionPairVector &Opts, size_t MaxArgLen) {
std::vector<OptionCategory *> SortedCategories;
std::map<OptionCategory *, std::vector<Option *> > CategorizedOptions;
+ std::set<std::string> CategoryNames;
// Collect registered option categories into vector in preparation for
// sorting.
for (OptionCatSet::const_iterator I = RegisteredOptionCategories->begin(),
E = RegisteredOptionCategories->end();
- I != E; ++I)
+ I != E; ++I) {
SortedCategories.push_back(*I);
+ // FIXME: Move this check to OptionCategory::registerCategory after the
+ // problem with analyzer plugins linking to llvm/Support and causing
+ // assertion on the duplicate llvm::cl::GeneralCategory is solved.
+ assert(CategoryNames.insert((*I)->getName()).second &&
+ "Duplicate option categories");
+ }
// Sort the different option categories alphabetically.
assert(SortedCategories.size() > 0 && "No option categories registered!");
OpenPOWER on IntegriCloud