cmark

My personal build of CMark ✏️

Commit
f1035464022a8a4e804f5915e6a1388ea49e3fb3
Parent
d12c040d58d70555cc98e397e05ab0d8326b6aca
Author
John MacFarlane <jgm@berkeley.edu>
Date

Straightforward fix for memory leak #32.

Diffstat

1 file changed, 4 insertions, 1 deletion

Status File Name N° Changes Insertions Deletions
Modified src/iterator.c 5 4 1
diff --git a/src/iterator.c b/src/iterator.c
@@ -121,6 +121,7 @@ void cmark_consolidate_text_nodes(cmark_node *root)
 	cmark_strbuf buf = GH_BUF_INIT;
 	cmark_event_type ev_type;
 	cmark_node *cur, *tmp, *next;
+	char *detached;
 
 	while ((ev_type = cmark_iter_next(iter)) != CMARK_EVENT_DONE) {
 		cur = cmark_iter_get_node(iter);
@@ -138,7 +139,9 @@ void cmark_consolidate_text_nodes(cmark_node *root)
 				cmark_node_free(tmp);
 				tmp = next;
 			}
-			cmark_node_set_literal(cur, (char *)cmark_strbuf_detach(&buf));
+			detached = (char *)cmark_strbuf_detach(&buf);
+			cmark_node_set_literal(cur, detached);
+			free(detached);
 		}
 	}