diff options
author | Ingo Schwarze <schwarze@openbsd.org> | 2019-09-03 18:08:02 +0000 |
---|---|---|
committer | Ingo Schwarze <schwarze@openbsd.org> | 2019-09-03 18:08:02 +0000 |
commit | 1e7136c9c7a91b3c7254d1c4b5daf7159f2b8170 (patch) | |
tree | c5d07ed80ee8fa2d4dac69b5acb4f3a232d3d4b7 | |
parent | 96fafeeaa0c21ab33480601821d24b8f099713d6 (diff) | |
download | mandoc-1e7136c9c7a91b3c7254d1c4b5daf7159f2b8170.tar.gz |
Wrap text and phrasing elements in paragraphs unless already
contained in flow containers; never put them directly into sections.
This helps to format paragraphs with the CSS class selector .Pp.
Suggested by bentley@ and also by Colin Watson <cjwatson at debian>
via Michael Stapelberg <stapelberg at debian>,
see https://github.com/Debian/debiman/issues/116
-rw-r--r-- | html.c | 25 |
1 files changed, 24 insertions, 1 deletions
@@ -590,7 +590,15 @@ print_otag(struct html *h, enum htmltag tag, const char *fmt, ...) assert((htmltags[t->tag].flags & HTML_TOPHRASE) == 0); break; } - } + + /* + * Always wrap phrasing elements in a paragraph + * unless already contained in some flow container; + * never put them directly into a section. + */ + + } else if (tflags & HTML_TOPHRASE && h->tag->tag == TAG_SECTION) + print_otag(h, TAG_P, "c", "Pp"); /* Push this tag onto the stack of open scopes. */ @@ -796,6 +804,16 @@ print_gen_comment(struct html *h, struct roff_node *n) void print_text(struct html *h, const char *word) { + /* + * Always wrap text in a paragraph unless already contained in + * some flow container; never put it directly into a section. + */ + + if (h->tag->tag == TAG_SECTION) + print_otag(h, TAG_P, "c", "Pp"); + + /* Output whitespace before this text? */ + if (h->col && (h->flags & HTML_NOSPACE) == 0) { if ( ! (HTML_KEEP & h->flags)) { if (HTML_PREKEEP & h->flags) @@ -805,6 +823,11 @@ print_text(struct html *h, const char *word) print_word(h, " "); } + /* + * Print the text, optionally surrounded by HTML whitespace, + * optionally manually switching fonts before and after. + */ + assert(h->metaf == NULL); print_metaf(h); print_indent(h); |