diff options
| -rw-r--r-- | args.hxx | 80 | ||||
| -rw-r--r-- | test.cxx | 14 | 
2 files changed, 74 insertions, 20 deletions
| @@ -877,6 +877,13 @@ namespace args                  defaultString = str;              } +            /** Gets default value string that will be added to argument description. +             */ +            std::string HelpDefault(const HelpParams ¶ms) const +            { +                return GetDefaultString(params); +            } +              /** Sets choices string that will be added to argument description.               *  Use empty string to disable it for this argument.               */ @@ -886,6 +893,13 @@ namespace args                  choicesString = str;              } +            /** Gets choices string that will be added to argument description. +             */ +            std::string HelpChoices(const HelpParams ¶ms) const +            { +                return GetChoicesString(params); +            } +              virtual std::vector<std::tuple<std::string, std::string, unsigned>> GetDescription(const HelpParams ¶ms, const unsigned indentLevel) const override              {                  std::tuple<std::string, std::string, unsigned> description; @@ -955,12 +969,39 @@ namespace args              s << value;              return s.str();          } +          template <typename T>          typename std::enable_if<!IsConvertableToString<T>::value, std::string>::type          ToString(const T &)          {              return {};          } + +        template <typename T> +        std::string MapKeysToString(const T &map) +        { +            std::string res; +            using K = typename std::decay<decltype(std::begin(map)->first)>::type; +            if (IsConvertableToString<K>::value) +            { +                std::vector<std::string> values; +                for (const auto &p : map) +                { +                    values.push_back(detail::ToString(p.first)); +                } + +                std::sort(values.begin(), values.end()); +                for (const auto &s : values) +                { +                    if (!res.empty()) +                    { +                        res += ", "; +                    } +                    res += s; +                } +            } +            return res; +        }      }      /** Base class for all flag options @@ -3196,26 +3237,7 @@ namespace args          protected:              virtual std::string GetChoicesString(const HelpParams &) const override              { -                std::string res; -                if (detail::IsConvertableToString<K>::value) -                { -                    std::vector<std::string> values; -                    for (const auto &p : map) -                    { -                        values.push_back(detail::ToString(p.first)); -                    } - -                    std::sort(values.begin(), values.end()); -                    for (const auto &s : values) -                    { -                        if (!res.empty()) -                        { -                            res += ", "; -                        } -                        res += s; -                    } -                } -                return res; +                return detail::MapKeysToString(map);              }          public: @@ -3294,6 +3316,12 @@ namespace args              Container values;              Reader reader; +        protected: +            virtual std::string GetChoicesString(const HelpParams &) const override +            { +                return detail::MapKeysToString(map); +            } +          public:              typedef T value_type;              typedef typename Container::allocator_type allocator_type; @@ -3565,6 +3593,12 @@ namespace args              T value;              Reader reader; +        protected: +            virtual std::string GetChoicesString(const HelpParams &) const override +            { +                return detail::MapKeysToString(map); +            } +          public:              MapPositional(Group &group_, const std::string &name_, const std::string &help_, const Map<K, T> &map_, const T &defaultValue_ = T()): PositionalBase(name_, help_), map(map_), value(defaultValue_) @@ -3634,6 +3668,12 @@ namespace args              Container values;              Reader reader; +        protected: +            virtual std::string GetChoicesString(const HelpParams &) const override +            { +                return detail::MapKeysToString(map); +            } +          public:              typedef T value_type;              typedef typename Container::allocator_type allocator_type; @@ -1231,6 +1231,20 @@ TEST_CASE("Default values work as expected", "[args]")  )");  } +TEST_CASE("Choices description works as expected", "[args]") +{ +    args::ArgumentParser p("parser"); +    args::MapFlag<int, int> map(p, "map", "map", {"map"}, {{1,1}, {2, 2}}); +    args::MapFlagList<char, int> maplist(p, "maplist", "maplist", {"maplist"}, {{'1',1}, {'2', 2}}); +    args::MapPositional<std::string, int, args::ValueReader, std::map> mappos(p, "mappos", "mappos", {{"1",1}, {"2", 2}}); +    args::MapPositionalList<char, int, std::vector, args::ValueReader, std::map> mapposlist(p, "mapposlist", "mapposlist", {{'1',1}, {'2', 2}}); + +    REQUIRE(map.HelpChoices(p.helpParams) == "1, 2"); +    REQUIRE(maplist.HelpChoices(p.helpParams) == "1, 2"); +    REQUIRE(mappos.HelpChoices(p.helpParams) == "1, 2"); +    REQUIRE(mapposlist.HelpChoices(p.helpParams) == "1, 2"); +} +  #undef ARGS_HXX  #define ARGS_TESTNAMESPACE  #define ARGS_NOEXCEPT | 
