aboutsummaryrefslogtreecommitdiff
path: root/man/man3/cmark.3
blob: 62d89e293b6d4c1da67e4b50004d8ade37ef0ad8 (plain)
  1. .TH cmark 3 "December 13, 2014" "LOCAL" "Library Functions Manual"
  2. .SH NAME
  3. .B cmark
  4. \- CommonMark parsing, manipulating, and rendering
  5. .SH DESCRIPTION
  6. .SS Simple Interface
  7. .nf
  8. \f[C]
  9. .RS 0n
  10. #define CMARK_VERSION "0.1"
  11. .RE
  12. \f[]
  13. .fi
  14. .PP
  15. Current version of library.
  16. \fIchar *\fR \fBcmark_markdown_to_html\fR(\fIconst char *text\fR, \fIint len\fR)
  17. .PP
  18. Convert \fItext\fR (assumed to be a UTF-8 encoded string with length
  19. \fIlen\fR from CommonMark Markdown to HTML, returning a null-terminated,
  20. UTF-8-encoded string.
  21. .SS Node Structure
  22. .nf
  23. \f[C]
  24. .RS 0n
  25. typedef enum {
  26. /* Error status */
  27. CMARK_NODE_NONE,
  28. /* Block */
  29. CMARK_NODE_DOCUMENT,
  30. CMARK_NODE_BLOCK_QUOTE,
  31. CMARK_NODE_LIST,
  32. CMARK_NODE_LIST_ITEM,
  33. CMARK_NODE_CODE_BLOCK,
  34. CMARK_NODE_HTML,
  35. CMARK_NODE_PARAGRAPH,
  36. CMARK_NODE_HEADER,
  37. CMARK_NODE_HRULE,
  38. CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT,
  39. CMARK_NODE_LAST_BLOCK = CMARK_NODE_HRULE,
  40. /* Inline */
  41. CMARK_NODE_TEXT,
  42. CMARK_NODE_SOFTBREAK,
  43. CMARK_NODE_LINEBREAK,
  44. CMARK_NODE_INLINE_CODE,
  45. CMARK_NODE_INLINE_HTML,
  46. CMARK_NODE_EMPH,
  47. CMARK_NODE_STRONG,
  48. CMARK_NODE_LINK,
  49. CMARK_NODE_IMAGE,
  50. CMARK_NODE_FIRST_INLINE = CMARK_NODE_TEXT,
  51. CMARK_NODE_LAST_INLINE = CMARK_NODE_IMAGE,
  52. } cmark_node_type;
  53. .RE
  54. \f[]
  55. .fi
  56. .PP
  57. .nf
  58. \f[C]
  59. .RS 0n
  60. typedef enum {
  61. CMARK_NO_LIST,
  62. CMARK_BULLET_LIST,
  63. CMARK_ORDERED_LIST
  64. } cmark_list_type;
  65. .RE
  66. \f[]
  67. .fi
  68. .PP
  69. .nf
  70. \f[C]
  71. .RS 0n
  72. typedef enum {
  73. CMARK_PERIOD_DELIM,
  74. CMARK_PAREN_DELIM
  75. } cmark_delim_type;
  76. .RE
  77. \f[]
  78. .fi
  79. .PP
  80. .SS Creating and Destroying Nodes
  81. \fIcmark_node*\fR \fBcmark_node_new\fR(\fIcmark_node_type type\fR)
  82. .PP
  83. \fIvoid\fR \fBcmark_node_free\fR(\fIcmark_node *node\fR)
  84. .PP
  85. \fIcmark_node*\fR \fBcmark_node_next\fR(\fIcmark_node *node\fR)
  86. .PP
  87. .SS Tree Traversal
  88. \fIcmark_node*\fR \fBcmark_node_previous\fR(\fIcmark_node *node\fR)
  89. .PP
  90. \fIcmark_node*\fR \fBcmark_node_parent\fR(\fIcmark_node *node\fR)
  91. .PP
  92. \fIcmark_node*\fR \fBcmark_node_first_child\fR(\fIcmark_node *node\fR)
  93. .PP
  94. \fIcmark_node*\fR \fBcmark_node_last_child\fR(\fIcmark_node *node\fR)
  95. .PP
  96. .SS Iterator
  97. \fIcmark_iter*\fR \fBcmark_iter_new\fR(\fIcmark_node *root\fR)
  98. .PP
  99. \fIvoid\fR \fBcmark_iter_free\fR(\fIcmark_iter *iter\fR)
  100. .PP
  101. \fIcmark_event_type\fR \fBcmark_iter_next\fR(\fIcmark_iter *iter\fR)
  102. .PP
  103. \fIcmark_node*\fR \fBcmark_iter_get_node\fR(\fIcmark_iter *iter\fR)
  104. .PP
  105. .SS Accessors
  106. \fIcmark_node_type\fR \fBcmark_node_get_type\fR(\fIcmark_node *node\fR)
  107. .PP
  108. \fIconst char*\fR \fBcmark_node_get_string_content\fR(\fIcmark_node *node\fR)
  109. .PP
  110. \fIint\fR \fBcmark_node_set_string_content\fR(\fIcmark_node *node\fR, \fIconst char *content\fR)
  111. .PP
  112. \fIint\fR \fBcmark_node_get_header_level\fR(\fIcmark_node *node\fR)
  113. .PP
  114. \fIint\fR \fBcmark_node_set_header_level\fR(\fIcmark_node *node\fR, \fIint level\fR)
  115. .PP
  116. \fIcmark_list_type\fR \fBcmark_node_get_list_type\fR(\fIcmark_node *node\fR)
  117. .PP
  118. \fIint\fR \fBcmark_node_set_list_type\fR(\fIcmark_node *node\fR, \fIcmark_list_type type\fR)
  119. .PP
  120. \fIint\fR \fBcmark_node_get_list_start\fR(\fIcmark_node *node\fR)
  121. .PP
  122. \fIint\fR \fBcmark_node_set_list_start\fR(\fIcmark_node *node\fR, \fIint start\fR)
  123. .PP
  124. \fIint\fR \fBcmark_node_get_list_tight\fR(\fIcmark_node *node\fR)
  125. .PP
  126. \fIint\fR \fBcmark_node_set_list_tight\fR(\fIcmark_node *node\fR, \fIint tight\fR)
  127. .PP
  128. \fIconst char*\fR \fBcmark_node_get_fence_info\fR(\fIcmark_node *node\fR)
  129. .PP
  130. \fIint\fR \fBcmark_node_set_fence_info\fR(\fIcmark_node *node\fR, \fIconst char *info\fR)
  131. .PP
  132. \fIconst char*\fR \fBcmark_node_get_url\fR(\fIcmark_node *node\fR)
  133. .PP
  134. \fIint\fR \fBcmark_node_set_url\fR(\fIcmark_node *node\fR, \fIconst char *url\fR)
  135. .PP
  136. \fIconst char*\fR \fBcmark_node_get_title\fR(\fIcmark_node *node\fR)
  137. .PP
  138. \fIint\fR \fBcmark_node_set_title\fR(\fIcmark_node *node\fR, \fIconst char *title\fR)
  139. .PP
  140. \fIint\fR \fBcmark_node_get_start_line\fR(\fIcmark_node *node\fR)
  141. .PP
  142. \fIint\fR \fBcmark_node_get_start_column\fR(\fIcmark_node *node\fR)
  143. .PP
  144. \fIint\fR \fBcmark_node_get_end_line\fR(\fIcmark_node *node\fR)
  145. .PP
  146. .SS Tree Manipulation
  147. \fIvoid\fR \fBcmark_node_unlink\fR(\fIcmark_node *node\fR)
  148. .PP
  149. \fIint\fR \fBcmark_node_insert_before\fR(\fIcmark_node *node\fR, \fIcmark_node *sibling\fR)
  150. .PP
  151. \fIint\fR \fBcmark_node_insert_after\fR(\fIcmark_node *node\fR, \fIcmark_node *sibling\fR)
  152. .PP
  153. \fIint\fR \fBcmark_node_prepend_child\fR(\fIcmark_node *node\fR, \fIcmark_node *child\fR)
  154. .PP
  155. \fIint\fR \fBcmark_node_append_child\fR(\fIcmark_node *node\fR, \fIcmark_node *child\fR)
  156. .PP
  157. .SS Parsing
  158. \fIcmark_parser *\fR \fBcmark_parser_new\fR(\fI\fR)
  159. .PP
  160. \fIvoid\fR \fBcmark_parser_free\fR(\fIcmark_parser *parser\fR)
  161. .PP
  162. \fIcmark_node *\fR \fBcmark_parser_finish\fR(\fIcmark_parser *parser\fR)
  163. .PP
  164. \fIvoid\fR \fBcmark_parser_feed\fR(\fIcmark_parser *parser\fR, \fIconst char *buffer\fR, \fIsize_t len\fR)
  165. .PP
  166. \fIcmark_node *\fR \fBcmark_parse_document\fR(\fIconst char *buffer\fR, \fIsize_t len\fR)
  167. .PP
  168. \fIcmark_node *\fR \fBcmark_parse_file\fR(\fIFILE *f\fR)
  169. .PP
  170. .SS Rendering
  171. \fIchar *\fR \fBcmark_render_ast\fR(\fIcmark_node *root\fR)
  172. .PP
  173. \fIchar *\fR \fBcmark_render_html\fR(\fIcmark_node *root\fR)
  174. .PP
  175. .SH AUTHORS
  176. John MacFarlane, Vicent Marti, Kārlis Gaņģis, Nick Wellnhofer.