=================================================================== RCS file: /cvs/mandoc/man.c,v retrieving revision 1.65 retrieving revision 1.70 diff -u -p -r1.65 -r1.70 --- mandoc/man.c 2010/05/12 16:46:28 1.65 +++ mandoc/man.c 2010/05/15 22:44:04 1.70 @@ -1,4 +1,4 @@ -/* $Id: man.c,v 1.65 2010/05/12 16:46:28 kristaps Exp $ */ +/* $Id: man.c,v 1.70 2010/05/15 22:44:04 kristaps Exp $ */ /* * Copyright (c) 2008, 2009 Kristaps Dzonsons * @@ -32,7 +32,6 @@ const char *const __man_merrnames[WERRMAX] = { "invalid character", /* WNPRINT */ - "invalid manual section", /* WMSEC */ "invalid date format", /* WDATE */ "scope of prior line violated", /* WLNSCOPE */ "over-zealous prior line scope violation", /* WLNSCOPE2 */ @@ -50,8 +49,6 @@ const char *const __man_merrnames[WERRMAX] = { "no scope context", /* WNOSCOPE */ "literal context already open", /* WOLITERAL */ "no literal context open", /* WNLITERAL */ - "invalid nesting of roff declarations", /* WROFFNEST */ - "scope in roff instructions broken", /* WROFFSCOPE */ "document title should be uppercase", /* WTITLECASE */ "deprecated comment style", /* WBADCOMMENT */ }; @@ -65,9 +62,7 @@ const char *const __man_macronames[MAN_MAX] = { "RI", "na", "i", "sp", "nf", "fi", "r", "RE", "RS", "DT", "UC", "PD", - "Sp", "Vb", "Ve", "de", - "dei", "am", "ami", "ig", - ".", + "Sp", "Vb", "Ve", }; const char * const *man_macronames = __man_macronames; @@ -174,6 +169,8 @@ man_free1(struct man *man) free(man->meta.source); if (man->meta.vol) free(man->meta.vol); + if (man->meta.msec) + free(man->meta.msec); } @@ -426,23 +423,13 @@ man_ptext(struct man *m, int line, char *buf) * sentence. The front-end will know how to interpret this. */ + /* FIXME: chain of close delims. */ + assert(i); - switch (buf[i - 1]) { - case ('.'): - if (i > 1 && '\\' == buf[i - 2]) - break; - /* FALLTHROUGH */ - case ('!'): - /* FALLTHROUGH */ - case ('?'): + if (mandoc_eos(buf, (size_t)i)) m->last->flags |= MAN_EOS; - break; - default: - break; - } - descope: /* * Co-ordinate what happens with having a next-line scope open: @@ -558,9 +545,6 @@ man_pmacro(struct man *m, int ln, char *buf) * Remove prior ELINE macro, as it's being clobbering by a new * macro. Note that NSCOPED macros do not close out ELINE * macros---they don't print text---so we let those slip by. - * NOTE: we don't allow roff blocks (NOCLOSE) to be embedded - * here because that would stipulate blocks as children of - * elements! */ if ( ! (MAN_NSCOPED & man_macros[tok].flags) &&