X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FUtility.ct;h=2f12892f51d2819bb736b8cfa15c94db39533f53;hb=a30f975608bae2dcee151af15dc7f40602627615;hp=14b5094a4cb5e880a2a2d0c5cb9f43583349cace;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Utils/Console/Utility.ct b/senf/Utils/Console/Utility.ct index 14b5094..2f12892 100644 --- a/senf/Utils/Console/Utility.ct +++ b/senf/Utils/Console/Utility.ct @@ -32,6 +32,9 @@ #define prefix_ ///////////////////////////////ct.p//////////////////////////////////////// +/////////////////////////////////////////////////////////////////////////// +// senf::console::ArgumentTraits< senf::console::ValueRange > + template prefix_ void senf::console::ArgumentTraits< senf::console::ValueRange >:: parse(ParseCommandInfo::TokensRange const & tokens, type & out) @@ -39,7 +42,7 @@ parse(ParseCommandInfo::TokensRange const & tokens, type & out) if (tokens.size() != 1) throw senf::console::SyntaxErrorException("parameter syntax error"); std::string v (tokens.begin()[0].value()); - unsigned i (v.find(':')); + std::string::size_type i (v.find(':')); try { if (i == std::string::npos) out.low = out.high = boost::lexical_cast(v); @@ -69,13 +72,67 @@ str(type const & value) return ss.str(); } +/////////////////////////////////////////////////////////////////////////// +// senf::console::ReturnValueTraits< senf::console::ValueRange > + template prefix_ void senf::console::ReturnValueTraits< senf::console::ValueRange >:: format(type const & value, std::ostream & os) { - os << value.low; + os << senf::console::str(value.low); if (value.low != value.high) - os << ':' << value.high; + os << ':' << senf::console::str(value.high); +} + +/////////////////////////////////////////////////////////////////////////// +// senf::console::ArgumentTraits< senf::console::FlagCollection > + +template +prefix_ void senf::console::ArgumentTraits< senf::console::FlagCollection >:: +parse(ParseCommandInfo::TokensRange const & tokens, type & out) +{ + CheckedArgumentIteratorWrapper arg (tokens); + out.value = 0; + while (arg) { + Enum v; + senf::console::parse( *(arg++), v); + out.value |= v; + } +} + +template +prefix_ std::string +senf::console::ArgumentTraits< senf::console::FlagCollection >::description() +{ + return ArgumentTraits::description(); +} + +template +prefix_ std::string +senf::console::ArgumentTraits< senf::console::FlagCollection >::str(type const & value) +{ + std::stringstream ss; + senf::console::format(value, ss); + return ss.str(); +} + +/////////////////////////////////////////////////////////////////////////// +// senf::console::ReturnValueTraits< senf::console::FlagCollection > + +template +prefix_ void senf::console::ReturnValueTraits< senf::console::FlagCollection >:: +format(type const & value, std::ostream & os) +{ + unsigned n (0); + std::stringstream ss; + unsigned long flag (1); + for (unsigned bit (0); bit(flag), ss); + } + } + os << (n != 1 ? "(" + ss.str() + ")" : ss.str()); } ///////////////////////////////ct.e////////////////////////////////////////