X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FSTLSupport.ct;h=e0f9a48421300ea36454c1c852d8807a57d711fb;hb=refs%2Fheads%2Fmaster;hp=18af3dcda5ece37e972058531b28b3b7c327b3b6;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/Utils/Console/STLSupport.ct b/senf/Utils/Console/STLSupport.ct index 18af3dc..e0f9a48 100644 --- a/senf/Utils/Console/STLSupport.ct +++ b/senf/Utils/Console/STLSupport.ct @@ -1,24 +1,29 @@ // $Id$ // -// Copyright (C) 2009 +// Copyright (C) 2009 // Fraunhofer Institute for Open Communication Systems (FOKUS) -// Competence Center NETwork research (NET), St. Augustin, GERMANY -// Stefan Bund // -// This program is free software; you can redistribute it and/or modify -// it under the terms of the GNU General Public License as published by -// the Free Software Foundation; either version 2 of the License, or -// (at your option) any later version. +// The contents of this file are subject to the Fraunhofer FOKUS Public License +// Version 1.0 (the "License"); you may not use this file except in compliance +// with the License. You may obtain a copy of the License at +// http://senf.berlios.de/license.html // -// This program is distributed in the hope that it will be useful, -// but WITHOUT ANY WARRANTY; without even the implied warranty of -// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -// GNU General Public License for more details. +// The Fraunhofer FOKUS Public License Version 1.0 is based on, +// but modifies the Mozilla Public License Version 1.1. +// See the full license text for the amendments. // -// You should have received a copy of the GNU General Public License -// along with this program; if not, write to the -// Free Software Foundation, Inc., -// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +// Software distributed under the License is distributed on an "AS IS" basis, +// WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License +// for the specific language governing rights and limitations under the License. +// +// The Original Code is Fraunhofer FOKUS code. +// +// The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. +// (registered association), Hansastraße 27 c, 80686 Munich, Germany. +// All Rights Reserved. +// +// Contributor(s): +// Stefan Bund /** \file \brief VectorSupport non-inline template implementation */ @@ -29,53 +34,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) { + typename Collection::value_type v; + senf::console::parse( *(arg++), v ); + Adder::add(out,v); + } +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// senf::console::detail::CollectionReturnValueTraits + +template +prefix_ void +senf::console::detail::CollectionReturnValueTraits::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 (;;) { + os << senf::console::str(*i); + if (++i == i_end) + break; + else + os << " "; + } + os << ")"; +} + +//-///////////////////////////////////////////////////////////////////////////////////////////////// +// 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) { - out.push_back(typename Sequence::value_type()); - senf::console::parse( *(arg++), out.back() ); + 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::SequenceArgumentTraits::description() +template +prefix_ std::string senf::console::detail::MapArgumentTraits::description() { - 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() + ">"; + return senf::prettyBaseName(typeid(Collection)) + "<" + + ArgumentTraits::description() + "," + + ArgumentTraits::description() + ">"; } -template -prefix_ std::string senf::console::SequenceArgumentTraits::str(type const & value) +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 +158,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 +186,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_