diff options
author | Titus Wormer <tituswormer@gmail.com> | 2022-06-20 17:06:00 +0200 |
---|---|---|
committer | Titus Wormer <tituswormer@gmail.com> | 2022-06-20 17:06:00 +0200 |
commit | 65dd765cceee8bdccc74c08066eec59a579a16b1 (patch) | |
tree | cb60ab00039135b6f0a65efcb508f73a8b39aa11 /src/content/flow.rs | |
parent | 61271d73128f8553f8c4c17927828cde52a25eba (diff) | |
download | markdown-rs-65dd765cceee8bdccc74c08066eec59a579a16b1.tar.gz markdown-rs-65dd765cceee8bdccc74c08066eec59a579a16b1.tar.bz2 markdown-rs-65dd765cceee8bdccc74c08066eec59a579a16b1.zip |
Add improved whitespace handling
* add several helpers for parsing betwen x and y `space_or_tab`s
* use those helpers in a bunch of places
* move initial indent parsing to flow constructs themselves
Diffstat (limited to 'src/content/flow.rs')
-rw-r--r-- | src/content/flow.rs | 45 |
1 files changed, 11 insertions, 34 deletions
diff --git a/src/content/flow.rs b/src/content/flow.rs index 22aa77f..f4af4ea 100644 --- a/src/content/flow.rs +++ b/src/content/flow.rs @@ -24,7 +24,7 @@ use crate::construct::{ code_indented::start as code_indented, definition::start as definition, heading_atx::start as heading_atx, heading_setext::start as heading_setext, html_flow::start as html_flow, paragraph::start as paragraph, - partial_whitespace::start as whitespace, thematic_break::start as thematic_break, + thematic_break::start as thematic_break, }; use crate::subtokenize::subtokenize; use crate::tokenizer::{Code, Event, Point, State, StateFnResult, TokenType, Tokenizer}; @@ -95,9 +95,16 @@ fn initial_before(tokenizer: &mut Tokenizer, code: Code) -> StateFnResult { match code { Code::None => (State::Ok, None), // To do: should all flow just start before the prefix? - _ => tokenizer.attempt_3(code_indented, code_fenced, html_flow, |ok| { - Box::new(if ok { after } else { before }) - })(tokenizer, code), + _ => tokenizer.attempt_7( + code_indented, + code_fenced, + html_flow, + heading_atx, + thematic_break, + definition, + heading_setext, + |ok| Box::new(if ok { after } else { before_paragraph }), + )(tokenizer, code), } } @@ -123,36 +130,6 @@ fn after(tokenizer: &mut Tokenizer, code: Code) -> StateFnResult { } } -/// Before flow, but not at code (indented) or code (fenced). -/// -/// Compared to flow (initial), normal flow can be arbitrarily prefixed. -/// -/// ```markdown -/// |qwe -/// ``` -fn before(tokenizer: &mut Tokenizer, code: Code) -> StateFnResult { - tokenizer.attempt( - |tokenizer, code| whitespace(tokenizer, code, TokenType::Whitespace), - |_ok| Box::new(before_after_prefix), - )(tokenizer, code) -} - -/// Before flow, after potential whitespace. -/// -/// ```markdown -/// |# asd -/// |*** -/// ``` -fn before_after_prefix(tokenizer: &mut Tokenizer, code: Code) -> StateFnResult { - tokenizer.attempt_4( - heading_atx, - thematic_break, - definition, - heading_setext, - |ok| Box::new(if ok { after } else { before_paragraph }), - )(tokenizer, code) -} - /// Before a paragraph. /// /// ```markdown |