diff options
author | John MacFarlane <jgm@berkeley.edu> | 2014-12-28 20:45:35 -0800 |
---|---|---|
committer | John MacFarlane <jgm@berkeley.edu> | 2014-12-28 20:52:17 -0800 |
commit | 96c7df6a8480b78ddc2540dd85877487af358ceb (patch) | |
tree | 548174d5a2fa85dcae0cd93be2ea41e1eeb10bd1 | |
parent | 2875252bf83c7a0f26ee940e5c29920b290d615f (diff) |
Added cmark_node_set_list_delim, cmark_node_get_list_delim.
Even though this doesn't make a difference in default HTML
output, it's worth keeping track; some output formats may allow
you to distinguish lists with `1)` and with `1.` delimiters.
-rw-r--r-- | api_test/main.c | 7 | ||||
-rw-r--r-- | src/cmark.h | 12 | ||||
-rw-r--r-- | src/node.c | 33 |
3 files changed, 52 insertions, 0 deletions
diff --git a/api_test/main.c b/api_test/main.c index 88f7cef..b098c41 100644 --- a/api_test/main.c +++ b/api_test/main.c @@ -75,6 +75,9 @@ constructor(test_batch_runner *runner) INT_EQ(runner, cmark_node_get_list_type(node), CMARK_BULLET_LIST, "default is list type is bullet"); + INT_EQ(runner, cmark_node_get_list_delim(node), + CMARK_NO_DELIM, + "default is list delim is NO_DELIM"); INT_EQ(runner, cmark_node_get_list_start(node), 1, "default is list start is 1"); INT_EQ(runner, cmark_node_get_list_tight(node), 0, @@ -130,6 +133,8 @@ accessors(test_batch_runner *runner) cmark_node *ordered_list = cmark_node_next(bullet_list); INT_EQ(runner, cmark_node_get_list_type(ordered_list), CMARK_ORDERED_LIST, "get_list_type ordered"); + INT_EQ(runner, cmark_node_get_list_delim(ordered_list), + CMARK_PERIOD_DELIM, "get_list_delim ordered"); INT_EQ(runner, cmark_node_get_list_start(ordered_list), 2, "get_list_start"); INT_EQ(runner, cmark_node_get_list_tight(ordered_list), 0, @@ -174,6 +179,8 @@ accessors(test_batch_runner *runner) OK(runner, cmark_node_set_list_type(bullet_list, CMARK_ORDERED_LIST), "set_list_type ordered"); + OK(runner, cmark_node_set_list_delim(bullet_list, CMARK_PAREN_DELIM), + "set_list_delim paren"); OK(runner, cmark_node_set_list_start(bullet_list, 3), "set_list_start"); OK(runner, cmark_node_set_list_tight(bullet_list, 0), diff --git a/src/cmark.h b/src/cmark.h index 3d2ed15..8196158 100644 --- a/src/cmark.h +++ b/src/cmark.h @@ -238,6 +238,18 @@ cmark_node_get_list_type(cmark_node *node); CMARK_EXPORT int cmark_node_set_list_type(cmark_node *node, cmark_list_type type); +/** Returns the list delimiter type of 'node', or `CMARK_NO_DELIM` if 'node' + * is not a list. + */ +CMARK_EXPORT cmark_delim_type +cmark_node_get_list_delim(cmark_node *node); + +/** Sets the list delimiter type of 'node', returning 1 on success and 0 + * on error. + */ +CMARK_EXPORT int +cmark_node_set_list_delim(cmark_node *node, cmark_delim_type delim); + /** Returns starting number of 'node', if it is an ordered list, otherwise 0. */ CMARK_EXPORT int @@ -292,6 +292,39 @@ cmark_node_set_list_type(cmark_node *node, cmark_list_type type) { } } +cmark_delim_type +cmark_node_get_list_delim(cmark_node *node) { + if (node == NULL) { + return CMARK_NO_DELIM; + } + + if (node->type == CMARK_NODE_LIST) { + return node->as.list.delimiter; + } + else { + return CMARK_NO_DELIM; + } +} + +int +cmark_node_set_list_delim(cmark_node *node, cmark_delim_type delim) { + if (!(delim == CMARK_PERIOD_DELIM || delim == CMARK_PAREN_DELIM)) { + return 0; + } + + if (node == NULL) { + return 0; + } + + if (node->type == CMARK_NODE_LIST) { + node->as.list.delimiter = delim; + return 1; + } + else { + return 0; + } +} + int cmark_node_get_list_start(cmark_node *node) { if (node == NULL) { |