version 1.109, 2011/07/21 10:24:35 |
version 1.115, 2012/01/03 15:16:24 |
Line 40 const char *const __man_macronames[MAN_MAX] = { |
|
Line 40 const char *const __man_macronames[MAN_MAX] = { |
|
"RI", "na", "sp", "nf", |
"RI", "na", "sp", "nf", |
"fi", "RE", "RS", "DT", |
"fi", "RE", "RS", "DT", |
"UC", "PD", "AT", "in", |
"UC", "PD", "AT", "in", |
"ft" |
"ft", "OP" |
}; |
}; |
|
|
const char * const *man_macronames = __man_macronames; |
const char * const *man_macronames = __man_macronames; |
|
|
man_word_alloc(struct man *m, int line, int pos, const char *word) |
man_word_alloc(struct man *m, int line, int pos, const char *word) |
{ |
{ |
struct man_node *n; |
struct man_node *n; |
size_t sv, len; |
|
|
|
len = strlen(word); |
|
|
|
n = man_node_alloc(m, line, pos, MAN_TEXT, MAN_MAX); |
n = man_node_alloc(m, line, pos, MAN_TEXT, MAN_MAX); |
n->string = mandoc_malloc(len + 1); |
n->string = roff_strdup(m->roff, word); |
sv = strlcpy(n->string, word, len + 1); |
|
|
|
/* Prohibit truncation. */ |
|
assert(sv < len + 1); |
|
|
|
if ( ! man_node_append(m, n)) |
if ( ! man_node_append(m, n)) |
return(0); |
return(0); |
|
|
Line 550 man_pmacro(struct man *m, int ln, char *buf, int offs) |
|
Line 543 man_pmacro(struct man *m, int ln, char *buf, int offs) |
|
n = n->parent; |
n = n->parent; |
|
|
mandoc_vmsg(MANDOCERR_LINESCOPE, m->parse, n->line, |
mandoc_vmsg(MANDOCERR_LINESCOPE, m->parse, n->line, |
n->pos, "%s", man_macronames[n->tok]); |
n->pos, "%s breaks %s", man_macronames[tok], |
|
man_macronames[n->tok]); |
|
|
man_node_delete(m, n); |
man_node_delete(m, n); |
m->flags &= ~MAN_ELINE; |
m->flags &= ~MAN_ELINE; |
} |
} |
|
|
/* |
/* |
|
* Remove prior BLINE macro that is being clobbered. |
|
*/ |
|
if ((m->flags & MAN_BLINE) && |
|
(MAN_BSCOPE & man_macros[tok].flags)) { |
|
n = m->last; |
|
|
|
/* Might be a text node like 8 in |
|
* .TP 8 |
|
* .SH foo |
|
*/ |
|
if (MAN_TEXT == n->type) |
|
n = n->parent; |
|
|
|
/* Remove element that didn't end BLINE, if any. */ |
|
if ( ! (MAN_BSCOPE & man_macros[n->tok].flags)) |
|
n = n->parent; |
|
|
|
assert(MAN_HEAD == n->type); |
|
n = n->parent; |
|
assert(MAN_BLOCK == n->type); |
|
assert(MAN_SCOPED & man_macros[n->tok].flags); |
|
|
|
mandoc_vmsg(MANDOCERR_LINESCOPE, m->parse, n->line, |
|
n->pos, "%s breaks %s", man_macronames[tok], |
|
man_macronames[n->tok]); |
|
|
|
man_node_delete(m, n); |
|
m->flags &= ~MAN_BLINE; |
|
} |
|
|
|
/* |
* Save the fact that we're in the next-line for a block. In |
* Save the fact that we're in the next-line for a block. In |
* this way, embedded roff instructions can "remember" state |
* this way, embedded roff instructions can "remember" state |
* when they exit. |
* when they exit. |
Line 654 man_node_unlink(struct man *m, struct man_node *n) |
|
Line 679 man_node_unlink(struct man *m, struct man_node *n) |
|
|
|
if (m && m->first == n) |
if (m && m->first == n) |
m->first = NULL; |
m->first = NULL; |
|
} |
|
|
|
const struct mparse * |
|
man_mparse(const struct man *m) |
|
{ |
|
|
|
assert(m && m->parse); |
|
return(m->parse); |
} |
} |