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.
Files changed (97) hide show
  1. checksums.yaml +4 -4
  2. data/Cargo.lock +1156 -0
  3. data/Cargo.toml +7 -0
  4. data/README.md +237 -172
  5. data/ext/commonmarker/Cargo.toml +20 -0
  6. data/ext/commonmarker/extconf.rb +3 -6
  7. data/ext/commonmarker/src/lib.rs +103 -0
  8. data/ext/commonmarker/src/node.rs +1221 -0
  9. data/ext/commonmarker/src/options.rs +220 -0
  10. data/ext/commonmarker/src/plugins/syntax_highlighting.rs +166 -0
  11. data/ext/commonmarker/src/plugins.rs +6 -0
  12. data/ext/commonmarker/src/utils.rs +8 -0
  13. data/lib/commonmarker/config.rb +92 -40
  14. data/lib/commonmarker/constants.rb +7 -0
  15. data/lib/commonmarker/extension.rb +14 -0
  16. data/lib/commonmarker/node/ast.rb +8 -0
  17. data/lib/commonmarker/node/inspect.rb +14 -4
  18. data/lib/commonmarker/node.rb +29 -47
  19. data/lib/commonmarker/renderer.rb +1 -127
  20. data/lib/commonmarker/utils.rb +22 -0
  21. data/lib/commonmarker/version.rb +2 -2
  22. data/lib/commonmarker.rb +27 -25
  23. metadata +38 -191
  24. data/Rakefile +0 -109
  25. data/bin/commonmarker +0 -118
  26. data/commonmarker.gemspec +0 -38
  27. data/ext/commonmarker/arena.c +0 -104
  28. data/ext/commonmarker/autolink.c +0 -508
  29. data/ext/commonmarker/autolink.h +0 -8
  30. data/ext/commonmarker/blocks.c +0 -1622
  31. data/ext/commonmarker/buffer.c +0 -278
  32. data/ext/commonmarker/buffer.h +0 -116
  33. data/ext/commonmarker/case_fold_switch.inc +0 -4327
  34. data/ext/commonmarker/chunk.h +0 -135
  35. data/ext/commonmarker/cmark-gfm-core-extensions.h +0 -54
  36. data/ext/commonmarker/cmark-gfm-extension_api.h +0 -737
  37. data/ext/commonmarker/cmark-gfm-extensions_export.h +0 -42
  38. data/ext/commonmarker/cmark-gfm.h +0 -833
  39. data/ext/commonmarker/cmark-gfm_export.h +0 -42
  40. data/ext/commonmarker/cmark-gfm_version.h +0 -7
  41. data/ext/commonmarker/cmark.c +0 -55
  42. data/ext/commonmarker/cmark_ctype.c +0 -44
  43. data/ext/commonmarker/cmark_ctype.h +0 -33
  44. data/ext/commonmarker/commonmark.c +0 -514
  45. data/ext/commonmarker/commonmarker.c +0 -1308
  46. data/ext/commonmarker/commonmarker.h +0 -16
  47. data/ext/commonmarker/config.h +0 -76
  48. data/ext/commonmarker/core-extensions.c +0 -27
  49. data/ext/commonmarker/entities.inc +0 -2138
  50. data/ext/commonmarker/ext_scanners.c +0 -879
  51. data/ext/commonmarker/ext_scanners.h +0 -24
  52. data/ext/commonmarker/footnotes.c +0 -63
  53. data/ext/commonmarker/footnotes.h +0 -27
  54. data/ext/commonmarker/houdini.h +0 -57
  55. data/ext/commonmarker/houdini_href_e.c +0 -100
  56. data/ext/commonmarker/houdini_html_e.c +0 -66
  57. data/ext/commonmarker/houdini_html_u.c +0 -149
  58. data/ext/commonmarker/html.c +0 -502
  59. data/ext/commonmarker/html.h +0 -27
  60. data/ext/commonmarker/inlines.c +0 -1788
  61. data/ext/commonmarker/inlines.h +0 -29
  62. data/ext/commonmarker/iterator.c +0 -159
  63. data/ext/commonmarker/iterator.h +0 -26
  64. data/ext/commonmarker/latex.c +0 -468
  65. data/ext/commonmarker/linked_list.c +0 -37
  66. data/ext/commonmarker/man.c +0 -274
  67. data/ext/commonmarker/map.c +0 -129
  68. data/ext/commonmarker/map.h +0 -44
  69. data/ext/commonmarker/node.c +0 -1045
  70. data/ext/commonmarker/node.h +0 -167
  71. data/ext/commonmarker/parser.h +0 -59
  72. data/ext/commonmarker/plaintext.c +0 -218
  73. data/ext/commonmarker/plugin.c +0 -36
  74. data/ext/commonmarker/plugin.h +0 -34
  75. data/ext/commonmarker/references.c +0 -43
  76. data/ext/commonmarker/references.h +0 -26
  77. data/ext/commonmarker/registry.c +0 -63
  78. data/ext/commonmarker/registry.h +0 -24
  79. data/ext/commonmarker/render.c +0 -213
  80. data/ext/commonmarker/render.h +0 -62
  81. data/ext/commonmarker/scanners.c +0 -14056
  82. data/ext/commonmarker/scanners.h +0 -70
  83. data/ext/commonmarker/scanners.re +0 -341
  84. data/ext/commonmarker/strikethrough.c +0 -167
  85. data/ext/commonmarker/strikethrough.h +0 -9
  86. data/ext/commonmarker/syntax_extension.c +0 -149
  87. data/ext/commonmarker/syntax_extension.h +0 -34
  88. data/ext/commonmarker/table.c +0 -917
  89. data/ext/commonmarker/table.h +0 -12
  90. data/ext/commonmarker/tagfilter.c +0 -60
  91. data/ext/commonmarker/tagfilter.h +0 -8
  92. data/ext/commonmarker/tasklist.c +0 -156
  93. data/ext/commonmarker/tasklist.h +0 -8
  94. data/ext/commonmarker/utf8.c +0 -317
  95. data/ext/commonmarker/utf8.h +0 -35
  96. data/ext/commonmarker/xml.c +0 -182
  97. data/lib/commonmarker/renderer/html_renderer.rb +0 -256
