apex-ruby 1.0.6
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 +7 -0
- data/README.md +119 -0
- data/apex-ruby.gemspec +31 -0
- data/ext/apex_ext/apex_ext.c +215 -0
- data/ext/apex_ext/apex_src/BENCHMARK.md +32 -0
- data/ext/apex_ext/apex_src/BENCHMARK_COMPARISON.md +67 -0
- data/ext/apex_ext/apex_src/CHANGELOG.md +2454 -0
- data/ext/apex_ext/apex_src/CMakeLists.txt +454 -0
- data/ext/apex_ext/apex_src/Dockerfile.linux-build +15 -0
- data/ext/apex_ext/apex_src/Formula/apex.rb +38 -0
- data/ext/apex_ext/apex_src/Info.plist.in +27 -0
- data/ext/apex_ext/apex_src/LICENSE +21 -0
- data/ext/apex_ext/apex_src/Package.swift +160 -0
- data/ext/apex_ext/apex_src/PackageSupport/README.md +17 -0
- data/ext/apex_ext/apex_src/PackageSupport/cmark-gfm/cmark-gfm_export.h +20 -0
- data/ext/apex_ext/apex_src/PackageSupport/cmark-gfm/cmark-gfm_version.h +14 -0
- data/ext/apex_ext/apex_src/PackageSupport/cmark-gfm/cmark_gfm_spm_stub.c +4 -0
- data/ext/apex_ext/apex_src/PackageSupport/cmark-gfm/config.h +41 -0
- data/ext/apex_ext/apex_src/README.md +452 -0
- data/ext/apex_ext/apex_src/VERSION +1 -0
- data/ext/apex_ext/apex_src/apex-header-2-rb@2x.webp +0 -0
- data/ext/apex_ext/apex_src/apex-plugins.json.example +20 -0
- data/ext/apex_ext/apex_src/apex.pc.in +11 -0
- data/ext/apex_ext/apex_src/cli/main.c +2720 -0
- data/ext/apex_ext/apex_src/debug_test.sh +22 -0
- data/ext/apex_ext/apex_src/docs/API_REFERENCE.md +451 -0
- data/ext/apex_ext/apex_src/docs/ARCHITECTURE.md +166 -0
- data/ext/apex_ext/apex_src/docs/CMARK_INTEGRATION.md +220 -0
- data/ext/apex_ext/apex_src/docs/CRITICMARKUP.md +501 -0
- data/ext/apex_ext/apex_src/docs/DEBUGGING.md +73 -0
- data/ext/apex_ext/apex_src/docs/FINAL_STATUS.md +391 -0
- data/ext/apex_ext/apex_src/docs/FINAL_STATUS_UPDATE.md +237 -0
- data/ext/apex_ext/apex_src/docs/FUTURE_FEATURES.md +456 -0
- data/ext/apex_ext/apex_src/docs/IAL_FEATURES.md +210 -0
- data/ext/apex_ext/apex_src/docs/IAL_STATUS.md +344 -0
- data/ext/apex_ext/apex_src/docs/INTEGRATION_EXAMPLE.m +144 -0
- data/ext/apex_ext/apex_src/docs/LIMITATIONS_RESOLVED.md +278 -0
- data/ext/apex_ext/apex_src/docs/OUTPUT_MODES.md +321 -0
- data/ext/apex_ext/apex_src/docs/PROGRESS.md +167 -0
- data/ext/apex_ext/apex_src/docs/STANDALONE_FEATURE.md +174 -0
- data/ext/apex_ext/apex_src/docs/TABLE_SPANS_STATUS.md +243 -0
- data/ext/apex_ext/apex_src/docs/TEST_COVERAGE.md +316 -0
- data/ext/apex_ext/apex_src/docs/USER_GUIDE.md +803 -0
- data/ext/apex_ext/apex_src/docs/WIKI_LINKS_ISSUE.md +91 -0
- data/ext/apex_ext/apex_src/documentation/README.md +160 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex Command Line Options.cheatsheet.txt +365 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Info.plist +24 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/C-API.html +1737 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Citations.html +1420 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Command-Line-Options.html +3574 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Configuration.html +1603 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Credits.html +910 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Examples.html +1168 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Getting-Started.html +1003 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Header-IDs.html +1308 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Home.html +1078 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Inline-Attribute-Lists.html +1622 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Installation.html +1168 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Limitations-and-Roadmap.html +1698 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Metadata-Transforms.html +1531 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Modes.html +1980 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Multi-File-Documents.html +1368 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Pandoc-Integration.html +1151 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Plugins.html +2861 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Syntax.html +3981 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Troubleshooting.html +1454 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Usage.html +1200 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/Documents/Xcode-Integration.html +2066 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/docSet.dsidx +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/optimizedIndex.dsidx +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/Apex.docset/Contents/Resources/tempOptimizedIndex.dsidx +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Info.plist +22 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans_Bold.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans_Bold_Italic.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans_Extrabold.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans_Extrabold_Italic.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans_Italic.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans_Semibold.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/cheatset_resources/Open_Sans_Semibold_Italic.woff +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/index.html +914 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/Documents/style.css +399 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/docSet.dsidx +0 -0
- data/ext/apex_ext/apex_src/documentation/docsets/ApexCLI.docset/Contents/Resources/optimizedIndex.dsidx +0 -0
- data/ext/apex_ext/apex_src/documentation/generate_app_docs.rb +772 -0
- data/ext/apex_ext/apex_src/documentation/generate_app_docs_ai.rb +678 -0
- data/ext/apex_ext/apex_src/documentation/generate_docset.rb +873 -0
- data/ext/apex_ext/apex_src/documentation/generate_single_html.rb +733 -0
- data/ext/apex_ext/apex_src/documentation/html/apex-docs.html +17073 -0
- data/ext/apex_ext/apex_src/documentation/shared_scripts.js +64 -0
- data/ext/apex_ext/apex_src/documentation/shared_styles.css +646 -0
- data/ext/apex_ext/apex_src/documentation/transform_for_app.example.md +260 -0
- data/ext/apex_ext/apex_src/examples/bracketed_spans_demo.md +119 -0
- data/ext/apex_ext/apex_src/examples/emoji_span_plugin.yml +11 -0
- data/ext/apex_ext/apex_src/examples/example.html +53 -0
- data/ext/apex_ext/apex_src/examples/example.md +85 -0
- data/ext/apex_ext/apex_src/examples/fenced_divs_demo.md +158 -0
- data/ext/apex_ext/apex_src/examples/kbd.md +8 -0
- data/ext/apex_ext/apex_src/examples/kbd_plugin.rb +250 -0
- data/ext/apex_ext/apex_src/examples/kbd_plugin.yml +9 -0
- data/ext/apex_ext/apex_src/icon/apexicon-outline-black.png +0 -0
- data/ext/apex_ext/apex_src/icon/apexicon-outline-black@2x.png +0 -0
- data/ext/apex_ext/apex_src/icon/apexicon-outline-mark.png +0 -0
- data/ext/apex_ext/apex_src/icon/apexicon-outline-mark@2x.png +0 -0
- data/ext/apex_ext/apex_src/icon/apexicon-outline-white.png +0 -0
- data/ext/apex_ext/apex_src/icon/apexicon-outline-white@2x.png +0 -0
- data/ext/apex_ext/apex_src/icon/apexicon.png +0 -0
- data/ext/apex_ext/apex_src/icon/apexicon@2x.png +0 -0
- data/ext/apex_ext/apex_src/include/apex/apex.h +247 -0
- data/ext/apex_ext/apex_src/include/apex/buffer.h +93 -0
- data/ext/apex_ext/apex_src/include/apex/module.modulemap +16 -0
- data/ext/apex_ext/apex_src/include/apex/parser.h +150 -0
- data/ext/apex_ext/apex_src/include/apex/renderer.h +39 -0
- data/ext/apex_ext/apex_src/man/apex-config.5 +374 -0
- data/ext/apex_ext/apex_src/man/apex-config.5.md +260 -0
- data/ext/apex_ext/apex_src/man/apex-plugins.7 +456 -0
- data/ext/apex_ext/apex_src/man/apex-plugins.7.md +365 -0
- data/ext/apex_ext/apex_src/man/apex.1 +828 -0
- data/ext/apex_ext/apex_src/man/apex.1.md +643 -0
- data/ext/apex_ext/apex_src/man/apex.1.new +338 -0
- data/ext/apex_ext/apex_src/objc/Apex.swift +237 -0
- data/ext/apex_ext/apex_src/objc/NSString+Apex.h +117 -0
- data/ext/apex_ext/apex_src/objc/NSString+Apex.m +332 -0
- data/ext/apex_ext/apex_src/src/_README.md +358 -0
- data/ext/apex_ext/apex_src/src/apex.c +6326 -0
- data/ext/apex_ext/apex_src/src/buffer.c +93 -0
- data/ext/apex_ext/apex_src/src/extensions/abbreviations.c +362 -0
- data/ext/apex_ext/apex_src/src/extensions/abbreviations.h +45 -0
- data/ext/apex_ext/apex_src/src/extensions/advanced_footnotes.c +184 -0
- data/ext/apex_ext/apex_src/src/extensions/advanced_footnotes.h +50 -0
- data/ext/apex_ext/apex_src/src/extensions/advanced_tables.c +1897 -0
- data/ext/apex_ext/apex_src/src/extensions/advanced_tables.h +42 -0
- data/ext/apex_ext/apex_src/src/extensions/callouts.c +215 -0
- data/ext/apex_ext/apex_src/src/extensions/callouts.h +53 -0
- data/ext/apex_ext/apex_src/src/extensions/citations.c +2042 -0
- data/ext/apex_ext/apex_src/src/extensions/citations.h +163 -0
- data/ext/apex_ext/apex_src/src/extensions/critic.c +329 -0
- data/ext/apex_ext/apex_src/src/extensions/critic.h +48 -0
- data/ext/apex_ext/apex_src/src/extensions/definition_list.c +1670 -0
- data/ext/apex_ext/apex_src/src/extensions/definition_list.h +42 -0
- data/ext/apex_ext/apex_src/src/extensions/emoji.c +710 -0
- data/ext/apex_ext/apex_src/src/extensions/emoji.h +38 -0
- data/ext/apex_ext/apex_src/src/extensions/emoji_data.h +942 -0
- data/ext/apex_ext/apex_src/src/extensions/fenced_divs.c +925 -0
- data/ext/apex_ext/apex_src/src/extensions/fenced_divs.h +43 -0
- data/ext/apex_ext/apex_src/src/extensions/github-emoji.txt +869 -0
- data/ext/apex_ext/apex_src/src/extensions/grid_tables.c +1121 -0
- data/ext/apex_ext/apex_src/src/extensions/grid_tables.h +33 -0
- data/ext/apex_ext/apex_src/src/extensions/header_ids.c +626 -0
- data/ext/apex_ext/apex_src/src/extensions/header_ids.h +60 -0
- data/ext/apex_ext/apex_src/src/extensions/highlight.c +135 -0
- data/ext/apex_ext/apex_src/src/extensions/highlight.h +16 -0
- data/ext/apex_ext/apex_src/src/extensions/html_markdown.c +408 -0
- data/ext/apex_ext/apex_src/src/extensions/html_markdown.h +42 -0
- data/ext/apex_ext/apex_src/src/extensions/ial.c +4084 -0
- data/ext/apex_ext/apex_src/src/extensions/ial.h +145 -0
- data/ext/apex_ext/apex_src/src/extensions/includes.c +1536 -0
- data/ext/apex_ext/apex_src/src/extensions/includes.h +54 -0
- data/ext/apex_ext/apex_src/src/extensions/index.c +967 -0
- data/ext/apex_ext/apex_src/src/extensions/index.h +90 -0
- data/ext/apex_ext/apex_src/src/extensions/inline_footnotes.c +205 -0
- data/ext/apex_ext/apex_src/src/extensions/inline_footnotes.h +34 -0
- data/ext/apex_ext/apex_src/src/extensions/inline_tables.c +332 -0
- data/ext/apex_ext/apex_src/src/extensions/inline_tables.h +13 -0
- data/ext/apex_ext/apex_src/src/extensions/insert.c +248 -0
- data/ext/apex_ext/apex_src/src/extensions/insert.h +18 -0
- data/ext/apex_ext/apex_src/src/extensions/math.c +279 -0
- data/ext/apex_ext/apex_src/src/extensions/math.h +32 -0
- data/ext/apex_ext/apex_src/src/extensions/metadata.c +3046 -0
- data/ext/apex_ext/apex_src/src/extensions/metadata.h +125 -0
- data/ext/apex_ext/apex_src/src/extensions/relaxed_tables.c +1297 -0
- data/ext/apex_ext/apex_src/src/extensions/relaxed_tables.h +39 -0
- data/ext/apex_ext/apex_src/src/extensions/special_markers.c +194 -0
- data/ext/apex_ext/apex_src/src/extensions/special_markers.h +29 -0
- data/ext/apex_ext/apex_src/src/extensions/sup_sub.c +405 -0
- data/ext/apex_ext/apex_src/src/extensions/sup_sub.h +16 -0
- data/ext/apex_ext/apex_src/src/extensions/syntax_highlight.c +468 -0
- data/ext/apex_ext/apex_src/src/extensions/syntax_highlight.h +44 -0
- data/ext/apex_ext/apex_src/src/extensions/table_html_postprocess.c +2679 -0
- data/ext/apex_ext/apex_src/src/extensions/table_html_postprocess.h +23 -0
- data/ext/apex_ext/apex_src/src/extensions/toc.c +255 -0
- data/ext/apex_ext/apex_src/src/extensions/toc.h +34 -0
- data/ext/apex_ext/apex_src/src/extensions/wiki_links.c +624 -0
- data/ext/apex_ext/apex_src/src/extensions/wiki_links.h +58 -0
- data/ext/apex_ext/apex_src/src/html_renderer.c +2762 -0
- data/ext/apex_ext/apex_src/src/html_renderer.h +126 -0
- data/ext/apex_ext/apex_src/src/parser.c +227 -0
- data/ext/apex_ext/apex_src/src/plugins.c +895 -0
- data/ext/apex_ext/apex_src/src/plugins.h +39 -0
- data/ext/apex_ext/apex_src/src/plugins_env.c +187 -0
- data/ext/apex_ext/apex_src/src/plugins_remote.c +263 -0
- data/ext/apex_ext/apex_src/src/pretty_html.c +358 -0
- data/ext/apex_ext/apex_src/src/renderer.c +241 -0
- data/ext/apex_ext/apex_src/src/utf8.c +56 -0
- data/ext/apex_ext/apex_src/test-linux-build.sh +20 -0
- data/ext/apex_ext/apex_src/test.html +103 -0
- data/ext/apex_ext/apex_src/test_coverage.sh +121 -0
- data/ext/apex_ext/apex_src/test_ial_fenced.md +6 -0
- data/ext/apex_ext/apex_src/test_math_norm.py +79 -0
- data/ext/apex_ext/apex_src/test_pandoc_output.html +48 -0
- data/ext/apex_ext/apex_src/test_spm.sh +107 -0
- data/ext/apex_ext/apex_src/tests/ApexSPMTest/main.swift +50 -0
- data/ext/apex_ext/apex_src/tests/BENCHMARK_RESULTS.md +229 -0
- data/ext/apex_ext/apex_src/tests/CMakeLists.txt +24 -0
- data/ext/apex_ext/apex_src/tests/README.md +146 -0
- data/ext/apex_ext/apex_src/tests/benchmark.sh +113 -0
- data/ext/apex_ext/apex_src/tests/benchmark_comparison.sh +166 -0
- data/ext/apex_ext/apex_src/tests/compare_header_ids.sh +31 -0
- data/ext/apex_ext/apex_src/tests/fixtures/basic/headers.md +25 -0
- data/ext/apex_ext/apex_src/tests/fixtures/basic/list-interruption.md +24 -0
- data/ext/apex_ext/apex_src/tests/fixtures/basic/misc_markup.md +33 -0
- data/ext/apex_ext/apex_src/tests/fixtures/basic/test_basic.md +26 -0
- data/ext/apex_ext/apex_src/tests/fixtures/code/code-blocks.md +260 -0
- data/ext/apex_ext/apex_src/tests/fixtures/combine_summary/SUMMARY.md +6 -0
- data/ext/apex_ext/apex_src/tests/fixtures/combine_summary/chapter1.md +7 -0
- data/ext/apex_ext/apex_src/tests/fixtures/combine_summary/index.txt +9 -0
- data/ext/apex_ext/apex_src/tests/fixtures/combine_summary/intro.md +5 -0
- data/ext/apex_ext/apex_src/tests/fixtures/combine_summary/section1_1.md +5 -0
- data/ext/apex_ext/apex_src/tests/fixtures/comprehensive_test.md +620 -0
- data/ext/apex_ext/apex_src/tests/fixtures/debug_ref_image_ial.md +3 -0
- data/ext/apex_ext/apex_src/tests/fixtures/demos/ial.md +11 -0
- data/ext/apex_ext/apex_src/tests/fixtures/demos/ial_demo.md +177 -0
- data/ext/apex_ext/apex_src/tests/fixtures/extensions/emoji-autocorrect.md +94 -0
- data/ext/apex_ext/apex_src/tests/fixtures/extensions/emoji_test.md +3 -0
- data/ext/apex_ext/apex_src/tests/fixtures/extensions/kbd_test.md +3 -0
- data/ext/apex_ext/apex_src/tests/fixtures/ial/bracketed_spans_test.md +74 -0
- data/ext/apex_ext/apex_src/tests/fixtures/images/image_and_encoding_test.md +27 -0
- data/ext/apex_ext/apex_src/tests/fixtures/images/multimarkdown_image_attributes_test.md +60 -0
- data/ext/apex_ext/apex_src/tests/fixtures/images/pandoc_ial_image_test.md +27 -0
- data/ext/apex_ext/apex_src/tests/fixtures/images/width_height_conversion_test.md +94 -0
- data/ext/apex_ext/apex_src/tests/fixtures/img-in-div.md +16 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/code.py +4 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/data.csv +5 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/data.tsv +5 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/image.png +2 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/metadata_options.yml +11 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/nested.md +8 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/raw.html +4 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/simple.md +7 -0
- data/ext/apex_ext/apex_src/tests/fixtures/includes/test_image.png +0 -0
- data/ext/apex_ext/apex_src/tests/fixtures/large_doc.md +1094 -0
- data/ext/apex_ext/apex_src/tests/fixtures/metadata_options.yml +11 -0
- data/ext/apex_ext/apex_src/tests/fixtures/output/gfm_header_id_test.md +96 -0
- data/ext/apex_ext/apex_src/tests/fixtures/output/test_citations.md +43 -0
- data/ext/apex_ext/apex_src/tests/fixtures/output/test_def_list_links.md +12 -0
- data/ext/apex_ext/apex_src/tests/fixtures/output/test_index_mmark.md +53 -0
- data/ext/apex_ext/apex_src/tests/fixtures/output/test_index_textindex.md +37 -0
- data/ext/apex_ext/apex_src/tests/fixtures/tables/advanced_tables_test.md +93 -0
- data/ext/apex_ext/apex_src/tests/fixtures/tables/inline_tables_test.md +38 -0
- data/ext/apex_ext/apex_src/tests/fixtures/tables/relaxed-table.md +12 -0
- data/ext/apex_ext/apex_src/tests/fixtures/tables/table_cr_line_endings.md +15 -0
- data/ext/apex_ext/apex_src/tests/fixtures/tables/table_no_trailing_newline.md +15 -0
- data/ext/apex_ext/apex_src/tests/generate_gfm_ids.sh +105 -0
- data/ext/apex_ext/apex_src/tests/generate_ial_demo.sh +143 -0
- data/ext/apex_ext/apex_src/tests/gfm_id_comparison_summary.md +96 -0
- data/ext/apex_ext/apex_src/tests/gh_api_test.md +6 -0
- data/ext/apex_ext/apex_src/tests/ial_demo.html +186 -0
- data/ext/apex_ext/apex_src/tests/include_code.py +19 -0
- data/ext/apex_ext/apex_src/tests/include_snippet.md +15 -0
- data/ext/apex_ext/apex_src/tests/multi_file_cli_test.sh +64 -0
- data/ext/apex_ext/apex_src/tests/sample_data.csv +7 -0
- data/ext/apex_ext/apex_src/tests/table_escaped_ltlt.md +4 -0
- data/ext/apex_ext/apex_src/tests/test_basic.c +74 -0
- data/ext/apex_ext/apex_src/tests/test_extensions.c +2116 -0
- data/ext/apex_ext/apex_src/tests/test_helpers.c +183 -0
- data/ext/apex_ext/apex_src/tests/test_helpers.h +91 -0
- data/ext/apex_ext/apex_src/tests/test_ial.c +282 -0
- data/ext/apex_ext/apex_src/tests/test_links.c +418 -0
- data/ext/apex_ext/apex_src/tests/test_marked_integration.c +265 -0
- data/ext/apex_ext/apex_src/tests/test_metadata.c +908 -0
- data/ext/apex_ext/apex_src/tests/test_output.c +1118 -0
- data/ext/apex_ext/apex_src/tests/test_plugins.c +219 -0
- data/ext/apex_ext/apex_src/tests/test_refs.bib +31 -0
- data/ext/apex_ext/apex_src/tests/test_runner.c +244 -0
- data/ext/apex_ext/apex_src/tests/test_syntax_highlight.c +198 -0
- data/ext/apex_ext/apex_src/tests/test_tables.c +862 -0
- data/ext/apex_ext/apex_src/tests/update_benchmarks.sh +9 -0
- data/ext/apex_ext/apex_src/tests/yaml_test.md +13 -0
- data/ext/apex_ext/apex_src/tests.rb +39 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/CMakeLists.txt +48 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/COPYING +170 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/CheckFileOffsetBits.c +14 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/CheckFileOffsetBits.cmake +43 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/FindAsan.cmake +74 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/Makefile.nmake +38 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/README.md +206 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/api_test/CMakeLists.txt +30 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/api_test/cplusplus.cpp +15 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/api_test/cplusplus.h +16 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/api_test/harness.c +111 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/api_test/harness.h +35 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/api_test/main.c +1169 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/appveyor.yml +21 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-bq-flat.md +16 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-bq-nested.md +13 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-code.md +11 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-fences.md +14 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-heading.md +9 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-hr.md +10 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-html.md +32 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-lheading.md +8 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-list-flat.md +67 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-list-nested.md +36 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-ref-flat.md +15 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/block-ref-nested.md +17 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-autolink.md +14 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-backticks.md +3 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-em-flat.md +5 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-em-nested.md +5 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-em-worst.md +5 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-entity.md +11 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-escape.md +15 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-html.md +44 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-links-flat.md +23 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-links-nested.md +13 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/inline-newlines.md +24 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/lorem1.md +13 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/samples/rawtabs.md +18 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/statistics.py +595 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/bench/stats.py +19 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/benchmarks.md +33 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/changelog.txt +1245 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/data/CaseFolding.txt +1495 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/CMakeLists.txt +119 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/autolink.c +508 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/autolink.h +8 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/cmark-gfm-core-extensions.h +54 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/core-extensions.c +27 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/ext_scanners.c +879 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/ext_scanners.h +24 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/ext_scanners.re +92 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/strikethrough.c +167 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/strikethrough.h +9 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/table.c +917 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/table.h +12 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/tagfilter.c +60 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/tagfilter.h +8 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/tasklist.c +156 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/extensions/tasklist.h +8 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/fuzz/CMakeLists.txt +22 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/fuzz/README.md +12 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/fuzz/fuzz_quadratic.c +91 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/fuzz/fuzz_quadratic_brackets.c +110 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/fuzz/fuzzloop.sh +28 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/man/CMakeLists.txt +10 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/man/make_man_page.py +133 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/man/man1/cmark-gfm.1 +78 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/man/man3/cmark-gfm.3 +1041 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/nmake.bat +1 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/CMakeLists.txt +230 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/arena.c +104 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/blocks.c +1622 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/buffer.c +278 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/buffer.h +116 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/case_fold_switch.inc +4327 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/chunk.h +135 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/cmark-gfm-extension_api.h +737 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/cmark-gfm.h +833 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/cmark-gfm_version.h.in +7 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/cmark.c +55 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/cmark_ctype.c +44 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/cmark_ctype.h +33 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/commonmark.c +514 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/config.h.in +76 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/entities.inc +2138 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/footnotes.c +63 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/footnotes.h +27 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/houdini.h +57 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/houdini_href_e.c +100 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/houdini_html_e.c +66 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/houdini_html_u.c +149 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/html.c +502 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/html.h +27 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/inlines.c +1788 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/inlines.h +29 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/iterator.c +159 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/iterator.h +26 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/latex.c +468 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/libcmark-gfm.pc.in +10 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/linked_list.c +37 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/main.c +328 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/man.c +274 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/map.c +129 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/map.h +44 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/node.c +1045 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/node.h +167 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/parser.h +59 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/plaintext.c +218 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/plugin.c +36 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/plugin.h +34 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/references.c +43 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/references.h +26 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/registry.c +63 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/registry.h +24 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/render.c +213 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/render.h +62 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/scanners.c +14056 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/scanners.h +70 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/scanners.re +365 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/syntax_extension.c +149 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/syntax_extension.h +34 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/utf8.c +317 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/utf8.h +35 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/src/xml.c +182 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/suppressions +10 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/CMakeLists.txt +114 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/afl_test_cases/test.md +49 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/cmark-fuzz.c +58 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/cmark.py +105 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/entity_tests.py +67 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/extensions-full-info-string.txt +0 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/extensions-table-prefer-style-attributes.txt +38 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/extensions.txt +920 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/fuzzing_dictionary +67 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/normalize.py +194 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/pathological_tests.py +160 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/regression.txt +375 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/roundtrip_tests.py +50 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/run-cmark-fuzz +4 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/smart_punct.txt +177 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/spec.txt +10212 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/test/spec_tests.py +152 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/toolchain-mingw32.cmake +17 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/tools/Dockerfile +41 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/tools/appveyor-build.bat +13 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/tools/make_entities_inc.py +32 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/tools/mkcasefold.pl +22 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/tools/xml2md.xsl +319 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/tools/xml2md_gfm.xsl +80 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/why-cmark-and-not-x.md +104 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/wrappers/wrapper.js +6 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/wrappers/wrapper.py +37 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/wrappers/wrapper.rb +15 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/wrappers/wrapper.rkt +208 -0
- data/ext/apex_ext/apex_src/vendor/cmark-gfm/wrappers/wrapper_ext.py +109 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/CMakeLists.txt +160 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/Changes +372 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/License +20 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/Makefile.am +51 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/ReadMe.md +46 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/announcement.msg +89 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/bootstrap +3 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/cmake/config.h.in +4 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/configure.ac +73 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/doc/doxygen.cfg +222 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/docker/README.mkd +17 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/docker/alpine-3.7 +26 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/docker/fedora-25 +26 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/docker/ubuntu-14.04 +29 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/docker/ubuntu-16.04 +24 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/anchors.yaml +10 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/array.yaml +2 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/global-tag.yaml +14 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/json.yaml +1 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/mapping.yaml +2 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/numbers.yaml +1 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/strings.yaml +7 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/tags.yaml +7 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/examples/yaml-version.yaml +3 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/include/Makefile.am +17 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/include/yaml.h +1999 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/pkg/ReadMe.md +77 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/pkg/docker/Dockerfile +32 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/pkg/docker/output/ReadMe +1 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/pkg/docker/scripts/libyaml-dist.sh +23 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/regression-inputs/clusterfuzz-testcase-minimized-5607885063061504.yml +1 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/Makefile.am +4 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/api.c +1393 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/dumper.c +394 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/emitter.c +2358 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/loader.c +544 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/parser.c +1416 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/reader.c +469 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/scanner.c +3598 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/writer.c +141 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/src/yaml_private.h +684 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/CMakeLists.txt +27 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/Makefile.am +9 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/ReadMe.md +63 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/example-deconstructor-alt.c +800 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/example-deconstructor.c +1127 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/example-reformatter-alt.c +217 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/example-reformatter.c +202 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-all-tests.sh +29 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-dumper.c +314 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-emitter-test-suite.c +290 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-emitter.c +327 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-loader.c +63 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-parser-test-suite.c +196 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-parser.c +88 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/run-scanner.c +63 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/test-reader.c +354 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/tests/test-version.c +29 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/yaml-0.1.pc.in +10 -0
- data/ext/apex_ext/apex_src/vendor/libyaml/yamlConfig.cmake.in +16 -0
- data/ext/apex_ext/extconf.rb +103 -0
- data/lib/apex/configurable.rb +46 -0
- data/lib/apex/document.rb +66 -0
- data/lib/apex/version.rb +15 -0
- data/lib/apex.rb +28 -0
- metadata +544 -0
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @file buffer.c
|
|
3
|
+
* @brief Dynamic buffer implementation
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
#include "apex/buffer.h"
|
|
7
|
+
#include <stdlib.h>
|
|
8
|
+
#include <string.h>
|
|
9
|
+
|
|
10
|
+
#define BUFFER_INIT_CAPACITY 256
|
|
11
|
+
#define BUFFER_GROWTH_FACTOR 2
|
|
12
|
+
|
|
13
|
+
void apex_buffer_init(apex_buffer *buf, size_t initial_capacity) {
|
|
14
|
+
if (initial_capacity == 0) {
|
|
15
|
+
initial_capacity = BUFFER_INIT_CAPACITY;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
buf->data = (char *)malloc(initial_capacity);
|
|
19
|
+
buf->size = 0;
|
|
20
|
+
buf->capacity = initial_capacity;
|
|
21
|
+
|
|
22
|
+
if (buf->data) {
|
|
23
|
+
buf->data[0] = '\0';
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
void apex_buffer_free(apex_buffer *buf) {
|
|
28
|
+
if (buf && buf->data) {
|
|
29
|
+
free(buf->data);
|
|
30
|
+
buf->data = NULL;
|
|
31
|
+
buf->size = 0;
|
|
32
|
+
buf->capacity = 0;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
void apex_buffer_clear(apex_buffer *buf) {
|
|
37
|
+
buf->size = 0;
|
|
38
|
+
if (buf->data) {
|
|
39
|
+
buf->data[0] = '\0';
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
static void apex_buffer_grow(apex_buffer *buf, size_t needed) {
|
|
44
|
+
size_t new_capacity = buf->capacity;
|
|
45
|
+
|
|
46
|
+
while (new_capacity < needed) {
|
|
47
|
+
new_capacity *= BUFFER_GROWTH_FACTOR;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
char *new_data = (char *)realloc(buf->data, new_capacity);
|
|
51
|
+
if (new_data) {
|
|
52
|
+
buf->data = new_data;
|
|
53
|
+
buf->capacity = new_capacity;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
void apex_buffer_append(apex_buffer *buf, const char *data, size_t len) {
|
|
58
|
+
if (!buf || !data || len == 0) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
size_t needed = buf->size + len + 1;
|
|
63
|
+
if (needed > buf->capacity) {
|
|
64
|
+
apex_buffer_grow(buf, needed);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
memcpy(buf->data + buf->size, data, len);
|
|
68
|
+
buf->size += len;
|
|
69
|
+
buf->data[buf->size] = '\0';
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
void apex_buffer_append_str(apex_buffer *buf, const char *str) {
|
|
73
|
+
if (str) {
|
|
74
|
+
apex_buffer_append(buf, str, strlen(str));
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
void apex_buffer_append_char(apex_buffer *buf, char c) {
|
|
79
|
+
apex_buffer_append(buf, &c, 1);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
const char *apex_buffer_cstr(const apex_buffer *buf) {
|
|
83
|
+
return buf ? buf->data : "";
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
char *apex_buffer_detach(apex_buffer *buf) {
|
|
87
|
+
char *result = buf->data;
|
|
88
|
+
buf->data = NULL;
|
|
89
|
+
buf->size = 0;
|
|
90
|
+
buf->capacity = 0;
|
|
91
|
+
return result;
|
|
92
|
+
}
|
|
93
|
+
|
|
@@ -0,0 +1,362 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Abbreviations Extension for Apex
|
|
3
|
+
* Implementation
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
#include "abbreviations.h"
|
|
7
|
+
#include <string.h>
|
|
8
|
+
#include <stdlib.h>
|
|
9
|
+
#include <ctype.h>
|
|
10
|
+
#include <stdio.h>
|
|
11
|
+
#include <stdbool.h>
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Free abbreviations list
|
|
15
|
+
*/
|
|
16
|
+
void apex_free_abbreviations(abbr_item *abbrs) {
|
|
17
|
+
while (abbrs) {
|
|
18
|
+
abbr_item *next = abbrs->next;
|
|
19
|
+
free(abbrs->abbr);
|
|
20
|
+
free(abbrs->expansion);
|
|
21
|
+
free(abbrs);
|
|
22
|
+
abbrs = next;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Trim whitespace
|
|
28
|
+
*/
|
|
29
|
+
static char *trim(char *str) {
|
|
30
|
+
while (isspace((unsigned char)*str)) str++;
|
|
31
|
+
char *end = str + strlen(str) - 1;
|
|
32
|
+
while (end > str && isspace((unsigned char)*end)) *end-- = '\0';
|
|
33
|
+
return str;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Process MMD 6 inline abbreviations in text (before parsing)
|
|
38
|
+
* Pattern: [>(abbr) expansion] → abbr (with definition added)
|
|
39
|
+
*/
|
|
40
|
+
static char *process_inline_abbreviations(const char *text, abbr_item **abbrs_list) {
|
|
41
|
+
if (!text) return NULL;
|
|
42
|
+
|
|
43
|
+
size_t len = strlen(text);
|
|
44
|
+
char *output = malloc(len * 2); /* Room for expansion */
|
|
45
|
+
if (!output) return strdup(text);
|
|
46
|
+
|
|
47
|
+
const char *read = text;
|
|
48
|
+
char *write = output;
|
|
49
|
+
|
|
50
|
+
while (*read) {
|
|
51
|
+
/* Check for [>(abbr) expansion] */
|
|
52
|
+
if (strncmp(read, "[>(", 3) == 0) {
|
|
53
|
+
const char *abbr_start = read + 3;
|
|
54
|
+
const char *abbr_end = strchr(abbr_start, ')');
|
|
55
|
+
|
|
56
|
+
if (abbr_end) {
|
|
57
|
+
const char *exp_start = abbr_end + 1;
|
|
58
|
+
while (*exp_start == ' ') exp_start++;
|
|
59
|
+
const char *exp_end = strchr(exp_start, ']');
|
|
60
|
+
|
|
61
|
+
if (exp_end) {
|
|
62
|
+
/* Extract abbreviation and expansion */
|
|
63
|
+
int abbr_len = abbr_end - abbr_start;
|
|
64
|
+
int exp_len = exp_end - exp_start;
|
|
65
|
+
|
|
66
|
+
if (abbr_len > 0 && abbr_len < 256 && exp_len > 0 && exp_len < 1024) {
|
|
67
|
+
char abbr_text[256], exp_text[1024];
|
|
68
|
+
memcpy(abbr_text, abbr_start, abbr_len);
|
|
69
|
+
abbr_text[abbr_len] = '\0';
|
|
70
|
+
memcpy(exp_text, exp_start, exp_len);
|
|
71
|
+
exp_text[exp_len] = '\0';
|
|
72
|
+
|
|
73
|
+
/* Add to abbreviations list */
|
|
74
|
+
abbr_item *item = malloc(sizeof(abbr_item));
|
|
75
|
+
if (item) {
|
|
76
|
+
item->abbr = strdup(trim(abbr_text));
|
|
77
|
+
item->expansion = strdup(trim(exp_text));
|
|
78
|
+
item->next = *abbrs_list;
|
|
79
|
+
*abbrs_list = item;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
/* Write just the abbreviation text */
|
|
83
|
+
strcpy(write, abbr_text);
|
|
84
|
+
write += abbr_len;
|
|
85
|
+
read = exp_end + 1;
|
|
86
|
+
continue;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/* Regular character */
|
|
93
|
+
*write++ = *read++;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
*write = '\0';
|
|
97
|
+
return output;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Extract abbreviations from text
|
|
102
|
+
* Pattern: *[abbr]: expansion or [>abbr]: expansion
|
|
103
|
+
*/
|
|
104
|
+
abbr_item *apex_extract_abbreviations(char **text_ptr) {
|
|
105
|
+
if (!text_ptr || !*text_ptr) return NULL;
|
|
106
|
+
|
|
107
|
+
char *text = *text_ptr;
|
|
108
|
+
abbr_item *abbrs = NULL;
|
|
109
|
+
abbr_item **tail = &abbrs;
|
|
110
|
+
|
|
111
|
+
|
|
112
|
+
/* First, process inline abbreviations [>(abbr) expansion] */
|
|
113
|
+
char *processed = process_inline_abbreviations(text, &abbrs);
|
|
114
|
+
if (processed) {
|
|
115
|
+
strcpy(text, processed);
|
|
116
|
+
free(processed);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
char *line_start = text;
|
|
120
|
+
char *line_end;
|
|
121
|
+
char *output = malloc(strlen(text) + 1);
|
|
122
|
+
char *output_write = output;
|
|
123
|
+
|
|
124
|
+
if (!output) return NULL;
|
|
125
|
+
|
|
126
|
+
while ((line_end = strchr(line_start, '\n')) != NULL || *line_start) {
|
|
127
|
+
if (!line_end) line_end = line_start + strlen(line_start);
|
|
128
|
+
|
|
129
|
+
size_t line_len = line_end - line_start;
|
|
130
|
+
char line[1024];
|
|
131
|
+
if (line_len >= sizeof(line)) line_len = sizeof(line) - 1;
|
|
132
|
+
memcpy(line, line_start, line_len);
|
|
133
|
+
line[line_len] = '\0';
|
|
134
|
+
|
|
135
|
+
/* Check for *[abbr]: expansion pattern (old MMD) */
|
|
136
|
+
if (line[0] == '*' && line[1] == '[') {
|
|
137
|
+
char *close_bracket = strchr(line + 2, ']');
|
|
138
|
+
if (close_bracket && close_bracket[1] == ':') {
|
|
139
|
+
/* Found abbreviation definition */
|
|
140
|
+
*close_bracket = '\0';
|
|
141
|
+
char *abbr = trim(line + 2);
|
|
142
|
+
char *expansion = trim(close_bracket + 2);
|
|
143
|
+
|
|
144
|
+
if (*abbr && *expansion) {
|
|
145
|
+
abbr_item *item = malloc(sizeof(abbr_item));
|
|
146
|
+
if (item) {
|
|
147
|
+
item->abbr = strdup(abbr);
|
|
148
|
+
item->expansion = strdup(expansion);
|
|
149
|
+
item->next = NULL;
|
|
150
|
+
|
|
151
|
+
*tail = item;
|
|
152
|
+
tail = &item->next;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
/* Skip this line in output */
|
|
157
|
+
line_start = *line_end ? line_end + 1 : line_end;
|
|
158
|
+
continue;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
/* Check for [>abbr]: expansion pattern (MMD 6) */
|
|
163
|
+
if (line[0] == '[' && line[1] == '>') {
|
|
164
|
+
char *close_bracket = strchr(line + 2, ']');
|
|
165
|
+
if (close_bracket && close_bracket[1] == ':') {
|
|
166
|
+
/* Found MMD 6 abbreviation definition */
|
|
167
|
+
*close_bracket = '\0';
|
|
168
|
+
char *abbr = trim(line + 2);
|
|
169
|
+
char *expansion = trim(close_bracket + 2);
|
|
170
|
+
|
|
171
|
+
if (*abbr && *expansion) {
|
|
172
|
+
abbr_item *item = malloc(sizeof(abbr_item));
|
|
173
|
+
if (item) {
|
|
174
|
+
item->abbr = strdup(abbr);
|
|
175
|
+
item->expansion = strdup(expansion);
|
|
176
|
+
item->next = NULL;
|
|
177
|
+
|
|
178
|
+
*tail = item;
|
|
179
|
+
tail = &item->next;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
/* Skip this line in output */
|
|
184
|
+
line_start = *line_end ? line_end + 1 : line_end;
|
|
185
|
+
continue;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
/* Not an abbreviation, copy line to output */
|
|
190
|
+
memcpy(output_write, line_start, line_len);
|
|
191
|
+
output_write += line_len;
|
|
192
|
+
if (*line_end) {
|
|
193
|
+
*output_write++ = '\n';
|
|
194
|
+
line_start = line_end + 1;
|
|
195
|
+
} else {
|
|
196
|
+
break;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
*output_write = '\0';
|
|
201
|
+
|
|
202
|
+
/* Update text pointer to cleaned text */
|
|
203
|
+
strcpy(text, output);
|
|
204
|
+
free(output);
|
|
205
|
+
|
|
206
|
+
return abbrs;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
/**
|
|
210
|
+
* Replace abbreviations in HTML
|
|
211
|
+
*/
|
|
212
|
+
char *apex_replace_abbreviations(const char *html, abbr_item *abbrs) {
|
|
213
|
+
if (!html || !abbrs) {
|
|
214
|
+
return html ? strdup(html) : NULL;
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
size_t html_len = strlen(html);
|
|
218
|
+
/* Calculate max possible expansion:
|
|
219
|
+
* Each abbreviation could be replaced with <abbr title="expansion">abbr</abbr>
|
|
220
|
+
* Worst case: very long expansions. Use html_len * 5 to be safe. */
|
|
221
|
+
size_t capacity = html_len * 5;
|
|
222
|
+
char *output = malloc(capacity);
|
|
223
|
+
if (!output) return strdup(html);
|
|
224
|
+
|
|
225
|
+
const char *read = html;
|
|
226
|
+
char *write = output;
|
|
227
|
+
size_t remaining = capacity;
|
|
228
|
+
|
|
229
|
+
while (*read) {
|
|
230
|
+
bool replaced = false;
|
|
231
|
+
|
|
232
|
+
/* Check for MMD 6 inline abbreviation (HTML-escaped): [>abbr] or [>(abbr) expansion] */
|
|
233
|
+
if (strncmp(read, "[>", 5) == 0) {
|
|
234
|
+
const char *start = read + 5;
|
|
235
|
+
const char *end = start;
|
|
236
|
+
|
|
237
|
+
/* Find closing ] */
|
|
238
|
+
while (*end && *end != ']' && *end != '\n' && *end != '<') end++;
|
|
239
|
+
|
|
240
|
+
if (*end == ']') {
|
|
241
|
+
/* Check for inline expansion: [>(abbr) expansion] */
|
|
242
|
+
if (*start == '(') {
|
|
243
|
+
const char *abbr_end = strchr(start + 1, ')');
|
|
244
|
+
if (abbr_end && abbr_end < end) {
|
|
245
|
+
/* Extract abbreviation and expansion */
|
|
246
|
+
int abbr_len = abbr_end - (start + 1);
|
|
247
|
+
int exp_len = end - (abbr_end + 1);
|
|
248
|
+
|
|
249
|
+
if (abbr_len > 0 && exp_len > 0) {
|
|
250
|
+
char abbr_text[256];
|
|
251
|
+
char exp_text[1024];
|
|
252
|
+
|
|
253
|
+
memcpy(abbr_text, start + 1, abbr_len);
|
|
254
|
+
abbr_text[abbr_len] = '\0';
|
|
255
|
+
|
|
256
|
+
memcpy(exp_text, abbr_end + 1, exp_len);
|
|
257
|
+
exp_text[exp_len] = '\0';
|
|
258
|
+
|
|
259
|
+
/* Trim whitespace */
|
|
260
|
+
char *abbr_trimmed = trim(abbr_text);
|
|
261
|
+
char *exp_trimmed = trim(exp_text);
|
|
262
|
+
|
|
263
|
+
/* Generate abbr tag */
|
|
264
|
+
char abbr_tag[2048];
|
|
265
|
+
snprintf(abbr_tag, sizeof(abbr_tag),
|
|
266
|
+
"<abbr title=\"%s\">%s</abbr>",
|
|
267
|
+
exp_trimmed, abbr_trimmed);
|
|
268
|
+
|
|
269
|
+
size_t tag_len = strlen(abbr_tag);
|
|
270
|
+
if (tag_len < remaining) {
|
|
271
|
+
memcpy(write, abbr_tag, tag_len);
|
|
272
|
+
write += tag_len;
|
|
273
|
+
remaining -= tag_len;
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
read = end + 1;
|
|
277
|
+
replaced = true;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
} else {
|
|
281
|
+
/* Reference abbreviation: [>MMD] */
|
|
282
|
+
int ref_len = end - start;
|
|
283
|
+
if (ref_len > 0 && ref_len < 256) {
|
|
284
|
+
char ref[256];
|
|
285
|
+
memcpy(ref, start, ref_len);
|
|
286
|
+
ref[ref_len] = '\0';
|
|
287
|
+
char *ref_trimmed = trim(ref);
|
|
288
|
+
|
|
289
|
+
/* Look up in abbreviation list */
|
|
290
|
+
for (abbr_item *item = abbrs; item; item = item->next) {
|
|
291
|
+
if (strcmp(item->abbr, ref_trimmed) == 0) {
|
|
292
|
+
/* Found match */
|
|
293
|
+
char abbr_tag[2048];
|
|
294
|
+
snprintf(abbr_tag, sizeof(abbr_tag),
|
|
295
|
+
"<abbr title=\"%s\">%s</abbr>",
|
|
296
|
+
item->expansion, item->abbr);
|
|
297
|
+
|
|
298
|
+
size_t tag_len = strlen(abbr_tag);
|
|
299
|
+
if (tag_len < remaining) {
|
|
300
|
+
memcpy(write, abbr_tag, tag_len);
|
|
301
|
+
write += tag_len;
|
|
302
|
+
remaining -= tag_len;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
read = end + 1;
|
|
306
|
+
replaced = true;
|
|
307
|
+
break;
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
if (replaced) continue;
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
/* Try each abbreviation (automatic replacement) */
|
|
318
|
+
for (abbr_item *item = abbrs; item; item = item->next) {
|
|
319
|
+
size_t abbr_len = strlen(item->abbr);
|
|
320
|
+
|
|
321
|
+
/* Check if we have a match */
|
|
322
|
+
if (strncmp(read, item->abbr, abbr_len) == 0) {
|
|
323
|
+
/* Check it's a whole word (not part of larger word) */
|
|
324
|
+
bool word_boundary = true;
|
|
325
|
+
if (read > html && isalnum((unsigned char)*(read - 1))) word_boundary = false;
|
|
326
|
+
if (isalnum((unsigned char)read[abbr_len])) word_boundary = false;
|
|
327
|
+
|
|
328
|
+
if (word_boundary) {
|
|
329
|
+
/* Replace with <abbr> tag */
|
|
330
|
+
char abbr_tag[2048];
|
|
331
|
+
snprintf(abbr_tag, sizeof(abbr_tag),
|
|
332
|
+
"<abbr title=\"%s\">%s</abbr>",
|
|
333
|
+
item->expansion, item->abbr);
|
|
334
|
+
|
|
335
|
+
size_t tag_len = strlen(abbr_tag);
|
|
336
|
+
if (tag_len < remaining) {
|
|
337
|
+
memcpy(write, abbr_tag, tag_len);
|
|
338
|
+
write += tag_len;
|
|
339
|
+
remaining -= tag_len;
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
read += abbr_len;
|
|
343
|
+
replaced = true;
|
|
344
|
+
break;
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
if (!replaced) {
|
|
350
|
+
if (remaining > 0) {
|
|
351
|
+
*write++ = *read++;
|
|
352
|
+
remaining--;
|
|
353
|
+
} else {
|
|
354
|
+
read++;
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
|
|
359
|
+
*write = '\0';
|
|
360
|
+
return output;
|
|
361
|
+
}
|
|
362
|
+
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Abbreviations Extension for Apex
|
|
3
|
+
*
|
|
4
|
+
* Supports Kramdown/MMD abbreviation syntax:
|
|
5
|
+
* *[HTML]: HyperText Markup Language
|
|
6
|
+
* *[CSS]: Cascading Style Sheets
|
|
7
|
+
*
|
|
8
|
+
* Then HTML and CSS in the text are wrapped in <abbr> tags
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
#ifndef APEX_ABBREVIATIONS_H
|
|
12
|
+
#define APEX_ABBREVIATIONS_H
|
|
13
|
+
|
|
14
|
+
#ifdef __cplusplus
|
|
15
|
+
extern "C" {
|
|
16
|
+
#endif
|
|
17
|
+
|
|
18
|
+
typedef struct abbr_item {
|
|
19
|
+
char *abbr;
|
|
20
|
+
char *expansion;
|
|
21
|
+
struct abbr_item *next;
|
|
22
|
+
} abbr_item;
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Extract abbreviation definitions from text
|
|
26
|
+
* Modifies text_ptr to skip abbreviation definitions
|
|
27
|
+
*/
|
|
28
|
+
abbr_item *apex_extract_abbreviations(char **text_ptr);
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Replace abbreviations in HTML with <abbr> tags
|
|
32
|
+
*/
|
|
33
|
+
char *apex_replace_abbreviations(const char *html, abbr_item *abbrs);
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Free abbreviation list
|
|
37
|
+
*/
|
|
38
|
+
void apex_free_abbreviations(abbr_item *abbrs);
|
|
39
|
+
|
|
40
|
+
#ifdef __cplusplus
|
|
41
|
+
}
|
|
42
|
+
#endif
|
|
43
|
+
|
|
44
|
+
#endif /* APEX_ABBREVIATIONS_H */
|
|
45
|
+
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Advanced Footnotes Extension for Apex
|
|
3
|
+
* Implementation
|
|
4
|
+
*
|
|
5
|
+
* Extends cmark-gfm's footnote system to support block-level Markdown
|
|
6
|
+
* content in footnote definitions.
|
|
7
|
+
*/
|
|
8
|
+
|
|
9
|
+
#include "advanced_footnotes.h"
|
|
10
|
+
#include "parser.h"
|
|
11
|
+
#include "node.h"
|
|
12
|
+
#include "inlines.h"
|
|
13
|
+
#include <string.h>
|
|
14
|
+
#include <stdlib.h>
|
|
15
|
+
#include <stdbool.h>
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Check if a footnote definition has block-level content
|
|
19
|
+
* (multiple paragraphs, code blocks, lists, etc.)
|
|
20
|
+
*/
|
|
21
|
+
static bool has_block_content(const char *content) {
|
|
22
|
+
if (!content) return false;
|
|
23
|
+
|
|
24
|
+
/* Check for multiple paragraphs (blank lines) */
|
|
25
|
+
const char *p = content;
|
|
26
|
+
bool found_text = false;
|
|
27
|
+
bool found_blank = false;
|
|
28
|
+
|
|
29
|
+
while (*p) {
|
|
30
|
+
if (*p == '\n') {
|
|
31
|
+
if (p[1] == '\n' || (p[1] == '\r' && p[2] == '\n')) {
|
|
32
|
+
/* Blank line */
|
|
33
|
+
if (found_text) {
|
|
34
|
+
found_blank = true;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
} else if (!found_blank && *p != ' ' && *p != '\t' && *p != '\r') {
|
|
38
|
+
found_text = true;
|
|
39
|
+
} else if (found_blank && *p != ' ' && *p != '\t' && *p != '\r') {
|
|
40
|
+
/* Text after blank line - block content */
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
p++;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/* Check for code blocks (4+ spaces indent) */
|
|
47
|
+
p = content;
|
|
48
|
+
while (*p) {
|
|
49
|
+
if (*p == '\n' && p[1] == ' ' && p[2] == ' ' && p[3] == ' ' && p[4] == ' ') {
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
p++;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/* Check for fenced code blocks */
|
|
56
|
+
if (strstr(content, "```") || strstr(content, "~~~")) {
|
|
57
|
+
return true;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/* Check for lists */
|
|
61
|
+
p = content;
|
|
62
|
+
while (*p) {
|
|
63
|
+
if (*p == '\n' && (p[1] == '-' || p[1] == '*' || p[1] == '+' ||
|
|
64
|
+
(p[1] >= '0' && p[1] <= '9'))) {
|
|
65
|
+
/* Potential list item */
|
|
66
|
+
const char *q = p + 2;
|
|
67
|
+
while (*q >= '0' && *q <= '9') q++;
|
|
68
|
+
if (*q == '.' || p[1] == '-' || p[1] == '*' || p[1] == '+') {
|
|
69
|
+
return true;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
p++;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Re-parse footnote content as block-level Markdown
|
|
80
|
+
*/
|
|
81
|
+
static void reparse_footnote_blocks(cmark_node *footnote_def, cmark_parser *parser) {
|
|
82
|
+
(void)parser;
|
|
83
|
+
if (!footnote_def) return;
|
|
84
|
+
|
|
85
|
+
/* Get the footnote content */
|
|
86
|
+
cmark_node *first_child = cmark_node_first_child(footnote_def);
|
|
87
|
+
if (!first_child) return;
|
|
88
|
+
|
|
89
|
+
/* If it's already parsed as blocks, nothing to do */
|
|
90
|
+
cmark_node_type type = cmark_node_get_type(first_child);
|
|
91
|
+
if (type == CMARK_NODE_PARAGRAPH || type == CMARK_NODE_CODE_BLOCK ||
|
|
92
|
+
type == CMARK_NODE_LIST || type == CMARK_NODE_BLOCK_QUOTE) {
|
|
93
|
+
return; /* Already has block content */
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
/* Get text content */
|
|
97
|
+
const char *literal = cmark_node_get_literal(first_child);
|
|
98
|
+
if (!literal) return;
|
|
99
|
+
|
|
100
|
+
/* Check if it needs block parsing */
|
|
101
|
+
if (!has_block_content(literal)) return;
|
|
102
|
+
|
|
103
|
+
/* Create a new parser for the footnote content */
|
|
104
|
+
cmark_parser *sub_parser = cmark_parser_new(CMARK_OPT_FOOTNOTES);
|
|
105
|
+
if (!sub_parser) return;
|
|
106
|
+
|
|
107
|
+
/* Parse the content */
|
|
108
|
+
cmark_parser_feed(sub_parser, literal, strlen(literal));
|
|
109
|
+
cmark_node *parsed = cmark_parser_finish(sub_parser);
|
|
110
|
+
|
|
111
|
+
if (parsed) {
|
|
112
|
+
/* Remove old content */
|
|
113
|
+
while (first_child) {
|
|
114
|
+
cmark_node *next = cmark_node_next(first_child);
|
|
115
|
+
cmark_node_unlink(first_child);
|
|
116
|
+
cmark_node_free(first_child);
|
|
117
|
+
first_child = next;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
/* Add parsed blocks */
|
|
121
|
+
cmark_node *child = cmark_node_first_child(parsed);
|
|
122
|
+
while (child) {
|
|
123
|
+
cmark_node *next = cmark_node_next(child);
|
|
124
|
+
cmark_node_unlink(child);
|
|
125
|
+
cmark_node_append_child(footnote_def, child);
|
|
126
|
+
child = next;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
cmark_node_free(parsed);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
cmark_parser_free(sub_parser);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* Post-process footnotes to support block-level content
|
|
137
|
+
*/
|
|
138
|
+
cmark_node *apex_process_advanced_footnotes(cmark_node *root, cmark_parser *parser) {
|
|
139
|
+
if (!root) return root;
|
|
140
|
+
|
|
141
|
+
cmark_iter *iter = cmark_iter_new(root);
|
|
142
|
+
cmark_event_type ev_type;
|
|
143
|
+
cmark_node *cur;
|
|
144
|
+
|
|
145
|
+
while ((ev_type = cmark_iter_next(iter)) != CMARK_EVENT_DONE) {
|
|
146
|
+
cur = cmark_iter_get_node(iter);
|
|
147
|
+
|
|
148
|
+
if (ev_type == CMARK_EVENT_ENTER) {
|
|
149
|
+
cmark_node_type type = cmark_node_get_type(cur);
|
|
150
|
+
|
|
151
|
+
/* Check if this is a footnote definition */
|
|
152
|
+
if (type == CMARK_NODE_FOOTNOTE_DEFINITION) {
|
|
153
|
+
reparse_footnote_blocks(cur, parser);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
cmark_iter_free(iter);
|
|
159
|
+
return root;
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* Postprocess function for the extension
|
|
164
|
+
*/
|
|
165
|
+
static cmark_node *postprocess(cmark_syntax_extension *ext,
|
|
166
|
+
cmark_parser *parser,
|
|
167
|
+
cmark_node *root) {
|
|
168
|
+
(void)ext;
|
|
169
|
+
return apex_process_advanced_footnotes(root, parser);
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Create advanced footnotes extension
|
|
174
|
+
*/
|
|
175
|
+
cmark_syntax_extension *create_advanced_footnotes_extension(void) {
|
|
176
|
+
cmark_syntax_extension *ext = cmark_syntax_extension_new("advanced_footnotes");
|
|
177
|
+
if (!ext) return NULL;
|
|
178
|
+
|
|
179
|
+
/* Set postprocess callback */
|
|
180
|
+
cmark_syntax_extension_set_postprocess_func(ext, postprocess);
|
|
181
|
+
|
|
182
|
+
return ext;
|
|
183
|
+
}
|
|
184
|
+
|