version 1.43, 2012/11/18 18:02:23 |
version 1.45, 2012/11/19 02:08:33 |
Line 253 static int outflags; |
|
Line 253 static int outflags; |
|
#define MMAN_Bk (1 << 7) /* word keep mode */ |
#define MMAN_Bk (1 << 7) /* word keep mode */ |
#define MMAN_An_split (1 << 8) /* author mode is "split" */ |
#define MMAN_An_split (1 << 8) /* author mode is "split" */ |
#define MMAN_An_nosplit (1 << 9) /* author mode is "nosplit" */ |
#define MMAN_An_nosplit (1 << 9) /* author mode is "nosplit" */ |
|
#define MMAN_PD (1 << 10) /* inter-paragraph spacing disabled */ |
|
|
#define BL_STACK_MAX 32 |
#define BL_STACK_MAX 32 |
|
|
Line 304 print_word(const char *s) |
|
Line 305 print_word(const char *s) |
|
* If we need a newline, print it now and start afresh. |
* If we need a newline, print it now and start afresh. |
*/ |
*/ |
if (MMAN_PP & outflags) { |
if (MMAN_PP & outflags) { |
if ( ! (MMAN_sp & outflags)) |
if (MMAN_sp & outflags) { |
printf("\n.sp -1v"); |
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"); |
printf("\n.PP\n"); |
} else if (MMAN_sp & outflags) |
} else if (MMAN_sp & outflags) |
printf("\n.sp\n"); |
printf("\n.sp\n"); |
Line 326 print_word(const char *s) |
|
Line 334 print_word(const char *s) |
|
*/ |
*/ |
if (MMAN_spc_force & outflags || '\0' == s[0] || |
if (MMAN_spc_force & outflags || '\0' == s[0] || |
NULL == strchr(".,:;)]?!", s[0]) || '\0' != s[1]) { |
NULL == strchr(".,:;)]?!", s[0]) || '\0' != s[1]) { |
if (MMAN_Bk & outflags) { |
if (MMAN_Bk & outflags) |
putchar('\\'); |
putchar('\\'); |
putchar('~'); |
putchar(' '); |
} else |
|
putchar(' '); |
|
if (TPremain) |
if (TPremain) |
TPremain--; |
TPremain--; |
} |
} |
Line 350 print_word(const char *s) |
|
Line 356 print_word(const char *s) |
|
for ( ; *s; s++) { |
for ( ; *s; s++) { |
switch (*s) { |
switch (*s) { |
case (ASCII_NBRSP): |
case (ASCII_NBRSP): |
printf("\\~"); |
printf("\\ "); |
break; |
break; |
case (ASCII_HYPH): |
case (ASCII_HYPH): |
putchar('-'); |
putchar('-'); |
Line 379 print_block(const char *s, int newflags) |
|
Line 385 print_block(const char *s, int newflags) |
|
{ |
{ |
|
|
outflags &= ~MMAN_PP; |
outflags &= ~MMAN_PP; |
if (MMAN_sp & outflags) |
if (MMAN_sp & outflags) { |
outflags &= ~(MMAN_sp | MMAN_br); |
outflags &= ~(MMAN_sp | MMAN_br); |
else |
if (MMAN_PD & outflags) { |
print_line(".sp -1v", 0); |
print_line(".PD", 0); |
|
outflags &= ~MMAN_PD; |
|
} |
|
} else if (! (MMAN_PD & outflags)) { |
|
print_line(".PD 0", 0); |
|
outflags |= MMAN_PD; |
|
} |
outflags |= MMAN_nl; |
outflags |= MMAN_nl; |
print_word(s); |
print_word(s); |
outflags |= newflags; |
outflags |= newflags; |
Line 521 man_mdoc(void *arg, const struct mdoc *mdoc) |
|
Line 533 man_mdoc(void *arg, const struct mdoc *mdoc) |
|
meta = mdoc_meta(mdoc); |
meta = mdoc_meta(mdoc); |
n = mdoc_node(mdoc); |
n = mdoc_node(mdoc); |
|
|
printf(".TH \"%s\" \"%s\" \"%s\" \"%s\" \"%s\"", |
printf(".TH \"%s\" \"%s\" \"%s\" \"%s\" \"%s\"\n", |
meta->title, meta->msec, meta->date, |
meta->title, meta->msec, meta->date, |
meta->os, meta->vol); |
meta->os, meta->vol); |
|
|
|
/* Disable hyphenation and if nroff, disable justification. */ |
|
printf(".nh\n.if n .ad l"); |
|
|
outflags = MMAN_nl | MMAN_Sm; |
outflags = MMAN_nl | MMAN_Sm; |
if (0 == fontqueue.size) { |
if (0 == fontqueue.size) { |
fontqueue.size = 8; |
fontqueue.size = 8; |
Line 1039 pre_fl(DECL_ARGS) |
|
Line 1054 pre_fl(DECL_ARGS) |
|
{ |
{ |
|
|
font_push('B'); |
font_push('B'); |
print_word("-"); |
print_word("\\-"); |
outflags &= ~MMAN_spc; |
outflags &= ~MMAN_spc; |
return(1); |
return(1); |
} |
} |
Line 1517 pre_ux(DECL_ARGS) |
|
Line 1532 pre_ux(DECL_ARGS) |
|
if (NULL == n->child) |
if (NULL == n->child) |
return(0); |
return(0); |
outflags &= ~MMAN_spc; |
outflags &= ~MMAN_spc; |
print_word("\\~"); |
print_word("\\ "); |
outflags &= ~MMAN_spc; |
outflags &= ~MMAN_spc; |
return(1); |
return(1); |
} |
} |