diff options
author | Tatsuya Kinoshita <tats@debian.org> | 2016-12-07 16:00:42 +0000 |
---|---|---|
committer | Tatsuya Kinoshita <tats@debian.org> | 2017-01-06 13:12:45 +0000 |
commit | dd35652c8200350de7d02178a1c1e2c2dc200ade (patch) | |
tree | 62c81abfdc9d4740c6a9eab46ef51137318b590f /libwc | |
parent | Prevent heap-use-after-free in HTMLlineproc0() (diff) | |
download | w3m-dd35652c8200350de7d02178a1c1e2c2dc200ade.tar.gz w3m-dd35652c8200350de7d02178a1c1e2c2dc200ade.zip |
Prevent overflow beyond the end of string in wtf_strwidth() and wtf_len()
Bug-Debian: https://github.com/tats/w3m/issues/57
Origin: https://anonscm.debian.org/cgit/collab-maint/w3m.git/commit/?id=7fbaf9444fcd2d3ce061775949b38deb4d489943
Origin: https://anonscm.debian.org/cgit/collab-maint/w3m.git/commit/?id=a56a8ef132945512c010cbcbc873dbb42274f9bd
Diffstat (limited to 'libwc')
-rw-r--r-- | libwc/wtf.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/libwc/wtf.c b/libwc/wtf.c index b8cfdc7..adee338 100644 --- a/libwc/wtf.c +++ b/libwc/wtf.c @@ -120,8 +120,9 @@ int wtf_strwidth(wc_uchar *p) { int w = 0; + wc_uchar *q = p + strlen(p); - while (*p) { + while (p < q) { w += wtf_width(p); p += WTF_LEN_MAP[*p]; } @@ -140,9 +141,10 @@ size_t wtf_len(wc_uchar *p) { wc_uchar *q = p; + wc_uchar *strz = p + strlen(p); q += WTF_LEN_MAP[*q]; - while (*q && ! WTF_WIDTH_MAP[*q]) + while (q < strz && ! WTF_WIDTH_MAP[*q]) q += WTF_LEN_MAP[*q]; return q - p; } |