version 1.60, 2009/07/24 11:54:54 |
version 1.63, 2009/07/25 16:03:03 |
|
|
}; |
}; |
|
|
static void termp____post(DECL_ARGS); |
static void termp____post(DECL_ARGS); |
|
static void termp_an_post(DECL_ARGS); |
static void termp_aq_post(DECL_ARGS); |
static void termp_aq_post(DECL_ARGS); |
static void termp_bd_post(DECL_ARGS); |
static void termp_bd_post(DECL_ARGS); |
static void termp_bl_post(DECL_ARGS); |
static void termp_bl_post(DECL_ARGS); |
Line 124 static void termp_vt_post(DECL_ARGS); |
|
Line 125 static void termp_vt_post(DECL_ARGS); |
|
|
|
static int termp__j_pre(DECL_ARGS); |
static int termp__j_pre(DECL_ARGS); |
static int termp__t_pre(DECL_ARGS); |
static int termp__t_pre(DECL_ARGS); |
|
static int termp_an_pre(DECL_ARGS); |
static int termp_ap_pre(DECL_ARGS); |
static int termp_ap_pre(DECL_ARGS); |
static int termp_aq_pre(DECL_ARGS); |
static int termp_aq_pre(DECL_ARGS); |
static int termp_ar_pre(DECL_ARGS); |
static int termp_ar_pre(DECL_ARGS); |
Line 191 static const struct termact termacts[MDOC_MAX] = { |
|
Line 193 static const struct termact termacts[MDOC_MAX] = { |
|
{ NULL, NULL }, /* El */ |
{ NULL, NULL }, /* El */ |
{ termp_it_pre, termp_it_post }, /* It */ |
{ termp_it_pre, termp_it_post }, /* It */ |
{ NULL, NULL }, /* Ad */ |
{ NULL, NULL }, /* Ad */ |
{ NULL, NULL }, /* An */ |
{ termp_an_pre, termp_an_post }, /* An */ |
{ termp_ar_pre, NULL }, /* Ar */ |
{ termp_ar_pre, NULL }, /* Ar */ |
{ termp_cd_pre, NULL }, /* Cd */ |
{ termp_cd_pre, NULL }, /* Cd */ |
{ termp_cm_pre, NULL }, /* Cm */ |
{ termp_cm_pre, NULL }, /* Cm */ |
Line 672 fmt_block_vspace(struct termp *p, |
|
Line 674 fmt_block_vspace(struct termp *p, |
|
|
|
if (MDOC_Bl == bl->tok && arg_hasattr(MDOC_Compact, bl)) |
if (MDOC_Bl == bl->tok && arg_hasattr(MDOC_Compact, bl)) |
return; |
return; |
|
assert(node); |
|
|
/* |
/* |
* Search through our prior nodes. If we follow a `Ss' or `Sh', |
* Search through our prior nodes. If we follow a `Ss' or `Sh', |
Line 856 termp_it_pre(DECL_ARGS) |
|
Line 859 termp_it_pre(DECL_ARGS) |
|
|
|
switch (type) { |
switch (type) { |
case (MDOC_Diag): |
case (MDOC_Diag): |
term_word(p, "\\ \\ "); |
if (MDOC_BODY == node->type) |
|
term_word(p, "\\ \\ "); |
break; |
break; |
case (MDOC_Inset): |
case (MDOC_Inset): |
if (MDOC_BODY == node->type) |
if (MDOC_BODY == node->type) |
Line 1125 termp_fl_pre(DECL_ARGS) |
|
Line 1129 termp_fl_pre(DECL_ARGS) |
|
term_word(p, "\\-"); |
term_word(p, "\\-"); |
p->flags |= TERMP_NOSPACE; |
p->flags |= TERMP_NOSPACE; |
return(1); |
return(1); |
|
} |
|
|
|
|
|
/* ARGSUSED */ |
|
static int |
|
termp_an_pre(DECL_ARGS) |
|
{ |
|
|
|
if (NULL == node->child) |
|
return(1); |
|
|
|
/* |
|
* XXX: this is poorly documented. If not in the AUTHORS |
|
* section, `An -split' will cause newlines to occur before the |
|
* author name. If in the AUTHORS section, by default, the |
|
* first `An' invocation is nosplit, then all subsequent ones, |
|
* regardless of whether interspersed with other macros/text, |
|
* are split. -split, in this case, will override the condition |
|
* of the implied first -nosplit. |
|
*/ |
|
|
|
if (node->sec == SEC_AUTHORS) { |
|
if ( ! (TERMP_ANPREC & p->flags)) { |
|
if (TERMP_SPLIT & p->flags) |
|
term_newln(p); |
|
return(1); |
|
} |
|
if (TERMP_NOSPLIT & p->flags) |
|
return(1); |
|
term_newln(p); |
|
return(1); |
|
} |
|
|
|
if (TERMP_SPLIT & p->flags) |
|
term_newln(p); |
|
|
|
return(1); |
|
} |
|
|
|
|
|
/* ARGSUSED */ |
|
static void |
|
termp_an_post(DECL_ARGS) |
|
{ |
|
|
|
if (node->child) { |
|
if (SEC_AUTHORS == node->sec) |
|
p->flags |= TERMP_ANPREC; |
|
return; |
|
} |
|
|
|
if (arg_getattr(MDOC_Split, node) > -1) { |
|
p->flags &= ~TERMP_NOSPLIT; |
|
p->flags |= TERMP_SPLIT; |
|
} else { |
|
p->flags &= ~TERMP_SPLIT; |
|
p->flags |= TERMP_NOSPLIT; |
|
} |
|
|
} |
} |
|
|
|
|