version 1.56, 2009/07/21 15:39:04 |
version 1.58, 2009/07/23 08:36:32 |
Line 66 const int ttypes[TTYPE_NMAX] = { |
|
Line 66 const int ttypes[TTYPE_NMAX] = { |
|
TERMP_UNDER, /* TTYPE_FUNC_ARG */ |
TERMP_UNDER, /* TTYPE_FUNC_ARG */ |
TERMP_UNDER, /* TTYPE_LINK */ |
TERMP_UNDER, /* TTYPE_LINK */ |
TERMP_BOLD, /* TTYPE_SSECTION */ |
TERMP_BOLD, /* TTYPE_SSECTION */ |
0, /* TTYPE_FILE */ |
TERMP_UNDER, /* TTYPE_FILE */ |
TERMP_UNDER, /* TTYPE_EMPH */ |
TERMP_UNDER, /* TTYPE_EMPH */ |
TERMP_BOLD, /* TTYPE_CONFIG */ |
TERMP_BOLD, /* TTYPE_CONFIG */ |
TERMP_BOLD, /* TTYPE_CMD */ |
TERMP_BOLD, /* TTYPE_CMD */ |
Line 155 static int termp_nd_pre(DECL_ARGS); |
|
Line 155 static int termp_nd_pre(DECL_ARGS); |
|
static int termp_nm_pre(DECL_ARGS); |
static int termp_nm_pre(DECL_ARGS); |
static int termp_ns_pre(DECL_ARGS); |
static int termp_ns_pre(DECL_ARGS); |
static int termp_op_pre(DECL_ARGS); |
static int termp_op_pre(DECL_ARGS); |
|
static int termp_pa_pre(DECL_ARGS); |
static int termp_pf_pre(DECL_ARGS); |
static int termp_pf_pre(DECL_ARGS); |
static int termp_pp_pre(DECL_ARGS); |
static int termp_pp_pre(DECL_ARGS); |
static int termp_pq_pre(DECL_ARGS); |
static int termp_pq_pre(DECL_ARGS); |
Line 210 static const struct termact termacts[MDOC_MAX] = { |
|
Line 211 static const struct termact termacts[MDOC_MAX] = { |
|
{ termp_nm_pre, NULL }, /* Nm */ |
{ termp_nm_pre, NULL }, /* Nm */ |
{ termp_op_pre, termp_op_post }, /* Op */ |
{ termp_op_pre, termp_op_post }, /* Op */ |
{ NULL, NULL }, /* Ot */ |
{ NULL, NULL }, /* Ot */ |
{ NULL, NULL }, /* Pa */ |
{ termp_pa_pre, NULL }, /* Pa */ |
{ termp_rv_pre, NULL }, /* Rv */ |
{ termp_rv_pre, NULL }, /* Rv */ |
{ NULL, NULL }, /* St */ |
{ NULL, NULL }, /* St */ |
{ termp_va_pre, NULL }, /* Va */ |
{ termp_va_pre, NULL }, /* Va */ |
Line 781 termp_it_pre(DECL_ARGS) |
|
Line 782 termp_it_pre(DECL_ARGS) |
|
case (MDOC_Column): |
case (MDOC_Column): |
if (MDOC_BODY == node->type) |
if (MDOC_BODY == node->type) |
break; |
break; |
for (i = 0, n = node->prev; n; n = n->prev, i++) |
/* |
|
* Work around groff's column handling. The offset is |
|
* equal to the sum of all widths leading to the current |
|
* column (plus the -offset value). If this column |
|
* exceeds the stated number of columns, the width is |
|
* set as 0, else it's the stated column width (later |
|
* the 0 will be adjusted to default 10 or, if in the |
|
* last column case, set to stretch to the margin). |
|
*/ |
|
for (i = 0, n = node->prev; n && n && |
|
i < (int)bl->args[vals[2]].argv->sz; |
|
n = n->prev, i++) |
offset += arg_width |
offset += arg_width |
(&bl->args->argv[vals[2]], i); |
(&bl->args->argv[vals[2]], i); |
assert(i < (int)bl->args->argv[vals[2]].sz); |
|
width = arg_width(&bl->args->argv[vals[2]], i); |
/* Whether exceeds maximum column. */ |
|
if (i < (int)bl->args[vals[2]].argv->sz) |
|
width = arg_width(&bl->args->argv[vals[2]], i); |
|
else |
|
width = 0; |
|
|
if (vals[1] >= 0) |
if (vals[1] >= 0) |
offset += arg_offset(&bl->args->argv[vals[1]]); |
offset += arg_offset(&bl->args->argv[vals[1]]); |
break; |
break; |
Line 1729 termp_sq_post(DECL_ARGS) |
|
Line 1746 termp_sq_post(DECL_ARGS) |
|
return; |
return; |
p->flags |= TERMP_NOSPACE; |
p->flags |= TERMP_NOSPACE; |
term_word(p, "\\(aq"); |
term_word(p, "\\(aq"); |
|
} |
|
|
|
|
|
/* ARGSUSED */ |
|
static int |
|
termp_pa_pre(DECL_ARGS) |
|
{ |
|
|
|
pair->flag |= ttypes[TTYPE_FILE]; |
|
return(1); |
} |
} |
|
|
|
|