Skip to content

Commit

Permalink
Merge branch 'main' into char_impl_for_grapheme
Browse files Browse the repository at this point in the history
  • Loading branch information
Hedgehogo committed Dec 8, 2024
2 parents 567e26d + 758065d commit 083969b
Show file tree
Hide file tree
Showing 3 changed files with 47 additions and 21 deletions.
19 changes: 18 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ all-features = true
rustdoc-args = ["--cfg", "docsrs"]

[dependencies]
hashbrown = "0.14"
hashbrown = "0.15"
stacker = { version = "0.1", optional = true }
regex-automata = { version = "0.3", default-features = false, optional = true, features = ["alloc", "meta", "perf", "unicode", "nfa", "dfa", "hybrid"] }
spin = { version = "0.9", features = ["once"], default-features = false, optional = true }
Expand Down
47 changes: 28 additions & 19 deletions src/primitive.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,11 +41,12 @@ where
{
#[inline]
fn go<M: Mode>(&self, inp: &mut InputRef<'src, '_, I, E>) -> PResult<M, ()> {
let before = inp.cursor();
let before = inp.save();
match inp.next_maybe_inner() {
None => Ok(M::bind(|| ())),
Some(tok) => {
let span = inp.span_since(&before);
let span = inp.span_since(&before.cursor());
inp.rewind(before);
inp.add_alt(Some(None), Some(tok.into()), span);
Err(())
}
Expand Down Expand Up @@ -261,12 +262,13 @@ where
{
#[inline]
fn go<M: Mode>(&self, inp: &mut InputRef<'src, '_, I, E>) -> PResult<M, I::Token> {
let before = inp.cursor();
let before = inp.save();
match inp.next_inner() {
#[allow(suspicious_double_ref_op)] // Is this a clippy bug?
Some(tok) if self.seq.contains(tok.borrow()) => Ok(M::bind(|| tok)),
found => {
let err_span = inp.span_since(&before);
let err_span = inp.span_since(&before.cursor());
inp.rewind(before);
inp.add_alt(
self.seq.seq_iter().map(|e| Some(T::to_maybe_ref(e))),
found.map(|f| f.into()),
Expand Down Expand Up @@ -335,12 +337,13 @@ where
{
#[inline]
fn go<M: Mode>(&self, inp: &mut InputRef<'src, '_, I, E>) -> PResult<M, I::Token> {
let before = inp.cursor();
let before = inp.save();
match inp.next_inner() {
// #[allow(suspicious_double_ref_op)] // Is this a clippy bug?
Some(tok) if !self.seq.contains(tok.borrow()) => Ok(M::bind(|| tok)),
found => {
let err_span = inp.span_since(&before);
let err_span = inp.span_since(&before.cursor());
inp.rewind(before);
inp.add_alt(None, found.map(|f| f.into()), err_span);
Err(())
}
Expand Down Expand Up @@ -454,16 +457,19 @@ where
{
#[inline]
fn go<M: Mode>(&self, inp: &mut InputRef<'src, '_, I, E>) -> PResult<M, O> {
let before = inp.cursor();
let before = inp.save();
let next = inp.next_inner();
let err_span = inp.span_since(&before);
let found = match next {
Some(tok) => match (self.filter)(tok.clone(), &mut MapExtra::new(&before, inp)) {
Some(out) => return Ok(M::bind(|| out)),
None => Some(tok.into()),
},
Some(tok) => {
match (self.filter)(tok.clone(), &mut MapExtra::new(&before.cursor(), inp)) {
Some(out) => return Ok(M::bind(|| out)),
None => Some(tok.into()),
}
}
found => found.map(|f| f.into()),
};
let err_span = inp.span_since(before.cursor());
inp.rewind(before);
inp.add_alt(None, found, err_span);
Err(())
}
Expand Down Expand Up @@ -511,16 +517,17 @@ where
{
#[inline]
fn go<M: Mode>(&self, inp: &mut InputRef<'src, '_, I, E>) -> PResult<M, O> {
let before = inp.cursor();
let before = inp.save();
let next = inp.next_ref_inner();
let found = match next {
Some(tok) => match (self.filter)(tok, &mut MapExtra::new(&before, inp)) {
Some(tok) => match (self.filter)(tok, &mut MapExtra::new(&before.cursor(), inp)) {
Some(out) => return Ok(M::bind(|| out)),
None => Some(tok.into()),
},
found => found.map(|f| f.into()),
};
let err_span = inp.span_since(&before);
let err_span = inp.span_since(before.cursor());
inp.rewind(before);
inp.add_alt(None, found, err_span);
Err(())
}
Expand Down Expand Up @@ -548,11 +555,12 @@ where
{
#[inline]
fn go<M: Mode>(&self, inp: &mut InputRef<'src, '_, I, E>) -> PResult<M, I::Token> {
let before = inp.cursor();
let before = inp.save();
match inp.next_inner() {
Some(tok) => Ok(M::bind(|| tok)),
found => {
let err_span = inp.span_since(&before);
let err_span = inp.span_since(&before.cursor());
inp.rewind(before);
inp.add_alt(None, found.map(|f| f.into()), err_span);
Err(())
}
Expand Down Expand Up @@ -603,11 +611,12 @@ where
{
#[inline]
fn go<M: Mode>(&self, inp: &mut InputRef<'src, '_, I, E>) -> PResult<M, &'src I::Token> {
let before = inp.cursor();
let before = inp.save();
match inp.next_ref_inner() {
Some(tok) => Ok(M::bind(|| tok)),
found => {
let err_span = inp.span_since(&before);
let err_span = inp.span_since(&before.cursor());
inp.rewind(before);
inp.add_alt(None, found.map(|f| f.into()), err_span);
Err(())
}
Expand Down

0 comments on commit 083969b

Please sign in to comment.