version 1.73, 2011/06/18 17:58:48 |
version 1.76, 2011/07/03 22:57:32 |
|
|
int (*post)(MAN_ARGS); |
int (*post)(MAN_ARGS); |
}; |
}; |
|
|
|
static void print_bvspace(struct html *, |
|
const struct man_node *); |
static void print_man(MAN_ARGS); |
static void print_man(MAN_ARGS); |
static void print_man_head(MAN_ARGS); |
static void print_man_head(MAN_ARGS); |
static void print_man_nodelist(MAN_ARGS); |
static void print_man_nodelist(MAN_ARGS); |
Line 114 static const struct htmlman mans[MAN_MAX] = { |
|
Line 116 static const struct htmlman mans[MAN_MAX] = { |
|
{ man_ign_pre, NULL }, /* ft */ |
{ man_ign_pre, NULL }, /* ft */ |
}; |
}; |
|
|
|
/* |
|
* 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 html *h, const struct man_node *n) |
|
{ |
|
|
|
if (n->body && n->body->child) |
|
if (MAN_TBL == n->body->child->type) |
|
return; |
|
|
|
if (MAN_ROOT == n->parent->type || MAN_RS != n->parent->tok) |
|
if (NULL == n->prev) |
|
return; |
|
|
|
print_otag(h, TAG_P, 0, NULL); |
|
} |
|
|
void |
void |
html_man(void *arg, const struct man *m) |
html_man(void *arg, const struct man *m) |
{ |
{ |
Line 390 man_br_pre(MAN_ARGS) |
|
Line 414 man_br_pre(MAN_ARGS) |
|
SCALE_VS_INIT(&su, 1); |
SCALE_VS_INIT(&su, 1); |
|
|
if (MAN_sp == n->tok) { |
if (MAN_sp == n->tok) { |
if (n->child) |
if (NULL != (n = n->child)) |
a2roffsu(n->child->string, &su, SCALE_VS); |
if ( ! a2roffsu(n->string, &su, SCALE_VS)) |
|
SCALE_VS_INIT(&su, atoi(n->string)); |
} else |
} else |
su.scale = 0; |
su.scale = 0; |
|
|
Line 414 man_SH_pre(MAN_ARGS) |
|
Line 439 man_SH_pre(MAN_ARGS) |
|
struct htmlpair tag; |
struct htmlpair tag; |
|
|
if (MAN_BLOCK == n->type) { |
if (MAN_BLOCK == n->type) { |
|
mh->fl &= ~MANH_LITERAL; |
PAIR_CLASS_INIT(&tag, "section"); |
PAIR_CLASS_INIT(&tag, "section"); |
print_otag(h, TAG_DIV, 1, &tag); |
print_otag(h, TAG_DIV, 1, &tag); |
return(1); |
return(1); |
Line 495 man_SS_pre(MAN_ARGS) |
|
Line 521 man_SS_pre(MAN_ARGS) |
|
struct htmlpair tag; |
struct htmlpair tag; |
|
|
if (MAN_BLOCK == n->type) { |
if (MAN_BLOCK == n->type) { |
|
mh->fl &= ~MANH_LITERAL; |
PAIR_CLASS_INIT(&tag, "subsection"); |
PAIR_CLASS_INIT(&tag, "subsection"); |
print_otag(h, TAG_DIV, 1, &tag); |
print_otag(h, TAG_DIV, 1, &tag); |
return(1); |
return(1); |
Line 513 man_PP_pre(MAN_ARGS) |
|
Line 540 man_PP_pre(MAN_ARGS) |
|
|
|
if (MAN_HEAD == n->type) |
if (MAN_HEAD == n->type) |
return(0); |
return(0); |
else if (MAN_BODY == n->type && n->prev) |
else if (MAN_BLOCK == n->type) |
print_otag(h, TAG_P, 0, NULL); |
print_bvspace(h, n); |
|
|
return(1); |
return(1); |
} |
} |
Line 562 man_IP_pre(MAN_ARGS) |
|
Line 589 man_IP_pre(MAN_ARGS) |
|
} |
} |
|
|
if (MAN_BLOCK == n->type) { |
if (MAN_BLOCK == n->type) { |
print_otag(h, TAG_P, 0, NULL); |
print_bvspace(h, n); |
print_otag(h, TAG_TABLE, 0, NULL); |
print_otag(h, TAG_TABLE, 0, NULL); |
bufinit(h); |
bufinit(h); |
bufcat_su(h, "width", &su); |
bufcat_su(h, "width", &su); |
Line 613 man_HP_pre(MAN_ARGS) |
|
Line 640 man_HP_pre(MAN_ARGS) |
|
print_otag(h, TAG_TD, 0, NULL); |
print_otag(h, TAG_TD, 0, NULL); |
return(0); |
return(0); |
} else if (MAN_BLOCK == n->type) { |
} else if (MAN_BLOCK == n->type) { |
print_otag(h, TAG_P, 0, NULL); |
print_bvspace(h, n); |
print_otag(h, TAG_TABLE, 0, NULL); |
print_otag(h, TAG_TABLE, 0, NULL); |
bufcat_su(h, "width", &su); |
bufcat_su(h, "width", &su); |
PAIR_STYLE_INIT(&tag, h); |
PAIR_STYLE_INIT(&tag, h); |