diff options
author | Kristaps Dzonsons <kristaps@bsd.lv> | 2011-01-01 22:19:15 +0000 |
---|---|---|
committer | Kristaps Dzonsons <kristaps@bsd.lv> | 2011-01-01 22:19:15 +0000 |
commit | 36060e6f93695c0dc996afbb3c9f53f6a825488b (patch) | |
tree | a2cd15e344c83690d76772d4bc5f31a634c9743d /tbl.c | |
parent | 3d67560a814d88e4c50985ee952dfe42794e083b (diff) | |
download | mandoc-36060e6f93695c0dc996afbb3c9f53f6a825488b.tar.gz |
Plug in the "head" concept for tables. A tbl_head specifies the full
layout for each row, including vertical spacers. One grabs the tbl_head
for a row and iterates through each entry, plugging data from the
tbl_span into the header as appropriate.
This is pulled in more or less verbatim from tbl.bsd.lv. In fact, this
is verbatim except that lists macros are made into hard-coded lists (for
compatibility, as long-ago noted by joerg@).
Diffstat (limited to 'tbl.c')
-rw-r--r-- | tbl.c | 12 |
1 files changed, 8 insertions, 4 deletions
@@ -87,9 +87,9 @@ tbl_free(struct tbl *p) struct tbl_cell *cp; struct tbl_span *sp; struct tbl_dat *dp; + struct tbl_head *hp; - while (p->first_row) { - rp = p->first_row; + while (NULL != (rp = p->first_row)) { p->first_row = rp->next; while (rp->first) { cp = rp->first; @@ -99,8 +99,7 @@ tbl_free(struct tbl *p) free(rp); } - while (p->first_span) { - sp = p->first_span; + while (NULL != (sp = p->first_span)) { p->first_span = sp->next; while (sp->first) { dp = sp->first; @@ -112,6 +111,11 @@ tbl_free(struct tbl *p) free(sp); } + while (NULL != (hp = p->first_head)) { + p->first_head = hp->next; + free(hp); + } + free(p); } |