// $Id$ // // 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. // // 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. // // 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. /** \file \brief Utility non-inline template implementation */ //#include "Utility.ih" // 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 >:: 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()); std::string::size_type i (v.find(':')); try { if (i == std::string::npos) out.low = out.high = boost::lexical_cast(v); else { out.low = boost::lexical_cast(v.substr(0,i)); out.high = boost::lexical_cast(v.substr(i+1)); } } catch (std::bad_cast & ex) { throw senf::console::SyntaxErrorException("parameter syntax error"); } } template prefix_ std::string senf::console::ArgumentTraits< senf::console::ValueRange >:: description() { return (boost::format("range<%s>") % ArgumentTraits::description()).str(); } template prefix_ std::string senf::console::ArgumentTraits< senf::console::ValueRange >:: str(type const & value) { std::stringstream ss; senf::console::format(value, ss); 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 << senf::console::str(value.low); if (value.low != 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_ // Local Variables: // mode: c++ // fill-column: 100 // comment-column: 40 // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" // End: