svn commit: r286490 - head/lib/libc/locale

Baptiste Daroussin bapt at freebsd.org
Tue Aug 11 16:36:01 UTC 2015


On Tue, Aug 11, 2015 at 06:27:01PM +0200, Ed Schouten wrote:
> 2015-08-09 1:59 GMT+02:00 Baptiste Daroussin <bapt at freebsd.org>:
> >   Remove 5 and 6 bytes sequences which are illegal in UTF-8 space.
> >
> >   Per rfc3629 value greater than 0x10ffff should be rejected
> 
> I think the change you made only ensures that the value cannot exceed
> 0x1fffff -- not 0x10ffff. You probably need to do something like this:
> 
> diff --git a/lib/libc/locale/utf8.c b/lib/libc/locale/utf8.c
> index 55e2931..8ccfdb1 100644
> --- a/lib/libc/locale/utf8.c
> +++ b/lib/libc/locale/utf8.c
> @@ -191,7 +191,7 @@ _UTF8_mbrtowc(wchar_t * __restrict pwc, const char
> * __restrict s, size_t n,
>   errno = EILSEQ;
>   return ((size_t)-1);
>   }
> - if (wch >= 0xd800 && wch <= 0xdfff) {
> + if ((wch >= 0xd800 && wch <= 0xdfff) || wch > 0x10ffff) {
>   /*
>   * Malformed input; invalid code points.
>   */

Please go ahead with that one.

Best regards,
Bapt
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 181 bytes
Desc: not available
URL: <http://lists.freebsd.org/pipermail/svn-src-head/attachments/20150811/e536a71c/attachment.bin>


More information about the svn-src-head mailing list