cmark

My personal build of CMark ✏️

Commit
96c7df6a8480b78ddc2540dd85877487af358ceb
Parent
2875252bf83c7a0f26ee940e5c29920b290d615f
Author
John MacFarlane <jgm@berkeley.edu>
Date

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.

Diffstat

3 files changed, 52 insertions, 0 deletions

Status File Name N° Changes Insertions Deletions
Modified api_test/main.c 7 7 0
Modified src/cmark.h 12 12 0
Modified src/node.c 33 33 0
diff --git 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
@@ -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
diff --git a/src/node.c b/src/node.c
@@ -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) {