From 0b746507aad92a8f7ec942e06889df62ec441f54 Mon Sep 17 00:00:00 2001 From: John MacFarlane Date: Fri, 28 Nov 2014 22:31:34 -0800 Subject: Removed cmark_free_nodes from public API. Replace it with static S_free_nodes. --- src/cmark.c | 8 +++---- src/cmark.h | 3 --- src/inlines.c | 3 +-- src/main.c | 2 +- src/node.c | 71 ++++++++++++++++++++++++++++++----------------------------- 5 files changed, 42 insertions(+), 45 deletions(-) diff --git a/src/cmark.c b/src/cmark.c index 945e392..140a14c 100644 --- a/src/cmark.c +++ b/src/cmark.c @@ -8,13 +8,13 @@ char *cmark_markdown_to_html(const char *text, int len) { - cmark_node *blocks; + cmark_node *doc; char *result; - blocks = cmark_parse_document(text, len); + doc = cmark_parse_document(text, len); - result = cmark_render_html(blocks); - cmark_free_nodes(blocks); + result = cmark_render_html(doc); + cmark_node_free(doc); return result; } diff --git a/src/cmark.h b/src/cmark.h index a1ec0b2..0950b2d 100644 --- a/src/cmark.h +++ b/src/cmark.h @@ -63,9 +63,6 @@ cmark_node_new(cmark_node_type type); CMARK_EXPORT void cmark_node_free(cmark_node *node); -CMARK_EXPORT void -cmark_free_nodes(cmark_node *e); - // Tree traversal CMARK_EXPORT cmark_node* diff --git a/src/inlines.c b/src/inlines.c index 5c28436..e08b757 100644 --- a/src/inlines.c +++ b/src/inlines.c @@ -450,8 +450,7 @@ static void process_emphasis(subject *subj, delimiter_stack *stack_bottom) if (tmp->next) { tmp->next->prev = emph; } - cmark_node_unlink(tmp); - cmark_free_nodes(tmp); + cmark_node_free(tmp); // remove closer from stack tempstack = closer->next; remove_delimiter(subj, closer); diff --git a/src/main.c b/src/main.c index bb4fd94..3a7ea4c 100644 --- a/src/main.c +++ b/src/main.c @@ -101,7 +101,7 @@ int main(int argc, char *argv[]) end_timer("print_document"); start_timer(); - cmark_free_nodes(document); + cmark_node_free(document); end_timer("free_blocks"); free(files); diff --git a/src/node.c b/src/node.c index d2c4431..4054881 100644 --- a/src/node.c +++ b/src/node.c @@ -32,11 +32,46 @@ cmark_node_new(cmark_node_type type) { return node; } +// Free a cmark_node list and any children. +static +void S_free_nodes(cmark_node *e) +{ + cmark_node *next; + while (e != NULL) { + strbuf_free(&e->string_content); + switch (e->type){ + case NODE_CODE_BLOCK: + strbuf_free(&e->as.code.info); + break; + case NODE_TEXT: + case NODE_INLINE_HTML: + case NODE_INLINE_CODE: + cmark_chunk_free(&e->as.literal); + break; + case NODE_LINK: + case NODE_IMAGE: + free(e->as.link.url); + free(e->as.link.title); + break; + default: + break; + } + if (e->last_child) { + // Splice children into list + e->last_child->next = e->next; + e->next = e->first_child; + } + next = e->next; + free(e); + e = next; + } +} + void cmark_node_free(cmark_node *node) { S_node_unlink(node); node->next = NULL; - cmark_free_nodes(node); + S_free_nodes(node); } cmark_node_type @@ -612,38 +647,4 @@ cmark_node_check(cmark_node *node, FILE *out) return errors; } -// Free a cmark_node list and any children. -void cmark_free_nodes(cmark_node *e) -{ - cmark_node *next; - while (e != NULL) { - strbuf_free(&e->string_content); - switch (e->type){ - case NODE_CODE_BLOCK: - strbuf_free(&e->as.code.info); - break; - case NODE_TEXT: - case NODE_INLINE_HTML: - case NODE_INLINE_CODE: - cmark_chunk_free(&e->as.literal); - break; - case NODE_LINK: - case NODE_IMAGE: - free(e->as.link.url); - free(e->as.link.title); - break; - default: - break; - } - if (e->last_child) { - // Splice children into list - e->last_child->next = e->next; - e->next = e->first_child; - } - next = e->next; - free(e); - e = next; - } -} - -- cgit v1.2.3