diff --git a/src/libhtml/build.c b/src/libhtml/build.c
index 7ce74449..06397086 100644
--- a/src/libhtml/build.c
+++ b/src/libhtml/build.c
@@ -2127,6 +2127,7 @@ getitems(ItemSource* is, uchar* data, int datalen)
outerps = lastps(ps);
ans = outerps->items->next;
/* note: ans may be nil and di->kids not nil, if there's a frameset! */
+ freeitem(outerps->items);
outerps->items = newispacer(ISPnull);
outerps->lastit = outerps->items;
is->psstk = ps;
@@ -2134,6 +2135,7 @@ getitems(ItemSource* is, uchar* data, int datalen)
/* TODO evalscript(nil); */
;
}
+ freeitems(outerps->items);
return_ans:
if(dbgbuild) {
@@ -2143,6 +2145,7 @@ return_ans:
else
printitems(ans, "getitems returning:");
}
+ _freetokens(toks, tokslen);
return ans;
}
diff --git a/src/libhtml/lex.c b/src/libhtml/lex.c
index 12127b58..258807dd 100644
--- a/src/libhtml/lex.c
+++ b/src/libhtml/lex.c
@@ -540,8 +540,11 @@ _gettoks(uchar* data, int datalen, int chset, int mtype, int* plen)
if(dbglex)
fprint(2, "lex: returning %d tokens\n", ai);
*plen = ai;
- if(ai == 0)
+ free(ts);
+ if(ai == 0) {
+ free(a);
return nil;
+ }
return a;
}
@@ -603,15 +606,18 @@ getplaindata(TokenSource* ts, Token* a, int* pai)
}
/* Return concatenation of s and buf[0:j] */
+/* Frees s. */
static Rune*
buftostr(Rune* s, Rune* buf, int j)
{
+ Rune *tmp;
buf[j] = 0;
if(s == nil)
- s = _Strndup(buf, j);
+ tmp = _Strndup(buf, j);
else
- s = _Strdup2(s, buf);
- return s;
+ tmp = _Strdup2(s, buf);
+ free(s);
+ return tmp;
}
/* Gather data up to next start-of-tag or end-of-buffer. */