From b8870fac3ab825d7d3b42483321f6ba32b67ec8f Mon Sep 17 00:00:00 2001 From: "Taylor C. Richberger" Date: Wed, 11 May 2016 20:40:18 -0600 Subject: finish mapping types --- test.cxx | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) (limited to 'test.cxx') diff --git a/test.cxx b/test.cxx index bcccdf4..b28a378 100644 --- a/test.cxx +++ b/test.cxx @@ -375,22 +375,21 @@ TEST_CASE("Mapping types work as needed", "[args]") args::MapFlag dmf(parser, "DMF", "Maps string to an enum", args::Matcher{"dmf"}, map); args::MapFlag mf(parser, "MF", "Maps string to an enum", args::Matcher{"mf"}, map); args::MapFlag cimf(parser, "CIMF", "Maps string to an enum case-insensitively", args::Matcher{"cimf"}, map); - //args::MapFlagList mfl(parser, "MFL", "Maps string to an enum list", args::Matcher{"mfl"}, map); - //args::MapPositional mp(parser, "MP", "Maps string to an enum", args::Matcher{"mp"}, map); - //args::MapPositionalList mpl(parser, "MPL", "Maps string to an enum list", args::Matcher{"mpl"}, map); - //parser.ParseArgs(std::vector{"--mf=red", "--cimf=YeLLoW", "--mfl=bar", "foo", "--mfl=green", "red", "--mfl", "bar", "default"}); - parser.ParseArgs(std::vector{"--mf=red", "--cimf=YeLLoW"}); + args::MapFlagList mfl(parser, "MFL", "Maps string to an enum list", args::Matcher{"mfl"}, map); + args::MapPositional mp(parser, "MP", "Maps string to an enum", map); + args::MapPositionalList mpl(parser, "MPL", "Maps string to an enum list", map); + parser.ParseArgs(std::vector{"--mf=red", "--cimf=YeLLoW", "--mfl=bar", "foo", "--mfl=green", "red", "--mfl", "bar", "default"}); REQUIRE_FALSE(dmf); REQUIRE(args::get(dmf) == MappingEnum::def); REQUIRE(mf); REQUIRE(args::get(mf) == MappingEnum::red); REQUIRE(cimf); REQUIRE(args::get(cimf) == MappingEnum::yellow); - //REQUIRE(mfl); - //REQUIRE(args::get(mfl) == std::vector{MappingEnum::bar, MappingEnum::green, MappingEnum::bar}); - //REQUIRE(mp); - //REQUIRE(args::get(mp) == MappingEnum::foo); - //REQUIRE(mpl); - //REQUIRE(args::get(mpl) == std::vector{MappingEnum::red, MappingEnum::def}); + REQUIRE(mfl); + REQUIRE((args::get(mfl) == std::vector{MappingEnum::bar, MappingEnum::green, MappingEnum::bar})); + REQUIRE(mp); + REQUIRE((args::get(mp) == MappingEnum::foo)); + REQUIRE(mpl); + REQUIRE((args::get(mpl) == std::vector{MappingEnum::red, MappingEnum::def})); REQUIRE_THROWS_AS(parser.ParseArgs(std::vector{"--mf=YeLLoW"}), args::MapError); } -- cgit v1.2.1