markdown_it/parser/
main.rs1use derivative::Derivative;
2
3use crate::common::ruler::Ruler;
4use crate::common::sourcemap::SourcePos;
5use crate::common::TypeKey;
6use crate::parser::block::{self, BlockParser};
7use crate::parser::core::{Root, *};
8use crate::parser::extset::MarkdownItExtSet;
9use crate::parser::inline::{self, InlineParser};
10use crate::parser::linkfmt::{LinkFormatter, MDLinkFormatter};
11use crate::Node;
12
13type RuleFn = fn (&mut Node, &MarkdownIt);
14
15#[derive(Derivative)]
16#[derivative(Debug)]
17pub struct MarkdownIt {
19 pub block: BlockParser,
21
22 pub inline: InlineParser,
24
25 pub link_formatter: Box<dyn LinkFormatter>,
27
28 pub ext: MarkdownItExtSet,
30
31 #[doc(hidden)]
36 pub max_nesting: u32,
37
38 pub max_indent: i32,
41
42 ruler: Ruler<TypeKey, RuleFn>,
43}
44
45impl MarkdownIt {
46 pub fn new() -> Self {
47 Self::default()
48 }
49
50 pub fn parse(&self, src: &str) -> Node {
51 let mut node = Node::new(Root::new(src.to_owned()));
52 node.srcmap = Some(SourcePos::new(0, src.len()));
53
54 for rule in self.ruler.iter() {
55 rule(&mut node, self);
56 debug_assert!(node.is::<Root>(), "root node of the AST must always be Root");
57 }
58 node
59 }
60
61 pub fn add_rule<T: CoreRule>(&mut self) -> RuleBuilder<RuleFn> {
62 let item = self.ruler.add(TypeKey::of::<T>(), T::run);
63 RuleBuilder::new(item)
64 }
65
66 pub fn has_rule<T: CoreRule>(&mut self) -> bool {
67 self.ruler.contains(TypeKey::of::<T>())
68 }
69
70 pub fn remove_rule<T: CoreRule>(&mut self) {
71 self.ruler.remove(TypeKey::of::<T>());
72 }
73}
74
75impl Default for MarkdownIt {
76 fn default() -> Self {
77 let mut md = Self {
78 block: BlockParser::new(),
79 inline: InlineParser::new(),
80 link_formatter: Box::new(MDLinkFormatter::new()),
81 ext: MarkdownItExtSet::new(),
82 max_nesting: 100,
83 ruler: Ruler::new(),
84 max_indent: i32::MAX,
85 };
86 block::builtin::add(&mut md);
87 inline::builtin::add(&mut md);
88 md
89 }
90}