summaryrefslogtreecommitdiffstats
path: root/llvm/include/llvm/Support/CommandLine.h
diff options
context:
space:
mode:
authorEvgeny Mankov <evgeny.mankov@gmail.com>2017-08-28 13:39:43 +0000
committerEvgeny Mankov <evgeny.mankov@gmail.com>2017-08-28 13:39:43 +0000
commit1587086f88b1dd10b8e35841b20235b7ca49ccb9 (patch)
treef303e00750f06655344856919ecf6095e829bf7f /llvm/include/llvm/Support/CommandLine.h
parent595c644f8467583d23922114f32faefa513febaa (diff)
downloadbcm5719-llvm-1587086f88b1dd10b8e35841b20235b7ca49ccb9.tar.gz
bcm5719-llvm-1587086f88b1dd10b8e35841b20235b7ca49ccb9.zip
[Support][CommandLine] Add cl::Option::setDefault()
Add abstract virtual method setDefault() to class Option and implement it in its inheritors in order to be able to set all the options to its default values in user's code without actually knowing all these options. For instance: for (auto &OM : cl::getRegisteredOptions(*cl::TopLevelSubCommand)) { cl::Option *O = OM.second; O->setDefault(); } Reviewed by: rampitec, Eugene.Zelenko, kasaurov Differential Revision: http://reviews.llvm.org/D36877 llvm-svn: 311887
Diffstat (limited to 'llvm/include/llvm/Support/CommandLine.h')
-rw-r--r--llvm/include/llvm/Support/CommandLine.h22
1 files changed, 22 insertions, 0 deletions
diff --git a/llvm/include/llvm/Support/CommandLine.h b/llvm/include/llvm/Support/CommandLine.h
index 771b0a8c26a..22d18194dd8 100644
--- a/llvm/include/llvm/Support/CommandLine.h
+++ b/llvm/include/llvm/Support/CommandLine.h
@@ -349,6 +349,8 @@ public:
virtual void printOptionValue(size_t GlobalWidth, bool Force) const = 0;
+ virtual void setDefault() = 0;
+
static void printHelpStr(StringRef HelpStr, size_t Indent,
size_t FirstLineIndentedBy);
@@ -1318,6 +1320,20 @@ class opt : public Option,
}
}
+ template <class T, class = typename std::enable_if<
+ std::is_assignable<T&, T>::value>::type>
+ void setDefaultImpl() {
+ const OptionValue<DataType> &V = this->getDefault();
+ if (V.hasValue())
+ this->setValue(V.getValue());
+ }
+
+ template <class T, class = typename std::enable_if<
+ !std::is_assignable<T&, T>::value>::type>
+ void setDefaultImpl(...) {}
+
+ void setDefault() override { setDefaultImpl<DataType>(); }
+
void done() {
addArgument();
Parser.initialize();
@@ -1493,6 +1509,8 @@ class list : public Option, public list_storage<DataType, StorageClass> {
void printOptionValue(size_t /*GlobalWidth*/, bool /*Force*/) const override {
}
+ void setDefault() override {}
+
void done() {
addArgument();
Parser.initialize();
@@ -1634,6 +1652,8 @@ class bits : public Option, public bits_storage<DataType, Storage> {
void printOptionValue(size_t /*GlobalWidth*/, bool /*Force*/) const override {
}
+ void setDefault() override {}
+
void done() {
addArgument();
Parser.initialize();
@@ -1684,6 +1704,8 @@ class alias : public Option {
void printOptionValue(size_t /*GlobalWidth*/, bool /*Force*/) const override {
}
+ void setDefault() override { AliasFor->setDefault(); }
+
ValueExpected getValueExpectedFlagDefault() const override {
return AliasFor->getValueExpectedFlag();
}
OpenPOWER on IntegriCloud