aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/llvm/Support/CommandLine.h18
-rw-r--r--lib/Support/CommandLine.cpp19
2 files changed, 21 insertions, 16 deletions
diff --git a/include/llvm/Support/CommandLine.h b/include/llvm/Support/CommandLine.h
index 52052e4465..12eb3a5f7a 100644
--- a/include/llvm/Support/CommandLine.h
+++ b/include/llvm/Support/CommandLine.h
@@ -540,22 +540,8 @@ class parser<bool> : public basic_parser<bool> {
bool IsInvertable; // Should we synthezise a -xno- style option?
const char *ArgStr;
public:
- void getExtraOptionNames(std::vector<const char*> &OptionNames) {
- if (IsInvertable) {
- char *s = new char [strlen(ArgStr) + 3 + 1];
- s[0] = ArgStr[0];
- if (strncmp(ArgStr+1, "no-", 3) == 0)
- strcpy(&s[1], &ArgStr[4]);
- else {
- s[1] = 'n';
- s[2] = 'o';
- s[3] = '-';
- strcpy(&s[4], ArgStr+1);
- }
- OptionNames.push_back(s);
- }
- }
-
+ void getExtraOptionNames(std::vector<const char*> &OptionNames);
+
// parse - Return true on error.
bool parse(Option &O, const char *ArgName, const std::string &Arg, bool &Val);
diff --git a/lib/Support/CommandLine.cpp b/lib/Support/CommandLine.cpp
index 2c56e0ffb8..f3f198b355 100644
--- a/lib/Support/CommandLine.cpp
+++ b/lib/Support/CommandLine.cpp
@@ -877,6 +877,25 @@ bool parser<bool>::parse(Option &O, const char *ArgName,
return false;
}
+void parser<bool>::getExtraOptionNames(std::vector<const char*> &OptionNames) {
+ if (!IsInvertable)
+ return;
+
+ char *s = new char [strlen(ArgStr) + 3 + 1];
+ s[0] = ArgStr[0];
+ if (strncmp(ArgStr+1, "no-", 3) == 0)
+ strcpy(&s[1], &ArgStr[4]);
+ else {
+ s[1] = 'n';
+ s[2] = 'o';
+ s[3] = '-';
+ strcpy(&s[4], ArgStr+1);
+ }
+ OptionNames.push_back(s);
+}
+
+
+
// parser<boolOrDefault> implementation
//
bool parser<boolOrDefault>::parse(Option &O, const char *ArgName,