=================================================================== RCS file: /cvs/docbook2mdoc/docbook2mdoc.c,v retrieving revision 1.89 retrieving revision 1.106 diff -u -p -r1.89 -r1.106 --- docbook2mdoc/docbook2mdoc.c 2019/04/03 16:52:51 1.89 +++ docbook2mdoc/docbook2mdoc.c 2019/04/12 07:05:19 1.106 @@ -1,4 +1,4 @@ -/* $Id: docbook2mdoc.c,v 1.89 2019/04/03 16:52:51 schwarze Exp $ */ +/* $Id: docbook2mdoc.c,v 1.106 2019/04/12 07:05:19 schwarze Exp $ */ /* * Copyright (c) 2014 Kristaps Dzonsons * Copyright (c) 2019 Ingo Schwarze @@ -19,6 +19,7 @@ #include #include #include +#include #include "node.h" #include "macro.h" @@ -32,63 +33,176 @@ static void pnode_print(struct format *, struct pnode static void -pnode_printpara(struct format *p, struct pnode *pn) +pnode_printtext(struct format *f, struct pnode *n) { - struct pnode *pp; + struct pnode *nn; + char *cp; + int accept_arg; + char last; - if ((pp = TAILQ_PREV(pn, pnodeq, child)) == NULL && - (pp = pn->parent) == NULL) + cp = n->b; + accept_arg = f->flags & FMT_ARG; + if (f->linestate == LINE_MACRO && n->spc == 0 && !accept_arg) { + for (;;) { + if (*cp == '\0') + return; + if (strchr("!),.:;?]", *cp) == NULL) + break; + printf(" %c", *cp++); + } + if (isspace((unsigned char)*cp)) { + while (isspace((unsigned char)*cp)) + cp++; + macro_close(f); + } else { + fputs(" Ns", stdout); + f->flags &= FMT_IMPL; + accept_arg = 1; + } + } + if (f->linestate == LINE_MACRO && !accept_arg && + (f->flags & (FMT_CHILD | FMT_IMPL)) == 0) + macro_close(f); + + /* + * Text preceding a macro without intervening whitespace + * requires a .Pf macro. + * Set the spacing flag to avoid a redundant .Ns macro. + */ + + if (f->linestate != LINE_MACRO && + (nn = TAILQ_NEXT(n, child)) != NULL && nn->spc == 0 && + (nn->node != NODE_TEXT && nn->node != NODE_ESCAPE)) { + macro_open(f, "Pf"); + accept_arg = 1; + f->flags |= FMT_CHILD; + nn->spc = 1; + } + + switch (f->linestate) { + case LINE_TEXT: + if (n->spc) { + if (n->node == NODE_TEXT) { + putchar('\n'); + last = '\n'; + break; + } + putchar(' '); + } + last = ' '; + break; + case LINE_MACRO: + if (accept_arg) { + putchar(' '); + last = ' '; + break; + } + macro_close(f); + /* FALLTHROUGH */ + case LINE_NEW: + f->linestate = LINE_TEXT; + last = '\n'; + break; + } + + if (n->node == NODE_ESCAPE) { + fputs(n->b, stdout); return; + } - switch (pp->node) { + /* + * Remove the prefix '-' from