From 52a4dab67cf9c71786907b7d91ed1040f5fd5f4e Mon Sep 17 00:00:00 2001 From: Tom Alexander Date: Thu, 14 Sep 2023 18:14:26 -0400 Subject: [PATCH] Use the timestamp parser in planning. Previously we did not support inactive timestamps in planning. This fixes that. --- src/parser/planning.rs | 29 ++++++++++++++++------------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/src/parser/planning.rs b/src/parser/planning.rs index 15312bb..cf9116b 100644 --- a/src/parser/planning.rs +++ b/src/parser/planning.rs @@ -1,16 +1,16 @@ use nom::branch::alt; -use nom::bytes::complete::is_not; use nom::bytes::complete::tag; use nom::bytes::complete::tag_no_case; -use nom::character::complete::line_ending; -use nom::character::complete::space0; -use nom::character::complete::space1; -use nom::combinator::eof; -use nom::multi::separated_list1; +use nom::multi::many1; use nom::sequence::tuple; use super::org_source::OrgSource; +use super::timestamp::timestamp; use super::util::maybe_consume_trailing_whitespace_if_not_exiting; +use super::util::org_line_ending; +use super::util::org_spaces0; +use super::util::org_spaces1; +use crate::context::parser_with_context; use crate::context::RefContext; use crate::error::Res; use crate::parser::util::get_consumed; @@ -23,9 +23,10 @@ pub(crate) fn planning<'b, 'g, 'r, 's>( input: OrgSource<'s>, ) -> Res, Planning<'s>> { start_of_line(input)?; - let (remaining, _leading_whitespace) = space0(input)?; - let (remaining, _planning_parameters) = separated_list1(space1, planning_parameter)(remaining)?; - let (remaining, _trailing_ws) = tuple((space0, alt((line_ending, eof))))(remaining)?; + let (remaining, _leading_whitespace) = org_spaces0(input)?; + let (remaining, _planning_parameters) = + many1(parser_with_context!(planning_parameter)(context))(remaining)?; + let (remaining, _trailing_ws) = tuple((org_spaces0, org_line_ending))(remaining)?; let (remaining, _trailing_ws) = maybe_consume_trailing_whitespace_if_not_exiting(context, remaining)?; @@ -40,15 +41,17 @@ pub(crate) fn planning<'b, 'g, 'r, 's>( } #[cfg_attr(feature = "tracing", tracing::instrument(ret, level = "debug"))] -fn planning_parameter<'s>(input: OrgSource<'s>) -> Res, OrgSource<'s>> { +fn planning_parameter<'b, 'g, 'r, 's>( + context: RefContext<'b, 'g, 'r, 's>, + input: OrgSource<'s>, +) -> Res, OrgSource<'s>> { let (remaining, _planning_type) = alt(( tag_no_case("DEADLINE"), tag_no_case("SCHEDULED"), tag_no_case("CLOSED"), ))(input)?; - let (remaining, _gap) = tuple((tag(":"), space1))(remaining)?; - // TODO: Make this invoke the real timestamp parser. - let (remaining, _timestamp) = tuple((tag("<"), is_not("\r\n>"), tag(">")))(remaining)?; + let (remaining, _gap) = tuple((tag(":"), org_spaces1))(remaining)?; + let (remaining, _timestamp) = timestamp(context, remaining)?; let source = get_consumed(input, remaining); Ok((remaining, source)) }