X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FSTLSupport.ct;h=ec605506ee334008be96c281fc999b0607d7872d;hb=4101c2b818ec67e7469ebb44f030eed2185c4ab0;hp=18af3dcda5ece37e972058531b28b3b7c327b3b6;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Utils/Console/STLSupport.ct b/senf/Utils/Console/STLSupport.ct index 18af3dc..ec60550 100644 --- a/senf/Utils/Console/STLSupport.ct +++ b/senf/Utils/Console/STLSupport.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 @@ -29,53 +29,123 @@ #include #define prefix_ -///////////////////////////////ct.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #ifndef DOXYGEN -template -prefix_ void senf::console::SequenceArgumentTraits:: -parse(ParseCommandInfo::TokensRange const & tokens, type & out) +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::detail::CollectionArgumentTraitsBase + +template +prefix_ std::string +senf::console::detail::CollectionArgumentTraitsBase::description() +{ + return senf::prettyBaseName(typeid(Collection)) + "<" + + ArgumentTraits::description() + ">"; +} + +template +prefix_ std::string +senf::console::detail::CollectionArgumentTraitsBase::str(Collection const & value) +{ + std::stringstream ss; + senf::console::format(value, ss); + return ss.str(); +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::detail::CollectionArgumentTraits + +template +prefix_ void senf::console::detail::CollectionArgumentTraits:: +parse(ParseCommandInfo::TokensRange const & tokens, Collection & out) { out.clear(); CheckedArgumentIteratorWrapper arg (tokens); while (arg) { - out.push_back(typename Sequence::value_type()); - senf::console::parse( *(arg++), out.back() ); + typename Collection::value_type v; + senf::console::parse( *(arg++), v ); + Adder::add(out,v); } } -template -prefix_ std::string senf::console::SequenceArgumentTraits::description() +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::detail::CollectionReturnValueTraits + +template +prefix_ void +senf::console::detail::CollectionReturnValueTraits::format(Collection const & value, + std::ostream & os) { - std::string type (prettyName(typeid(Sequence))); - std::string::size_type e (type.find('<')); - if (e == std::string::npos) e = type.size(); - std::string::size_type b (type.rfind(':', e)); - if (b == std::string::npos) b = 0; else ++b; - return type.substr(b,e-b) + "<" - + ArgumentTraits::description() + ">"; + os << "("; + typename type::const_iterator i (value.begin()); + typename type::const_iterator const i_end (value.end()); + if (i != i_end) + for (;;) { + os << senf::console::str(*i); + if (++i == i_end) + break; + else + os << " "; + } + os << ")"; } -template -prefix_ std::string senf::console::SequenceArgumentTraits::str(type const & value) +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::detail::MapArgumentTraits + +template +prefix_ void senf::console::detail::MapArgumentTraits:: +parse(ParseCommandInfo::TokensRange const & tokens, Collection & out) +{ + out.clear(); + CheckedArgumentIteratorWrapper arg (tokens); + while (arg) { + typename Collection::key_type key; + typename Collection::mapped_type data; + senf::console::parse( *(arg++), key ); + ParseCommandInfo::TokensRange sep (*(arg++)); + if (sep.size() != 1 || sep[0].type() != Token::OtherPunctuation || sep[0].value() != "=") + throw SyntaxErrorException("'=' expected"); + senf::console::parse( *(arg++), data ); + out.insert(std::make_pair(key,data)); + } +} + +template +prefix_ std::string senf::console::detail::MapArgumentTraits::description() +{ + return senf::prettyBaseName(typeid(Collection)) + "<" + + ArgumentTraits::description() + "," + + ArgumentTraits::description() + ">"; +} + +template +prefix_ std::string +senf::console::detail::MapArgumentTraits::str(Collection const & value) { std::stringstream ss; senf::console::format(value, ss); return ss.str(); } -template -prefix_ void senf::console::SequenceReturnValueTraits::format(type const & value, - std::ostream & os) +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::detail::MapReturnValueTraits + +template +prefix_ void +senf::console::detail::MapReturnValueTraits::format(Collection const & value, + std::ostream & os) { os << "("; typename type::const_iterator i (value.begin()); typename type::const_iterator const i_end (value.end()); if (i != i_end) for (;;) { - senf::console::format(*i, os); - if (++i == i_end) + os << senf::console::str(i->first) + << "=" + << senf::console::str(i->second); + if (++i == i_end) break; else os << " "; @@ -83,6 +153,9 @@ prefix_ void senf::console::SequenceReturnValueTraits::format(type con os << ")"; } +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::ArgumentTraits< std::pair > + template prefix_ void senf::console::ArgumentTraits< std::pair >:: parse(ParseCommandInfo::TokensRange const & tokens, type & out) @@ -108,20 +181,20 @@ prefix_ std::string senf::console::ArgumentTraits< std::pair >::str(type return ss.str(); } +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::ReturnValueTraits< std::pair > + template prefix_ void senf::console::ReturnValueTraits< std::pair >::format(type const & value, std::ostream & os) { - os << "("; - senf::console::format(value.first, os); - os << " "; - senf::console::format(value.second, os); - os << ")"; + os << "(" << senf::console::str(value.first) + << " " << senf::console::str(value.second) << ")"; } #endif -///////////////////////////////ct.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_