diff options
author | Dale Johannesen <dalej@apple.com> | 2007-05-22 17:14:46 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2007-05-22 17:14:46 +0000 |
commit | 82810c8a13bea59b73b7c6dcc83263abaa2247f0 (patch) | |
tree | 364a4b172c117c237e436038e5101b194ca4c3cc /llvm/lib/Support/CommandLine.cpp | |
parent | 83d7dd419ad5f8b2214a458a2a1589fa05789547 (diff) | |
download | bcm5719-llvm-82810c8a13bea59b73b7c6dcc83263abaa2247f0.tar.gz bcm5719-llvm-82810c8a13bea59b73b7c6dcc83263abaa2247f0.zip |
Make tail merging the default, except on powerPC. There was no prior art
for a target-dependent default with a command-line override; this way
should be generally usable.
llvm-svn: 37285
Diffstat (limited to 'llvm/lib/Support/CommandLine.cpp')
-rw-r--r-- | llvm/lib/Support/CommandLine.cpp | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/llvm/lib/Support/CommandLine.cpp b/llvm/lib/Support/CommandLine.cpp index 2b0798aa770..1f5008a3faa 100644 --- a/llvm/lib/Support/CommandLine.cpp +++ b/llvm/lib/Support/CommandLine.cpp @@ -36,6 +36,7 @@ using namespace cl; // Template instantiations and anchors. // TEMPLATE_INSTANTIATION(class basic_parser<bool>); +TEMPLATE_INSTANTIATION(class basic_parser<boolOrDefault>); TEMPLATE_INSTANTIATION(class basic_parser<int>); TEMPLATE_INSTANTIATION(class basic_parser<unsigned>); TEMPLATE_INSTANTIATION(class basic_parser<double>); @@ -50,6 +51,7 @@ TEMPLATE_INSTANTIATION(class opt<bool>); void Option::anchor() {} void basic_parser_impl::anchor() {} void parser<bool>::anchor() {} +void parser<boolOrDefault>::anchor() {} void parser<int>::anchor() {} void parser<unsigned>::anchor() {} void parser<double>::anchor() {} @@ -767,6 +769,22 @@ bool parser<bool>::parse(Option &O, const char *ArgName, return false; } +// parser<boolOrDefault> implementation +// +bool parser<boolOrDefault>::parse(Option &O, const char *ArgName, + const std::string &Arg, boolOrDefault &Value) { + if (Arg == "" || Arg == "true" || Arg == "TRUE" || Arg == "True" || + Arg == "1") { + Value = BOU_TRUE; + } else if (Arg == "false" || Arg == "FALSE" || Arg == "False" || Arg == "0") { + Value = BOU_FALSE; + } 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, |