X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fformatter.cc;fp=libtest%2Fformatter.cc;h=7cb3ea0ab8fb55ca8b7e0083b66638527128017a;hb=8a04c53710520be5a4d37b6acb682045a6c41faf;hp=a45d9c4f376927b27e22539252efc4623f5c5cb0;hpb=7be9389170df33175d87c12f3b6cf48fdf7d0934;p=awesomized%2Flibmemcached diff --git a/libtest/formatter.cc b/libtest/formatter.cc index a45d9c4f..7cb3ea0a 100644 --- a/libtest/formatter.cc +++ b/libtest/formatter.cc @@ -52,39 +52,41 @@ std::string& escape4XML(std::string const& arg, std::string& escaped_string) for (std::string::const_iterator x= arg.begin(), end= arg.end(); x != end; ++x) { unsigned char c= *x; - if (' ' <= c and c <= '~' and c != '\\' and c != '"' and c != '>' and c != '<') + if (c == '&') { - escaped_string+= c; + escaped_string+= "&"; } else if (c == '>') { - escaped_string+= '&'; - escaped_string+= 'g'; - escaped_string+= 't'; - escaped_string+= ';'; + escaped_string+= ">"; } else if (c == '<') { - escaped_string+= '&'; - escaped_string+= 'l'; - escaped_string+= 't'; - escaped_string+= ';'; + escaped_string+= "<"; + } + else if (c == '\'') + { + escaped_string+= "'"; break; + } + else if (c == '"') + { + escaped_string+= """; + } + else if (c == ' ') + { + escaped_string+= ' '; + } + else if (isalnum(c)) + { + escaped_string+= c; } else { - escaped_string+= '\\'; - switch (c) { - case '"': escaped_string+= '"'; break; - case '\\': escaped_string+= '\\'; break; - case '\t': escaped_string+='t'; break; - case '\r': escaped_string+='r'; break; - case '\n': escaped_string+='n'; break; - default: - char const* const hexdig= "0123456789ABCDEF"; - escaped_string+= 'x'; - escaped_string+= hexdig[c >> 4]; - escaped_string+= hexdig[c & 0xF]; - } + char const* const hexdig= "0123456789ABCDEF"; + escaped_string+= "&#x"; + escaped_string+= hexdig[c >> 4]; + escaped_string+= hexdig[c & 0xF]; + escaped_string+= ';'; } } escaped_string+= '"';