summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJohn MacFarlane <jgm@berkeley.edu>2014-12-12 23:19:34 -0800
committerJohn MacFarlane <jgm@berkeley.edu>2014-12-12 23:20:36 -0800
commit3d0110a36054a9af1532d52f2671360fa1c802a3 (patch)
tree5cc5fbdff5f05dc11688716f4568f1e02aa32b04 /src
parentb598b52a4acdc2332be3d34e30237d1b93b7dd03 (diff)
Rudimentary documentation for cmark_walk.
Diffstat (limited to 'src')
-rw-r--r--src/cmark.h10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/cmark.h b/src/cmark.h
index 12d0c01..224ef3a 100644
--- a/src/cmark.h
+++ b/src/cmark.h
@@ -308,7 +308,15 @@ char *cmark_render_ast(cmark_node *root);
CMARK_EXPORT
char *cmark_render_html(cmark_node *root);
-/**
+/** Walks the tree starting from root, applying handler to each node.
+ * Nodes that can have children are visited twice, once on the way in
+ * and once on the way out. handler is a function that takes a node
+ * pointer, an integer direction (1 for entering, 0 for leaving),
+ * and a pointer to a state structure that can be consulted and
+ * updated by the handler. The handler should return 1 on success,
+ * 0 on failure. cmark_walk returns 1 if it traversed the entire
+ * tree, 0 if it quit early in response to a 0 status from the
+ * handler.
*/
CMARK_EXPORT
int cmark_walk(cmark_node *root, cmark_node_handler handler, void *state);