4 releases (2 breaking)

0.3.0 Aug 3, 2023
0.2.0 Jun 17, 2023
0.1.1 Jun 14, 2023
0.1.0 Jun 14, 2023

#9 in #markdown-it

Download history 26/week @ 2024-10-08 39/week @ 2024-10-15 209/week @ 2024-10-22 24/week @ 2024-10-29 10/week @ 2024-11-05 6/week @ 2024-11-12 18/week @ 2024-11-19 11/week @ 2024-11-26 22/week @ 2024-12-03 43/week @ 2024-12-10 18/week @ 2024-12-17 23/week @ 2024-12-24 15/week @ 2024-12-31 23/week @ 2025-01-07 11/week @ 2025-01-14 19/week @ 2025-01-21

68 downloads per month
Used in mdbook-journal

Apache-2.0

7KB
59 lines

markdown-it-front-matter.rs

crates.io

A markdown-it.rs plugin to process front matter containers.

Usage

let parser = &mut markdown_it::MarkdownIt::new();
markdown_it_front_matter::add(parser);
let ast  = parser.parse("---\nfoo: bar\n---\n");

print!("{:#?}", ast.children);
// [
//     Node {
//         children: [],
//         srcmap: Some(
//             (
//                 0,
//                 16,
//             ),
//         ),
//         ext: NodeExtSet(
//             {},
//         ),
//         attrs: [],
//         node_type: markdown_it_front_matter::FrontMatter,
//         node_value: FrontMatter {
//             content: "foo: bar\n",
//         },
//     },
// ]

Valid Front Matter

Essentially, valid front matter is a fenced block:

  • Indicated by three or more dashes: ---
  • Opening and closing fences must be the same number of dash characters
  • Opening fence must begin on the first line of the markdown string/file
  • Opening fence must not be indented
---
valid-front-matter: true
---

Dependencies

~5–14MB
~189K SLoC