aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/tbl.c
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2010-12-30 09:34:06 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2010-12-30 09:34:06 +0000
commit106912a8afaf5d13433f9c31bf444d8c6c1361de (patch)
treedf6c158982dfb1808e5a75dc616fb38d5e0537ef /tbl.c
parent2af1c510e72c986dadae0d6e4235fc0ec111608d (diff)
downloadmandoc-106912a8afaf5d13433f9c31bf444d8c6c1361de.tar.gz
mandoc-106912a8afaf5d13433f9c31bf444d8c6c1361de.tar.zst
mandoc-106912a8afaf5d13433f9c31bf444d8c6c1361de.zip
Move clean-up of parsed tbl nodes into the tbl_clear() function, called
once per invocation.
Diffstat (limited to 'tbl.c')
-rw-r--r--tbl.c47
1 files changed, 27 insertions, 20 deletions
diff --git a/tbl.c b/tbl.c
index 42e0f0a7..44e80aa6 100644
--- a/tbl.c
+++ b/tbl.c
@@ -1,4 +1,4 @@
-/* $Id: tbl.c,v 1.8 2010/12/29 16:44:23 kristaps Exp $ */
+/* $Id: tbl.c,v 1.9 2010/12/30 09:34:07 kristaps Exp $ */
/*
* Copyright (c) 2009, 2010 Kristaps Dzonsons <kristaps@bsd.lv>
*
@@ -33,10 +33,12 @@ tbl_clear(struct tbl *tbl)
{
struct tbl_row *rp;
struct tbl_cell *cp;
+ struct tbl_span *sp;
+ struct tbl_dat *dp;
- while (tbl->first) {
- rp = tbl->first;
- tbl->first = rp->next;
+ while (tbl->first_row) {
+ rp = tbl->first_row;
+ tbl->first_row = rp->next;
while (rp->first) {
cp = rp->first;
rp->first = cp->next;
@@ -45,7 +47,22 @@ tbl_clear(struct tbl *tbl)
free(rp);
}
- tbl->last = NULL;
+ tbl->last_row = NULL;
+
+ while (tbl->first_span) {
+ sp = tbl->first_span;
+ tbl->first_span = sp->next;
+ while (sp->first) {
+ dp = sp->first;
+ sp->first = dp->next;
+ if (dp->string)
+ free(dp->string);
+ free(dp);
+ }
+ free(sp);
+ }
+
+ tbl->last_span = NULL;
}
static void
@@ -63,8 +80,6 @@ tbl_read(struct tbl *tbl, int ln, const char *p, int offs)
{
int len;
const char *cp;
- struct tbl_dat *dp;
- struct tbl_span *sp;
cp = &p[offs];
len = (int)strlen(cp);
@@ -91,18 +106,11 @@ tbl_read(struct tbl *tbl, int ln, const char *p, int offs)
break;
}
- /* XXX: throw away data for now. */
- if (NULL != (sp = tbl_data(tbl, ln, p))) {
- while (NULL != (dp = sp->first)) {
- sp->first = sp->first->next;
- if (dp->string)
- free(dp->string);
- free(dp);
- }
- free(sp);
- }
-
- return(ROFF_CONT);
+ /*
+ * FIXME: allow the original string to slip through for the time
+ * being.
+ */
+ return(tbl_data(tbl, ln, p) ? ROFF_CONT : ROFF_ERR);
}
struct tbl *
@@ -137,7 +145,6 @@ void
tbl_restart(struct tbl *tbl)
{
- tbl_clear(tbl);
tbl->part = TBL_PART_LAYOUT;
}