Footnote definitions are parsing on their own.
This commit is contained in:
		
							parent
							
								
									45db182421
								
							
						
					
					
						commit
						e5bc4cb14b
					
				| @ -21,6 +21,7 @@ use crate::parser::parser_context::ContextElement; | ||||
| use crate::parser::parser_context::ContextTree; | ||||
| use crate::parser::parser_context::ExitMatcherNode; | ||||
| use crate::parser::util::element_trailing_whitespace; | ||||
| use crate::parser::util::maybe_consume_trailing_whitespace; | ||||
| 
 | ||||
| use super::element::Element; | ||||
| use super::error::Res; | ||||
| @ -115,12 +116,7 @@ fn section<'r, 's>(context: Context<'r, 's>, input: &'s str) -> Res<&'s str, Sec | ||||
|     // Check if a parent exit matcher is causing the exit
 | ||||
|     exit_matcher_parser(context, remaining)?; | ||||
| 
 | ||||
|     let (remaining, _trailing_ws) = if context.should_consume_trailing_whitespace() { | ||||
|         opt(parser_with_context!(element_trailing_whitespace)(&parser_context))(remaining)? | ||||
| 
 | ||||
|     } else { | ||||
|         (remaining, None) | ||||
|     }; | ||||
|     let (remaining, _trailing_ws) = maybe_consume_trailing_whitespace(context, remaining)?; | ||||
| 
 | ||||
|     let source = get_consumed(input, remaining); | ||||
|     Ok((remaining, Section { source, children })) | ||||
|  | ||||
| @ -20,10 +20,6 @@ pub enum Element<'s> { | ||||
|     PlainList(PlainList<'s>), | ||||
|     GreaterBlock(GreaterBlock<'s>), | ||||
|     FootnoteDefinition(FootnoteDefinition<'s>), | ||||
|     /// The whitespace that follows an element.
 | ||||
|     ///
 | ||||
|     /// This isn't a real org-mode element. Except for items in plain lists, trailing blank lines belong to the preceding element. It is a separate `Element` in this enum to make parsing easier.
 | ||||
|     TrailingWhitespace(&'s str), | ||||
| } | ||||
| 
 | ||||
| impl<'s> Source<'s> for Element<'s> { | ||||
| @ -32,7 +28,6 @@ impl<'s> Source<'s> for Element<'s> { | ||||
|             Element::Paragraph(obj) => obj.source, | ||||
|             Element::PlainList(obj) => obj.source, | ||||
|             Element::GreaterBlock(obj) => obj.source, | ||||
|             Element::TrailingWhitespace(src) => src, | ||||
|             Element::FootnoteDefinition(obj) => obj.source, | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @ -8,8 +8,10 @@ use crate::parser::parser_context::ContextElement; | ||||
| use crate::parser::parser_context::ExitMatcherNode; | ||||
| use crate::parser::parser_with_context::parser_with_context; | ||||
| use crate::parser::util::blank_line; | ||||
| use crate::parser::util::element_trailing_whitespace; | ||||
| use crate::parser::util::exit_matcher_parser; | ||||
| use crate::parser::util::get_consumed; | ||||
| use crate::parser::util::maybe_consume_trailing_whitespace; | ||||
| use crate::parser::util::start_of_line; | ||||
| use crate::parser::util::whitespace_eof; | ||||
| use nom::branch::alt; | ||||
| @ -19,6 +21,7 @@ use nom::bytes::complete::take_while; | ||||
| use nom::character::complete::digit1; | ||||
| use nom::character::complete::multispace0; | ||||
| use nom::character::complete::space0; | ||||
| use nom::combinator::opt; | ||||
| use nom::combinator::recognize; | ||||
| use nom::combinator::verify; | ||||
| use nom::multi::many1; | ||||
| @ -44,6 +47,9 @@ pub fn footnote_definition<'r, 's>( | ||||
|     let exit_matcher = parser_with_context!(exit_matcher_parser)(&parser_context); | ||||
|     let (remaining, (children, _exit_contents)) = | ||||
|         many_till(element_matcher, exit_matcher)(remaining)?; | ||||
| 
 | ||||
|     let (remaining, _trailing_ws) = maybe_consume_trailing_whitespace(context, remaining)?; | ||||
| 
 | ||||
|     let source = get_consumed(input, remaining); | ||||
|     Ok(( | ||||
|         remaining, | ||||
|  | ||||
| @ -8,8 +8,10 @@ use crate::parser::parser_context::ChainBehavior; | ||||
| use crate::parser::parser_context::ContextElement; | ||||
| use crate::parser::parser_context::ExitMatcherNode; | ||||
| use crate::parser::parser_with_context::parser_with_context; | ||||
| use crate::parser::util::element_trailing_whitespace; | ||||
| use crate::parser::util::exit_matcher_parser; | ||||
| use crate::parser::util::get_consumed; | ||||
| use crate::parser::util::maybe_consume_trailing_whitespace; | ||||
| use crate::parser::util::start_of_line; | ||||
| use nom::branch::alt; | ||||
| use nom::bytes::complete::is_not; | ||||
| @ -53,6 +55,11 @@ pub fn greater_block<'r, 's>( | ||||
|     let (remaining, (children, _exit_contents)) = | ||||
|         many_till(element_matcher, exit_matcher)(remaining)?; | ||||
|     let (remaining, _end) = greater_block_end(&parser_context, remaining)?; | ||||
| 
 | ||||
|     // Not checking if parent exit matcher is causing exit because the greater_block_end matcher asserts we matched a full greater block
 | ||||
| 
 | ||||
|     let (remaining, _trailing_ws) = maybe_consume_trailing_whitespace(context, remaining)?; | ||||
| 
 | ||||
|     let parameters = match parameters { | ||||
|         Some((_ws, parameters)) => Some(parameters), | ||||
|         None => None, | ||||
|  | ||||
| @ -14,6 +14,7 @@ use crate::parser::parser_context::ExitMatcherNode; | ||||
| use crate::parser::parser_with_context::parser_with_context; | ||||
| use crate::parser::util::element_trailing_whitespace; | ||||
| use crate::parser::util::exit_matcher_parser; | ||||
| use crate::parser::util::maybe_consume_trailing_whitespace; | ||||
| use crate::parser::util::start_of_line; | ||||
| 
 | ||||
| use super::element::non_paragraph_element; | ||||
| @ -39,13 +40,7 @@ pub fn paragraph<'r, 's>(context: Context<'r, 's>, input: &'s str) -> Res<&'s st | ||||
| 
 | ||||
|     // Not checking parent exit matcher because if there are any children matched then we have a valid paragraph.
 | ||||
| 
 | ||||
|     let (remaining, _trailing_ws) = if context.should_consume_trailing_whitespace() { | ||||
|         opt(parser_with_context!(element_trailing_whitespace)( | ||||
|             &parser_context, | ||||
|         ))(remaining)? | ||||
|     } else { | ||||
|         (remaining, None) | ||||
|     }; | ||||
|     let (remaining, _trailing_ws) = maybe_consume_trailing_whitespace(context, remaining)?; | ||||
| 
 | ||||
|     let source = get_consumed(input, remaining); | ||||
| 
 | ||||
|  | ||||
| @ -4,6 +4,7 @@ use super::error::Res; | ||||
| use super::greater_element::PlainList; | ||||
| use super::greater_element::PlainListItem; | ||||
| use super::parser_with_context::parser_with_context; | ||||
| use super::util::maybe_consume_trailing_whitespace; | ||||
| use super::util::non_whitespace_character; | ||||
| use super::Context; | ||||
| use crate::parser::element::element; | ||||
| @ -49,6 +50,9 @@ pub fn plain_list<'r, 's>(context: Context<'r, 's>, input: &'s str) -> Res<&'s s | ||||
|             Ok(_) | Err(_) => break, | ||||
|         }; | ||||
|     } | ||||
| 
 | ||||
|     let (remaining, _trailing_ws) = maybe_consume_trailing_whitespace(context, remaining)?; | ||||
| 
 | ||||
|     let source = get_consumed(input, remaining); | ||||
|     Ok((remaining, PlainList { source, children })) | ||||
| } | ||||
|  | ||||
| @ -1,3 +1,5 @@ | ||||
| use crate::parser::parser_with_context::parser_with_context; | ||||
| 
 | ||||
| use super::error::CustomError; | ||||
| use super::error::MyError; | ||||
| use super::error::Res; | ||||
| @ -10,6 +12,7 @@ use nom::character::complete::none_of; | ||||
| use nom::character::complete::space0; | ||||
| use nom::combinator::eof; | ||||
| use nom::combinator::not; | ||||
| use nom::combinator::opt; | ||||
| use nom::combinator::peek; | ||||
| use nom::combinator::recognize; | ||||
| use nom::multi::many0; | ||||
| @ -89,6 +92,20 @@ pub fn element_trailing_whitespace<'r, 's>( | ||||
|     alt((eof, recognize(many0(blank_line))))(input) | ||||
| } | ||||
| 
 | ||||
| #[tracing::instrument(ret, level = "debug")] | ||||
| pub fn maybe_consume_trailing_whitespace<'r, 's>( | ||||
|     context: Context<'r, 's>, | ||||
|     input: &'s str, | ||||
| ) -> Res<&'s str, Option<&'s str>> { | ||||
|     if context.should_consume_trailing_whitespace() { | ||||
|         Ok(opt(parser_with_context!(element_trailing_whitespace)( | ||||
|             context, | ||||
|         ))(input)?) | ||||
|     } else { | ||||
|         Ok((input, None)) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| #[tracing::instrument(ret, level = "debug")] | ||||
| pub fn trailing_whitespace(input: &str) -> Res<&str, &str> { | ||||
|     alt((eof, recognize(tuple((line_ending, many0(blank_line))))))(input) | ||||
|  | ||||
| @ -1,3 +1,33 @@ | ||||
| prologue *goes here* I guess *bold | ||||
| text* | ||||
| 
 | ||||
| bold*wont* start *or stop*when there is text outside it | ||||
| 
 | ||||
| I guess *regular | ||||
| 
 | ||||
| text* | ||||
| 
 | ||||
| [foo *bar] baz* car | ||||
| 
 | ||||
| 
 | ||||
| *nesting *bold entrances* and* exits | ||||
| 
 | ||||
| * Heading | ||||
| 
 | ||||
| body of heading | ||||
| 
 | ||||
| ** Child heading | ||||
| ** Immediate second child heading | ||||
| 
 | ||||
| * Second top-level heading | ||||
| foo bar | ||||
| 1. This is a list immediately after a paragraph | ||||
| 2. This is a second item in the list | ||||
|   1. This is a child of the second item | ||||
| #+begin_center | ||||
| 1. foo | ||||
| 2. bar | ||||
| #+end_center | ||||
| [fn:1] A footnote. | ||||
| 
 | ||||
| [fn:2] A multi- | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Tom Alexander
						Tom Alexander