]> git.cameronkatri.com Git - mandoc.git/blobdiff - man_html.c
In HTML output, avoid printing a newline right after <pre>
[mandoc.git] / man_html.c
index 80f69e1ad33d1b526a7cb09ccca445069dd96c3f..147c20e46443118f00cbacd8609b713254452b48 100644 (file)
@@ -1,4 +1,4 @@
-/* $Id: man_html.c,v 1.178 2020/04/04 20:33:33 schwarze Exp $ */
+/* $Id: man_html.c,v 1.179 2020/10/16 17:22:43 schwarze Exp $ */
 /*
  * Copyright (c) 2013-2015, 2017-2020 Ingo Schwarze <schwarze@openbsd.org>
  * Copyright (c) 2008-2012, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
@@ -169,7 +169,12 @@ print_man_node(MAN_ARGS)
        if (n->type == ROFFT_COMMENT || n->flags & NODE_NOPRT)
                return;
 
-       html_fillmode(h, n->flags & NODE_NOFILL ? ROFF_nf : ROFF_fi);
+       if ((n->flags & NODE_NOFILL) == 0)
+               html_fillmode(h, ROFF_fi);
+       else if (html_fillmode(h, ROFF_nf) == ROFF_nf &&
+           n->tok != ROFF_fi && n->flags & NODE_LINE &&
+           (n->prev == NULL || n->prev->tok != MAN_YS))
+               print_endline(h);
 
        child = 1;
        switch (n->type) {
@@ -253,13 +258,6 @@ print_man_node(MAN_ARGS)
        }
        if (t != NULL)
                print_stagq(h, t);
-
-       if (n->flags & NODE_NOFILL && n->tok != MAN_YS &&
-           (n->next != NULL && n->next->flags & NODE_LINE)) {
-               /* In .nf = <pre>, print even empty lines. */
-               h->col++;
-               print_endline(h);
-       }
 }
 
 static void