X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FTraits.cti;h=1bdd459f25178f784777c4cbf9c9a83e7f854c5b;hb=57daeae6f2e924ce3f16f9677c3474f531cba9e5;hp=2d9c65a5f586ec4c4562738dde48b206b18602e1;hpb=ea5f02fb88dfab3932368bbafdc863b8ad585cc1;p=senf.git diff --git a/senf/Utils/Console/Traits.cti b/senf/Utils/Console/Traits.cti index 2d9c65a..1bdd459 100644 --- a/senf/Utils/Console/Traits.cti +++ b/senf/Utils/Console/Traits.cti @@ -1,6 +1,6 @@ // $Id$ // -// Copyright (C) 2008 +// Copyright (C) 2008 // Fraunhofer Institute for Open Communication Systems (FOKUS) // Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund @@ -28,12 +28,13 @@ // Custom includes #include #include +#include #include #define prefix_ inline -///////////////////////////////cti.p/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::detail::ReturnValueTraits template @@ -49,7 +50,7 @@ prefix_ void senf::console::senf_console_format_value(Type const & value, std::o os << value; } -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::ArgumentTraits template @@ -88,10 +89,28 @@ prefix_ std::string senf::console::ArgumentTraits::str(Type const & value) { std::stringstream ss; senf::console::format(value, ss); + std::string rv (ss.str()); + + if (rv.empty() || ! boost::algorithm::all(rv, CommandParser::isWordChar)) { + for (std::string::size_type i (0); i < rv.size(); ++i) + if (rv[i] == '"' || rv[i] == '\\') + rv.insert(i++,"\\"); + else if (rv[i] < ' ' || rv[i] > 126) { + rv.insert(i+1, (boost::format("x%02x") + % unsigned(static_cast(rv[i]))).str().c_str()); + rv[i] = '\\'; + i += 3; + } + + rv.insert(0,"\""); + rv.push_back('"'); + return rv; + } + return ss.str(); } -/////////////////////////////////////////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::console::detail::CharArgumentTraits template @@ -109,7 +128,7 @@ prefix_ std::string senf::console::detail::CharArgumentTraits::descriptio return std::numeric_limits::is_signed ? "byte" : "ubyte"; } -///////////////////////////////cti.e/////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_