X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FUtility.ct;h=603bbc7b0f7ace185f4cd13bc4c7dae99b7bb56a;hb=93d9568d448749dc187e7622b733a4a3caa319df;hp=bd132fbce9c1d48bf15c0fa2e7f6f6d7d4b89a2b;hpb=71b18ab7945f6adc60d1717e1f3d2b95c8d199f1;p=senf.git diff --git a/senf/Utils/Console/Utility.ct b/senf/Utils/Console/Utility.ct index bd132fb..603bbc7 100644 --- a/senf/Utils/Console/Utility.ct +++ b/senf/Utils/Console/Utility.ct @@ -1,6 +1,6 @@ // $Id$ // -// Copyright (C) 2009 +// Copyright (C) 2009 // Fraunhofer Institute for Open Communication Systems (FOKUS) // Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund @@ -27,10 +27,50 @@ // Custom includes #include +#include #include +#include "Traits.hh" #define prefix_ -///////////////////////////////ct.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// + +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::ArgumentTraits< CharAsString > + +template +prefix_ void senf::console::ArgumentTraits< senf::console::CharAsString >:: +parse(ParseCommandInfo::TokensRange const & tokens, CharAsString & out) +{ + std::string v; + senf::console::parse(tokens,v); + if (v.size() != 1) + throw SyntaxErrorException("Invalid size of character constant"); + out.value = static_cast(v[0]); +} + +template +prefix_ std::string +senf::console::ArgumentTraits< senf::console::CharAsString >::description() +{ + return std::numeric_limits::is_signed ? "char" : "uchar"; +} + +template +prefix_ std::string senf::console::ArgumentTraits< senf::console::CharAsString >:: +str(CharAsString value) +{ + return senf::console::str(std::string(1,value.value)); +} + +template +prefix_ void senf::console::ReturnValueTraits< senf::console::CharAsString >:: +format(CharAsString value, std::ostream & os) +{ + return senf::console::format(std::string(1,value.value),os); +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::ArgumentTraits< senf::console::ValueRange > template prefix_ void senf::console::ArgumentTraits< senf::console::ValueRange >:: @@ -69,16 +109,70 @@ 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//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_