Skip to content

Commit

Permalink
Fix parsing of boolean value (#152)
Browse files Browse the repository at this point in the history
* Fix parsing of boolean value

* Review feedback

* Update source/argparse/internal/valueparser.d

Co-authored-by: Nickolay Bukreyev <[email protected]>

---------

Co-authored-by: Nickolay Bukreyev <[email protected]>
(cherry picked from commit a2092ca)
  • Loading branch information
andrey-zherikov committed Oct 31, 2024
1 parent 5715dd2 commit c13f5e9
Showing 1 changed file with 20 additions and 8 deletions.
28 changes: 20 additions & 8 deletions source/argparse/internal/valueparser.d
Original file line number Diff line number Diff line change
Expand Up @@ -144,18 +144,24 @@ if(!is(T == void))
else static if(isBoolean!T)
{
alias DefaultValueParser = ValueParser!(
void, // pre process
void, // pre validate
(ref RawParam param) // pre process
{
import std.algorithm.iteration: map;
import std.array: array;
import std.ascii: toLower;
import std.string: representation;

// convert values to lower case and replace "" with "y"
foreach(ref value; param.value)
value = value.length == 0 ? "y" : value.representation.map!(_ => immutable char(_.toLower)).array;
},
ValueInList!(["true","yes","y","false","no","n"], typeof(RawParam.value)), // pre validate
(string value) // parse
{
switch(value)
{
case "": goto case;
case "yes": goto case;
case "y": return true;
case "no": goto case;
case "n": return false;
default: return value.to!T;
case "true", "yes", "y": return true;
default: return false;
}
},
void, // validate
Expand Down Expand Up @@ -346,11 +352,17 @@ unittest
assert(test!bool([]) == true);
assert(test!bool([""]) == true);
assert(test!bool(["yes"]) == true);
assert(test!bool(["Yes"]) == true);
assert(test!bool(["y"]) == true);
assert(test!bool(["Y"]) == true);
assert(test!bool(["true"]) == true);
assert(test!bool(["True"]) == true);
assert(test!bool(["no"]) == false);
assert(test!bool(["No"]) == false);
assert(test!bool(["n"]) == false);
assert(test!bool(["N"]) == false);
assert(test!bool(["false"]) == false);
assert(test!bool(["False"]) == false);
assert(test!MyEnum(["foo"]) == MyEnum.foo);
assert(test!MyEnum(["bar"]) == MyEnum.bar);
assert(test!(MyEnum[])(["bar","foo"]) == [MyEnum.bar, MyEnum.foo]);
Expand Down

0 comments on commit c13f5e9

Please sign in to comment.