diff options
author | Mike Stump <mrs@apple.com> | 2009-01-30 08:19:46 +0000 |
---|---|---|
committer | Mike Stump <mrs@apple.com> | 2009-01-30 08:19:46 +0000 |
commit | ecbe4a0860319ba3373962b13c9a775f6eb94c84 (patch) | |
tree | e275b10786a73ba7184da02da691cc9f7672910d /llvm/lib/Support/CommandLine.cpp | |
parent | f5222fa0ad3200b9771fa088108d7f970219cc3c (diff) | |
download | bcm5719-llvm-ecbe4a0860319ba3373962b13c9a775f6eb94c84.tar.gz bcm5719-llvm-ecbe4a0860319ba3373962b13c9a775f6eb94c84.zip |
Add opposite_of and inverse_opt to support -fno- style options. This
is necessary for eventual gcc commmand line compatibility.
llvm-svn: 63384
Diffstat (limited to 'llvm/lib/Support/CommandLine.cpp')
-rw-r--r-- | llvm/lib/Support/CommandLine.cpp | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/llvm/lib/Support/CommandLine.cpp b/llvm/lib/Support/CommandLine.cpp index 2414734869d..e06f324c871 100644 --- a/llvm/lib/Support/CommandLine.cpp +++ b/llvm/lib/Support/CommandLine.cpp @@ -40,6 +40,7 @@ using namespace cl; // TEMPLATE_INSTANTIATION(class basic_parser<bool>); TEMPLATE_INSTANTIATION(class basic_parser<boolOrDefault>); +TEMPLATE_INSTANTIATION(class basic_parser<boolInverse>); TEMPLATE_INSTANTIATION(class basic_parser<int>); TEMPLATE_INSTANTIATION(class basic_parser<unsigned>); TEMPLATE_INSTANTIATION(class basic_parser<double>); @@ -55,6 +56,7 @@ void Option::anchor() {} void basic_parser_impl::anchor() {} void parser<bool>::anchor() {} void parser<boolOrDefault>::anchor() {} +void parser<boolInverse>::anchor() {} void parser<int>::anchor() {} void parser<unsigned>::anchor() {} void parser<double>::anchor() {} @@ -882,7 +884,8 @@ bool parser<boolOrDefault>::parse(Option &O, const char *ArgName, if (Arg == "" || Arg == "true" || Arg == "TRUE" || Arg == "True" || Arg == "1") { Value = BOU_TRUE; - } else if (Arg == "false" || Arg == "FALSE" || Arg == "False" || Arg == "0") { + } else if (Arg == "false" || Arg == "FALSE" + || Arg == "False" || Arg == "0") { Value = BOU_FALSE; } else { return O.error(": '" + Arg + @@ -891,6 +894,23 @@ bool parser<boolOrDefault>::parse(Option &O, const char *ArgName, return false; } +// parser<boolInverse> implementation +// +bool parser<boolInverse>::parse(Option &O, const char *ArgName, + const std::string &Arg, bool &Value) { + if (Arg == "" || Arg == "true" || Arg == "TRUE" || Arg == "True" || + Arg == "1") { + Value = false; + } else if (Arg == "false" || Arg == "FALSE" + || Arg == "False" || Arg == "0") { + Value = true; + } else { + return O.error(": '" + Arg + + "' is invalid value for boolean argument! Try 0 or 1"); + } + return false; +} + // parser<int> implementation // bool parser<int>::parse(Option &O, const char *ArgName, |