aboutsummaryrefslogtreecommitdiff
path: root/man/man3/cmark.3
blob: 5228cf17903d24c89d547f6fe1f5a2c204ef8735 (plain)
  1. .TH cmark 3 "December 13, 2014" "LOCAL" "Library Functions Manual"
  2. .SH
  3. NAME
  4. .PP
  5. \f[B]cmark\f[] \- CommonMark parsing, manipulating, and rendering
  6. .SH
  7. DESCRIPTION
  8. .SS
  9. Simple Interface
  10. .nf
  11. \f[C]
  12. .RS 0n
  13. #define CMARK_VERSION "0.1"
  14. .RE
  15. \f[]
  16. .fi
  17. Current version of library.
  18. \fIchar *\fR \fBcmark_markdown_to_html\fR(\fIconst char *text\fR, \fIint len\fR)
  19. Convert \fItext\fR (assumed to be a UTF-8 encoded string with length
  20. \fIlen\fR from CommonMark Markdown to HTML, returning a null-terminated,
  21. UTF-8-encoded string.
  22. .SS
  23. Node Structure
  24. .nf
  25. \f[C]
  26. .RS 0n
  27. typedef enum {
  28. /* Error status */
  29. CMARK_NODE_NONE,
  30. /* Block */
  31. CMARK_NODE_DOCUMENT,
  32. CMARK_NODE_BLOCK_QUOTE,
  33. CMARK_NODE_LIST,
  34. CMARK_NODE_LIST_ITEM,
  35. CMARK_NODE_CODE_BLOCK,
  36. CMARK_NODE_HTML,
  37. CMARK_NODE_PARAGRAPH,
  38. CMARK_NODE_HEADER,
  39. CMARK_NODE_HRULE,
  40. CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT,
  41. CMARK_NODE_LAST_BLOCK = CMARK_NODE_HRULE,
  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_type;
  55. .RE
  56. \f[]
  57. .fi
  58. .nf
  59. \f[C]
  60. .RS 0n
  61. typedef enum {
  62. CMARK_NO_LIST,
  63. CMARK_BULLET_LIST,
  64. CMARK_ORDERED_LIST
  65. } cmark_list_type;
  66. .RE
  67. \f[]
  68. .fi
  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. .SS
  80. Creating and Destroying Nodes
  81. \fIcmark_node*\fR \fBcmark_node_new\fR(\fIcmark_node_type type\fR)
  82. \fIvoid\fR \fBcmark_node_free\fR(\fIcmark_node *node\fR)
  83. .SS
  84. Tree Traversal
  85. \fIcmark_node*\fR \fBcmark_node_previous\fR(\fIcmark_node *node\fR)
  86. \fIcmark_node*\fR \fBcmark_node_parent\fR(\fIcmark_node *node\fR)
  87. \fIcmark_node*\fR \fBcmark_node_first_child\fR(\fIcmark_node *node\fR)
  88. \fIcmark_node*\fR \fBcmark_node_last_child\fR(\fIcmark_node *node\fR)
  89. .SS
  90. Iterator
  91. \fIcmark_iter*\fR \fBcmark_iter_new\fR(\fIcmark_node *root\fR)
  92. \fIvoid\fR \fBcmark_iter_free\fR(\fIcmark_iter *iter\fR)
  93. \fIcmark_event_type\fR \fBcmark_iter_next\fR(\fIcmark_iter *iter\fR)
  94. \fIcmark_node*\fR \fBcmark_iter_get_node\fR(\fIcmark_iter *iter\fR)
  95. .SS
  96. Accessors
  97. \fIcmark_node_type\fR \fBcmark_node_get_type\fR(\fIcmark_node *node\fR)
  98. \fIconst char*\fR \fBcmark_node_get_string_content\fR(\fIcmark_node *node\fR)
  99. \fIint\fR \fBcmark_node_set_string_content\fR(\fIcmark_node *node\fR, \fIconst char *content\fR)
  100. \fIint\fR \fBcmark_node_get_header_level\fR(\fIcmark_node *node\fR)
  101. \fIint\fR \fBcmark_node_set_header_level\fR(\fIcmark_node *node\fR, \fIint level\fR)
  102. \fIcmark_list_type\fR \fBcmark_node_get_list_type\fR(\fIcmark_node *node\fR)
  103. \fIint\fR \fBcmark_node_set_list_type\fR(\fIcmark_node *node\fR, \fIcmark_list_type type\fR)
  104. \fIint\fR \fBcmark_node_get_list_start\fR(\fIcmark_node *node\fR)
  105. \fIint\fR \fBcmark_node_set_list_start\fR(\fIcmark_node *node\fR, \fIint start\fR)
  106. \fIint\fR \fBcmark_node_get_list_tight\fR(\fIcmark_node *node\fR)
  107. \fIint\fR \fBcmark_node_set_list_tight\fR(\fIcmark_node *node\fR, \fIint tight\fR)
  108. \fIconst char*\fR \fBcmark_node_get_fence_info\fR(\fIcmark_node *node\fR)
  109. \fIint\fR \fBcmark_node_set_fence_info\fR(\fIcmark_node *node\fR, \fIconst char *info\fR)
  110. \fIconst char*\fR \fBcmark_node_get_url\fR(\fIcmark_node *node\fR)
  111. \fIint\fR \fBcmark_node_set_url\fR(\fIcmark_node *node\fR, \fIconst char *url\fR)
  112. \fIconst char*\fR \fBcmark_node_get_title\fR(\fIcmark_node *node\fR)
  113. \fIint\fR \fBcmark_node_set_title\fR(\fIcmark_node *node\fR, \fIconst char *title\fR)
  114. \fIint\fR \fBcmark_node_get_start_line\fR(\fIcmark_node *node\fR)
  115. \fIint\fR \fBcmark_node_get_start_column\fR(\fIcmark_node *node\fR)
  116. \fIint\fR \fBcmark_node_get_end_line\fR(\fIcmark_node *node\fR)
  117. .SS
  118. Tree Manipulation
  119. \fIvoid\fR \fBcmark_node_unlink\fR(\fIcmark_node *node\fR)
  120. \fIint\fR \fBcmark_node_insert_before\fR(\fIcmark_node *node\fR, \fIcmark_node *sibling\fR)
  121. \fIint\fR \fBcmark_node_insert_after\fR(\fIcmark_node *node\fR, \fIcmark_node *sibling\fR)
  122. \fIint\fR \fBcmark_node_prepend_child\fR(\fIcmark_node *node\fR, \fIcmark_node *child\fR)
  123. \fIint\fR \fBcmark_node_append_child\fR(\fIcmark_node *node\fR, \fIcmark_node *child\fR)
  124. .SS
  125. Parsing
  126. \fIcmark_parser *\fR \fBcmark_parser_new\fR(\fI\fR)
  127. \fIvoid\fR \fBcmark_parser_free\fR(\fIcmark_parser *parser\fR)
  128. \fIcmark_node *\fR \fBcmark_parser_finish\fR(\fIcmark_parser *parser\fR)
  129. \fIvoid\fR \fBcmark_parser_feed\fR(\fIcmark_parser *parser\fR, \fIconst char *buffer\fR, \fIsize_t len\fR)
  130. \fIcmark_node *\fR \fBcmark_parse_document\fR(\fIconst char *buffer\fR, \fIsize_t len\fR)
  131. \fIcmark_node *\fR \fBcmark_parse_file\fR(\fIFILE *f\fR)
  132. .SS
  133. Rendering
  134. \fIchar *\fR \fBcmark_render_ast\fR(\fIcmark_node *root\fR)
  135. \fIchar *\fR \fBcmark_render_html\fR(\fIcmark_node *root\fR)
  136. \fIchar *\fR \fBcmark_render_man\fR(\fIcmark_node *root\fR)
  137. .SH
  138. AUTHORS
  139. .PP
  140. John MacFarlane, Vicent Marti, Kārlis Gaņģis, Nick Wellnhofer.