before paragraphs and/or within `RS' blocks.
************************************************************************
* Official mandoc TODO.
-* $Id: TODO,v 1.112 2011/06/18 17:36:52 kristaps Exp $
+* $Id: TODO,v 1.113 2011/06/18 17:58:48 kristaps Exp $
************************************************************************
************************************************************************
should not produce two blank lines before the .SH,
see for example named-checkconf(8).
-- In man(7), the sequence
- regular text
- .RS
- .IP
- should have a blank line between the text and the beginning of the
- indented paragraph, see for example sudo(1).
-
- In man(7), the sequence
.SH HEADER
<blank line>
see for example rsync(1).
Reported by naddy@ Mon, 28 Mar 2011 20:45:42 +0200
-- In man(7), the sequence
- regular text
- .PP
- .RS
- indented text
- should produce one blank line between the regular and indented texts,
- see for example rsync(1), and
- .RE
- <blank line>
- .PP
- .RS
- should produce two,not one blank lines.
- Reported by naddy@ Mon, 28 Mar 2011 20:45:42 +0200
-
- In man(7), the sequence
regular text
.IP
-/* $Id: man_html.c,v 1.72 2011/05/17 11:34:31 kristaps Exp $ */
+/* $Id: man_html.c,v 1.73 2011/06/18 17:58:48 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
*
printf("\n");
}
-
static void
print_man(MAN_ARGS)
{
-/* $Id: man_term.c,v 1.110 2011/06/18 17:36:52 kristaps Exp $ */
+/* $Id: man_term.c,v 1.111 2011/06/18 17:58:48 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2010, 2011 Ingo Schwarze <schwarze@openbsd.org>
return((int)term_hspan(p, &su));
}
-
+/*
+ * Printing leading vertical space before a block.
+ * This is used for the paragraph macros.
+ * The rules are pretty simple, since there's very little nesting going
+ * on here. Basically, if we're the first within another block (SS/SH),
+ * then don't emit vertical space. If we are (RS), then do. If not the
+ * first, print it.
+ */
static void
print_bvspace(struct termp *p, const struct man_node *n)
{
- term_newln(p);
- if (n->body && n->body->child && MAN_TBL == n->body->child->type)
- return;
+ term_newln(p);
- if (NULL == n->prev)
- return;
+ if (n->body && n->body->child)
+ if (MAN_TBL == n->body->child->type)
+ return;
- if (MAN_SS == n->prev->tok)
- return;
- if (MAN_SH == n->prev->tok)
- return;
+ if (MAN_ROOT == n->parent->type || MAN_RS != n->parent->tok)
+ if (NULL == n->prev)
+ return;
term_vspace(p);
}
-
/* ARGSUSED */
static int
pre_ign(DECL_ARGS)