aboutsummaryrefslogtreecommitdiff
path: root/src/cmark.h
blob: a43703abe92c1c9430a5f6dd7e5e920d44e6d763 (plain)
  1. #ifndef CMARK_H
  2. #define CMARK_H
  3. #include <stdio.h>
  4. #include "cmark_export.h"
  5. #ifdef __cplusplus
  6. extern "C" {
  7. #endif
  8. /** .SH NAME
  9. *
  10. * .B cmark
  11. * \- CommonMark parsing, manipulating, and rendering
  12. */
  13. /** .SH SIMPLE INTERFACE
  14. */
  15. /** Current version of library.
  16. */
  17. #define CMARK_VERSION "0.1"
  18. /** Convert 'text' (assumed to be a UTF-8 encoded string with length
  19. * 'len' from CommonMark Markdown to HTML, returning a null-terminated,
  20. * UTF-8-encoded string.
  21. */
  22. CMARK_EXPORT
  23. char *cmark_markdown_to_html(const char *text, int len);
  24. /** .SH NODE STRUCTURE
  25. */
  26. /**
  27. */
  28. typedef enum {
  29. /* Error status */
  30. CMARK_NODE_NONE,
  31. /* Block */
  32. CMARK_NODE_DOCUMENT,
  33. CMARK_NODE_BLOCK_QUOTE,
  34. CMARK_NODE_LIST,
  35. CMARK_NODE_LIST_ITEM,
  36. CMARK_NODE_CODE_BLOCK,
  37. CMARK_NODE_HTML,
  38. CMARK_NODE_PARAGRAPH,
  39. CMARK_NODE_HEADER,
  40. CMARK_NODE_HRULE,
  41. CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT,
  42. CMARK_NODE_LAST_BLOCK = CMARK_NODE_HRULE,
  43. /* Inline */
  44. CMARK_NODE_TEXT,
  45. CMARK_NODE_SOFTBREAK,
  46. CMARK_NODE_LINEBREAK,
  47. CMARK_NODE_INLINE_CODE,
  48. CMARK_NODE_INLINE_HTML,
  49. CMARK_NODE_EMPH,
  50. CMARK_NODE_STRONG,
  51. CMARK_NODE_LINK,
  52. CMARK_NODE_IMAGE,
  53. CMARK_NODE_FIRST_INLINE = CMARK_NODE_TEXT,
  54. CMARK_NODE_LAST_INLINE = CMARK_NODE_IMAGE,
  55. } cmark_node_type;
  56. /**
  57. */
  58. typedef enum {
  59. CMARK_NO_LIST,
  60. CMARK_BULLET_LIST,
  61. CMARK_ORDERED_LIST
  62. } cmark_list_type;
  63. /**
  64. */
  65. typedef enum {
  66. CMARK_PERIOD_DELIM,
  67. CMARK_PAREN_DELIM
  68. } cmark_delim_type;
  69. typedef struct cmark_node cmark_node;
  70. typedef struct cmark_parser cmark_parser;
  71. typedef enum {
  72. CMARK_EVENT_DONE,
  73. CMARK_EVENT_ENTER,
  74. CMARK_EVENT_EXIT
  75. } cmark_event_type;
  76. typedef int (*cmark_node_handler)(cmark_node *node, cmark_event_type ev_type,
  77. void *state);
  78. /**
  79. * .SH CREATING AND DESTROYING NODES
  80. */
  81. /**
  82. */
  83. CMARK_EXPORT cmark_node*
  84. cmark_node_new(cmark_node_type type);
  85. /**
  86. */
  87. CMARK_EXPORT void
  88. cmark_node_free(cmark_node *node);
  89. /**
  90. * .SH TREE TRAVERSAL
  91. */
  92. CMARK_EXPORT cmark_node*
  93. cmark_node_next(cmark_node *node);
  94. /**
  95. */
  96. CMARK_EXPORT cmark_node*
  97. cmark_node_previous(cmark_node *node);
  98. /**
  99. */
  100. CMARK_EXPORT cmark_node*
  101. cmark_node_parent(cmark_node *node);
  102. /**
  103. */
  104. CMARK_EXPORT cmark_node*
  105. cmark_node_first_child(cmark_node *node);
  106. /**
  107. */
  108. CMARK_EXPORT cmark_node*
  109. cmark_node_last_child(cmark_node *node);
  110. /**
  111. * .SH ACCESSORS
  112. */
  113. /**
  114. */
  115. CMARK_EXPORT cmark_node_type
  116. cmark_node_get_type(cmark_node *node);
  117. /**
  118. */
  119. CMARK_EXPORT const char*
  120. cmark_node_get_string_content(cmark_node *node);
  121. /**
  122. */
  123. CMARK_EXPORT int
  124. cmark_node_set_string_content(cmark_node *node, const char *content);
  125. /**
  126. */
  127. CMARK_EXPORT int
  128. cmark_node_get_header_level(cmark_node *node);
  129. /**
  130. */
  131. CMARK_EXPORT int
  132. cmark_node_set_header_level(cmark_node *node, int level);
  133. /**
  134. */
  135. CMARK_EXPORT cmark_list_type
  136. cmark_node_get_list_type(cmark_node *node);
  137. /**
  138. */
  139. CMARK_EXPORT int
  140. cmark_node_set_list_type(cmark_node *node, cmark_list_type type);
  141. /**
  142. */
  143. CMARK_EXPORT int
  144. cmark_node_get_list_start(cmark_node *node);
  145. /**
  146. */
  147. CMARK_EXPORT int
  148. cmark_node_set_list_start(cmark_node *node, int start);
  149. /**
  150. */
  151. CMARK_EXPORT int
  152. cmark_node_get_list_tight(cmark_node *node);
  153. /**
  154. */
  155. CMARK_EXPORT int
  156. cmark_node_set_list_tight(cmark_node *node, int tight);
  157. /**
  158. */
  159. CMARK_EXPORT const char*
  160. cmark_node_get_fence_info(cmark_node *node);
  161. /**
  162. */
  163. CMARK_EXPORT int
  164. cmark_node_set_fence_info(cmark_node *node, const char *info);
  165. /**
  166. */
  167. CMARK_EXPORT const char*
  168. cmark_node_get_url(cmark_node *node);
  169. /**
  170. */
  171. CMARK_EXPORT int
  172. cmark_node_set_url(cmark_node *node, const char *url);
  173. /**
  174. */
  175. CMARK_EXPORT const char*
  176. cmark_node_get_title(cmark_node *node);
  177. /**
  178. */
  179. CMARK_EXPORT int
  180. cmark_node_set_title(cmark_node *node, const char *title);
  181. /**
  182. */
  183. CMARK_EXPORT int
  184. cmark_node_get_start_line(cmark_node *node);
  185. /**
  186. */
  187. CMARK_EXPORT int
  188. cmark_node_get_start_column(cmark_node *node);
  189. /**
  190. */
  191. CMARK_EXPORT int
  192. cmark_node_get_end_line(cmark_node *node);
  193. /**
  194. * .SH TREE MANIPULATION
  195. */
  196. /**
  197. */
  198. CMARK_EXPORT void
  199. cmark_node_unlink(cmark_node *node);
  200. /**
  201. */
  202. CMARK_EXPORT int
  203. cmark_node_insert_before(cmark_node *node, cmark_node *sibling);
  204. /**
  205. */
  206. CMARK_EXPORT int
  207. cmark_node_insert_after(cmark_node *node, cmark_node *sibling);
  208. /**
  209. */
  210. CMARK_EXPORT int
  211. cmark_node_prepend_child(cmark_node *node, cmark_node *child);
  212. /**
  213. */
  214. CMARK_EXPORT int
  215. cmark_node_append_child(cmark_node *node, cmark_node *child);
  216. /**
  217. * .SH PARSING
  218. */
  219. /**
  220. */
  221. CMARK_EXPORT
  222. cmark_parser *cmark_parser_new();
  223. /**
  224. */
  225. CMARK_EXPORT
  226. void cmark_parser_free(cmark_parser *parser);
  227. /**
  228. */
  229. CMARK_EXPORT
  230. cmark_node *cmark_parser_finish(cmark_parser *parser);
  231. /**
  232. */
  233. CMARK_EXPORT
  234. void cmark_parser_feed(cmark_parser *parser, const char *buffer, size_t len);
  235. /**
  236. */
  237. CMARK_EXPORT
  238. cmark_node *cmark_parse_document(const char *buffer, size_t len);
  239. /**
  240. */
  241. CMARK_EXPORT
  242. cmark_node *cmark_parse_file(FILE *f);
  243. /**
  244. * .SH RENDERING
  245. */
  246. /**
  247. */
  248. CMARK_EXPORT
  249. char *cmark_render_ast(cmark_node *root);
  250. /**
  251. */
  252. CMARK_EXPORT
  253. char *cmark_render_html(cmark_node *root);
  254. /** Walks the tree starting from root, applying handler to each node.
  255. * Nodes that can have children are visited twice, once on the way in
  256. * and once on the way out. handler is a function that takes a node
  257. * pointer, a cmark_event_type,
  258. * and a pointer to a state structure that can be consulted and
  259. * updated by the handler. The handler should return 1 on success,
  260. * 0 on failure. cmark_walk returns 1 if it traversed the entire
  261. * tree, 0 if it quit early in response to a 0 status from the
  262. * handler.
  263. */
  264. CMARK_EXPORT
  265. int cmark_walk(cmark_node *root, cmark_node_handler handler, void *state);
  266. /** .SH AUTHORS
  267. *
  268. * John MacFarlane, Vicent Marti, Kārlis Gaņģis, Nick Wellnhofer.
  269. */
  270. #ifndef CMARK_NO_SHORT_NAMES
  271. #define NODE_DOCUMENT CMARK_NODE_DOCUMENT
  272. #define NODE_BLOCK_QUOTE CMARK_NODE_BLOCK_QUOTE
  273. #define NODE_LIST CMARK_NODE_LIST
  274. #define NODE_LIST_ITEM CMARK_NODE_LIST_ITEM
  275. #define NODE_CODE_BLOCK CMARK_NODE_CODE_BLOCK
  276. #define NODE_HTML CMARK_NODE_HTML
  277. #define NODE_PARAGRAPH CMARK_NODE_PARAGRAPH
  278. #define NODE_HEADER CMARK_NODE_HEADER
  279. #define NODE_HRULE CMARK_NODE_HRULE
  280. #define NODE_TEXT CMARK_NODE_TEXT
  281. #define NODE_SOFTBREAK CMARK_NODE_SOFTBREAK
  282. #define NODE_LINEBREAK CMARK_NODE_LINEBREAK
  283. #define NODE_INLINE_CODE CMARK_NODE_INLINE_CODE
  284. #define NODE_INLINE_HTML CMARK_NODE_INLINE_HTML
  285. #define NODE_EMPH CMARK_NODE_EMPH
  286. #define NODE_STRONG CMARK_NODE_STRONG
  287. #define NODE_LINK CMARK_NODE_LINK
  288. #define NODE_IMAGE CMARK_NODE_IMAGE
  289. #define NODE_LINK_LABEL CMARK_NODE_LINK_LABEL
  290. #define BULLET_LIST CMARK_BULLET_LIST
  291. #define ORDERED_LIST CMARK_ORDERED_LIST
  292. #define PERIOD_DELIM CMARK_PERIOD_DELIM
  293. #define PAREN_DELIM CMARK_PAREN_DELIM
  294. #endif
  295. #ifdef __cplusplus
  296. }
  297. #endif
  298. #endif