Struct pulldown_cmark_to_cmark::State
source · pub struct State<'a> {
pub newlines_before_start: usize,
pub list_stack: Vec<Option<u64>>,
pub padding: Vec<Cow<'a, str>>,
pub table_alignments: Vec<Alignment>,
pub table_headers: Vec<String>,
pub text_for_header: Option<String>,
pub is_in_code_block: bool,
pub last_was_html: bool,
pub last_was_text_without_trailing_newline: bool,
pub current_shortcut_text: Option<String>,
pub shortcuts: Vec<(String, String, String)>,
}
Expand description
The state of the cmark_resume()
and cmark_resume_with_options()
functions.
This does not only allow introspection, but enables the user
to halt the serialization at any time, and resume it later.
Fields§
§newlines_before_start: usize
The amount of newlines to insert after Event::Start(...)
list_stack: Vec<Option<u64>>
The lists and their types for which we have seen a Event::Start(List(...))
tag
padding: Vec<Cow<'a, str>>
The computed padding and prefix to print after each newline.
This changes with the level of BlockQuote
and List
events.
table_alignments: Vec<Alignment>
Keeps the current table alignments, if we are currently serializing a table.
table_headers: Vec<String>
Keeps the current table headers, if we are currently serializing a table.
text_for_header: Option<String>
The last seen text when serializing a header
is_in_code_block: bool
Is set while we are handling text in a code block
last_was_html: bool
True if the last event was html. Used to inject additional newlines to support markdown inside of HTML tags.
last_was_text_without_trailing_newline: bool
True if the last event was text and the text does not have trailing newline. Used to inject additional newlines before code block end fence.
current_shortcut_text: Option<String>
Keeps track of the last seen shortcut/link
shortcuts: Vec<(String, String, String)>
A list of shortcuts seen so far for later emission
Implementations§
Trait Implementations§
source§impl<'a> Ord for State<'a>
impl<'a> Ord for State<'a>
source§impl<'a> PartialEq<State<'a>> for State<'a>
impl<'a> PartialEq<State<'a>> for State<'a>
source§impl<'a> PartialOrd<State<'a>> for State<'a>
impl<'a> PartialOrd<State<'a>> for State<'a>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read more