summaryrefslogtreecommitdiffstats
path: root/tbl.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2011-01-01 22:19:15 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2011-01-01 22:19:15 +0000
commit36060e6f93695c0dc996afbb3c9f53f6a825488b (patch)
treea2cd15e344c83690d76772d4bc5f31a634c9743d /tbl.c
parent3d67560a814d88e4c50985ee952dfe42794e083b (diff)
downloadmandoc-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.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/tbl.c b/tbl.c
index f2e54b91..dbfdd49e 100644
--- a/tbl.c
+++ b/tbl.c
@@ -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);
}