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