Parse FROM, UNTIL and EXCEPT

This commit is contained in:
Joscha 2021-11-19 01:04:48 +01:00
parent d7c843ed86
commit 2724d2aefe

View file

@ -13,6 +13,7 @@ struct TodayfileParser;
type Result<T> = result::Result<T, Error<Rule>>; type Result<T> = result::Result<T, Error<Rule>>;
#[must_use]
fn fail<S: Into<String>, T>(span: Span, message: S) -> Result<T> { fn fail<S: Into<String>, T>(span: Span, message: S) -> Result<T> {
Err(Error::new_from_span( Err(Error::new_from_span(
ErrorVariant::CustomError { ErrorVariant::CustomError {
@ -46,6 +47,31 @@ fn parse_datum(p: Pair<Rule>) -> Result<NaiveDate> {
} }
} }
fn parse_date(p: Pair<Rule>) -> Result<Spec> {
dbg!(p);
todo!()
}
fn parse_from(p: Pair<Rule>) -> Result<NaiveDate> {
assert_eq!(p.as_rule(), Rule::from);
parse_datum(p.into_inner().next().unwrap())
}
fn parse_until(p: Pair<Rule>) -> Result<NaiveDate> {
assert_eq!(p.as_rule(), Rule::until);
parse_datum(p.into_inner().next().unwrap())
}
fn parse_except(p: Pair<Rule>) -> Result<NaiveDate> {
assert_eq!(p.as_rule(), Rule::except);
parse_datum(p.into_inner().next().unwrap())
}
fn parse_done(p: Pair<Rule>) -> Result<Done> {
dbg!(p);
todo!()
}
#[derive(Default)] #[derive(Default)]
struct Options { struct Options {
when: Vec<Spec>, when: Vec<Spec>,
@ -55,26 +81,6 @@ struct Options {
done: Vec<Done>, done: Vec<Done>,
} }
fn parse_date(p: Pair<Rule>, opts: &mut Options) -> Result<()> {
todo!()
}
fn parse_from(p: Pair<Rule>, opts: &mut Options) -> Result<()> {
todo!()
}
fn parse_until(p: Pair<Rule>, opts: &mut Options) -> Result<()> {
todo!()
}
fn parse_except(p: Pair<Rule>, opts: &mut Options) -> Result<()> {
todo!()
}
fn parse_done(p: Pair<Rule>, opts: &mut Options) -> Result<()> {
todo!()
}
fn parse_options(p: Pair<Rule>) -> Result<Options> { fn parse_options(p: Pair<Rule>) -> Result<Options> {
assert!(matches!( assert!(matches!(
p.as_rule(), p.as_rule(),
@ -84,11 +90,13 @@ fn parse_options(p: Pair<Rule>) -> Result<Options> {
let mut opts = Options::default(); let mut opts = Options::default();
for opt in p.into_inner() { for opt in p.into_inner() {
match opt.as_rule() { match opt.as_rule() {
Rule::date => parse_date(opt, &mut opts)?, Rule::date => opts.when.push(parse_date(opt)?),
Rule::from => parse_from(opt, &mut opts)?, Rule::from if opts.from.is_none() => opts.from = Some(parse_from(opt)?),
Rule::until => parse_until(opt, &mut opts)?, Rule::from => fail(opt.as_span(), "FROM already defined earlier")?,
Rule::except => parse_except(opt, &mut opts)?, Rule::until if opts.until.is_none() => opts.until = Some(parse_until(opt)?),
Rule::done => parse_done(opt, &mut opts)?, Rule::until => fail(opt.as_span(), "UNTIL already defined earlier")?,
Rule::except => opts.except.push(parse_except(opt)?),
Rule::done => opts.done.push(parse_done(opt)?),
_ => unreachable!(), _ => unreachable!(),
} }
} }