=================================================================== RCS file: /cvs/mandoc/term.c,v retrieving revision 1.188 retrieving revision 1.189 diff -u -p -r1.188 -r1.189 --- mandoc/term.c 2011/05/14 18:15:20 1.188 +++ mandoc/term.c 2011/05/15 14:50:01 1.189 @@ -1,4 +1,4 @@ -/* $Id: term.c,v 1.188 2011/05/14 18:15:20 kristaps Exp $ */ +/* $Id: term.c,v 1.189 2011/05/15 14:50:01 kristaps Exp $ */ /* * Copyright (c) 2008, 2009, 2010 Kristaps Dzonsons * Copyright (c) 2010, 2011 Ingo Schwarze @@ -606,8 +606,8 @@ term_strlen(const struct termp *p, const char *cp) { size_t sz, rsz, i; int ssz; - enum mandoc_esc esc; const char *seq, *rhs; + static const char rej[] = { '\\', ASCII_HYPH, ASCII_NBRSP, '\0' }; /* * Account for escaped sequences within string length @@ -616,15 +616,17 @@ term_strlen(const struct termp *p, const char *cp) */ sz = 0; - while ('\0' != *cp) + while ('\0' != *cp) { + rsz = strcspn(cp, rej); + for (i = 0; i < rsz; i++) + sz += (*p->width)(p, *cp++); + switch (*cp) { case ('\\'): - ++cp; - esc = mandoc_escape(&cp, &seq, &ssz); - if (ESCAPE_ERROR == esc) + cp++; + switch (mandoc_escape(&cp, &seq, &ssz)) { + case (ESCAPE_ERROR): return(sz); - - switch (esc) { case (ESCAPE_PREDEF): rhs = mchars_res2str (p->symtab, seq, ssz, &rsz); @@ -659,14 +661,13 @@ term_strlen(const struct termp *p, const char *cp) cp++; break; default: - sz += (*p->width)(p, *cp++); break; } + } return(sz); } - /* ARGSUSED */ size_t term_vspan(const struct termp *p, const struct roffsu *su) @@ -702,7 +703,6 @@ term_vspan(const struct termp *p, const struct roffsu return(/* LINTED */(size_t) r); } - size_t term_hspan(const struct termp *p, const struct roffsu *su)