- #ifndef CMARK_H
- #define CMARK_H
- #include <stdio.h>
- #include "cmark_export.h"
- #ifdef __cplusplus
- extern "C" {
- #endif
- /** # NAME
- *
- * **cmark** - CommonMark parsing, manipulating, and rendering
- */
- /** # DESCRIPTION
- *
- * ## Simple Interface
- */
- /** Current version of library.
- */
- #define CMARK_VERSION "0.1"
- /** Convert 'text' (assumed to be a UTF-8 encoded string with length
- * 'len' from CommonMark Markdown to HTML, returning a null-terminated,
- * UTF-8-encoded string.
- */
- CMARK_EXPORT
- char *cmark_markdown_to_html(const char *text, int len);
- /** ## Node Structure
- */
- typedef enum {
- /* Error status */
- CMARK_NODE_NONE,
- /* Block */
- CMARK_NODE_DOCUMENT,
- CMARK_NODE_BLOCK_QUOTE,
- CMARK_NODE_LIST,
- CMARK_NODE_ITEM,
- CMARK_NODE_CODE_BLOCK,
- CMARK_NODE_HTML,
- CMARK_NODE_PARAGRAPH,
- CMARK_NODE_HEADER,
- CMARK_NODE_HRULE,
- CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT,
- CMARK_NODE_LAST_BLOCK = CMARK_NODE_HRULE,
- /* Inline */
- CMARK_NODE_TEXT,
- CMARK_NODE_SOFTBREAK,
- CMARK_NODE_LINEBREAK,
- CMARK_NODE_CODE,
- CMARK_NODE_INLINE_HTML,
- CMARK_NODE_EMPH,
- CMARK_NODE_STRONG,
- CMARK_NODE_LINK,
- CMARK_NODE_IMAGE,
- CMARK_NODE_FIRST_INLINE = CMARK_NODE_TEXT,
- CMARK_NODE_LAST_INLINE = CMARK_NODE_IMAGE,
- } cmark_node_type;
- typedef enum {
- CMARK_NO_LIST,
- CMARK_BULLET_LIST,
- CMARK_ORDERED_LIST
- } cmark_list_type;
- typedef enum {
- CMARK_NO_DELIM,
- CMARK_PERIOD_DELIM,
- CMARK_PAREN_DELIM
- } cmark_delim_type;
- typedef struct cmark_node cmark_node;
- typedef struct cmark_parser cmark_parser;
- typedef struct cmark_iter cmark_iter;
- typedef enum {
- CMARK_EVENT_DONE,
- CMARK_EVENT_ENTER,
- CMARK_EVENT_EXIT
- } cmark_event_type;
- /**
- * ## Creating and Destroying Nodes
- */
- /** Creates a new node of type 'type'. Note that the node may have
- * other required properties, which it is the caller's responsibility
- * to assign.
- */
- CMARK_EXPORT cmark_node*
- cmark_node_new(cmark_node_type type);
- /** Frees the memory allocated for a node.
- */
- CMARK_EXPORT void
- cmark_node_free(cmark_node *node);
- /**
- * ## Tree Traversal
- */
- /** Returns the next node in the sequence after 'node', or NULL if
- * there is none.
- */
- CMARK_EXPORT cmark_node*
- cmark_node_next(cmark_node *node);
- /** Returns the previous node in the sequence after 'node', or NULL if
- * there is none.
- */
- CMARK_EXPORT cmark_node*
- cmark_node_previous(cmark_node *node);
- /** Returns the parent of 'node', or NULL if there is none.
- */
- CMARK_EXPORT cmark_node*
- cmark_node_parent(cmark_node *node);
- /** Returns the first child of 'node', or NULL if 'node' has no children.
- */
- CMARK_EXPORT cmark_node*
- cmark_node_first_child(cmark_node *node);
- /** Returns the last child of 'node', or NULL if 'node' has no children.
- */
- CMARK_EXPORT cmark_node*
- cmark_node_last_child(cmark_node *node);
- /**
- * ## Iterator
- *
- * An iterator will walk through a tree of nodes, starting from a root
- * node, returning one node at a time, together with information about
- * whether the node is being entered or exited. The iterator will
- * first descend to a child node, if there is one. When there is no
- * child, the iterator will go to the next sibling. When there is no
- * next sibling, the iterator will return to the parent (but with
- * a 'cmark_event_type' of `CMARK_EVENT_EXIT`). The iterator will
- * return `CMARK_EVENT_DONE` when it reaches the root node again.
- * One natural application is an HTML renderer, where an `ENTER` event
- * outputs an open tag and an `EXIT` event outputs a close tag.
- * An iterator might also be used to transform an AST in some systematic
- * way, for example, turning all level-3 headers into regular paragraphs.
- *
- * void
- * usage_example(cmark_node *root) {
- * cmark_event_type ev_type;
- * cmark_iter *iter = cmark_iter_new(root);
- *
- * while ((ev_type = cmark_iter_next(iter)) != CMARK_EVENT_DONE) {
- * cmark_node *cur = cmark_iter_get_node(iter);
- * // Do something with `cur` and `ev_type`
- * }
- *
- * cmark_iter_free(iter);
- * }
- */
- /** Creates a new iterator starting at 'root'.
- */
- CMARK_EXPORT
- cmark_iter*
- cmark_iter_new(cmark_node *root);
- /** Frees the memory allocated for an iterator.
- */
- CMARK_EXPORT
- void
- cmark_iter_free(cmark_iter *iter);
- /** Returns the event type (`CMARK_EVENT_ENTER`, `CMARK_EVENT_EXIT`,
- * or `CMARK_EVENT_DONE`) for the next node.
- */
- CMARK_EXPORT
- cmark_event_type
- cmark_iter_next(cmark_iter *iter);
- /** Returns the next node in the sequence described above.
- */
- CMARK_EXPORT
- cmark_node*
- cmark_iter_get_node(cmark_iter *iter);
- /**
- * ## Accessors
- */
- /** Returns the type of 'node', or `CMARK_NODE_NONE` on error.
- */
- CMARK_EXPORT cmark_node_type
- cmark_node_get_type(cmark_node *node);
- /** Like 'cmark_node_get_type', but returns a string representation
- of the type, or `"<unknown>"`.
- */
- CMARK_EXPORT
- const char*
- cmark_node_get_type_string(cmark_node *node);
- /** Returns the string contents of 'node', or NULL if none.
- */
- CMARK_EXPORT const char*
- cmark_node_get_literal(cmark_node *node);
- /** Sets the string contents of 'node'. Returns 1 on success,
- * 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_set_literal(cmark_node *node, const char *content);
- /** Returns the header level of 'node', or 0 if 'node' is not a header.
- */
- CMARK_EXPORT int
- cmark_node_get_header_level(cmark_node *node);
- /** Sets the header level of 'node', returning 1 on success and 0 on error.
- */
- CMARK_EXPORT int
- cmark_node_set_header_level(cmark_node *node, int level);
- /** Returns the list type of 'node', or `CMARK_NO_LIST` if 'node'
- * is not a list.
- */
- CMARK_EXPORT cmark_list_type
- cmark_node_get_list_type(cmark_node *node);
- /** Sets the list type of 'node', returning 1 on success and 0 on error.
- */
- CMARK_EXPORT int
- cmark_node_set_list_type(cmark_node *node, cmark_list_type type);
- /** Returns the list delimiter type of 'node', or `CMARK_NO_DELIM` if 'node'
- * is not a list.
- */
- CMARK_EXPORT cmark_delim_type
- cmark_node_get_list_delim(cmark_node *node);
- /** Sets the list delimiter type of 'node', returning 1 on success and 0
- * on error.
- */
- CMARK_EXPORT int
- cmark_node_set_list_delim(cmark_node *node, cmark_delim_type delim);
- /** Returns starting number of 'node', if it is an ordered list, otherwise 0.
- */
- CMARK_EXPORT int
- cmark_node_get_list_start(cmark_node *node);
- /** Sets starting number of 'node', if it is an ordered list. Returns 1
- * on success, 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_set_list_start(cmark_node *node, int start);
- /** Returns 1 if 'node' is a tight list, 0 otherwise.
- */
- CMARK_EXPORT int
- cmark_node_get_list_tight(cmark_node *node);
- /** Sets the "tightness" of a list. Returns 1 on success, 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_set_list_tight(cmark_node *node, int tight);
- /** Returns the info string from a fenced code block, or NULL if none.
- */
- CMARK_EXPORT const char*
- cmark_node_get_fence_info(cmark_node *node);
- /** Sets the info string in a fenced code block, returning 1 on
- * success and 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_set_fence_info(cmark_node *node, const char *info);
- /** Gets the URL of a link or image 'node', or NULL if none.
- */
- CMARK_EXPORT const char*
- cmark_node_get_url(cmark_node *node);
- /** Sets the URL of a link or image 'node'. Returns 1 on success,
- * 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_set_url(cmark_node *node, const char *url);
- /** Gets the title of a link or image 'node', or NULL if none.
- */
- CMARK_EXPORT const char*
- cmark_node_get_title(cmark_node *node);
- /** Sets the title of a link or image 'node'. Returns 1 on success,
- * 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_set_title(cmark_node *node, const char *title);
- /** Returns the line on which 'node' begins.
- */
- CMARK_EXPORT int
- cmark_node_get_start_line(cmark_node *node);
- /** Returns the column at which 'node' begins.
- */
- CMARK_EXPORT int
- cmark_node_get_start_column(cmark_node *node);
- /** Returns the line on which 'node' ends.
- */
- CMARK_EXPORT int
- cmark_node_get_end_line(cmark_node *node);
- /** Returns the column at which 'node' ends.
- */
- CMARK_EXPORT int
- cmark_node_get_end_column(cmark_node *node);
- /**
- * ## Tree Manipulation
- */
- /** Unlinks a 'node', removing it from the tree, but not freeing its
- * memory. (Use 'cmark_node_free' for that.)
- */
- CMARK_EXPORT void
- cmark_node_unlink(cmark_node *node);
- /** Inserts 'sibling' before 'node'. Returns 1 on success, 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_insert_before(cmark_node *node, cmark_node *sibling);
- /** Inserts 'sibling' after 'node'. Returns 1 on success, 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_insert_after(cmark_node *node, cmark_node *sibling);
- /** Adds 'child' to the beginning of the children of 'node'.
- * Returns 1 on success, 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_prepend_child(cmark_node *node, cmark_node *child);
- /** Adds 'child' to the end of the children of 'node'.
- * Returns 1 on success, 0 on failure.
- */
- CMARK_EXPORT int
- cmark_node_append_child(cmark_node *node, cmark_node *child);
- /**
- * ## Parsing
- *
- * Simple interface:
- *
- * cmark_node *document = cmark_parse_document("Hello *world*", 12);
- *
- * Streaming interface:
- *
- * cmark_parser *parser = cmark_parser_new();
- * FILE *fp = fopen("myfile.md", "r");
- * while ((bytes = fread(buffer, 1, sizeof(buffer), fp)) > 0) {
- * cmark_parser_feed(parser, buffer, bytes);
- * if (bytes < sizeof(buffer)) {
- * break;
- * }
- * }
- * document = cmark_parser_finish(parser);
- * cmark_parser_free(parser);
- */
- /** Creates a new parser object.
- */
- CMARK_EXPORT
- cmark_parser *cmark_parser_new();
- /** Frees memory allocated for a parser object.
- */
- CMARK_EXPORT
- void cmark_parser_free(cmark_parser *parser);
- /** Feeds a string of length 'len' to 'parser'.
- */
- CMARK_EXPORT
- void cmark_parser_feed(cmark_parser *parser, const char *buffer, size_t len);
- /** Finish parsing and return a pointer to a tree of nodes.
- */
- CMARK_EXPORT
- cmark_node *cmark_parser_finish(cmark_parser *parser);
- /** Parse a CommonMark document in 'buffer' of length 'len'.
- * Returns a pointer to a tree of nodes.
- */
- CMARK_EXPORT
- cmark_node *cmark_parse_document(const char *buffer, size_t len);
- /** Parse a CommonMark document in file 'f', returning a pointer to
- * a tree of nodes.
- */
- CMARK_EXPORT
- cmark_node *cmark_parse_file(FILE *f);
- /**
- * ## Rendering
- */
- /** Render a 'node' tree as XML.
- */
- CMARK_EXPORT
- char *cmark_render_xml(cmark_node *root, long options);
- /** Render a 'node' tree as an HTML fragment. It is up to the user
- * to add an appropriate header and footer.
- */
- CMARK_EXPORT
- char *cmark_render_html(cmark_node *root, long options);
- /** Render a 'node' tree as a groff man page, without the header.
- */
- CMARK_EXPORT
- char *cmark_render_man(cmark_node *root, long options);
- /** Default writer options.
- */
- #define CMARK_OPT_DEFAULT 0
- /** Include a `data-sourcepos` attribute on all block elements.
- */
- #define CMARK_OPT_SOURCEPOS 1
- /** Render `softbreak` elements as hard line breaks.
- */
- #define CMARK_OPT_HARDBREAKS 2
- /** # AUTHORS
- *
- * John MacFarlane, Vicent Marti, Kārlis Gaņģis, Nick Wellnhofer.
- */
- #ifndef CMARK_NO_SHORT_NAMES
- #define NODE_DOCUMENT CMARK_NODE_DOCUMENT
- #define NODE_BLOCK_QUOTE CMARK_NODE_BLOCK_QUOTE
- #define NODE_LIST CMARK_NODE_LIST
- #define NODE_ITEM CMARK_NODE_ITEM
- #define NODE_CODE_BLOCK CMARK_NODE_CODE_BLOCK
- #define NODE_HTML CMARK_NODE_HTML
- #define NODE_PARAGRAPH CMARK_NODE_PARAGRAPH
- #define NODE_HEADER CMARK_NODE_HEADER
- #define NODE_HRULE CMARK_NODE_HRULE
- #define NODE_TEXT CMARK_NODE_TEXT
- #define NODE_SOFTBREAK CMARK_NODE_SOFTBREAK
- #define NODE_LINEBREAK CMARK_NODE_LINEBREAK
- #define NODE_CODE CMARK_NODE_CODE
- #define NODE_INLINE_HTML CMARK_NODE_INLINE_HTML
- #define NODE_EMPH CMARK_NODE_EMPH
- #define NODE_STRONG CMARK_NODE_STRONG
- #define NODE_LINK CMARK_NODE_LINK
- #define NODE_IMAGE CMARK_NODE_IMAGE
- #define NODE_LINK_LABEL CMARK_NODE_LINK_LABEL
- #define BULLET_LIST CMARK_BULLET_LIST
- #define ORDERED_LIST CMARK_ORDERED_LIST
- #define PERIOD_DELIM CMARK_PERIOD_DELIM
- #define PAREN_DELIM CMARK_PAREN_DELIM
- #endif
- #ifdef __cplusplus
- }
- #endif
- #endif
|