Handle things separated by things differently
I noticed that programs like '{} would parse correctly while '{ } would
expect an inner element. This was because the leading space was actually
part of the element parser, which is a violation of the (as of yet
unspoken) rule that parsers should not parse surrounding whitespace.
Because whitespace whas treated differently from everywhere else and
because this implementation was wrong, I decided to reimplement it,
abstracting the concept of things separated by other things with
optional trailing things. I did this in such a way that surrounding
whitespace is not touched.
This commit is contained in:
parent
407786b98c
commit
6533c9dcf7
10 changed files with 116 additions and 77 deletions
|
|
@ -4,12 +4,12 @@ use chumsky::prelude::*;
|
|||
|
||||
use crate::ast::{Expr, Ident, Space, TableDestr, TablePattern, TablePatternElem};
|
||||
|
||||
use super::basic::{EParser, Error};
|
||||
use super::basic::{separated_by, EParser, Error};
|
||||
|
||||
fn table_pattern_elem(
|
||||
space: EParser<Space>,
|
||||
ident: EParser<Ident>,
|
||||
) -> impl Parser<char, TablePatternElem, Error = Error> {
|
||||
) -> impl Parser<char, TablePatternElem, Error = Error> + Clone {
|
||||
let positional = ident.clone().map(TablePatternElem::Positional);
|
||||
|
||||
let named = ident
|
||||
|
|
@ -30,22 +30,19 @@ fn table_pattern_elem(
|
|||
}
|
||||
|
||||
pub fn table_pattern(space: EParser<Space>, ident: EParser<Ident>) -> EParser<TablePattern> {
|
||||
let elem = space
|
||||
let elem = table_pattern_elem(space.clone(), ident);
|
||||
let separator = space.clone().then_ignore(just(',')).then(space.clone());
|
||||
let trailing_separator = space.clone().then_ignore(just(','));
|
||||
|
||||
space
|
||||
.clone()
|
||||
.then(table_pattern_elem(space.clone(), ident))
|
||||
.then(space.clone())
|
||||
.map(|((s0, elem), s1)| (s0, elem, s1));
|
||||
|
||||
let trailing_comma = just(',').ignore_then(space).or_not();
|
||||
|
||||
let elems = elem.separated_by(just(',')).then(trailing_comma);
|
||||
|
||||
just('{')
|
||||
.ignore_then(elems)
|
||||
.then_ignore(just('}'))
|
||||
.map_with_span(|(elems, trailing_comma), span| TablePattern {
|
||||
.then(separated_by(elem, separator, trailing_separator))
|
||||
.then(space)
|
||||
.delimited_by(just('{'), just('}'))
|
||||
.map_with_span(|((s0, elems), s1), span| TablePattern {
|
||||
s0,
|
||||
elems,
|
||||
trailing_comma,
|
||||
s1,
|
||||
span,
|
||||
})
|
||||
.boxed()
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue