diff options
author | Igor Sysoev <igor@sysoev.ru> | 2007-09-27 09:36:50 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2007-09-27 09:36:50 +0000 |
commit | 1730c758a18847f1f92dcd6aa7184b733bc0c4bf (patch) | |
tree | 762fa9ac0046f4ea248b12c694f2e4d7c86c8d32 /src/core/ngx_string.c | |
parent | 0659720dc87e606498a13e753299396bceb07188 (diff) | |
download | nginx-1730c758a18847f1f92dcd6aa7184b733bc0c4bf.tar.gz nginx-1730c758a18847f1f92dcd6aa7184b733bc0c4bf.zip |
ngx_escape_html()
Diffstat (limited to 'src/core/ngx_string.c')
-rw-r--r-- | src/core/ngx_string.c | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/src/core/ngx_string.c b/src/core/ngx_string.c index 68b2d61f0..6b40d0f91 100644 --- a/src/core/ngx_string.c +++ b/src/core/ngx_string.c @@ -1299,6 +1299,67 @@ done: } +uintptr_t +ngx_escape_html(u_char *dst, u_char *src, size_t size) +{ + u_char ch; + ngx_uint_t i, len; + + if (dst == NULL) { + + len = 0; + + for (i = 0; i < size; i++) { + switch (*src++) { + + case '<': + len += sizeof("<") - 2; + break; + + case '>': + len += sizeof(">") - 2; + break; + + case '&': + len += sizeof("&") - 2; + break; + + default: + break; + } + } + + return (uintptr_t) len; + } + + for (i = 0; i < size; i++) { + ch = *src++; + + switch (ch) { + + case '<': + *dst++ = '&'; *dst++ = 'l'; *dst++ = 't'; *dst++ = ';'; + break; + + case '>': + *dst++ = '&'; *dst++ = 'g'; *dst++ = 't'; *dst++ = ';'; + break; + + case '&': + *dst++ = '&'; *dst++ = 'a'; *dst++ = 'm'; *dst++ = 'p'; + *dst++ = ';'; + break; + + default: + *dst++ = ch; + break; + } + } + + return (uintptr_t) dst; +} + + /* ngx_sort() is implemented as insertion sort because we need stable sort */ void |