[PATCH] D58499: [CommandLine] Do not crash if an option has both ValueRequired and Grouping.
Igor Kudrin via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Feb 22 09:01:51 PST 2019
ikudrin updated this revision to Diff 187944.
ikudrin added a comment.
- Updated the documentation (feel free to correct my wording).
- Amended a comment in the test.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D58499/new/
https://reviews.llvm.org/D58499
Files:
docs/CommandLine.rst
lib/Support/CommandLine.cpp
unittests/Support/CommandLineTest.cpp
Index: unittests/Support/CommandLineTest.cpp
===================================================================
--- unittests/Support/CommandLineTest.cpp
+++ unittests/Support/CommandLineTest.cpp
@@ -1128,4 +1128,25 @@
EXPECT_TRUE(MacroDefs.front().compare("HAVE_FOO") == 0);
}
+TEST(CommandLineTest, GroupingWithValue) {
+ cl::ResetCommandLineParser();
+
+ StackOption<bool> OptF("f", cl::Grouping, cl::desc("Some flag"));
+ StackOption<std::string> OptV("v", cl::Grouping,
+ cl::desc("Grouping option with a value"));
+
+ // Should be possible to use an option which requires a value
+ // at the end of a group.
+ const char *args1[] = {"prog", "-fv", "val1"};
+ EXPECT_TRUE(
+ cl::ParseCommandLineOptions(3, args1, StringRef(), &llvm::nulls()));
+ EXPECT_STREQ("val1", OptV.c_str());
+ cl::ResetAllOptionOccurrences();
+
+ // Should not crash if it is accidentally used elsewhere in the group.
+ const char *args2[] = {"prog", "-vf", "val2"};
+ EXPECT_FALSE(
+ cl::ParseCommandLineOptions(3, args2, StringRef(), &llvm::nulls()));
+}
+
} // anonymous namespace
Index: lib/Support/CommandLine.cpp
===================================================================
--- lib/Support/CommandLine.cpp
+++ lib/Support/CommandLine.cpp
@@ -671,10 +671,13 @@
StringRef OneArgName = Arg.substr(0, Length);
Arg = Arg.substr(Length);
- // Because ValueRequired is an invalid flag for grouped arguments,
- // we don't need to pass argc/argv in.
- assert(PGOpt->getValueExpectedFlag() != cl::ValueRequired &&
- "Option can not be cl::Grouping AND cl::ValueRequired!");
+ if (PGOpt->getValueExpectedFlag() == cl::ValueRequired) {
+ ErrorParsing |= PGOpt->error("may not occur within a group!");
+ return nullptr;
+ }
+
+ // Because the value for the option is not required, we don't need to pass
+ // argc/argv in.
int Dummy = 0;
ErrorParsing |=
ProvideOption(PGOpt, OneArgName, StringRef(), 0, nullptr, Dummy);
Index: docs/CommandLine.rst
===================================================================
--- docs/CommandLine.rst
+++ docs/CommandLine.rst
@@ -1172,7 +1172,8 @@
``ls``) that have lots of single letter arguments, but only require a single
dash. For example, the '``ls -labF``' command actually enables four different
options, all of which are single letters. Note that **cl::Grouping** options
- cannot have values.
+ can have values only if they are used separately or at the end of their group.
+ It is a runtime error if such an option is used elsewhere in the group.
The CommandLine library does not restrict how you use the **cl::Prefix** or
**cl::Grouping** modifiers, but it is possible to specify ambiguous argument
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D58499.187944.patch
Type: text/x-patch
Size: 2781 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190222/c9990415/attachment.bin>
More information about the llvm-commits
mailing list