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