=================================================================== RCS file: /cvs/mandoc/html.c,v retrieving revision 1.174 retrieving revision 1.177 diff -u -p -r1.174 -r1.177 --- mandoc/html.c 2014/09/28 20:14:20 1.174 +++ mandoc/html.c 2014/10/26 17:12:03 1.177 @@ -1,6 +1,6 @@ -/* $Id: html.c,v 1.174 2014/09/28 20:14:20 kristaps Exp $ */ +/* $Id: html.c,v 1.177 2014/10/26 17:12:03 schwarze Exp $ */ /* - * Copyright (c) 2008, 2009, 2010, 2011, 2014 Kristaps Dzonsons + * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons * Copyright (c) 2011, 2012, 2013, 2014 Ingo Schwarze * * Permission to use, copy, modify, and distribute this software for any @@ -105,6 +105,7 @@ static const char *const htmlattrs[ATTR_MAX] = { "charset", /* ATTR_CHARSET */ "open", /* ATTR_OPEN */ "close", /* ATTR_CLOSE */ + "mathvariant", /* ATTR_MATHVARIANT */ }; static const char *const roffscales[SCALE_MAX] = { @@ -436,8 +437,18 @@ print_encode(struct html *h, const char *p, int norecu case ESCAPE_UNICODE: /* Skip past "u" header. */ c = mchars_num2uc(seq + 1, len - 1); - if ('\0' != c) - printf("&#x%x;", c); + + /* + * XXX Security warning: + * For now, forbid Unicode obfuscation of ASCII + * characters. An audit of the callers is + * required before this can be removed. + */ + + if (c < 0x80) + c = 0xFFFD; + + printf("&#x%x;", c); break; case ESCAPE_NUMBERED: c = mchars_num2char(seq, len);