cmark

My personal build of CMark ✏️

cmark.h (19550B)

  1 #ifndef CMARK_H
  2 #define CMARK_H
  3 
  4 #include <stdio.h>
  5 #include <cmark_export.h>
  6 #include <cmark_version.h>
  7 
  8 #ifdef __cplusplus
  9 extern "C" {
 10 #endif
 11 
 12 /** # NAME
 13  *
 14  * **cmark** - CommonMark parsing, manipulating, and rendering
 15  */
 16 
 17 /** # DESCRIPTION
 18  *
 19  * ## Simple Interface
 20  */
 21 
 22 /** Convert 'text' (assumed to be a UTF-8 encoded string with length
 23  * 'len') from CommonMark Markdown to HTML, returning a null-terminated,
 24  * UTF-8-encoded string. It is the caller's responsibility
 25  * to free the returned buffer.
 26  */
 27 CMARK_EXPORT
 28 char *cmark_markdown_to_html(const char *text, size_t len, int options);
 29 
 30 /** ## Node Structure
 31  */
 32 
 33 typedef enum {
 34   /* Error status */
 35   CMARK_NODE_NONE,
 36 
 37   /* Block */
 38   CMARK_NODE_DOCUMENT,
 39   CMARK_NODE_BLOCK_QUOTE,
 40   CMARK_NODE_LIST,
 41   CMARK_NODE_ITEM,
 42   CMARK_NODE_CODE_BLOCK,
 43   CMARK_NODE_HTML_BLOCK,
 44   CMARK_NODE_CUSTOM_BLOCK,
 45   CMARK_NODE_PARAGRAPH,
 46   CMARK_NODE_HEADING,
 47   CMARK_NODE_THEMATIC_BREAK,
 48 
 49   CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT,
 50   CMARK_NODE_LAST_BLOCK = CMARK_NODE_THEMATIC_BREAK,
 51 
 52   /* Inline */
 53   CMARK_NODE_TEXT,
 54   CMARK_NODE_SOFTBREAK,
 55   CMARK_NODE_LINEBREAK,
 56   CMARK_NODE_CODE,
 57   CMARK_NODE_HTML_INLINE,
 58   CMARK_NODE_CUSTOM_INLINE,
 59   CMARK_NODE_EMPH,
 60   CMARK_NODE_STRONG,
 61   CMARK_NODE_LINK,
 62   CMARK_NODE_IMAGE,
 63 
 64   CMARK_NODE_FIRST_INLINE = CMARK_NODE_TEXT,
 65   CMARK_NODE_LAST_INLINE = CMARK_NODE_IMAGE,
 66 } cmark_node_type;
 67 
 68 /* For backwards compatibility: */
 69 #define CMARK_NODE_HEADER CMARK_NODE_HEADING
 70 #define CMARK_NODE_HRULE CMARK_NODE_THEMATIC_BREAK
 71 #define CMARK_NODE_HTML CMARK_NODE_HTML_BLOCK
 72 #define CMARK_NODE_INLINE_HTML CMARK_NODE_HTML_INLINE
 73 
 74 typedef enum {
 75   CMARK_NO_LIST,
 76   CMARK_BULLET_LIST,
 77   CMARK_ORDERED_LIST
 78 } cmark_list_type;
 79 
 80 typedef enum {
 81   CMARK_NO_DELIM,
 82   CMARK_PERIOD_DELIM,
 83   CMARK_PAREN_DELIM
 84 } cmark_delim_type;
 85 
 86 typedef struct cmark_node cmark_node;
 87 typedef struct cmark_parser cmark_parser;
 88 typedef struct cmark_iter cmark_iter;
 89 
 90 /**
 91  * ## Custom memory allocator support
 92  */
 93 
 94 /** Defines the memory allocation functions to be used by CMark
 95  * when parsing and allocating a document tree
 96  */
 97 typedef struct cmark_mem {
 98   void *(*calloc)(size_t, size_t);
 99   void *(*realloc)(void *, size_t);
100   void (*free)(void *);
101 } cmark_mem;
102 
103 /** Returns a pointer to the default memory allocator.
104  */
105 CMARK_EXPORT cmark_mem *cmark_get_default_mem_allocator();
106 
107 /**
108  * ## Creating and Destroying Nodes
109  */
110 
111 /** Creates a new node of type 'type'.  Note that the node may have
112  * other required properties, which it is the caller's responsibility
113  * to assign.
114  */
115 CMARK_EXPORT cmark_node *cmark_node_new(cmark_node_type type);
116 
117 /** Same as `cmark_node_new`, but explicitly listing the memory
118  * allocator used to allocate the node.  Note:  be sure to use the same
119  * allocator for every node in a tree, or bad things can happen.
120  */
121 CMARK_EXPORT cmark_node *cmark_node_new_with_mem(cmark_node_type type,
122                                                  cmark_mem *mem);
123 
124 /** Frees the memory allocated for a node and any children.
125  */
126 CMARK_EXPORT void cmark_node_free(cmark_node *node);
127 
128 /**
129  * ## Tree Traversal
130  */
131 
132 /** Returns the next node in the sequence after 'node', or NULL if
133  * there is none.
134  */
135 CMARK_EXPORT cmark_node *cmark_node_next(cmark_node *node);
136 
137 /** Returns the previous node in the sequence after 'node', or NULL if
138  * there is none.
139  */
140 CMARK_EXPORT cmark_node *cmark_node_previous(cmark_node *node);
141 
142 /** Returns the parent of 'node', or NULL if there is none.
143  */
144 CMARK_EXPORT cmark_node *cmark_node_parent(cmark_node *node);
145 
146 /** Returns the first child of 'node', or NULL if 'node' has no children.
147  */
148 CMARK_EXPORT cmark_node *cmark_node_first_child(cmark_node *node);
149 
150 /** Returns the last child of 'node', or NULL if 'node' has no children.
151  */
152 CMARK_EXPORT cmark_node *cmark_node_last_child(cmark_node *node);
153 
154 /**
155  * ## Iterator
156  *
157  * An iterator will walk through a tree of nodes, starting from a root
158  * node, returning one node at a time, together with information about
159  * whether the node is being entered or exited.  The iterator will
160  * first descend to a child node, if there is one.  When there is no
161  * child, the iterator will go to the next sibling.  When there is no
162  * next sibling, the iterator will return to the parent (but with
163  * a 'cmark_event_type' of `CMARK_EVENT_EXIT`).  The iterator will
164  * return `CMARK_EVENT_DONE` when it reaches the root node again.
165  * One natural application is an HTML renderer, where an `ENTER` event
166  * outputs an open tag and an `EXIT` event outputs a close tag.
167  * An iterator might also be used to transform an AST in some systematic
168  * way, for example, turning all level-3 headings into regular paragraphs.
169  *
170  *     void
171  *     usage_example(cmark_node *root) {
172  *         cmark_event_type ev_type;
173  *         cmark_iter *iter = cmark_iter_new(root);
174  *
175  *         while ((ev_type = cmark_iter_next(iter)) != CMARK_EVENT_DONE) {
176  *             cmark_node *cur = cmark_iter_get_node(iter);
177  *             // Do something with `cur` and `ev_type`
178  *         }
179  *
180  *         cmark_iter_free(iter);
181  *     }
182  *
183  * Iterators will never return `EXIT` events for leaf nodes, which are nodes
184  * of type:
185  *
186  * * CMARK_NODE_HTML_BLOCK
187  * * CMARK_NODE_THEMATIC_BREAK
188  * * CMARK_NODE_CODE_BLOCK
189  * * CMARK_NODE_TEXT
190  * * CMARK_NODE_SOFTBREAK
191  * * CMARK_NODE_LINEBREAK
192  * * CMARK_NODE_CODE
193  * * CMARK_NODE_HTML_INLINE
194  *
195  * Nodes must only be modified after an `EXIT` event, or an `ENTER` event for
196  * leaf nodes.
197  */
198 
199 typedef enum {
200   CMARK_EVENT_NONE,
201   CMARK_EVENT_DONE,
202   CMARK_EVENT_ENTER,
203   CMARK_EVENT_EXIT
204 } cmark_event_type;
205 
206 /** Creates a new iterator starting at 'root'.  The current node and event
207  * type are undefined until 'cmark_iter_next' is called for the first time.
208  * The memory allocated for the iterator should be released using
209  * 'cmark_iter_free' when it is no longer needed.
210  */
211 CMARK_EXPORT
212 cmark_iter *cmark_iter_new(cmark_node *root);
213 
214 /** Frees the memory allocated for an iterator.
215  */
216 CMARK_EXPORT
217 void cmark_iter_free(cmark_iter *iter);
218 
219 /** Advances to the next node and returns the event type (`CMARK_EVENT_ENTER`,
220  * `CMARK_EVENT_EXIT` or `CMARK_EVENT_DONE`).
221  */
222 CMARK_EXPORT
223 cmark_event_type cmark_iter_next(cmark_iter *iter);
224 
225 /** Returns the current node.
226  */
227 CMARK_EXPORT
228 cmark_node *cmark_iter_get_node(cmark_iter *iter);
229 
230 /** Returns the current event type.
231  */
232 CMARK_EXPORT
233 cmark_event_type cmark_iter_get_event_type(cmark_iter *iter);
234 
235 /** Returns the root node.
236  */
237 CMARK_EXPORT
238 cmark_node *cmark_iter_get_root(cmark_iter *iter);
239 
240 /** Resets the iterator so that the current node is 'current' and
241  * the event type is 'event_type'.  The new current node must be a
242  * descendant of the root node or the root node itself.
243  */
244 CMARK_EXPORT
245 void cmark_iter_reset(cmark_iter *iter, cmark_node *current,
246                       cmark_event_type event_type);
247 
248 /**
249  * ## Accessors
250  */
251 
252 /** Returns the user data of 'node'.
253  */
254 CMARK_EXPORT void *cmark_node_get_user_data(cmark_node *node);
255 
256 /** Sets arbitrary user data for 'node'.  Returns 1 on success,
257  * 0 on failure.
258  */
259 CMARK_EXPORT int cmark_node_set_user_data(cmark_node *node, void *user_data);
260 
261 /** Returns the type of 'node', or `CMARK_NODE_NONE` on error.
262  */
263 CMARK_EXPORT cmark_node_type cmark_node_get_type(cmark_node *node);
264 
265 /** Like 'cmark_node_get_type', but returns a string representation
266     of the type, or `"<unknown>"`.
267  */
268 CMARK_EXPORT
269 const char *cmark_node_get_type_string(cmark_node *node);
270 
271 /** Returns the string contents of 'node', or an empty
272     string if none is set.  Returns NULL if called on a
273     node that does not have string content.
274  */
275 CMARK_EXPORT const char *cmark_node_get_literal(cmark_node *node);
276 
277 /** Sets the string contents of 'node'.  Returns 1 on success,
278  * 0 on failure.
279  */
280 CMARK_EXPORT int cmark_node_set_literal(cmark_node *node, const char *content);
281 
282 /** Returns the heading level of 'node', or 0 if 'node' is not a heading.
283  */
284 CMARK_EXPORT int cmark_node_get_heading_level(cmark_node *node);
285 
286 /* For backwards compatibility */
287 #define cmark_node_get_header_level cmark_node_get_heading_level
288 #define cmark_node_set_header_level cmark_node_set_heading_level
289 
290 /** Sets the heading level of 'node', returning 1 on success and 0 on error.
291  */
292 CMARK_EXPORT int cmark_node_set_heading_level(cmark_node *node, int level);
293 
294 /** Returns the list type of 'node', or `CMARK_NO_LIST` if 'node'
295  * is not a list.
296  */
297 CMARK_EXPORT cmark_list_type cmark_node_get_list_type(cmark_node *node);
298 
299 /** Sets the list type of 'node', returning 1 on success and 0 on error.
300  */
301 CMARK_EXPORT int cmark_node_set_list_type(cmark_node *node,
302                                           cmark_list_type type);
303 
304 /** Returns the list delimiter type of 'node', or `CMARK_NO_DELIM` if 'node'
305  * is not a list.
306  */
307 CMARK_EXPORT cmark_delim_type cmark_node_get_list_delim(cmark_node *node);
308 
309 /** Sets the list delimiter type of 'node', returning 1 on success and 0
310  * on error.
311  */
312 CMARK_EXPORT int cmark_node_set_list_delim(cmark_node *node,
313                                            cmark_delim_type delim);
314 
315 /** Returns starting number of 'node', if it is an ordered list, otherwise 0.
316  */
317 CMARK_EXPORT int cmark_node_get_list_start(cmark_node *node);
318 
319 /** Sets starting number of 'node', if it is an ordered list. Returns 1
320  * on success, 0 on failure.
321  */
322 CMARK_EXPORT int cmark_node_set_list_start(cmark_node *node, int start);
323 
324 /** Returns 1 if 'node' is a tight list, 0 otherwise.
325  */
326 CMARK_EXPORT int cmark_node_get_list_tight(cmark_node *node);
327 
328 /** Sets the "tightness" of a list.  Returns 1 on success, 0 on failure.
329  */
330 CMARK_EXPORT int cmark_node_set_list_tight(cmark_node *node, int tight);
331 
332 /** Returns the info string from a fenced code block.
333  */
334 CMARK_EXPORT const char *cmark_node_get_fence_info(cmark_node *node);
335 
336 /** Sets the info string in a fenced code block, returning 1 on
337  * success and 0 on failure.
338  */
339 CMARK_EXPORT int cmark_node_set_fence_info(cmark_node *node, const char *info);
340 
341 /** Returns the URL of a link or image 'node', or an empty string
342     if no URL is set.  Returns NULL if called on a node that is
343     not a link or image.
344  */
345 CMARK_EXPORT const char *cmark_node_get_url(cmark_node *node);
346 
347 /** Sets the URL of a link or image 'node'. Returns 1 on success,
348  * 0 on failure.
349  */
350 CMARK_EXPORT int cmark_node_set_url(cmark_node *node, const char *url);
351 
352 /** Returns the title of a link or image 'node', or an empty
353     string if no title is set.  Returns NULL if called on a node
354     that is not a link or image.
355  */
356 CMARK_EXPORT const char *cmark_node_get_title(cmark_node *node);
357 
358 /** Sets the title of a link or image 'node'. Returns 1 on success,
359  * 0 on failure.
360  */
361 CMARK_EXPORT int cmark_node_set_title(cmark_node *node, const char *title);
362 
363 /** Returns the literal "on enter" text for a custom 'node', or
364     an empty string if no on_enter is set.  Returns NULL if called
365     on a non-custom node.
366  */
367 CMARK_EXPORT const char *cmark_node_get_on_enter(cmark_node *node);
368 
369 /** Sets the literal text to render "on enter" for a custom 'node'.
370     Any children of the node will be rendered after this text.
371     Returns 1 on success 0 on failure.
372  */
373 CMARK_EXPORT int cmark_node_set_on_enter(cmark_node *node,
374                                          const char *on_enter);
375 
376 /** Returns the literal "on exit" text for a custom 'node', or
377     an empty string if no on_exit is set.  Returns NULL if
378     called on a non-custom node.
379  */
380 CMARK_EXPORT const char *cmark_node_get_on_exit(cmark_node *node);
381 
382 /** Sets the literal text to render "on exit" for a custom 'node'.
383     Any children of the node will be rendered before this text.
384     Returns 1 on success 0 on failure.
385  */
386 CMARK_EXPORT int cmark_node_set_on_exit(cmark_node *node, const char *on_exit);
387 
388 /** Returns the line on which 'node' begins.
389  */
390 CMARK_EXPORT int cmark_node_get_start_line(cmark_node *node);
391 
392 /** Returns the column at which 'node' begins.
393  */
394 CMARK_EXPORT int cmark_node_get_start_column(cmark_node *node);
395 
396 /** Returns the line on which 'node' ends.
397  */
398 CMARK_EXPORT int cmark_node_get_end_line(cmark_node *node);
399 
400 /** Returns the column at which 'node' ends.
401  */
402 CMARK_EXPORT int cmark_node_get_end_column(cmark_node *node);
403 
404 /**
405  * ## Tree Manipulation
406  */
407 
408 /** Unlinks a 'node', removing it from the tree, but not freeing its
409  * memory.  (Use 'cmark_node_free' for that.)
410  */
411 CMARK_EXPORT void cmark_node_unlink(cmark_node *node);
412 
413 /** Inserts 'sibling' before 'node'.  Returns 1 on success, 0 on failure.
414  */
415 CMARK_EXPORT int cmark_node_insert_before(cmark_node *node,
416                                           cmark_node *sibling);
417 
418 /** Inserts 'sibling' after 'node'. Returns 1 on success, 0 on failure.
419  */
420 CMARK_EXPORT int cmark_node_insert_after(cmark_node *node, cmark_node *sibling);
421 
422 /** Replaces 'oldnode' with 'newnode' and unlinks 'oldnode' (but does
423  * not free its memory).
424  * Returns 1 on success, 0 on failure.
425  */
426 CMARK_EXPORT int cmark_node_replace(cmark_node *oldnode, cmark_node *newnode);
427 
428 /** Adds 'child' to the beginning of the children of 'node'.
429  * Returns 1 on success, 0 on failure.
430  */
431 CMARK_EXPORT int cmark_node_prepend_child(cmark_node *node, cmark_node *child);
432 
433 /** Adds 'child' to the end of the children of 'node'.
434  * Returns 1 on success, 0 on failure.
435  */
436 CMARK_EXPORT int cmark_node_append_child(cmark_node *node, cmark_node *child);
437 
438 /** Consolidates adjacent text nodes.
439  */
440 CMARK_EXPORT void cmark_consolidate_text_nodes(cmark_node *root);
441 
442 /**
443  * ## Parsing
444  *
445  * Simple interface:
446  *
447  *     cmark_node *document = cmark_parse_document("Hello *world*", 13,
448  *                                                 CMARK_OPT_DEFAULT);
449  *
450  * Streaming interface:
451  *
452  *     cmark_parser *parser = cmark_parser_new(CMARK_OPT_DEFAULT);
453  *     FILE *fp = fopen("myfile.md", "rb");
454  *     while ((bytes = fread(buffer, 1, sizeof(buffer), fp)) > 0) {
455  *     	   cmark_parser_feed(parser, buffer, bytes);
456  *     	   if (bytes < sizeof(buffer)) {
457  *     	       break;
458  *     	   }
459  *     }
460  *     document = cmark_parser_finish(parser);
461  *     cmark_parser_free(parser);
462  */
463 
464 /** Creates a new parser object.
465  */
466 CMARK_EXPORT
467 cmark_parser *cmark_parser_new(int options);
468 
469 /** Creates a new parser object with the given memory allocator
470  */
471 CMARK_EXPORT
472 cmark_parser *cmark_parser_new_with_mem(int options, cmark_mem *mem);
473 
474 /** Frees memory allocated for a parser object.
475  */
476 CMARK_EXPORT
477 void cmark_parser_free(cmark_parser *parser);
478 
479 /** Feeds a string of length 'len' to 'parser'.
480  */
481 CMARK_EXPORT
482 void cmark_parser_feed(cmark_parser *parser, const char *buffer, size_t len);
483 
484 /** Finish parsing and return a pointer to a tree of nodes.
485  */
486 CMARK_EXPORT
487 cmark_node *cmark_parser_finish(cmark_parser *parser);
488 
489 /** Parse a CommonMark document in 'buffer' of length 'len'.
490  * Returns a pointer to a tree of nodes.  The memory allocated for
491  * the node tree should be released using 'cmark_node_free'
492  * when it is no longer needed.
493  */
494 CMARK_EXPORT
495 cmark_node *cmark_parse_document(const char *buffer, size_t len, int options);
496 
497 /** Parse a CommonMark document in file 'f', returning a pointer to
498  * a tree of nodes.  The memory allocated for the node tree should be
499  * released using 'cmark_node_free' when it is no longer needed.
500  */
501 CMARK_EXPORT
502 cmark_node *cmark_parse_file(FILE *f, int options);
503 
504 /**
505  * ## Rendering
506  */
507 
508 /** Render a 'node' tree as XML.  It is the caller's responsibility
509  * to free the returned buffer.
510  */
511 CMARK_EXPORT
512 char *cmark_render_xml(cmark_node *root, int options);
513 
514 /** Render a 'node' tree as an HTML fragment.  It is up to the user
515  * to add an appropriate header and footer. It is the caller's
516  * responsibility to free the returned buffer.
517  */
518 CMARK_EXPORT
519 char *cmark_render_html(cmark_node *root, int options);
520 
521 /** Render a 'node' tree as a groff man page, without the header.
522  * It is the caller's responsibility to free the returned buffer.
523  */
524 CMARK_EXPORT
525 char *cmark_render_man(cmark_node *root, int options, int width);
526 
527 /** Render a 'node' tree as a commonmark document.
528  * It is the caller's responsibility to free the returned buffer.
529  */
530 CMARK_EXPORT
531 char *cmark_render_commonmark(cmark_node *root, int options, int width);
532 
533 /** Render a 'node' tree as a LaTeX document.
534  * It is the caller's responsibility to free the returned buffer.
535  */
536 CMARK_EXPORT
537 char *cmark_render_latex(cmark_node *root, int options, int width);
538 
539 /**
540  * ## Options
541  */
542 
543 /** Default options.
544  */
545 #define CMARK_OPT_DEFAULT 0
546 
547 /**
548  * ### Options affecting rendering
549  */
550 
551 /** Include a `data-sourcepos` attribute on all block elements.
552  */
553 #define CMARK_OPT_SOURCEPOS (1 << 1)
554 
555 /** Render `softbreak` elements as hard line breaks.
556  */
557 #define CMARK_OPT_HARDBREAKS (1 << 2)
558 
559 /** `CMARK_OPT_SAFE` is defined here for API compatibility,
560     but it no longer has any effect. "Safe" mode is now the default:
561     set `CMARK_OPT_UNSAFE` to disable it.
562  */
563 #define CMARK_OPT_SAFE (1 << 3)
564 
565 /** Render raw HTML and unsafe links (`javascript:`, `vbscript:`,
566  * `file:`, and `data:`, except for `image/png`, `image/gif`,
567  * `image/jpeg`, or `image/webp` mime types).  By default,
568  * raw HTML is replaced by a placeholder HTML comment. Unsafe
569  * links are replaced by empty strings.
570  */
571 #define CMARK_OPT_UNSAFE (1 << 17)
572 
573 /** Render `softbreak` elements as spaces.
574  */
575 #define CMARK_OPT_NOBREAKS (1 << 4)
576 
577 /**
578  * ### Options affecting parsing
579  */
580 
581 /** Legacy option (no effect).
582  */
583 #define CMARK_OPT_NORMALIZE (1 << 8)
584 
585 /** Validate UTF-8 in the input before parsing, replacing illegal
586  * sequences with the replacement character U+FFFD.
587  */
588 #define CMARK_OPT_VALIDATE_UTF8 (1 << 9)
589 
590 /** Convert straight quotes to curly, --- to em dashes, -- to en dashes.
591  */
592 #define CMARK_OPT_SMART (1 << 10)
593 
594 /**
595  * ## Version information
596  */
597 
598 /** The library version as integer for runtime checks. Also available as
599  * macro CMARK_VERSION for compile time checks.
600  *
601  * * Bits 16-23 contain the major version.
602  * * Bits 8-15 contain the minor version.
603  * * Bits 0-7 contain the patchlevel.
604  *
605  * In hexadecimal format, the number 0x010203 represents version 1.2.3.
606  */
607 CMARK_EXPORT
608 int cmark_version(void);
609 
610 /** The library version string for runtime checks. Also available as
611  * macro CMARK_VERSION_STRING for compile time checks.
612  */
613 CMARK_EXPORT
614 const char *cmark_version_string(void);
615 
616 /** # AUTHORS
617  *
618  * John MacFarlane, Vicent Marti,  Kārlis Gaņģis, Nick Wellnhofer.
619  */
620 
621 #ifndef CMARK_NO_SHORT_NAMES
622 #define NODE_DOCUMENT CMARK_NODE_DOCUMENT
623 #define NODE_BLOCK_QUOTE CMARK_NODE_BLOCK_QUOTE
624 #define NODE_LIST CMARK_NODE_LIST
625 #define NODE_ITEM CMARK_NODE_ITEM
626 #define NODE_CODE_BLOCK CMARK_NODE_CODE_BLOCK
627 #define NODE_HTML_BLOCK CMARK_NODE_HTML_BLOCK
628 #define NODE_CUSTOM_BLOCK CMARK_NODE_CUSTOM_BLOCK
629 #define NODE_PARAGRAPH CMARK_NODE_PARAGRAPH
630 #define NODE_HEADING CMARK_NODE_HEADING
631 #define NODE_HEADER CMARK_NODE_HEADER
632 #define NODE_THEMATIC_BREAK CMARK_NODE_THEMATIC_BREAK
633 #define NODE_HRULE CMARK_NODE_HRULE
634 #define NODE_TEXT CMARK_NODE_TEXT
635 #define NODE_SOFTBREAK CMARK_NODE_SOFTBREAK
636 #define NODE_LINEBREAK CMARK_NODE_LINEBREAK
637 #define NODE_CODE CMARK_NODE_CODE
638 #define NODE_HTML_INLINE CMARK_NODE_HTML_INLINE
639 #define NODE_CUSTOM_INLINE CMARK_NODE_CUSTOM_INLINE
640 #define NODE_EMPH CMARK_NODE_EMPH
641 #define NODE_STRONG CMARK_NODE_STRONG
642 #define NODE_LINK CMARK_NODE_LINK
643 #define NODE_IMAGE CMARK_NODE_IMAGE
644 #define BULLET_LIST CMARK_BULLET_LIST
645 #define ORDERED_LIST CMARK_ORDERED_LIST
646 #define PERIOD_DELIM CMARK_PERIOD_DELIM
647 #define PAREN_DELIM CMARK_PAREN_DELIM
648 #endif
649 
650 #ifdef __cplusplus
651 }
652 #endif
653 
654 #endif