@@ -1,1308 +0,0 @@
1
- #include "commonmarker.h"
2
- #include "cmark-gfm.h"
3
- #include "houdini.h"
4
- #include "node.h"
5
- #include "registry.h"
6
- #include "parser.h"
7
- #include "syntax_extension.h"
8
- #include "cmark-gfm-core-extensions.h"
9
-
10
- static VALUE rb_eNodeError;
11
- static VALUE rb_cNode;
12
-
13
- static VALUE sym_document;
14
- static VALUE sym_blockquote;
15
- static VALUE sym_list;
16
- static VALUE sym_list_item;
17
- static VALUE sym_code_block;
18
- static VALUE sym_html;
19
- static VALUE sym_paragraph;
20
- static VALUE sym_header;
21
- static VALUE sym_hrule;
22
- static VALUE sym_text;
23
- static VALUE sym_softbreak;
24
- static VALUE sym_linebreak;
25
- static VALUE sym_code;
26
- static VALUE sym_inline_html;
27
- static VALUE sym_emph;
28
- static VALUE sym_strong;
29
- static VALUE sym_link;
30
- static VALUE sym_image;
31
- static VALUE sym_footnote_reference;
32
- static VALUE sym_footnote_definition;
33
-
34
- static VALUE sym_bullet_list;
35
- static VALUE sym_ordered_list;
36
-
37
- static VALUE sym_left;
38
- static VALUE sym_right;
39
- static VALUE sym_center;
40
-
41
- static VALUE encode_utf8_string(const char *c_string) {
42
- VALUE string = rb_str_new2(c_string);
43
- int enc = rb_enc_find_index("UTF-8");
44
- rb_enc_associate_index(string, enc);
45
- return string;
46
- }
47
-
48
- /* Encode a C string using the encoding from Ruby string +source+. */
49
- static VALUE encode_source_string(const char *c_string, VALUE source) {
50
- VALUE string = rb_str_new2(c_string);
51
- rb_enc_copy(string, source);
52
- return string;
53
- }
54
-
55
- static void rb_mark_c_struct(void *data) {
56
- cmark_node *node = data;
57
- cmark_node *child;
58
-
59
- /* Mark the parent to make sure that the tree won't be freed as
60
- long as a child node is referenced. */
61
- cmark_node *parent = cmark_node_parent(node);
62
- if (parent) {
63
- void *user_data = cmark_node_get_user_data(parent);
64
- if (!user_data) {
65
- /* This should never happen. Child can nodes can only
66
- be returned from parents that already are
67
- associated with a Ruby object. */
68
- fprintf(stderr, "parent without user_data\n");
69
- abort();
70
- }
71
- rb_gc_mark((VALUE)user_data);
72
- }
73
-
74
- /* Mark all children to make sure their cached Ruby objects won't
75
- be freed. */
76
- for (child = cmark_node_first_child(node); child != NULL;
77
- child = cmark_node_next(child)) {
78
- void *user_data = cmark_node_get_user_data(child);
79
- if (user_data)
80
- rb_gc_mark((VALUE)user_data);
81
- }
82
- }
83
-
84
- static void rb_free_c_struct(void *data) {
85
- /* It's important that the `free` function does not inspect the
86
- node data, as it may be part of a tree that was already freed. */
87
- cmark_node_free(data);
88
- }
89
-
90
- static VALUE rb_node_to_value(cmark_node *node) {
91
- void *user_data;
92
- RUBY_DATA_FUNC free_func;
93
- VALUE val;
94
-
95
- if (node == NULL)
96
- return Qnil;
97
-
98
- user_data = cmark_node_get_user_data(node);
99
- if (user_data)
100
- return (VALUE)user_data;
101
-
102
- /* Only free tree roots. */
103
- free_func = cmark_node_parent(node) ? NULL : rb_free_c_struct;
104
- val = Data_Wrap_Struct(rb_cNode, rb_mark_c_struct, free_func, node);
105
- cmark_node_set_user_data(node, (void *)val);
106
-
107
- return val;
108
- }
109
-
110
- /* If the node structure is changed, the finalizers must be updated. */
111
-
112
- static void rb_parent_added(VALUE val) { RDATA(val)->dfree = NULL; }
113
-
114
- static void rb_parent_removed(VALUE val) {
115
- RDATA(val)->dfree = rb_free_c_struct;
116
- }
117
-
118
- static cmark_parser *prepare_parser(VALUE rb_options, VALUE rb_extensions) {
119
- int options;
120
- VALUE rb_ext_name;
121
- int i;
122
-
123
- FIXNUM_P(rb_options);
124
- options = FIX2INT(rb_options);
125
-
126
- Check_Type(rb_extensions, T_ARRAY);
127
-
128
- cmark_parser *parser = cmark_parser_new(options);
129
-
130
- for (i = 0; i < RARRAY_LEN(rb_extensions); ++i) {
131
- rb_ext_name = rb_ary_entry(rb_extensions, i);
132
-
133
- if (!SYMBOL_P(rb_ext_name)) {
134
- cmark_parser_free(parser);
135
- rb_raise(rb_eTypeError, "extension names should be Symbols; got a %"PRIsVALUE"", rb_obj_class(rb_ext_name));
136
- }
137
-
138
- cmark_syntax_extension *syntax_extension =
139
- cmark_find_syntax_extension(rb_id2name(SYM2ID(rb_ext_name)));
140
-
141
- if (!syntax_extension) {
142
- cmark_parser_free(parser);
143
- rb_raise(rb_eArgError, "extension %s not found", rb_id2name(SYM2ID(rb_ext_name)));
144
- }
145
-
146
- cmark_parser_attach_syntax_extension(parser, syntax_extension);
147
- }
148
-
149
- return parser;
150
- }
151
-
152
- /*
153
- * Internal: Parses a Markdown string into an HTML string.
154
- *
155
- */
156
- static VALUE rb_markdown_to_html(VALUE self, VALUE rb_text, VALUE rb_options, VALUE rb_extensions) {
157
- char *html;
158
- cmark_parser *parser;
159
- cmark_node *doc;
160
-
161
- Check_Type(rb_text, T_STRING);
162
-
163
- parser = prepare_parser(rb_options, rb_extensions);
164
-
165
- cmark_parser_feed(parser, StringValuePtr(rb_text), RSTRING_LEN(rb_text));
166
- doc = cmark_parser_finish(parser);
167
-
168
- if (doc == NULL) {
169
- cmark_parser_free(parser);
170
- rb_raise(rb_eNodeError, "error parsing document");
171
- }
172
-
173
- html = cmark_render_html(doc, parser->options, parser->syntax_extensions);
174
-
175
- cmark_parser_free(parser);
176
- cmark_node_free(doc);
177
-
178
- return rb_utf8_str_new_cstr(html);
179
- }
180
-
181
- /*
182
- * Internal: Parses a Markdown string into an HTML string.
183
- *
184
- */
185
- static VALUE rb_markdown_to_xml(VALUE self, VALUE rb_text, VALUE rb_options, VALUE rb_extensions) {
186
- char *xml;
187
- cmark_parser *parser;
188
- cmark_node *doc;
189
-
190
- Check_Type(rb_text, T_STRING);
191
-
192
- parser = prepare_parser(rb_options, rb_extensions);
193
-
194
- cmark_parser_feed(parser, StringValuePtr(rb_text), RSTRING_LEN(rb_text));
195
- doc = cmark_parser_finish(parser);
196
-
197
- if (doc == NULL) {
198
- cmark_parser_free(parser);
199
- rb_raise(rb_eNodeError, "error parsing document");
200
- }
201
-
202
- xml = cmark_render_xml(doc, parser->options);
203
-
204
- cmark_parser_free(parser);
205
- cmark_node_free(doc);
206
-
207
- return rb_utf8_str_new_cstr(xml);
208
- }
209
-
210
- /*
211
- * Internal: Creates a node based on a node type.
212
- *
213
- * type - A {Symbol} representing the node to be created. Must be one of the
214
- * following:
215
- * - `:document`
216
- * - `:blockquote`
217
- * - `:list`
218
- * - `:list_item`
219
- * - `:code_block`
220
- * - `:html`
221
- * - `:paragraph`
222
- * - `:header`
223
- * - `:hrule`
224
- * - `:text`
225
- * - `:softbreak`
226
- * - `:linebreak`
227
- * - `:code`
228
- * - `:inline_html`
229
- * - `:emph`
230
- * - `:strong`
231
- * - `:link`
232
- * - `:image`
233
- */
234
- static VALUE rb_node_new(VALUE self, VALUE type) {
235
- cmark_node_type node_type = 0;
236
- cmark_node *node;
237
-
238
- Check_Type(type, T_SYMBOL);
239
-
240
- if (type == sym_document)
241
- node_type = CMARK_NODE_DOCUMENT;
242
- else if (type == sym_blockquote)
243
- node_type = CMARK_NODE_BLOCK_QUOTE;
244
- else if (type == sym_list)
245
- node_type = CMARK_NODE_LIST;
246
- else if (type == sym_list_item)
247
- node_type = CMARK_NODE_ITEM;
248
- else if (type == sym_code_block)
249
- node_type = CMARK_NODE_CODE_BLOCK;
250
- else if (type == sym_html)
251
- node_type = CMARK_NODE_HTML;
252
- else if (type == sym_paragraph)
253
- node_type = CMARK_NODE_PARAGRAPH;
254
- else if (type == sym_header)
255
- node_type = CMARK_NODE_HEADER;
256
- else if (type == sym_hrule)
257
- node_type = CMARK_NODE_HRULE;
258
- else if (type == sym_text)
259
- node_type = CMARK_NODE_TEXT;
260
- else if (type == sym_softbreak)
261
- node_type = CMARK_NODE_SOFTBREAK;
262
- else if (type == sym_linebreak)
263
- node_type = CMARK_NODE_LINEBREAK;
264
- else if (type == sym_code)
265
- node_type = CMARK_NODE_CODE;
266
- else if (type == sym_inline_html)
267
- node_type = CMARK_NODE_INLINE_HTML;
268
- else if (type == sym_emph)
269
- node_type = CMARK_NODE_EMPH;
270
- else if (type == sym_strong)
271
- node_type = CMARK_NODE_STRONG;
272
- else if (type == sym_link)
273
- node_type = CMARK_NODE_LINK;
274
- else if (type == sym_image)
275
- node_type = CMARK_NODE_IMAGE;
276
- else if (type == sym_footnote_reference)
277
- node_type = CMARK_NODE_FOOTNOTE_REFERENCE;
278
- else if (type == sym_footnote_definition)
279
- node_type = CMARK_NODE_FOOTNOTE_DEFINITION;
280
- else
281
- rb_raise(rb_eNodeError, "invalid node of type %d", node_type);
282
-
283
- node = cmark_node_new(node_type);
284
- if (node == NULL) {
285
- rb_raise(rb_eNodeError, "could not create node of type %d", node_type);
286
- }
287
-
288
- return rb_node_to_value(node);
289
- }
290
-
291
- /*
292
- * Internal: Parses a Markdown string into a document.
293
- *
294
- */
295
- static VALUE rb_parse_document(VALUE self, VALUE rb_text, VALUE rb_len,
296
- VALUE rb_options, VALUE rb_extensions) {
297
- char *text;
298
- int len;
299
- cmark_parser *parser;
300
- cmark_node *doc;
301
- Check_Type(rb_text, T_STRING);
302
- Check_Type(rb_len, T_FIXNUM);
303
- Check_Type(rb_options, T_FIXNUM);
304
-
305
- parser = prepare_parser(rb_options, rb_extensions);
306
-
307
- text = (char *)RSTRING_PTR(rb_text);
308
- len = FIX2INT(rb_len);
309
-
310
- cmark_parser_feed(parser, text, len);
311
- doc = cmark_parser_finish(parser);
312
- if (doc == NULL) {
313
- rb_raise(rb_eNodeError, "error parsing document");
314
- }
315
- cmark_parser_free(parser);
316
-
317
- return rb_node_to_value(doc);
318
- }
319
-
320
- /*
321
- * Public: Fetch the string contents of the node.
322
- *
323
- * Returns a {String}.
324
- */
325
- static VALUE rb_node_get_string_content(VALUE self) {
326
- const char *text;
327
- cmark_node *node;
328
- Data_Get_Struct(self, cmark_node, node);
329
-
330
- text = cmark_node_get_literal(node);
331
- if (text == NULL) {
332
- rb_raise(rb_eNodeError, "could not get string content");
333
- }
334
-
335
- return encode_utf8_string(text);
336
- }
337
-
338
- /*
339
- * Public: Sets the string content of the node.
340
- *
341
- * string - A {String} containing new content.
342
- *
343
- * Raises NodeError if the string content can't be set.
344
- */
345
- static VALUE rb_node_set_string_content(VALUE self, VALUE s) {
346
- char *text;
347
- cmark_node *node;
348
- Check_Type(s, T_STRING);
349
-
350
- Data_Get_Struct(self, cmark_node, node);
351
- text = StringValueCStr(s);
352
-
353
- if (!cmark_node_set_literal(node, text)) {
354
- rb_raise(rb_eNodeError, "could not set string content");
355
- }
356
-
357
- return Qnil;
358
- }
359
-
360
- /*
361
- * Public: Fetches the list type of the node.
362
- *
363
- * Returns a {Symbol} representing the node's type.
364
- */
365
- static VALUE rb_node_get_type(VALUE self) {
366
- int node_type;
367
- cmark_node *node;
368
- VALUE symbol;
369
- const char *s;
370
-
371
- Data_Get_Struct(self, cmark_node, node);
372
-
373
- node_type = cmark_node_get_type(node);
374
- symbol = Qnil;
375
-
376
- switch (node_type) {
377
- case CMARK_NODE_DOCUMENT:
378
- symbol = sym_document;
379
- break;
380
- case CMARK_NODE_BLOCK_QUOTE:
381
- symbol = sym_blockquote;
382
- break;
383
- case CMARK_NODE_LIST:
384
- symbol = sym_list;
385
- break;
386
- case CMARK_NODE_ITEM:
387
- symbol = sym_list_item;
388
- break;
389
- case CMARK_NODE_CODE_BLOCK:
390
- symbol = sym_code_block;
391
- break;
392
- case CMARK_NODE_HTML:
393
- symbol = sym_html;
394
- break;
395
- case CMARK_NODE_PARAGRAPH:
396
- symbol = sym_paragraph;
397
- break;
398
- case CMARK_NODE_HEADER:
399
- symbol = sym_header;
400
- break;
401
- case CMARK_NODE_HRULE:
402
- symbol = sym_hrule;
403
- break;
404
- case CMARK_NODE_TEXT:
405
- symbol = sym_text;
406
- break;
407
- case CMARK_NODE_SOFTBREAK:
408
- symbol = sym_softbreak;
409
- break;
410
- case CMARK_NODE_LINEBREAK:
411
- symbol = sym_linebreak;
412
- break;
413
- case CMARK_NODE_CODE:
414
- symbol = sym_code;
415
- break;
416
- case CMARK_NODE_INLINE_HTML:
417
- symbol = sym_inline_html;
418
- break;
419
- case CMARK_NODE_EMPH:
420
- symbol = sym_emph;
421
- break;
422
- case CMARK_NODE_STRONG:
423
- symbol = sym_strong;
424
- break;
425
- case CMARK_NODE_LINK:
426
- symbol = sym_link;
427
- break;
428
- case CMARK_NODE_IMAGE:
429
- symbol = sym_image;
430
- break;
431
- case CMARK_NODE_FOOTNOTE_REFERENCE:
432
- symbol = sym_footnote_reference;
433
- break;
434
- case CMARK_NODE_FOOTNOTE_DEFINITION:
435
- symbol = sym_footnote_definition;
436
- break;
437
- default:
438
- if (node->extension) {
439
- s = node->extension->get_type_string_func(node->extension, node);
440
- return ID2SYM(rb_intern(s));
441
- }
442
- rb_raise(rb_eNodeError, "invalid node type %d", node_type);
443
- }
444
-
445
- return symbol;
446
- }
447
-
448
- /*
449
- * Public: Fetches the sourcepos of the node.
450
- *
451
- * Returns a {Hash} containing {Symbol} keys of the positions.
452
- */
453
- static VALUE rb_node_get_sourcepos(VALUE self) {
454
- int start_line, start_column, end_line, end_column;
455
- VALUE result;
456
-
457
- cmark_node *node;
458
- Data_Get_Struct(self, cmark_node, node);
459
-
460
- start_line = cmark_node_get_start_line(node);
461
- start_column = cmark_node_get_start_column(node);
462
- end_line = cmark_node_get_end_line(node);
463
- end_column = cmark_node_get_end_column(node);
464
-
465
- result = rb_hash_new();
466
- rb_hash_aset(result, CSTR2SYM("start_line"), INT2NUM(start_line));
467
- rb_hash_aset(result, CSTR2SYM("start_column"), INT2NUM(start_column));
468
- rb_hash_aset(result, CSTR2SYM("end_line"), INT2NUM(end_line));
469
- rb_hash_aset(result, CSTR2SYM("end_column"), INT2NUM(end_column));
470
-
471
- return result;
472
- }
473
-
474
- /*
475
- * Public: Returns the type of the current pointer as a string.
476
- *
477
- * Returns a {String}.
478
- */
479
- static VALUE rb_node_get_type_string(VALUE self) {
480
- cmark_node *node;
481
- Data_Get_Struct(self, cmark_node, node);
482
-
483
- return rb_str_new2(cmark_node_get_type_string(node));
484
- }
485
-
486
- /*
487
- * Internal: Unlinks the node from the tree (fixing pointers in
488
- * parents and siblings appropriately).
489
- */
490
- static VALUE rb_node_unlink(VALUE self) {
491
- cmark_node *node;
492
- Data_Get_Struct(self, cmark_node, node);
493
-
494
- cmark_node_unlink(node);
495
-
496
- rb_parent_removed(self);
497
-
498
- return Qnil;
499
- }
500
-
501
- /* Public: Fetches the first child of the node.
502
- *
503
- * Returns a {Node} if a child exists, `nil` otherise.
504
- */
505
- static VALUE rb_node_first_child(VALUE self) {
506
- cmark_node *node, *child;
507
- Data_Get_Struct(self, cmark_node, node);
508
-
509
- child = cmark_node_first_child(node);
510
-
511
- return rb_node_to_value(child);
512
- }
513
-
514
- /* Public: Fetches the next sibling of the node.
515
- *
516
- * Returns a {Node} if a sibling exists, `nil` otherwise.
517
- */
518
- static VALUE rb_node_next(VALUE self) {
519
- cmark_node *node, *next;
520
- Data_Get_Struct(self, cmark_node, node);
521
-
522
- next = cmark_node_next(node);
523
-
524
- return rb_node_to_value(next);
525
- }
526
-
527
- /*
528
- * Public: Inserts a node as a sibling before the current node.
529
- *
530
- * sibling - A sibling {Node} to insert.
531
- *
532
- * Returns `true` if successful.
533
- * Raises NodeError if the node can't be inserted.
534
- */
535
- static VALUE rb_node_insert_before(VALUE self, VALUE sibling) {
536
- cmark_node *node1, *node2;
537
- Data_Get_Struct(self, cmark_node, node1);
538
-
539
- Data_Get_Struct(sibling, cmark_node, node2);
540
-
541
- if (!cmark_node_insert_before(node1, node2)) {
542
- rb_raise(rb_eNodeError, "could not insert before");
543
- }
544
-
545
- rb_parent_added(sibling);
546
-
547
- return Qtrue;
548
- }
549
-
550
- /* Internal: Convert the node to an HTML string.
551
- *
552
- * Returns a {String}.
553
- */
554
- static VALUE rb_render_html(VALUE self, VALUE rb_options, VALUE rb_extensions) {
555
- int options, extensions_len;
556
- VALUE rb_ext_name;
557
- int i;
558
- cmark_node *node;
559
- cmark_llist *extensions = NULL;
560
- cmark_mem *mem = cmark_get_default_mem_allocator();
561
- Check_Type(rb_options, T_FIXNUM);
562
- Check_Type(rb_extensions, T_ARRAY);
563
-
564
- options = FIX2INT(rb_options);
565
- extensions_len = RARRAY_LEN(rb_extensions);
566
-
567
- Data_Get_Struct(self, cmark_node, node);
568
-
569
- for (i = 0; i < extensions_len; ++i) {
570
- rb_ext_name = RARRAY_PTR(rb_extensions)[i];
571
-
572
- if (!SYMBOL_P(rb_ext_name)) {
573
- cmark_llist_free(mem, extensions);
574
- rb_raise(rb_eTypeError, "extension names should be Symbols; got a %"PRIsVALUE"", rb_obj_class(rb_ext_name));
575
- }
576
-
577
- cmark_syntax_extension *syntax_extension =
578
- cmark_find_syntax_extension(rb_id2name(SYM2ID(rb_ext_name)));
579
-
580
- if (!syntax_extension) {
581
- cmark_llist_free(mem, extensions);
582
- rb_raise(rb_eArgError, "extension %s not found\n", rb_id2name(SYM2ID(rb_ext_name)));
583
- }
584
-
585
- extensions = cmark_llist_append(mem, extensions, syntax_extension);
586
- }
587
-
588
- char *html = cmark_render_html(node, options, extensions);
589
- VALUE ruby_html = rb_str_new2(html);
590
-
591
- cmark_llist_free(mem, extensions);
592
- free(html);
593
-
594
- return ruby_html;
595
- }
596
-
597
- /* Internal: Convert the node to an XML string.
598
- *
599
- * Returns a {String}.
600
- */
601
- static VALUE rb_render_xml(VALUE self, VALUE rb_options) {
602
- int options;
603
- cmark_node *node;
604
- Check_Type(rb_options, T_FIXNUM);
605
-
606
- options = FIX2INT(rb_options);
607
-
608
- Data_Get_Struct(self, cmark_node, node);
609
-
610
- char *xml = cmark_render_xml(node, options);
611
- VALUE ruby_xml = rb_str_new2(xml);
612
-
613
- free(xml);
614
-
615
- return ruby_xml;
616
- }
617
-
618
- /* Internal: Convert the node to a CommonMark string.
619
- *
620
- * Returns a {String}.
621
- */
622
- static VALUE rb_render_commonmark(int argc, VALUE *argv, VALUE self) {
623
- VALUE rb_options, rb_width;
624
- rb_scan_args(argc, argv, "11", &rb_options, &rb_width);
625
-
626
- int width = 120;
627
- if (!NIL_P(rb_width)) {
628
- Check_Type(rb_width, T_FIXNUM);
629
- width = FIX2INT(rb_width);
630
- }
631
-
632
- int options;
633
- cmark_node *node;
634
- Check_Type(rb_options, T_FIXNUM);
635
-
636
- options = FIX2INT(rb_options);
637
- Data_Get_Struct(self, cmark_node, node);
638
-
639
- char *cmark = cmark_render_commonmark(node, options, width);
640
- VALUE ruby_cmark = rb_str_new2(cmark);
641
- free(cmark);
642
-
643
- return ruby_cmark;
644
- }
645
-
646
- /* Internal: Convert the node to a plain textstring.
647
- *
648
- * Returns a {String}.
649
- */
650
- static VALUE rb_render_plaintext(int argc, VALUE *argv, VALUE self) {
651
- VALUE rb_options, rb_width;
652
- rb_scan_args(argc, argv, "11", &rb_options, &rb_width);
653
-
654
- int width = 120;
655
- if (!NIL_P(rb_width)) {
656
- Check_Type(rb_width, T_FIXNUM);
657
- width = FIX2INT(rb_width);
658
- }
659
-
660
- int options;
661
- cmark_node *node;
662
- Check_Type(rb_options, T_FIXNUM);
663
-
664
- options = FIX2INT(rb_options);
665
- Data_Get_Struct(self, cmark_node, node);
666
-
667
- char *text = cmark_render_plaintext(node, options, width);
668
- VALUE ruby_text = rb_str_new2(text);
669
- free(text);
670
-
671
- return ruby_text;
672
- }
673
-
674
- /*
675
- * Public: Inserts a node as a sibling after the current node.
676
- *
677
- * sibling - A sibling {Node} to insert.
678
- *
679
- * Returns `true` if successful.
680
- * Raises NodeError if the node can't be inserted.
681
- */
682
- static VALUE rb_node_insert_after(VALUE self, VALUE sibling) {
683
- cmark_node *node1, *node2;
684
- Data_Get_Struct(self, cmark_node, node1);
685
-
686
- Data_Get_Struct(sibling, cmark_node, node2);
687
-
688
- if (!cmark_node_insert_after(node1, node2)) {
689
- rb_raise(rb_eNodeError, "could not insert after");
690
- }
691
-
692
- rb_parent_added(sibling);
693
-
694
- return Qtrue;
695
- }
696
-
697
- /*
698
- * Public: Inserts a node as the first child of the current node.
699
- *
700
- * child - A child {Node} to insert.
701
- *
702
- * Returns `true` if successful.
703
- * Raises NodeError if the node can't be inserted.
704
- */
705
- static VALUE rb_node_prepend_child(VALUE self, VALUE child) {
706
- cmark_node *node1, *node2;
707
- Data_Get_Struct(self, cmark_node, node1);
708
-
709
- Data_Get_Struct(child, cmark_node, node2);
710
-
711
- if (!cmark_node_prepend_child(node1, node2)) {
712
- rb_raise(rb_eNodeError, "could not prepend child");
713
- }
714
-
715
- rb_parent_added(child);
716
-
717
- return Qtrue;
718
- }
719
-
720
- /*
721
- * Public: Inserts a node as the last child of the current node.
722
- *
723
- * child - A child {Node} to insert.
724
- *
725
- * Returns `true` if successful.
726
- * Raises NodeError if the node can't be inserted.
727
- */
728
- static VALUE rb_node_append_child(VALUE self, VALUE child) {
729
- cmark_node *node1, *node2;
730
- Data_Get_Struct(self, cmark_node, node1);
731
-
732
- Data_Get_Struct(child, cmark_node, node2);
733
-
734
- if (!cmark_node_append_child(node1, node2)) {
735
- rb_raise(rb_eNodeError, "could not append child");
736
- }
737
-
738
- rb_parent_added(child);
739
-
740
- return Qtrue;
741
- }
742
-
743
- /* Public: Fetches the first child of the current node.
744
- *
745
- * Returns a {Node} if a child exists, `nil` otherise.
746
- */
747
- static VALUE rb_node_last_child(VALUE self) {
748
- cmark_node *node, *child;
749
- Data_Get_Struct(self, cmark_node, node);
750
-
751
- child = cmark_node_last_child(node);
752
-
753
- return rb_node_to_value(child);
754
- }
755
-
756
- /* Public: Fetches the parent of the current node.
757
- *
758
- * Returns a {Node} if a parent exists, `nil` otherise.
759
- */
760
- static VALUE rb_node_parent(VALUE self) {
761
- cmark_node *node, *parent;
762
- Data_Get_Struct(self, cmark_node, node);
763
-
764
- parent = cmark_node_parent(node);
765
-
766
- return rb_node_to_value(parent);
767
- }
768
-
769
- /* Public: Fetches the previous sibling of the current node.
770
- *
771
- * Returns a {Node} if a parent exists, `nil` otherise.
772
- */
773
- static VALUE rb_node_previous(VALUE self) {
774
- cmark_node *node, *previous;
775
- Data_Get_Struct(self, cmark_node, node);
776
-
777
- previous = cmark_node_previous(node);
778
-
779
- return rb_node_to_value(previous);
780
- }
781
-
782
- /*
783
- * Public: Gets the URL of the current node (must be a `:link` or `:image`).
784
- *
785
- * Returns a {String}.
786
- * Raises a NodeError if the URL can't be retrieved.
787
- */
788
- static VALUE rb_node_get_url(VALUE self) {
789
- const char *text;
790
- cmark_node *node;
791
- Data_Get_Struct(self, cmark_node, node);
792
-
793
- text = cmark_node_get_url(node);
794
- if (text == NULL) {
795
- rb_raise(rb_eNodeError, "could not get url");
796
- }
797
-
798
- return rb_str_new2(text);
799
- }
800
-
801
- /*
802
- * Public: Sets the URL of the current node (must be a `:link` or `:image`).
803
- *
804
- * url - A {String} representing the new URL
805
- *
806
- * Raises a NodeError if the URL can't be set.
807
- */
808
- static VALUE rb_node_set_url(VALUE self, VALUE url) {
809
- cmark_node *node;
810
- char *text;
811
- Check_Type(url, T_STRING);
812
-
813
- Data_Get_Struct(self, cmark_node, node);
814
- text = StringValueCStr(url);
815
-
816
- if (!cmark_node_set_url(node, text)) {
817
- rb_raise(rb_eNodeError, "could not set url");
818
- }
819
-
820
- return Qnil;
821
- }
822
-
823
- /*
824
- * Public: Gets the title of the current node (must be a `:link` or `:image`).
825
- *
826
- * Returns a {String}.
827
- * Raises a NodeError if the title can't be retrieved.
828
- */
829
- static VALUE rb_node_get_title(VALUE self) {
830
- const char *text;
831
- cmark_node *node;
832
- Data_Get_Struct(self, cmark_node, node);
833
-
834
- text = cmark_node_get_title(node);
835
- if (text == NULL) {
836
- rb_raise(rb_eNodeError, "could not get title");
837
- }
838
-
839
- return rb_str_new2(text);
840
- }
841
-
842
- /*
843
- * Public: Sets the title of the current node (must be a `:link` or `:image`).
844
- *
845
- * title - A {String} representing the new title
846
- *
847
- * Raises a NodeError if the title can't be set.
848
- */
849
- static VALUE rb_node_set_title(VALUE self, VALUE title) {
850
- char *text;
851
- cmark_node *node;
852
- Check_Type(title, T_STRING);
853
-
854
- Data_Get_Struct(self, cmark_node, node);
855
- text = StringValueCStr(title);
856
-
857
- if (!cmark_node_set_title(node, text)) {
858
- rb_raise(rb_eNodeError, "could not set title");
859
- }
860
-
861
- return Qnil;
862
- }
863
-
864
- /*
865
- * Public: Gets the header level of the current node (must be a `:header`).
866
- *
867
- * Returns a {Number} representing the header level.
868
- * Raises a NodeError if the header level can't be retrieved.
869
- */
870
- static VALUE rb_node_get_header_level(VALUE self) {
871
- int header_level;
872
- cmark_node *node;
873
- Data_Get_Struct(self, cmark_node, node);
874
-
875
- header_level = cmark_node_get_header_level(node);
876
-
877
- if (header_level == 0) {
878
- rb_raise(rb_eNodeError, "could not get header_level");
879
- }
880
-
881
- return INT2NUM(header_level);
882
- }
883
-
884
- /*
885
- * Public: Sets the header level of the current node (must be a `:header`).
886
- *
887
- * level - A {Number} representing the new header level
888
- *
889
- * Raises a NodeError if the header level can't be set.
890
- */
891
- static VALUE rb_node_set_header_level(VALUE self, VALUE level) {
892
- int l;
893
- cmark_node *node;
894
- Check_Type(level, T_FIXNUM);
895
-
896
- Data_Get_Struct(self, cmark_node, node);
897
- l = FIX2INT(level);
898
-
899
- if (!cmark_node_set_header_level(node, l)) {
900
- rb_raise(rb_eNodeError, "could not set header_level");
901
- }
902
-
903
- return Qnil;
904
- }
905
-
906
- /*
907
- * Public: Gets the list type of the current node (must be a `:list`).
908
- *
909
- * Returns a {Symbol}.
910
- * Raises a NodeError if the title can't be retrieved.
911
- */
912
- static VALUE rb_node_get_list_type(VALUE self) {
913
- int list_type;
914
- cmark_node *node;
915
- VALUE symbol;
916
- Data_Get_Struct(self, cmark_node, node);
917
-
918
- list_type = cmark_node_get_list_type(node);
919
-
920
- if (list_type == CMARK_BULLET_LIST) {
921
- symbol = sym_bullet_list;
922
- } else if (list_type == CMARK_ORDERED_LIST) {
923
- symbol = sym_ordered_list;
924
- } else {
925
- rb_raise(rb_eNodeError, "could not get list_type");
926
- }
927
-
928
- return symbol;
929
- }
930
-
931
- /*
932
- * Public: Sets the list type of the current node (must be a `:list`).
933
- *
934
- * level - A {Symbol} representing the new list type
935
- *
936
- * Raises a NodeError if the list type can't be set.
937
- */
938
- static VALUE rb_node_set_list_type(VALUE self, VALUE list_type) {
939
- int type = 0;
940
- cmark_node *node;
941
- Check_Type(list_type, T_SYMBOL);
942
-
943
- Data_Get_Struct(self, cmark_node, node);
944
-
945
- if (list_type == sym_bullet_list) {
946
- type = CMARK_BULLET_LIST;
947
- } else if (list_type == sym_ordered_list) {
948
- type = CMARK_ORDERED_LIST;
949
- } else {
950
- rb_raise(rb_eNodeError, "invalid list_type");
951
- }
952
-
953
- if (!cmark_node_set_list_type(node, type)) {
954
- rb_raise(rb_eNodeError, "could not set list_type");
955
- }
956
-
957
- return Qnil;
958
- }
959
-
960
- /*
961
- * Public: Gets the starting number the current node (must be an
962
- * `:ordered_list`).
963
- *
964
- * Returns a {Number} representing the starting number.
965
- * Raises a NodeError if the starting number can't be retrieved.
966
- */
967
- static VALUE rb_node_get_list_start(VALUE self) {
968
- cmark_node *node;
969
- Data_Get_Struct(self, cmark_node, node);
970
-
971
- if (cmark_node_get_type(node) != CMARK_NODE_LIST ||
972
- cmark_node_get_list_type(node) != CMARK_ORDERED_LIST) {
973
- rb_raise(rb_eNodeError, "can't get list_start for non-ordered list %d",
974
- cmark_node_get_list_type(node));
975
- }
976
-
977
- return INT2NUM(cmark_node_get_list_start(node));
978
- }
979
-
980
- /*
981
- * Public: Sets the starting number of the current node (must be an
982
- * `:ordered_list`).
983
- *
984
- * level - A {Number} representing the new starting number
985
- *
986
- * Raises a NodeError if the starting number can't be set.
987
- */
988
- static VALUE rb_node_set_list_start(VALUE self, VALUE start) {
989
- int s;
990
- cmark_node *node;
991
- Check_Type(start, T_FIXNUM);
992
-
993
- Data_Get_Struct(self, cmark_node, node);
994
- s = FIX2INT(start);
995
-
996
- if (!cmark_node_set_list_start(node, s)) {
997
- rb_raise(rb_eNodeError, "could not set list_start");
998
- }
999
-
1000
- return Qnil;
1001
- }
1002
-
1003
- /*
1004
- * Public: Gets the tight status the current node (must be a `:list`).
1005
- *
1006
- * Returns a `true` if the list is tight, `false` otherwise.
1007
- * Raises a NodeError if the starting number can't be retrieved.
1008
- */
1009
- static VALUE rb_node_get_list_tight(VALUE self) {
1010
- int flag;
1011
- cmark_node *node;
1012
- Data_Get_Struct(self, cmark_node, node);
1013
-
1014
- if (cmark_node_get_type(node) != CMARK_NODE_LIST) {
1015
- rb_raise(rb_eNodeError, "can't get list_tight for non-list");
1016
- }
1017
-
1018
- flag = cmark_node_get_list_tight(node);
1019
-
1020
- return flag ? Qtrue : Qfalse;
1021
- }
1022
-
1023
- /*
1024
- * Public: Sets the tight status of the current node (must be a `:list`).
1025
- *
1026
- * tight - A {Boolean} representing the new tightness
1027
- *
1028
- * Raises a NodeError if the tightness can't be set.
1029
- */
1030
- static VALUE rb_node_set_list_tight(VALUE self, VALUE tight) {
1031
- int t;
1032
- cmark_node *node;
1033
- Data_Get_Struct(self, cmark_node, node);
1034
- t = RTEST(tight);
1035
-
1036
- if (!cmark_node_set_list_tight(node, t)) {
1037
- rb_raise(rb_eNodeError, "could not set list_tight");
1038
- }
1039
-
1040
- return Qnil;
1041
- }
1042
-
1043
- /*
1044
- * Public: Gets the fence info of the current node (must be a `:code_block`).
1045
- *
1046
- * Returns a {String} representing the fence info.
1047
- * Raises a NodeError if the fence info can't be retrieved.
1048
- */
1049
- static VALUE rb_node_get_fence_info(VALUE self) {
1050
- const char *fence_info;
1051
- cmark_node *node;
1052
- Data_Get_Struct(self, cmark_node, node);
1053
-
1054
- fence_info = cmark_node_get_fence_info(node);
1055
-
1056
- if (fence_info == NULL) {
1057
- rb_raise(rb_eNodeError, "could not get fence_info");
1058
- }
1059
-
1060
- return rb_str_new2(fence_info);
1061
- }
1062
-
1063
- /*
1064
- * Public: Sets the fence info of the current node (must be a `:code_block`).
1065
- *
1066
- * info - A {String} representing the new fence info
1067
- *
1068
- * Raises a NodeError if the fence info can't be set.
1069
- */
1070
- static VALUE rb_node_set_fence_info(VALUE self, VALUE info) {
1071
- char *text;
1072
- cmark_node *node;
1073
- Check_Type(info, T_STRING);
1074
-
1075
- Data_Get_Struct(self, cmark_node, node);
1076
- text = StringValueCStr(info);
1077
-
1078
- if (!cmark_node_set_fence_info(node, text)) {
1079
- rb_raise(rb_eNodeError, "could not set fence_info");
1080
- }
1081
-
1082
- return Qnil;
1083
- }
1084
-
1085
- static VALUE rb_node_get_tasklist_item_checked(VALUE self) {
1086
- int tasklist_state;
1087
- cmark_node *node;
1088
- Data_Get_Struct(self, cmark_node, node);
1089
-
1090
- tasklist_state = cmark_gfm_extensions_get_tasklist_item_checked(node);
1091
-
1092
- if (tasklist_state == 1) {
1093
- return Qtrue;
1094
- } else {
1095
- return Qfalse;
1096
- }
1097
- }
1098
-
1099
- /*
1100
- * Public: Sets the checkbox state of the current node (must be a `:tasklist`).
1101
- *
1102
- * item_checked - A {Boolean} representing the new checkbox state
1103
- *
1104
- * Returns a {Boolean} representing the new checkbox state.
1105
- * Raises a NodeError if the checkbox state can't be set.
1106
- */
1107
- static VALUE rb_node_set_tasklist_item_checked(VALUE self, VALUE item_checked) {
1108
- int tasklist_state;
1109
- cmark_node *node;
1110
- Data_Get_Struct(self, cmark_node, node);
1111
- tasklist_state = RTEST(item_checked);
1112
-
1113
- if (!cmark_gfm_extensions_set_tasklist_item_checked(node, tasklist_state)) {
1114
- rb_raise(rb_eNodeError, "could not set tasklist_item_checked");
1115
- };
1116
-
1117
- if (tasklist_state) {
1118
- return Qtrue;
1119
- } else {
1120
- return Qfalse;
1121
- }
1122
- }
1123
-
1124
- // TODO: remove this, superseded by the above method
1125
- static VALUE rb_node_get_tasklist_state(VALUE self) {
1126
- int tasklist_state;
1127
- cmark_node *node;
1128
- Data_Get_Struct(self, cmark_node, node);
1129
-
1130
- tasklist_state = cmark_gfm_extensions_get_tasklist_item_checked(node);
1131
-
1132
- if (tasklist_state == 1) {
1133
- return rb_str_new2("checked");
1134
- } else {
1135
- return rb_str_new2("unchecked");
1136
- }
1137
- }
1138
-
1139
- static VALUE rb_node_get_table_alignments(VALUE self) {
1140
- uint16_t column_count, i;
1141
- uint8_t *alignments;
1142
- cmark_node *node;
1143
- VALUE ary;
1144
- Data_Get_Struct(self, cmark_node, node);
1145
-
1146
- column_count = cmark_gfm_extensions_get_table_columns(node);
1147
- alignments = cmark_gfm_extensions_get_table_alignments(node);
1148
-
1149
- if (!column_count || !alignments) {
1150
- rb_raise(rb_eNodeError, "could not get column_count or alignments");
1151
- }
1152
-
1153
- ary = rb_ary_new();
1154
- for (i = 0; i < column_count; ++i) {
1155
- if (alignments[i] == 'l')
1156
- rb_ary_push(ary, sym_left);
1157
- else if (alignments[i] == 'c')
1158
- rb_ary_push(ary, sym_center);
1159
- else if (alignments[i] == 'r')
1160
- rb_ary_push(ary, sym_right);
1161
- else
1162
- rb_ary_push(ary, Qnil);
1163
- }
1164
- return ary;
1165
- }
1166
-
1167
- /* Internal: Escapes href URLs safely. */
1168
- static VALUE rb_html_escape_href(VALUE self, VALUE rb_text) {
1169
- char *result;
1170
- cmark_node *node;
1171
- Check_Type(rb_text, T_STRING);
1172
-
1173
- Data_Get_Struct(self, cmark_node, node);
1174
-
1175
- cmark_mem *mem = cmark_node_mem(node);
1176
- cmark_strbuf buf = CMARK_BUF_INIT(mem);
1177
-
1178
- if (houdini_escape_href(&buf, (const uint8_t *)RSTRING_PTR(rb_text),
1179
- RSTRING_LEN(rb_text))) {
1180
- result = (char *)cmark_strbuf_detach(&buf);
1181
- return encode_source_string(result, rb_text);
1182
-
1183
- }
1184
-
1185
- return rb_text;
1186
- }
1187
-
1188
- /* Internal: Escapes HTML content safely. */
1189
- static VALUE rb_html_escape_html(VALUE self, VALUE rb_text) {
1190
- char *result;
1191
- cmark_node *node;
1192
- Check_Type(rb_text, T_STRING);
1193
-
1194
- Data_Get_Struct(self, cmark_node, node);
1195
-
1196
- cmark_mem *mem = cmark_node_mem(node);
1197
- cmark_strbuf buf = CMARK_BUF_INIT(mem);
1198
-
1199
- if (houdini_escape_html0(&buf, (const uint8_t *)RSTRING_PTR(rb_text),
1200
- RSTRING_LEN(rb_text), 0)) {
1201
- result = (char *)cmark_strbuf_detach(&buf);
1202
- return encode_source_string(result, rb_text);
1203
- }
1204
-
1205
- return rb_text;
1206
- }
1207
-
1208
- VALUE rb_extensions(VALUE self) {
1209
- cmark_llist *exts, *it;
1210
- cmark_syntax_extension *ext;
1211
- VALUE ary = rb_ary_new();
1212
-
1213
- cmark_mem *mem = cmark_get_default_mem_allocator();
1214
- exts = cmark_list_syntax_extensions(mem);
1215
- for (it = exts; it; it = it->next) {
1216
- ext = it->data;
1217
- rb_ary_push(ary, rb_str_new2(ext->name));
1218
- }
1219
- cmark_llist_free(mem, exts);
1220
-
1221
- return ary;
1222
- }
1223
-
1224
- __attribute__((visibility("default"))) void Init_commonmarker() {
1225
- VALUE module;
1226
- sym_document = ID2SYM(rb_intern("document"));
1227
- sym_blockquote = ID2SYM(rb_intern("blockquote"));
1228
- sym_list = ID2SYM(rb_intern("list"));
1229
- sym_list_item = ID2SYM(rb_intern("list_item"));
1230
- sym_code_block = ID2SYM(rb_intern("code_block"));
1231
- sym_html = ID2SYM(rb_intern("html"));
1232
- sym_paragraph = ID2SYM(rb_intern("paragraph"));
1233
- sym_header = ID2SYM(rb_intern("header"));
1234
- sym_hrule = ID2SYM(rb_intern("hrule"));
1235
- sym_text = ID2SYM(rb_intern("text"));
1236
- sym_softbreak = ID2SYM(rb_intern("softbreak"));
1237
- sym_linebreak = ID2SYM(rb_intern("linebreak"));
1238
- sym_code = ID2SYM(rb_intern("code"));
1239
- sym_inline_html = ID2SYM(rb_intern("inline_html"));
1240
- sym_emph = ID2SYM(rb_intern("emph"));
1241
- sym_strong = ID2SYM(rb_intern("strong"));
1242
- sym_link = ID2SYM(rb_intern("link"));
1243
- sym_image = ID2SYM(rb_intern("image"));
1244
- sym_footnote_reference = ID2SYM(rb_intern("footnote_reference"));
1245
- sym_footnote_definition = ID2SYM(rb_intern("footnote_definition"));
1246
-
1247
- sym_bullet_list = ID2SYM(rb_intern("bullet_list"));
1248
- sym_ordered_list = ID2SYM(rb_intern("ordered_list"));
1249
-
1250
- sym_left = ID2SYM(rb_intern("left"));
1251
- sym_right = ID2SYM(rb_intern("right"));
1252
- sym_center = ID2SYM(rb_intern("center"));
1253
-
1254
- module = rb_define_module("CommonMarker");
1255
- rb_define_singleton_method(module, "extensions", rb_extensions, 0);
1256
- rb_eNodeError = rb_define_class_under(module, "NodeError", rb_eStandardError);
1257
- rb_cNode = rb_define_class_under(module, "Node", rb_cObject);
1258
- rb_undef_alloc_func(rb_cNode);
1259
- rb_define_singleton_method(rb_cNode, "markdown_to_html", rb_markdown_to_html,
1260
- 3);
1261
- rb_define_singleton_method(rb_cNode, "markdown_to_xml", rb_markdown_to_xml,
1262
- 3);
1263
- rb_define_singleton_method(rb_cNode, "new", rb_node_new, 1);
1264
- rb_define_singleton_method(rb_cNode, "parse_document", rb_parse_document, 4);
1265
- rb_define_method(rb_cNode, "string_content", rb_node_get_string_content, 0);
1266
- rb_define_method(rb_cNode, "string_content=", rb_node_set_string_content, 1);
1267
- rb_define_method(rb_cNode, "type", rb_node_get_type, 0);
1268
- rb_define_method(rb_cNode, "type_string", rb_node_get_type_string, 0);
1269
- rb_define_method(rb_cNode, "sourcepos", rb_node_get_sourcepos, 0);
1270
- rb_define_method(rb_cNode, "delete", rb_node_unlink, 0);
1271
- rb_define_method(rb_cNode, "first_child", rb_node_first_child, 0);
1272
- rb_define_method(rb_cNode, "next", rb_node_next, 0);
1273
- rb_define_method(rb_cNode, "insert_before", rb_node_insert_before, 1);
1274
- rb_define_method(rb_cNode, "_render_html", rb_render_html, 2);
1275
- rb_define_method(rb_cNode, "_render_xml", rb_render_xml, 1);
1276
- rb_define_method(rb_cNode, "_render_commonmark", rb_render_commonmark, -1);
1277
- rb_define_method(rb_cNode, "_render_plaintext", rb_render_plaintext, -1);
1278
- rb_define_method(rb_cNode, "insert_after", rb_node_insert_after, 1);
1279
- rb_define_method(rb_cNode, "prepend_child", rb_node_prepend_child, 1);
1280
- rb_define_method(rb_cNode, "append_child", rb_node_append_child, 1);
1281
- rb_define_method(rb_cNode, "last_child", rb_node_last_child, 0);
1282
- rb_define_method(rb_cNode, "parent", rb_node_parent, 0);
1283
- rb_define_method(rb_cNode, "previous", rb_node_previous, 0);
1284
- rb_define_method(rb_cNode, "url", rb_node_get_url, 0);
1285
- rb_define_method(rb_cNode, "url=", rb_node_set_url, 1);
1286
- rb_define_method(rb_cNode, "title", rb_node_get_title, 0);
1287
- rb_define_method(rb_cNode, "title=", rb_node_set_title, 1);
1288
- rb_define_method(rb_cNode, "header_level", rb_node_get_header_level, 0);
1289
- rb_define_method(rb_cNode, "header_level=", rb_node_set_header_level, 1);
1290
- rb_define_method(rb_cNode, "list_type", rb_node_get_list_type, 0);
1291
- rb_define_method(rb_cNode, "list_type=", rb_node_set_list_type, 1);
1292
- rb_define_method(rb_cNode, "list_start", rb_node_get_list_start, 0);
1293
- rb_define_method(rb_cNode, "list_start=", rb_node_set_list_start, 1);
1294
- rb_define_method(rb_cNode, "list_tight", rb_node_get_list_tight, 0);
1295
- rb_define_method(rb_cNode, "list_tight=", rb_node_set_list_tight, 1);
1296
- rb_define_method(rb_cNode, "fence_info", rb_node_get_fence_info, 0);
1297
- rb_define_method(rb_cNode, "fence_info=", rb_node_set_fence_info, 1);
1298
- rb_define_method(rb_cNode, "table_alignments", rb_node_get_table_alignments, 0);
1299
- rb_define_method(rb_cNode, "tasklist_state", rb_node_get_tasklist_state, 0);
1300
- rb_define_method(rb_cNode, "tasklist_item_checked?", rb_node_get_tasklist_item_checked, 0);
1301
- rb_define_method(rb_cNode, "tasklist_item_checked=", rb_node_set_tasklist_item_checked, 1);
1302
-
1303
- rb_define_method(rb_cNode, "html_escape_href", rb_html_escape_href, 1);
1304
- rb_define_method(rb_cNode, "html_escape_html", rb_html_escape_html, 1);
1305
-
1306
- cmark_gfm_core_extensions_ensure_registered();
1307
- cmark_init_standard_node_flags();
1308
- }