commonmarker 0.23.10 → 2.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Cargo.lock +1156 -0
- data/Cargo.toml +7 -0
- data/README.md +237 -172
- data/ext/commonmarker/Cargo.toml +20 -0
- data/ext/commonmarker/extconf.rb +3 -6
- data/ext/commonmarker/src/lib.rs +103 -0
- data/ext/commonmarker/src/node.rs +1221 -0
- data/ext/commonmarker/src/options.rs +220 -0
- data/ext/commonmarker/src/plugins/syntax_highlighting.rs +166 -0
- data/ext/commonmarker/src/plugins.rs +6 -0
- data/ext/commonmarker/src/utils.rs +8 -0
- data/lib/commonmarker/config.rb +92 -40
- data/lib/commonmarker/constants.rb +7 -0
- data/lib/commonmarker/extension.rb +14 -0
- data/lib/commonmarker/node/ast.rb +8 -0
- data/lib/commonmarker/node/inspect.rb +14 -4
- data/lib/commonmarker/node.rb +29 -47
- data/lib/commonmarker/renderer.rb +1 -127
- data/lib/commonmarker/utils.rb +22 -0
- data/lib/commonmarker/version.rb +2 -2
- data/lib/commonmarker.rb +27 -25
- metadata +38 -191
- data/Rakefile +0 -109
- data/bin/commonmarker +0 -118
- data/commonmarker.gemspec +0 -38
- data/ext/commonmarker/arena.c +0 -104
- data/ext/commonmarker/autolink.c +0 -508
- data/ext/commonmarker/autolink.h +0 -8
- data/ext/commonmarker/blocks.c +0 -1622
- data/ext/commonmarker/buffer.c +0 -278
- data/ext/commonmarker/buffer.h +0 -116
- data/ext/commonmarker/case_fold_switch.inc +0 -4327
- data/ext/commonmarker/chunk.h +0 -135
- data/ext/commonmarker/cmark-gfm-core-extensions.h +0 -54
- data/ext/commonmarker/cmark-gfm-extension_api.h +0 -737
- data/ext/commonmarker/cmark-gfm-extensions_export.h +0 -42
- data/ext/commonmarker/cmark-gfm.h +0 -833
- data/ext/commonmarker/cmark-gfm_export.h +0 -42
- data/ext/commonmarker/cmark-gfm_version.h +0 -7
- data/ext/commonmarker/cmark.c +0 -55
- data/ext/commonmarker/cmark_ctype.c +0 -44
- data/ext/commonmarker/cmark_ctype.h +0 -33
- data/ext/commonmarker/commonmark.c +0 -514
- data/ext/commonmarker/commonmarker.c +0 -1308
- data/ext/commonmarker/commonmarker.h +0 -16
- data/ext/commonmarker/config.h +0 -76
- data/ext/commonmarker/core-extensions.c +0 -27
- data/ext/commonmarker/entities.inc +0 -2138
- data/ext/commonmarker/ext_scanners.c +0 -879
- data/ext/commonmarker/ext_scanners.h +0 -24
- data/ext/commonmarker/footnotes.c +0 -63
- data/ext/commonmarker/footnotes.h +0 -27
- data/ext/commonmarker/houdini.h +0 -57
- data/ext/commonmarker/houdini_href_e.c +0 -100
- data/ext/commonmarker/houdini_html_e.c +0 -66
- data/ext/commonmarker/houdini_html_u.c +0 -149
- data/ext/commonmarker/html.c +0 -502
- data/ext/commonmarker/html.h +0 -27
- data/ext/commonmarker/inlines.c +0 -1788
- data/ext/commonmarker/inlines.h +0 -29
- data/ext/commonmarker/iterator.c +0 -159
- data/ext/commonmarker/iterator.h +0 -26
- data/ext/commonmarker/latex.c +0 -468
- data/ext/commonmarker/linked_list.c +0 -37
- data/ext/commonmarker/man.c +0 -274
- data/ext/commonmarker/map.c +0 -129
- data/ext/commonmarker/map.h +0 -44
- data/ext/commonmarker/node.c +0 -1045
- data/ext/commonmarker/node.h +0 -167
- data/ext/commonmarker/parser.h +0 -59
- data/ext/commonmarker/plaintext.c +0 -218
- data/ext/commonmarker/plugin.c +0 -36
- data/ext/commonmarker/plugin.h +0 -34
- data/ext/commonmarker/references.c +0 -43
- data/ext/commonmarker/references.h +0 -26
- data/ext/commonmarker/registry.c +0 -63
- data/ext/commonmarker/registry.h +0 -24
- data/ext/commonmarker/render.c +0 -213
- data/ext/commonmarker/render.h +0 -62
- data/ext/commonmarker/scanners.c +0 -14056
- data/ext/commonmarker/scanners.h +0 -70
- data/ext/commonmarker/scanners.re +0 -341
- data/ext/commonmarker/strikethrough.c +0 -167
- data/ext/commonmarker/strikethrough.h +0 -9
- data/ext/commonmarker/syntax_extension.c +0 -149
- data/ext/commonmarker/syntax_extension.h +0 -34
- data/ext/commonmarker/table.c +0 -917
- data/ext/commonmarker/table.h +0 -12
- data/ext/commonmarker/tagfilter.c +0 -60
- data/ext/commonmarker/tagfilter.h +0 -8
- data/ext/commonmarker/tasklist.c +0 -156
- data/ext/commonmarker/tasklist.h +0 -8
- data/ext/commonmarker/utf8.c +0 -317
- data/ext/commonmarker/utf8.h +0 -35
- data/ext/commonmarker/xml.c +0 -182
- data/lib/commonmarker/renderer/html_renderer.rb +0 -256
data/ext/commonmarker/render.c
DELETED
@@ -1,213 +0,0 @@
|
|
1
|
-
#include <stdlib.h>
|
2
|
-
#include "buffer.h"
|
3
|
-
#include "chunk.h"
|
4
|
-
#include "cmark-gfm.h"
|
5
|
-
#include "utf8.h"
|
6
|
-
#include "render.h"
|
7
|
-
#include "node.h"
|
8
|
-
#include "syntax_extension.h"
|
9
|
-
|
10
|
-
static CMARK_INLINE void S_cr(cmark_renderer *renderer) {
|
11
|
-
if (renderer->need_cr < 1) {
|
12
|
-
renderer->need_cr = 1;
|
13
|
-
}
|
14
|
-
}
|
15
|
-
|
16
|
-
static CMARK_INLINE void S_blankline(cmark_renderer *renderer) {
|
17
|
-
if (renderer->need_cr < 2) {
|
18
|
-
renderer->need_cr = 2;
|
19
|
-
}
|
20
|
-
}
|
21
|
-
|
22
|
-
static void S_out(cmark_renderer *renderer, cmark_node *node,
|
23
|
-
const char *source, bool wrap,
|
24
|
-
cmark_escaping escape) {
|
25
|
-
int length = (int)strlen(source);
|
26
|
-
unsigned char nextc;
|
27
|
-
int32_t c;
|
28
|
-
int i = 0;
|
29
|
-
int last_nonspace;
|
30
|
-
int len;
|
31
|
-
cmark_chunk remainder = cmark_chunk_literal("");
|
32
|
-
int k = renderer->buffer->size - 1;
|
33
|
-
|
34
|
-
cmark_syntax_extension *ext = node->ancestor_extension;
|
35
|
-
if (ext && !ext->commonmark_escape_func)
|
36
|
-
ext = NULL;
|
37
|
-
|
38
|
-
wrap = wrap && !renderer->no_linebreaks;
|
39
|
-
|
40
|
-
if (renderer->in_tight_list_item && renderer->need_cr > 1) {
|
41
|
-
renderer->need_cr = 1;
|
42
|
-
}
|
43
|
-
while (renderer->need_cr) {
|
44
|
-
if (k < 0 || renderer->buffer->ptr[k] == '\n') {
|
45
|
-
k -= 1;
|
46
|
-
} else {
|
47
|
-
cmark_strbuf_putc(renderer->buffer, '\n');
|
48
|
-
if (renderer->need_cr > 1) {
|
49
|
-
cmark_strbuf_put(renderer->buffer, renderer->prefix->ptr,
|
50
|
-
renderer->prefix->size);
|
51
|
-
}
|
52
|
-
}
|
53
|
-
renderer->column = 0;
|
54
|
-
renderer->last_breakable = 0;
|
55
|
-
renderer->begin_line = true;
|
56
|
-
renderer->begin_content = true;
|
57
|
-
renderer->need_cr -= 1;
|
58
|
-
}
|
59
|
-
|
60
|
-
while (i < length) {
|
61
|
-
if (renderer->begin_line) {
|
62
|
-
cmark_strbuf_put(renderer->buffer, renderer->prefix->ptr,
|
63
|
-
renderer->prefix->size);
|
64
|
-
// note: this assumes prefix is ascii:
|
65
|
-
renderer->column = renderer->prefix->size;
|
66
|
-
}
|
67
|
-
|
68
|
-
len = cmark_utf8proc_iterate((const uint8_t *)source + i, length - i, &c);
|
69
|
-
if (len == -1) { // error condition
|
70
|
-
return; // return without rendering rest of string
|
71
|
-
}
|
72
|
-
|
73
|
-
if (ext && ext->commonmark_escape_func(ext, node, c))
|
74
|
-
cmark_strbuf_putc(renderer->buffer, '\\');
|
75
|
-
|
76
|
-
nextc = source[i + len];
|
77
|
-
if (c == 32 && wrap) {
|
78
|
-
if (!renderer->begin_line) {
|
79
|
-
last_nonspace = renderer->buffer->size;
|
80
|
-
cmark_strbuf_putc(renderer->buffer, ' ');
|
81
|
-
renderer->column += 1;
|
82
|
-
renderer->begin_line = false;
|
83
|
-
renderer->begin_content = false;
|
84
|
-
// skip following spaces
|
85
|
-
while (source[i + 1] == ' ') {
|
86
|
-
i++;
|
87
|
-
}
|
88
|
-
// We don't allow breaks that make a digit the first character
|
89
|
-
// because this causes problems with commonmark output.
|
90
|
-
if (!cmark_isdigit(source[i + 1])) {
|
91
|
-
renderer->last_breakable = last_nonspace;
|
92
|
-
}
|
93
|
-
}
|
94
|
-
|
95
|
-
} else if (escape == LITERAL) {
|
96
|
-
if (c == 10) {
|
97
|
-
cmark_strbuf_putc(renderer->buffer, '\n');
|
98
|
-
renderer->column = 0;
|
99
|
-
renderer->begin_line = true;
|
100
|
-
renderer->begin_content = true;
|
101
|
-
renderer->last_breakable = 0;
|
102
|
-
} else {
|
103
|
-
cmark_render_code_point(renderer, c);
|
104
|
-
renderer->begin_line = false;
|
105
|
-
// we don't set 'begin_content' to false til we've
|
106
|
-
// finished parsing a digit. Reason: in commonmark
|
107
|
-
// we need to escape a potential list marker after
|
108
|
-
// a digit:
|
109
|
-
renderer->begin_content =
|
110
|
-
renderer->begin_content && cmark_isdigit((char)c) == 1;
|
111
|
-
}
|
112
|
-
} else {
|
113
|
-
(renderer->outc)(renderer, node, escape, c, nextc);
|
114
|
-
renderer->begin_line = false;
|
115
|
-
renderer->begin_content =
|
116
|
-
renderer->begin_content && cmark_isdigit((char)c) == 1;
|
117
|
-
}
|
118
|
-
|
119
|
-
// If adding the character went beyond width, look for an
|
120
|
-
// earlier place where the line could be broken:
|
121
|
-
if (renderer->width > 0 && renderer->column > renderer->width &&
|
122
|
-
!renderer->begin_line && renderer->last_breakable > 0) {
|
123
|
-
|
124
|
-
// copy from last_breakable to remainder
|
125
|
-
cmark_chunk_set_cstr(renderer->mem, &remainder,
|
126
|
-
(char *)renderer->buffer->ptr +
|
127
|
-
renderer->last_breakable + 1);
|
128
|
-
// truncate at last_breakable
|
129
|
-
cmark_strbuf_truncate(renderer->buffer, renderer->last_breakable);
|
130
|
-
// add newline, prefix, and remainder
|
131
|
-
cmark_strbuf_putc(renderer->buffer, '\n');
|
132
|
-
cmark_strbuf_put(renderer->buffer, renderer->prefix->ptr,
|
133
|
-
renderer->prefix->size);
|
134
|
-
cmark_strbuf_put(renderer->buffer, remainder.data, remainder.len);
|
135
|
-
renderer->column = renderer->prefix->size + remainder.len;
|
136
|
-
cmark_chunk_free(renderer->mem, &remainder);
|
137
|
-
renderer->last_breakable = 0;
|
138
|
-
renderer->begin_line = false;
|
139
|
-
renderer->begin_content = false;
|
140
|
-
}
|
141
|
-
|
142
|
-
i += len;
|
143
|
-
}
|
144
|
-
}
|
145
|
-
|
146
|
-
// Assumes no newlines, assumes ascii content:
|
147
|
-
void cmark_render_ascii(cmark_renderer *renderer, const char *s) {
|
148
|
-
int origsize = renderer->buffer->size;
|
149
|
-
cmark_strbuf_puts(renderer->buffer, s);
|
150
|
-
renderer->column += renderer->buffer->size - origsize;
|
151
|
-
}
|
152
|
-
|
153
|
-
void cmark_render_code_point(cmark_renderer *renderer, uint32_t c) {
|
154
|
-
cmark_utf8proc_encode_char(c, renderer->buffer);
|
155
|
-
renderer->column += 1;
|
156
|
-
}
|
157
|
-
|
158
|
-
char *cmark_render(cmark_mem *mem, cmark_node *root, int options, int width,
|
159
|
-
void (*outc)(cmark_renderer *, cmark_node *,
|
160
|
-
cmark_escaping, int32_t,
|
161
|
-
unsigned char),
|
162
|
-
int (*render_node)(cmark_renderer *renderer,
|
163
|
-
cmark_node *node,
|
164
|
-
cmark_event_type ev_type, int options)) {
|
165
|
-
cmark_strbuf pref = CMARK_BUF_INIT(mem);
|
166
|
-
cmark_strbuf buf = CMARK_BUF_INIT(mem);
|
167
|
-
cmark_node *cur;
|
168
|
-
cmark_event_type ev_type;
|
169
|
-
char *result;
|
170
|
-
cmark_iter *iter = cmark_iter_new(root);
|
171
|
-
|
172
|
-
cmark_renderer renderer = {mem, &buf, &pref, 0, width,
|
173
|
-
0, 0, true, true, false,
|
174
|
-
false, outc, S_cr, S_blankline, S_out,
|
175
|
-
0};
|
176
|
-
|
177
|
-
while ((ev_type = cmark_iter_next(iter)) != CMARK_EVENT_DONE) {
|
178
|
-
cur = cmark_iter_get_node(iter);
|
179
|
-
if (cur->extension) {
|
180
|
-
cur->ancestor_extension = cur->extension;
|
181
|
-
} else if (cur->parent) {
|
182
|
-
cur->ancestor_extension = cur->parent->ancestor_extension;
|
183
|
-
}
|
184
|
-
if (cur->type == CMARK_NODE_ITEM) {
|
185
|
-
// Calculate the list item's index, for the benefit of output formats
|
186
|
-
// like commonmark and plaintext.
|
187
|
-
if (cur->prev) {
|
188
|
-
cmark_node_set_item_index(cur, 1 + cmark_node_get_item_index(cur->prev));
|
189
|
-
} else {
|
190
|
-
cmark_node_set_item_index(cur, cmark_node_get_list_start(cur->parent));
|
191
|
-
}
|
192
|
-
}
|
193
|
-
if (!render_node(&renderer, cur, ev_type, options)) {
|
194
|
-
// a false value causes us to skip processing
|
195
|
-
// the node's contents. this is used for
|
196
|
-
// autolinks.
|
197
|
-
cmark_iter_reset(iter, cur, CMARK_EVENT_EXIT);
|
198
|
-
}
|
199
|
-
}
|
200
|
-
|
201
|
-
// ensure final newline
|
202
|
-
if (renderer.buffer->size == 0 || renderer.buffer->ptr[renderer.buffer->size - 1] != '\n') {
|
203
|
-
cmark_strbuf_putc(renderer.buffer, '\n');
|
204
|
-
}
|
205
|
-
|
206
|
-
result = (char *)cmark_strbuf_detach(renderer.buffer);
|
207
|
-
|
208
|
-
cmark_iter_free(iter);
|
209
|
-
cmark_strbuf_free(renderer.prefix);
|
210
|
-
cmark_strbuf_free(renderer.buffer);
|
211
|
-
|
212
|
-
return result;
|
213
|
-
}
|
data/ext/commonmarker/render.h
DELETED
@@ -1,62 +0,0 @@
|
|
1
|
-
#ifndef CMARK_RENDER_H
|
2
|
-
#define CMARK_RENDER_H
|
3
|
-
|
4
|
-
#ifdef __cplusplus
|
5
|
-
extern "C" {
|
6
|
-
#endif
|
7
|
-
|
8
|
-
#include <stdlib.h>
|
9
|
-
#include "buffer.h"
|
10
|
-
#include "chunk.h"
|
11
|
-
|
12
|
-
typedef enum { LITERAL, NORMAL, TITLE, URL } cmark_escaping;
|
13
|
-
|
14
|
-
struct cmark_renderer {
|
15
|
-
cmark_mem *mem;
|
16
|
-
cmark_strbuf *buffer;
|
17
|
-
cmark_strbuf *prefix;
|
18
|
-
int column;
|
19
|
-
int width;
|
20
|
-
int need_cr;
|
21
|
-
bufsize_t last_breakable;
|
22
|
-
bool begin_line;
|
23
|
-
bool begin_content;
|
24
|
-
bool no_linebreaks;
|
25
|
-
bool in_tight_list_item;
|
26
|
-
void (*outc)(struct cmark_renderer *, cmark_node *, cmark_escaping, int32_t, unsigned char);
|
27
|
-
void (*cr)(struct cmark_renderer *);
|
28
|
-
void (*blankline)(struct cmark_renderer *);
|
29
|
-
void (*out)(struct cmark_renderer *, cmark_node *, const char *, bool, cmark_escaping);
|
30
|
-
unsigned int footnote_ix;
|
31
|
-
};
|
32
|
-
|
33
|
-
typedef struct cmark_renderer cmark_renderer;
|
34
|
-
|
35
|
-
struct cmark_html_renderer {
|
36
|
-
cmark_strbuf *html;
|
37
|
-
cmark_node *plain;
|
38
|
-
cmark_llist *filter_extensions;
|
39
|
-
unsigned int footnote_ix;
|
40
|
-
unsigned int written_footnote_ix;
|
41
|
-
void *opaque;
|
42
|
-
};
|
43
|
-
|
44
|
-
typedef struct cmark_html_renderer cmark_html_renderer;
|
45
|
-
|
46
|
-
void cmark_render_ascii(cmark_renderer *renderer, const char *s);
|
47
|
-
|
48
|
-
void cmark_render_code_point(cmark_renderer *renderer, uint32_t c);
|
49
|
-
|
50
|
-
char *cmark_render(cmark_mem *mem, cmark_node *root, int options, int width,
|
51
|
-
void (*outc)(cmark_renderer *, cmark_node *,
|
52
|
-
cmark_escaping, int32_t,
|
53
|
-
unsigned char),
|
54
|
-
int (*render_node)(cmark_renderer *renderer,
|
55
|
-
cmark_node *node,
|
56
|
-
cmark_event_type ev_type, int options));
|
57
|
-
|
58
|
-
#ifdef __cplusplus
|
59
|
-
}
|
60
|
-
#endif
|
61
|
-
|
62
|
-
#endif
|