diff options
-rwxr-xr-x | wrapper.lua | 230 |
1 files changed, 145 insertions, 85 deletions
diff --git a/wrapper.lua b/wrapper.lua index d8cd320..d89ebc9 100755 --- a/wrapper.lua +++ b/wrapper.lua @@ -6,138 +6,198 @@ cmark = ffi.load("libcmark") ffi.cdef[[ -char *cmark_markdown_to_html(const char *text, int len); -typedef enum { - /* Block */ - CMARK_NODE_DOCUMENT, - CMARK_NODE_BLOCK_QUOTE, - CMARK_NODE_LIST, - CMARK_NODE_LIST_ITEM, - CMARK_NODE_CODE_BLOCK, - CMARK_NODE_HTML, - CMARK_NODE_PARAGRAPH, - CMARK_NODE_HEADER, - CMARK_NODE_HRULE, - CMARK_NODE_REFERENCE_DEF, + char *cmark_markdown_to_html(const char *text, int len); + typedef enum { + /* Block */ + CMARK_NODE_DOCUMENT, + CMARK_NODE_BLOCK_QUOTE, + CMARK_NODE_LIST, + CMARK_NODE_LIST_ITEM, + CMARK_NODE_CODE_BLOCK, + CMARK_NODE_HTML, + CMARK_NODE_PARAGRAPH, + CMARK_NODE_HEADER, + CMARK_NODE_HRULE, + CMARK_NODE_REFERENCE_DEF, - CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT, - CMARK_NODE_LAST_BLOCK = CMARK_NODE_REFERENCE_DEF, + CMARK_NODE_FIRST_BLOCK = CMARK_NODE_DOCUMENT, + CMARK_NODE_LAST_BLOCK = CMARK_NODE_REFERENCE_DEF, - /* Inline */ - CMARK_NODE_TEXT, - CMARK_NODE_SOFTBREAK, - CMARK_NODE_LINEBREAK, - CMARK_NODE_INLINE_CODE, - CMARK_NODE_INLINE_HTML, - CMARK_NODE_EMPH, - CMARK_NODE_STRONG, - CMARK_NODE_LINK, - CMARK_NODE_IMAGE, + /* Inline */ + CMARK_NODE_TEXT, + CMARK_NODE_SOFTBREAK, + CMARK_NODE_LINEBREAK, + CMARK_NODE_INLINE_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; + 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_LIST, + CMARK_BULLET_LIST, + CMARK_ORDERED_LIST + } cmark_list_type; -typedef enum { - CMARK_PERIOD_DELIM, - CMARK_PAREN_DELIM -} cmark_delim_type; + typedef enum { + CMARK_PERIOD_DELIM, + CMARK_PAREN_DELIM + } cmark_delim_type; -typedef struct cmark_node cmark_node; -typedef struct cmark_parser cmark_parser; + typedef struct cmark_node cmark_node; + typedef struct cmark_parser cmark_parser; -cmark_node* cmark_node_new(cmark_node_type type); + cmark_node* cmark_node_new(cmark_node_type type); -void -cmark_node_free(cmark_node *node); + void + cmark_node_free(cmark_node *node); -cmark_node* cmark_node_next(cmark_node *node); + cmark_node* cmark_node_next(cmark_node *node); -cmark_node* cmark_node_previous(cmark_node *node); + cmark_node* cmark_node_previous(cmark_node *node); -cmark_node* cmark_node_parent(cmark_node *node); + cmark_node* cmark_node_parent(cmark_node *node); -cmark_node* cmark_node_first_child(cmark_node *node); + cmark_node* cmark_node_first_child(cmark_node *node); -cmark_node* cmark_node_last_child(cmark_node *node); + cmark_node* cmark_node_last_child(cmark_node *node); -cmark_node_type cmark_node_get_type(cmark_node *node); + cmark_node_type cmark_node_get_type(cmark_node *node); -const char* cmark_node_get_string_content(cmark_node *node); + const char* cmark_node_get_string_content(cmark_node *node); -int cmark_node_set_string_content(cmark_node *node, const char *content); + int cmark_node_set_string_content(cmark_node *node, const char *content); -int cmark_node_get_header_level(cmark_node *node); + int cmark_node_get_header_level(cmark_node *node); -int cmark_node_set_header_level(cmark_node *node, int level); + int cmark_node_set_header_level(cmark_node *node, int level); -cmark_list_type cmark_node_get_list_type(cmark_node *node); + cmark_list_type cmark_node_get_list_type(cmark_node *node); -int cmark_node_set_list_type(cmark_node *node, cmark_list_type type); + int cmark_node_set_list_type(cmark_node *node, cmark_list_type type); -int cmark_node_get_list_start(cmark_node *node); + int cmark_node_get_list_start(cmark_node *node); -int cmark_node_set_list_start(cmark_node *node, int start); + int cmark_node_set_list_start(cmark_node *node, int start); -int cmark_node_get_list_tight(cmark_node *node); + int cmark_node_get_list_tight(cmark_node *node); -int cmark_node_set_list_tight(cmark_node *node, int tight); + int cmark_node_set_list_tight(cmark_node *node, int tight); -const char* cmark_node_get_fence_info(cmark_node *node); + const char* cmark_node_get_fence_info(cmark_node *node); -int cmark_node_set_fence_info(cmark_node *node, const char *info); + int cmark_node_set_fence_info(cmark_node *node, const char *info); -const char* cmark_node_get_url(cmark_node *node); + const char* cmark_node_get_url(cmark_node *node); -int cmark_node_set_url(cmark_node *node, const char *url); + int cmark_node_set_url(cmark_node *node, const char *url); -const char* cmark_node_get_title(cmark_node *node); + const char* cmark_node_get_title(cmark_node *node); -int cmark_node_set_title(cmark_node *node, const char *title); + int cmark_node_set_title(cmark_node *node, const char *title); -int cmark_node_get_start_line(cmark_node *node); + int cmark_node_get_start_line(cmark_node *node); -int cmark_node_get_start_column(cmark_node *node); + int cmark_node_get_start_column(cmark_node *node); -int cmark_node_get_end_line(cmark_node *node); + int cmark_node_get_end_line(cmark_node *node); -void cmark_node_unlink(cmark_node *node); + void cmark_node_unlink(cmark_node *node); -int cmark_node_insert_before(cmark_node *node, cmark_node *sibling); + int cmark_node_insert_before(cmark_node *node, cmark_node *sibling); -int cmark_node_insert_after(cmark_node *node, cmark_node *sibling); + int cmark_node_insert_after(cmark_node *node, cmark_node *sibling); -int cmark_node_prepend_child(cmark_node *node, cmark_node *child); + int cmark_node_prepend_child(cmark_node *node, cmark_node *child); -int cmark_node_append_child(cmark_node *node, cmark_node *child); + int cmark_node_append_child(cmark_node *node, cmark_node *child); -cmark_parser *cmark_parser_new(); + cmark_parser *cmark_parser_new(); -void cmark_parser_free(cmark_parser *parser); + void cmark_parser_free(cmark_parser *parser); -cmark_node *cmark_parser_finish(cmark_parser *parser); + cmark_node *cmark_parser_finish(cmark_parser *parser); -void cmark_parser_feed(cmark_parser *parser, const char *buffer, size_t len); + void cmark_parser_feed(cmark_parser *parser, const char *buffer, size_t len); -cmark_node *cmark_parse_document(const char *buffer, size_t len); + cmark_node *cmark_parse_document(const char *buffer, size_t len); -char *cmark_render_ast(cmark_node *root); + char *cmark_render_ast(cmark_node *root); -char *cmark_render_html(cmark_node *root); + char *cmark_render_html(cmark_node *root); -]] + ]] local doc = cmark.cmark_parse_document("hi *there*", 10) -local d2 = cmark.cmark_node_first_child(doc) -local d3 = cmark.cmark_node_first_child(d2) -local d4 = cmark.cmark_node_next(d3) -cmark.cmark_node_unlink(d4) + +local cur = doc +local next +local child + +local walk = function(action) + level = 0 + while cur ~= nil do + action(cur, level) + child = cmark.cmark_node_first_child(cur) + if child == nil then + next = cmark.cmark_node_next(cur) + while next == nil do + cur = cmark.cmark_node_parent(cur) + level = level - 1 + if cur == nil then + break + else + next = cmark.cmark_node_next(cur) + end + end + cur = next + else + level = level + 1 + cur = child + end + end +end + +local type_table = { + 'BLOCK_QUOTE', + 'LIST', + 'LIST_ITEM', + 'CODE_BLOCK', + 'HTML', + 'PARAGRAPH', + 'HEADER', + 'HRULE', + 'REFERENCE_DEF', + 'TEXT', + 'SOFTBREAK', + 'LINEBREAK', + 'INLINE_CODE', + 'INLINE_HTML', + 'EMPH', + 'STRONG', + 'LINK', + 'IMAGE', +} +type_table[0] = 'DOCUMENT' + +local function print_type(node, level) + local t = tonumber(cmark.cmark_node_get_type(node)) + io.write(string.rep(' ', level) .. type_table[t]) + if t == cmark.CMARK_NODE_TEXT then + io.write(' ' .. ffi.string(cmark.cmark_node_get_string_content(node))) + end + io.write('\n') +end + +walk(print_type) + +local t1 = cmark.cmark_node_get_type(doc) +print(t1 == cmark.CMARK_NODE_DOCUMENT) + local html = ffi.string(cmark.cmark_render_html(doc)) print(html) - |