//! Turn a string of markdown into events. use crate::content::document::document; use crate::event::{Event, Point}; use crate::{Constructs, Options}; /// Info needed, in all content types, when parsing markdown. /// /// Importantly, this contains a set of known definitions. /// It also references the input value as bytes (`u8`). #[derive(Debug)] pub struct ParseState<'a> { pub constructs: &'a Constructs, /// List of chars. pub bytes: &'a [u8], /// Set of defined identifiers. pub definitions: Vec, } /// Turn a string of markdown into events. /// /// Passes the bytes back so the compiler can access the source. pub fn parse<'a>(value: &'a str, options: &'a Options) -> (Vec, &'a [u8]) { let mut parse_state = ParseState { constructs: &options.constructs, bytes: value.as_bytes(), definitions: vec![], }; let events = document( &mut parse_state, Point { line: 1, column: 1, index: 0, vs: 0, }, ); (events, parse_state.bytes) }