From: Karel Zak Date: Wed, 20 Dec 2017 12:01:43 +0000 (+0100) Subject: lib/mbsalign: encode \x to \xecx X-Git-Tag: v2.32-rc1~115 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=43afa84581de8984aa00ef2e9208198929f72ddf;p=thirdparty%2Futil-linux.git lib/mbsalign: encode \x to \xecx Don't encode stand alone '\', our encoding is about \x, so we need to care about \x prefix only. Signed-off-by: Karel Zak --- diff --git a/lib/mbsalign.c b/lib/mbsalign.c index dce1a13214..07fc313b84 100644 --- a/lib/mbsalign.c +++ b/lib/mbsalign.c @@ -54,7 +54,8 @@ size_t mbs_safe_nwidth(const char *buf, size_t bufsz, size_t *sz) last = p + (bufsz - 1); while (p && *p && p <= last) { - if (*p == '\\' || iscntrl((unsigned char) *p)) { + if ((p < last && *p == '\\' && *(p + 1) == 'x') + || iscntrl((unsigned char) *p)) { width += 4, bytes += 4; /* *p encoded to \x?? */ p++; } @@ -135,7 +136,8 @@ char *mbs_safe_encode_to_buffer(const char *s, size_t *width, char *buf, const c continue; } - if (*p == '\\' || iscntrl((unsigned char) *p)) { + if ((*p == '\\' && *(p + 1) == 'x') + || iscntrl((unsigned char) *p)) { sprintf(r, "\\x%02x", (unsigned char) *p); r += 4; *width += 4; @@ -239,6 +241,10 @@ char *mbs_invalid_encode_to_buffer(const char *s, size_t *width, char *buf) (*width)++; *r++ = *p; } + } else if (*p == '\\' && *(p + 1) == 'x') { + sprintf(r, "\\x%02x", (unsigned char) *p); + r += 4; + *width += 4; } else { memcpy(r, p, len); r += len;