diff options
author | Ingo Schwarze <schwarze@openbsd.org> | 2012-07-07 13:46:59 +0000 |
---|---|---|
committer | Ingo Schwarze <schwarze@openbsd.org> | 2012-07-07 13:46:59 +0000 |
commit | ffda514f4f441208dbd540b23df572aba77505de (patch) | |
tree | 53c3d98b8d156259c2c298b6d2fa476ed21263d4 /mdoc_man.c | |
parent | 822a820e13c606b6885482a788be638d3a9552b7 (diff) | |
download | mandoc-ffda514f4f441208dbd540b23df572aba77505de.tar.gz |
implement -Tman .Bd -offset and -compact; OpenBSD rev. 1.8
Diffstat (limited to 'mdoc_man.c')
-rw-r--r-- | mdoc_man.c | 36 |
1 files changed, 35 insertions, 1 deletions
@@ -1,6 +1,6 @@ /* $Id$ */ /* - * Copyright (c) 2011 Ingo Schwarze <schwarze@openbsd.org> + * Copyright (c) 2011, 2012 Ingo Schwarze <schwarze@openbsd.org> * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above @@ -22,6 +22,7 @@ #include <string.h> #include "mandoc.h" +#include "out.h" #include "man.h" #include "mdoc.h" #include "main.h" @@ -68,6 +69,7 @@ static int pre_sect(DECL_ARGS); static int pre_ux(DECL_ARGS); static int pre_xr(DECL_ARGS); static void print_word(struct mman *, const char *); +static void print_offs(struct mman *, const char *); static void print_node(DECL_ARGS); static const struct manact manacts[MDOC_MAX + 1] = { @@ -245,6 +247,29 @@ print_word(struct mman *mm, const char *s) } } +static void +print_offs(struct mman *mm, const char *v) +{ + char buf[24]; + struct roffsu su; + size_t sz; + + if (NULL == v || '\0' == *v || 0 == strcmp(v, "left")) + sz = 0; + else if (0 == strcmp(v, "indent")) + sz = 6; + else if (0 == strcmp(v, "indent-two")) + sz = 12; + else if (a2roffsu(v, &su, SCALE_MAX)) { + print_word(mm, v); + return; + } else + sz = strlen(v); + + snprintf(buf, sizeof(buf), "%ldn", sz); + print_word(mm, buf); +} + void man_man(void *arg, const struct man *man) { @@ -445,12 +470,19 @@ static int pre_bd(DECL_ARGS) { + if (0 == n->norm->Bd.comp) { + mm->need_nl = 1; + print_word(mm, ".sp"); + } if (DISP_unfilled == n->norm->Bd.type || DISP_literal == n->norm->Bd.type) { mm->need_nl = 1; print_word(mm, ".nf"); } mm->need_nl = 1; + print_word(mm, ".RS"); + print_offs(mm, n->norm->Bd.offs); + mm->need_nl = 1; return(1); } @@ -458,6 +490,8 @@ static void post_bd(DECL_ARGS) { + mm->need_nl = 1; + print_word(mm, ".RE"); if (DISP_unfilled == n->norm->Bd.type || DISP_literal == n->norm->Bd.type) { mm->need_nl = 1; |