=================================================================== RCS file: /cvs/mandoc/demandoc.c,v retrieving revision 1.4 retrieving revision 1.10 diff -u -p -r1.4 -r1.10 --- mandoc/demandoc.c 2011/09/01 20:55:50 1.4 +++ mandoc/demandoc.c 2014/03/19 22:20:43 1.10 @@ -1,4 +1,4 @@ -/* $Id: demandoc.c,v 1.4 2011/09/01 20:55:50 kristaps Exp $ */ +/* $Id: demandoc.c,v 1.10 2014/03/19 22:20:43 schwarze Exp $ */ /* * Copyright (c) 2011 Kristaps Dzonsons * @@ -76,7 +76,7 @@ main(int argc, char *argv[]) argc -= optind; argv += optind; - mp = mparse_alloc(MPARSE_AUTO, MANDOCLEVEL_FATAL, NULL, NULL); + mp = mparse_alloc(MPARSE_SO, MANDOCLEVEL_FATAL, NULL, NULL); assert(mp); if (0 == argc) @@ -110,7 +110,7 @@ pmandoc(struct mparse *mp, int fd, const char *fn, int return; } - mparse_result(mp, &mdoc, &man); + mparse_result(mp, &mdoc, &man, NULL); line = 1; col = 0; @@ -121,7 +121,8 @@ pmandoc(struct mparse *mp, int fd, const char *fn, int else return; - putchar('\n'); + if ( ! list) + putchar('\n'); } /* @@ -131,12 +132,70 @@ static void pstring(const char *p, int col, int *colp, int list) { enum mandoc_esc esc; + const char *start, *end; + int emit; + /* + * Print as many column spaces til we achieve parity with the + * input document. + */ + +again: + if (list && '\0' != *p) { + while (isspace((unsigned char)*p)) + p++; + + while ('\'' == *p || '(' == *p || '"' == *p) + p++; + + emit = isalpha((unsigned char)p[0]) && + isalpha((unsigned char)p[1]); + + for (start = p; '\0' != *p; p++) + if ('\\' == *p) { + p++; + esc = mandoc_escape(&p, NULL, NULL); + if (ESCAPE_ERROR == esc) + return; + emit = 0; + } else if (isspace((unsigned char)*p)) + break; + + end = p - 1; + + while (end > start) + if ('.' == *end || ',' == *end || + '\'' == *end || '"' == *end || + ')' == *end || '!' == *end || + '?' == *end || ':' == *end || + ';' == *end) + end--; + else + break; + + if (emit && end - start >= 1) { + for ( ; start <= end; start++) + if (ASCII_HYPH == *start) + putchar('-'); + else + putchar((unsigned char)*start); + putchar('\n'); + } + + if (isspace((unsigned char)*p)) + goto again; + + return; + } + while (*colp < col) { putchar(' '); (*colp)++; } + /* + * Print the input word, skipping any special characters. + */ while ('\0' != *p) if ('\\' == *p) { p++; @@ -152,6 +211,14 @@ pstring(const char *p, int col, int *colp, int list) static void pline(int line, int *linep, int *col, int list) { + + if (list) + return; + + /* + * Print out as many lines as needed to reach parity with the + * original input. + */ while (*linep < line) { putchar('\n');