version 1.9, 2011/01/03 13:59:21 |
version 1.11, 2011/01/07 13:03:48 |
Line 29 struct tbl_phrase { |
|
Line 29 struct tbl_phrase { |
|
enum tbl_cellt key; |
enum tbl_cellt key; |
}; |
}; |
|
|
|
/* |
|
* FIXME: we can make this parse a lot nicer by, when an error is |
|
* encountered in a layout key, bailing to the next key (i.e. to the |
|
* next whitespace then continuing). |
|
*/ |
|
|
#define KEYS_MAX 11 |
#define KEYS_MAX 11 |
|
|
static const struct tbl_phrase keys[KEYS_MAX] = { |
static const struct tbl_phrase keys[KEYS_MAX] = { |
|
|
case ('d'): |
case ('d'): |
cp->flags |= TBL_CELL_BALIGN; |
cp->flags |= TBL_CELL_BALIGN; |
goto mod; |
goto mod; |
|
case ('w'): /* XXX for now, ignore minimal column width */ |
|
goto mod; |
case ('f'): |
case ('f'): |
break; |
break; |
case ('b'): |
case ('b'): |
Line 171 cell(struct tbl_node *tbl, struct tbl_row *rp, |
|
Line 179 cell(struct tbl_node *tbl, struct tbl_row *rp, |
|
return(0); |
return(0); |
} |
} |
|
|
(*pos)++; |
|
c = keys[i].key; |
c = keys[i].key; |
|
|
|
/* |
|
* If a span cell is found first, raise a warning and abort the |
|
* parse. FIXME: recover from this somehow? |
|
*/ |
|
|
|
if (NULL == rp->first && TBL_CELL_SPAN == c) { |
|
TBL_MSG(tbl, MANDOCERR_TBLLAYOUT, ln, *pos); |
|
return(0); |
|
} |
|
|
|
(*pos)++; |
|
|
/* Extra check for the double-vertical. */ |
/* Extra check for the double-vertical. */ |
|
|