version 1.10, 2010/12/31 14:52:41 |
version 1.13, 2011/01/01 15:45:18 |
Line 56 tbl_read(struct tbl *tbl, int ln, const char *p, int o |
|
Line 56 tbl_read(struct tbl *tbl, int ln, const char *p, int o |
|
break; |
break; |
} |
} |
|
|
/* |
/* |
* FIXME: allow the original string to slip through for the time |
* This only returns zero if the line is empty, so we ignore it |
* being. |
* and continue on. |
*/ |
*/ |
return(tbl_data(tbl, ln, p) ? ROFF_CONT : ROFF_ERR); |
return(tbl_data(tbl, ln, p) ? ROFF_TBL : ROFF_IGN); |
} |
} |
|
|
struct tbl * |
struct tbl * |
tbl_alloc(void *data, const mandocmsg msg) |
tbl_alloc(int pos, int line, void *data, const mandocmsg msg) |
{ |
{ |
struct tbl *p; |
struct tbl *p; |
|
|
p = mandoc_calloc(1, sizeof(struct tbl)); |
p = mandoc_calloc(1, sizeof(struct tbl)); |
|
p->line = line; |
|
p->pos = pos; |
p->data = data; |
p->data = data; |
p->msg = msg; |
p->msg = msg; |
p->part = TBL_PART_OPTS; |
p->part = TBL_PART_OPTS; |
Line 120 tbl_restart(struct tbl *tbl) |
|
Line 122 tbl_restart(struct tbl *tbl) |
|
tbl->part = TBL_PART_LAYOUT; |
tbl->part = TBL_PART_LAYOUT; |
} |
} |
|
|
|
const struct tbl_span * |
|
tbl_span(const struct tbl *tbl) |
|
{ |
|
|
|
assert(tbl); |
|
return(tbl->last_span); |
|
} |
|
|
|
void |
|
tbl_end(struct tbl *tbl) |
|
{ |
|
|
|
if (NULL == tbl->first_span || NULL == tbl->first_span->first) |
|
TBL_MSG(tbl, MANDOCERR_TBLNODATA, tbl->line, tbl->pos); |
|
} |