// $Id$ // // Copyright (C) 2009 // Fraunhofer Institute for Open Communication Systems (FOKUS) // // 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 // // 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. // // 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 Utility non-inline template implementation */ //#include "Utility.ih" // Custom includes #include #include #include #include "Traits.hh" #define prefix_ //-///////////////////////////////////////////////////////////////////////////////////////////////// //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::ArgumentTraits< CharAsString > template prefix_ void senf::console::ArgumentTraits< senf::console::CharAsString >:: parse(ParseCommandInfo::TokensRange const & tokens, CharAsString & out) { std::string v; 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 console::str(std::string(1,value.value)); } template prefix_ void senf::console::ReturnValueTraits< senf::console::CharAsString >:: format(CharAsString value, std::ostream & os) { 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 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 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; 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; 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()); } //-///////////////////////////////////////////////////////////////////////////////////////////////// #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: