=================================================================== RCS file: /cvs/mandoc/chars.c,v retrieving revision 1.47 retrieving revision 1.50 diff -u -p -r1.47 -r1.50 --- mandoc/chars.c 2011/07/07 06:41:50 1.47 +++ mandoc/chars.c 2011/07/31 11:24:39 1.50 @@ -1,4 +1,4 @@ -/* $Id: chars.c,v 1.47 2011/07/07 06:41:50 kristaps Exp $ */ +/* $Id: chars.c,v 1.50 2011/07/31 11:24:39 schwarze Exp $ */ /* * Copyright (c) 2009, 2010 Kristaps Dzonsons * Copyright (c) 2011 Ingo Schwarze @@ -37,7 +37,7 @@ struct ln { int unicode; }; -#define LINES_MAX 325 +#define LINES_MAX 328 #define CHAR(in, ch, code) \ { NULL, (in), (ch), (code) }, @@ -111,9 +111,9 @@ mchars_num2char(const char *p, size_t sz) { int i; - if ((i = mandoc_strntou(p, sz, 10)) < 0) + if ((i = mandoc_strntoi(p, sz, 10)) < 0) return('\0'); - return(isprint(i) ? i : '\0'); + return(i > 0 && i < 256 && isprint(i) ? i : '\0'); } int @@ -121,7 +121,7 @@ mchars_num2uc(const char *p, size_t sz) { int i; - if ((i = mandoc_strntou(p, sz, 16)) < 0) + if ((i = mandoc_strntoi(p, sz, 16)) < 0) return('\0'); /* FIXME: make sure we're not in a bogus range. */ return(i > 0x80 && i <= 0x10FFFF ? i : '\0'); @@ -133,8 +133,10 @@ mchars_spec2str(struct mchars *arg, const char *p, siz const struct ln *ln; ln = find(arg, p, sz); - if (NULL == ln) + if (NULL == ln) { + *rsz = 1; return(NULL); + } *rsz = strlen(ln->ascii); return(ln->ascii);