From: Luigi Rizzo Date: Tue, 17 Oct 2006 17:19:31 +0000 (+0000) Subject: document xml_copy_escape() and add an extra function, namely X-Git-Tag: 1.6.0-beta1~3^2~4389 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=0c7e8f99a4ccbc79ebc83d8a1649cc413aa010d1;p=thirdparty%2Fasterisk.git document xml_copy_escape() and add an extra function, namely replace non-alphanum chars with underscore. This is useful when building field names in xml formatting. git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@45325 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/main/manager.c b/main/manager.c index 532ceb87ef..45cdd6e6b2 100644 --- a/main/manager.c +++ b/main/manager.c @@ -240,9 +240,19 @@ static char *complete_show_mancmd(const char *line, const char *word, int pos, i return ret; } -static void xml_copy_escape(char **dst, size_t *maxlen, const char *src, int lower) +/* + * convert to xml with various conversion: + * mode & 1 -> lowercase; + * mode & 2 -> replace non-alphanumeric chars with underscore + */ +static void xml_copy_escape(char **dst, size_t *maxlen, const char *src, int mode) { - while (*src && (*maxlen > 6)) { + for ( ; *src && *maxlen > 6; src++) { + if ( (mode & 2) && !isalnum(*src)) { + *(*dst)++ = '_'; + (*maxlen)--; + continue; + } switch (*src) { case '<': strcpy(*dst, "<"); @@ -269,11 +279,11 @@ static void xml_copy_escape(char **dst, size_t *maxlen, const char *src, int low (*dst) += 5; *maxlen -= 5; break; + default: - *(*dst)++ = lower ? tolower(*src) : *src; + *(*dst)++ = mode ? tolower(*src) : *src; (*maxlen)--; } - src++; } }