-
Notifications
You must be signed in to change notification settings - Fork 390
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow an option to have multiple values assigned using a comma-separated list #37
Comments
Regex patterns are definitely not my forte, so if someone else sees this and wants it done faster than I can do, feel free to take it (and if possible, I'd love to pair on it). I'll make sure to push any tests I write to a WIP PR. |
@PandaMagnus, the lexer isn't using a regex, but the tokenizer is. This feature would impact both, assuming spaces between comma-grouped items are allowed as in @MarkMichaelis's example. |
@jonsequitur Understood. I'll make sure to take a look at the lexer as well. If I get in over my head I'll pair or set it aside. |
I expect that the lexer and core parse operations will need an overhaul at some point. The implementation isn't elegant and the performance needs to be improved. That might be the kind of thing that we undertake first, with improvements like this in mind, before adding support for additional cases. |
In addition to |
#736 adds support for easier custom argument parsing, so enabling custom split delimiters can be done like this: [Fact]
public void custom_parsing_of_sequence_value_from_an_argument_with_one_token()
{
var argument = new Argument<IEnumerable<int>>(result =>
{
result.Value = result.Tokens.Single().Value.Split(",").Select(int.Parse);
return true;
});
argument.Parse("1,2,3")
.FindResultFor(argument)
.GetValueOrDefault()
.Should()
.BeEquivalentTo(new[] { 1, 2, 3 });
} |
Update the lexer to support specifying an option that supports more than one argument using a comma-separated list:
e.g.
DisplayTable -column FirstColumn, SecondColumn
Whitespace around the comma is allowed.
The text was updated successfully, but these errors were encountered: