aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/mdoc_man.c
diff options
context:
space:
mode:
authorIngo Schwarze <schwarze@openbsd.org>2012-11-18 19:34:19 +0000
committerIngo Schwarze <schwarze@openbsd.org>2012-11-18 19:34:19 +0000
commitdd41ba9876ecdb30f9dbb35bcdeff569f90b2c0a (patch)
tree3ff6250d60d06bd23295aa0b8f1cd5a6bdf604b8 /mdoc_man.c
parent929d19c1a26c28f58bcef7321ca58ef8fda8f9f4 (diff)
downloadmandoc-dd41ba9876ecdb30f9dbb35bcdeff569f90b2c0a.tar.gz
mandoc-dd41ba9876ecdb30f9dbb35bcdeff569f90b2c0a.tar.zst
mandoc-dd41ba9876ecdb30f9dbb35bcdeff569f90b2c0a.zip
Make the generated man(7) code more portable by using .PD
instead of .sp -1v, which for example Solaris nroff handles poorly. Problem report and patch by millert@, with the print_word chunk tweaked by me.
Diffstat (limited to 'mdoc_man.c')
-rw-r--r--mdoc_man.c26
1 files changed, 20 insertions, 6 deletions
diff --git a/mdoc_man.c b/mdoc_man.c
index 23c70e15..960e9ea8 100644
--- a/mdoc_man.c
+++ b/mdoc_man.c
@@ -1,4 +1,4 @@
-/* $Id: mdoc_man.c,v 1.43 2012/11/18 18:02:23 schwarze Exp $ */
+/* $Id: mdoc_man.c,v 1.44 2012/11/18 19:34:19 schwarze Exp $ */
/*
* Copyright (c) 2011, 2012 Ingo Schwarze <schwarze@openbsd.org>
*
@@ -253,6 +253,7 @@ static int outflags;
#define MMAN_Bk (1 << 7) /* word keep mode */
#define MMAN_An_split (1 << 8) /* author mode is "split" */
#define MMAN_An_nosplit (1 << 9) /* author mode is "nosplit" */
+#define MMAN_PD (1 << 10) /* inter-paragraph spacing disabled */
#define BL_STACK_MAX 32
@@ -304,8 +305,15 @@ print_word(const char *s)
* If we need a newline, print it now and start afresh.
*/
if (MMAN_PP & outflags) {
- if ( ! (MMAN_sp & outflags))
- printf("\n.sp -1v");
+ if (MMAN_sp & outflags) {
+ if (MMAN_PD & outflags) {
+ printf("\n.PD");
+ outflags &= ~MMAN_PD;
+ }
+ } else if ( ! (MMAN_PD & outflags)) {
+ printf("\n.PD 0");
+ outflags |= MMAN_PD;
+ }
printf("\n.PP\n");
} else if (MMAN_sp & outflags)
printf("\n.sp\n");
@@ -379,10 +387,16 @@ print_block(const char *s, int newflags)
{
outflags &= ~MMAN_PP;
- if (MMAN_sp & outflags)
+ if (MMAN_sp & outflags) {
outflags &= ~(MMAN_sp | MMAN_br);
- else
- print_line(".sp -1v", 0);
+ if (MMAN_PD & outflags) {
+ print_line(".PD", 0);
+ outflags &= ~MMAN_PD;
+ }
+ } else if (! (MMAN_PD & outflags)) {
+ print_line(".PD 0", 0);
+ outflags |= MMAN_PD;
+ }
outflags |= MMAN_nl;
print_word(s);
outflags |= newflags;