aboutsummaryrefslogtreecommitdiff
path: root/src/cmark.h
blob: 2559b5fdc17241189bdb862097b28bb5e22a7e88 (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. /* Block */
  30. CMARK_NODE_DOCUMENT,
  31. CMARK_NODE_BLOCK_QUOTE,
  32. CMARK_NODE_LIST,
  33. CMARK_NODE_LIST_ITEM,
  34. CMARK_NODE_CODE_BLOCK,
  35. CMARK_NODE_HTML,
  36. CMARK_NODE_PARAGRAPH,
  37. CMARK_NODE_HEADER,
  38. CMARK_NODE_HRULE,
  39. CMARK_NODE_REFERENCE_DEF,
  40. CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT,
  41. CMARK_NODE_LAST_BLOCK = CMARK_NODE_REFERENCE_DEF,
  42. /* Inline */
  43. CMARK_NODE_TEXT,
  44. CMARK_NODE_SOFTBREAK,
  45. CMARK_NODE_LINEBREAK,
  46. CMARK_NODE_INLINE_CODE,
  47. CMARK_NODE_INLINE_HTML,
  48. CMARK_NODE_EMPH,
  49. CMARK_NODE_STRONG,
  50. CMARK_NODE_LINK,
  51. CMARK_NODE_IMAGE,
  52. CMARK_NODE_FIRST_INLINE = CMARK_NODE_TEXT,
  53. CMARK_NODE_LAST_INLINE = CMARK_NODE_IMAGE,
  54. CMARK_NODE_NONE = -1
  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. /**
  72. * .SH CREATING AND DESTROYING NODES
  73. */
  74. /**
  75. */
  76. CMARK_EXPORT cmark_node*
  77. cmark_node_new(cmark_node_type type);
  78. /**
  79. */
  80. CMARK_EXPORT void
  81. cmark_node_free(cmark_node *node);
  82. /**
  83. * .SH TREE TRAVERSAL
  84. */
  85. CMARK_EXPORT cmark_node*
  86. cmark_node_next(cmark_node *node);
  87. /**
  88. */
  89. CMARK_EXPORT cmark_node*
  90. cmark_node_previous(cmark_node *node);
  91. /**
  92. */
  93. CMARK_EXPORT cmark_node*
  94. cmark_node_parent(cmark_node *node);
  95. /**
  96. */
  97. CMARK_EXPORT cmark_node*
  98. cmark_node_first_child(cmark_node *node);
  99. /**
  100. */
  101. CMARK_EXPORT cmark_node*
  102. cmark_node_last_child(cmark_node *node);
  103. /**
  104. * .SH ACCESSORS
  105. */
  106. /**
  107. */
  108. CMARK_EXPORT cmark_node_type
  109. cmark_node_get_type(cmark_node *node);
  110. /**
  111. */
  112. CMARK_EXPORT const char*
  113. cmark_node_get_string_content(cmark_node *node);
  114. /**
  115. */
  116. CMARK_EXPORT int
  117. cmark_node_set_string_content(cmark_node *node, const char *content);
  118. /**
  119. */
  120. CMARK_EXPORT int
  121. cmark_node_get_header_level(cmark_node *node);
  122. /**
  123. */
  124. CMARK_EXPORT int
  125. cmark_node_set_header_level(cmark_node *node, int level);
  126. /**
  127. */
  128. CMARK_EXPORT cmark_list_type
  129. cmark_node_get_list_type(cmark_node *node);
  130. /**
  131. */
  132. CMARK_EXPORT int
  133. cmark_node_set_list_type(cmark_node *node, cmark_list_type type);
  134. /**
  135. */
  136. CMARK_EXPORT int
  137. cmark_node_get_list_start(cmark_node *node);
  138. /**
  139. */
  140. CMARK_EXPORT int
  141. cmark_node_set_list_start(cmark_node *node, int start);
  142. /**
  143. */
  144. CMARK_EXPORT int
  145. cmark_node_get_list_tight(cmark_node *node);
  146. /**
  147. */
  148. CMARK_EXPORT int
  149. cmark_node_set_list_tight(cmark_node *node, int tight);
  150. /**
  151. */
  152. CMARK_EXPORT const char*
  153. cmark_node_get_fence_info(cmark_node *node);
  154. /**
  155. */
  156. CMARK_EXPORT int
  157. cmark_node_set_fence_info(cmark_node *node, const char *info);
  158. /**
  159. */
  160. CMARK_EXPORT const char*
  161. cmark_node_get_url(cmark_node *node);
  162. /**
  163. */
  164. CMARK_EXPORT int
  165. cmark_node_set_url(cmark_node *node, const char *url);
  166. /**
  167. */
  168. CMARK_EXPORT const char*
  169. cmark_node_get_title(cmark_node *node);
  170. /**
  171. */
  172. CMARK_EXPORT int
  173. cmark_node_set_title(cmark_node *node, const char *title);
  174. /**
  175. */
  176. CMARK_EXPORT int
  177. cmark_node_get_start_line(cmark_node *node);
  178. /**
  179. */
  180. CMARK_EXPORT int
  181. cmark_node_get_start_column(cmark_node *node);
  182. /**
  183. */
  184. CMARK_EXPORT int
  185. cmark_node_get_end_line(cmark_node *node);
  186. /**
  187. * .SH TREE MANIPULATION
  188. */
  189. /**
  190. */
  191. CMARK_EXPORT void
  192. cmark_node_unlink(cmark_node *node);
  193. /**
  194. */
  195. CMARK_EXPORT int
  196. cmark_node_insert_before(cmark_node *node, cmark_node *sibling);
  197. /**
  198. */
  199. CMARK_EXPORT int
  200. cmark_node_insert_after(cmark_node *node, cmark_node *sibling);
  201. /**
  202. */
  203. CMARK_EXPORT int
  204. cmark_node_prepend_child(cmark_node *node, cmark_node *child);
  205. /**
  206. */
  207. CMARK_EXPORT int
  208. cmark_node_append_child(cmark_node *node, cmark_node *child);
  209. /**
  210. * .SH PARSING
  211. */
  212. /**
  213. */
  214. CMARK_EXPORT
  215. cmark_parser *cmark_parser_new();
  216. /**
  217. */
  218. CMARK_EXPORT
  219. void cmark_parser_free(cmark_parser *parser);
  220. /**
  221. */
  222. CMARK_EXPORT
  223. cmark_node *cmark_parser_finish(cmark_parser *parser);
  224. /**
  225. */
  226. CMARK_EXPORT
  227. void cmark_parser_feed(cmark_parser *parser, const char *buffer, size_t len);
  228. /**
  229. */
  230. CMARK_EXPORT
  231. cmark_node *cmark_parse_document(const char *buffer, size_t len);
  232. /**
  233. */
  234. CMARK_EXPORT
  235. cmark_node *cmark_parse_file(FILE *f);
  236. /**
  237. * .SH RENDERING
  238. */
  239. /**
  240. */
  241. CMARK_EXPORT
  242. char *cmark_render_ast(cmark_node *root);
  243. /**
  244. */
  245. CMARK_EXPORT
  246. char *cmark_render_html(cmark_node *root);
  247. /** .SH AUTHORS
  248. *
  249. * John MacFarlane, Vicent Marti, Kārlis Gaņģis, Nick Wellnhofer.
  250. */
  251. #ifndef CMARK_NO_SHORT_NAMES
  252. #define NODE_DOCUMENT CMARK_NODE_DOCUMENT
  253. #define NODE_BLOCK_QUOTE CMARK_NODE_BLOCK_QUOTE
  254. #define NODE_LIST CMARK_NODE_LIST
  255. #define NODE_LIST_ITEM CMARK_NODE_LIST_ITEM
  256. #define NODE_CODE_BLOCK CMARK_NODE_CODE_BLOCK
  257. #define NODE_HTML CMARK_NODE_HTML
  258. #define NODE_PARAGRAPH CMARK_NODE_PARAGRAPH
  259. #define NODE_HEADER CMARK_NODE_HEADER
  260. #define NODE_HRULE CMARK_NODE_HRULE
  261. #define NODE_REFERENCE_DEF CMARK_NODE_REFERENCE_DEF
  262. #define NODE_TEXT CMARK_NODE_TEXT
  263. #define NODE_SOFTBREAK CMARK_NODE_SOFTBREAK
  264. #define NODE_LINEBREAK CMARK_NODE_LINEBREAK
  265. #define NODE_INLINE_CODE CMARK_NODE_INLINE_CODE
  266. #define NODE_INLINE_HTML CMARK_NODE_INLINE_HTML
  267. #define NODE_EMPH CMARK_NODE_EMPH
  268. #define NODE_STRONG CMARK_NODE_STRONG
  269. #define NODE_LINK CMARK_NODE_LINK
  270. #define NODE_IMAGE CMARK_NODE_IMAGE
  271. #define NODE_LINK_LABEL CMARK_NODE_LINK_LABEL
  272. #define BULLET_LIST CMARK_BULLET_LIST
  273. #define ORDERED_LIST CMARK_ORDERED_LIST
  274. #define PERIOD_DELIM CMARK_PERIOD_DELIM
  275. #define PAREN_DELIM CMARK_PAREN_DELIM
  276. #endif
  277. #ifdef __cplusplus
  278. }
  279. #endif
  280. #endif