From b237ba0a8eaa5001283ac8448872021723b90aff Mon Sep 17 00:00:00 2001 From: Peter Stephenson Date: Fri, 20 Feb 2015 16:25:47 +0000 Subject: 34587: ensure multibyte characters don't overflow. They could start incorporating tokens, with bad karma. Add test. --- Src/utils.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'Src') diff --git a/Src/utils.c b/Src/utils.c index 702829c0c..1bcceb091 100644 --- a/Src/utils.c +++ b/Src/utils.c @@ -4797,6 +4797,14 @@ mb_metacharlenconv_r(const char *s, wint_t *wcp, mbstate_t *mbsp) inchar = *++ptr ^ 32; DPUTS(!*ptr, "BUG: unexpected end of string in mb_metacharlen()\n"); + } else if (imeta(*ptr)) { + /* + * As this is metafied input, this is a token --- this + * can't be a part of the string. It might be + * something on the end of an unbracketed parameter + * reference, for example. + */ + break; } else inchar = *ptr; ptr++; -- cgit 1.4.1