=================================================================== RCS file: /cvs/mandoc/read.c,v retrieving revision 1.150.2.6 retrieving revision 1.150.2.8 diff -u -p -r1.150.2.6 -r1.150.2.8 --- mandoc/read.c 2017/01/28 23:35:05 1.150.2.6 +++ mandoc/read.c 2017/02/18 17:33:24 1.150.2.8 @@ -1,4 +1,4 @@ -/* $Id: read.c,v 1.150.2.6 2017/01/28 23:35:05 schwarze Exp $ */ +/* $Id: read.c,v 1.150.2.8 2017/02/18 17:33:24 schwarze Exp $ */ /* * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons * Copyright (c) 2010-2017 Ingo Schwarze @@ -32,7 +32,6 @@ #include #include #include -#include #include #include #include @@ -50,8 +49,8 @@ #define REPARSE_LIMIT 1000 struct mparse { - struct roff_man *man; /* man parser */ struct roff *roff; /* roff parser (!NULL) */ + struct roff_man *man; /* man parser */ char *sodest; /* filename pointed to by .so */ const char *file; /* filename of current input file */ struct buf *primary; /* buffer currently being parsed */ @@ -605,13 +604,14 @@ static int read_whole_file(struct mparse *curp, const char *file, int fd, struct buf *fb, int *with_mmap) { +#if HAVE_MMAP + struct stat st; +#endif gzFile gz; size_t off; ssize_t ssz; #if HAVE_MMAP - struct stat st; - if (fstat(fd, &st) == -1) err((int)MANDOCLEVEL_SYSERR, "%s", file); @@ -836,13 +836,15 @@ mparse_reset(struct mparse *curp) { roff_reset(curp->roff); roff_man_reset(curp->man); + + free(curp->sodest); + curp->sodest = NULL; + if (curp->secondary) curp->secondary->sz = 0; curp->file_status = MANDOCLEVEL_OK; - - free(curp->sodest); - curp->sodest = NULL; + curp->gzip = 0; } void @@ -850,8 +852,7 @@ mparse_free(struct mparse *curp) { roff_man_free(curp->man); - if (curp->roff) - roff_free(curp->roff); + roff_free(curp->roff); if (curp->secondary) free(curp->secondary->buf);