aboutsummaryrefslogtreecommitdiffstats
path: root/libwc/wtf.c
diff options
context:
space:
mode:
authorTatsuya Kinoshita <tats@debian.org>2016-12-10 08:10:17 +0000
committerTatsuya Kinoshita <tats@debian.org>2016-12-10 09:18:47 +0000
commitb4d27ba5ccffaa38e968c2bf3a8eeb9cd43928ff (patch)
tree6360f966dcec8cd380f034bb8873bf9bf5239b74 /libwc/wtf.c
parentPrevent overflow beyond the end of string in form_update_line() (diff)
downloadw3m-b4d27ba5ccffaa38e968c2bf3a8eeb9cd43928ff.tar.gz
w3m-b4d27ba5ccffaa38e968c2bf3a8eeb9cd43928ff.zip
Prevent overflow beyond the end of string for wtf to wcs macros
Bug-Debian: https://github.com/tats/w3m/issues/77
Diffstat (limited to 'libwc/wtf.c')
-rw-r--r--libwc/wtf.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/libwc/wtf.c b/libwc/wtf.c
index 83839d7..bf87e5f 100644
--- a/libwc/wtf.c
+++ b/libwc/wtf.c
@@ -167,15 +167,17 @@ wtf_type(wc_uchar *p)
((p)[3] = (((c) >> 7) & 0x7f) | 0x80), \
((p)[4] = ( (c) & 0x7f) | 0x80)
#define wtf_to_wcs16(p) \
+ (strlen(p) < 3 ? 0 : \
((wc_uint32)((p)[0] & 0x03) << 14) \
| ((wc_uint32)((p)[1] & 0x7f) << 7) \
- | ((wc_uint32)((p)[2] & 0x7f) )
+ | ((wc_uint32)((p)[2] & 0x7f) ))
#define wtf_to_wcs32(p) \
+ (strlen(p) < 5 ? 0 : \
((wc_uint32)((p)[0] & 0x0f) << 28) \
| ((wc_uint32)((p)[1] & 0x7f) << 21) \
| ((wc_uint32)((p)[2] & 0x7f) << 14) \
| ((wc_uint32)((p)[3] & 0x7f) << 7) \
- | ((wc_uint32)((p)[4] & 0x7f) )
+ | ((wc_uint32)((p)[4] & 0x7f) ))
void
wtf_push(Str os, wc_ccs ccs, wc_uint32 code)