=================================================================== RCS file: /cvs/mandoc/demandoc.c,v retrieving revision 1.19 retrieving revision 1.23 diff -u -p -r1.19 -r1.23 --- mandoc/demandoc.c 2015/04/18 16:34:25 1.19 +++ mandoc/demandoc.c 2015/10/20 02:01:31 1.23 @@ -1,4 +1,4 @@ -/* $Id: demandoc.c,v 1.19 2015/04/18 16:34:25 schwarze Exp $ */ +/* $Id: demandoc.c,v 1.23 2015/10/20 02:01:31 schwarze Exp $ */ /* * Copyright (c) 2011 Kristaps Dzonsons * @@ -44,7 +44,6 @@ int main(int argc, char *argv[]) { struct mparse *mp; - struct mchars *mchars; int ch, fd, i, list; extern int optind; @@ -73,14 +72,14 @@ main(int argc, char *argv[]) break; default: usage(); - return((int)MANDOCLEVEL_BADARG); + return (int)MANDOCLEVEL_BADARG; } argc -= optind; argv += optind; - mchars = mchars_alloc(); - mp = mparse_alloc(MPARSE_SO, MANDOCLEVEL_BADARG, NULL, mchars, NULL); + mchars_alloc(); + mp = mparse_alloc(MPARSE_SO, MANDOCLEVEL_BADARG, NULL, NULL); assert(mp); if (argc < 1) @@ -96,8 +95,8 @@ main(int argc, char *argv[]) } mparse_free(mp); - mchars_free(mchars); - return((int)MANDOCLEVEL_OK); + mchars_free(); + return (int)MANDOCLEVEL_OK; } static void @@ -120,10 +119,11 @@ pmandoc(struct mparse *mp, int fd, const char *fn, int if (man == NULL) return; - if (man->macroset == MACROSET_MDOC) - pmdoc(mdoc_node(man), &line, &col, list); - else - pman(man_node(man), &line, &col, list); + if (man->macroset == MACROSET_MDOC) { + mdoc_validate(man); + pmdoc(man->first->child, &line, &col, list); + } else + pman(man->first->child, &line, &col, list); if ( ! list) putchar('\n');