From 1ce16abed551138d4754c84b05af6cbcff6161fd Mon Sep 17 00:00:00 2001 From: Ed Page Date: Wed, 1 Feb 2023 15:16:33 -0600 Subject: [PATCH] feat(input): Blankt impl for all slices This does not help with `Compare` (because of ignore case) and `FindSlice` (`memchr`). Inspired by rust-bakery/nom#1482 --- src/input.rs | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) diff --git a/src/input.rs b/src/input.rs index 411c39c3..28774844 100644 --- a/src/input.rs +++ b/src/input.rs @@ -54,7 +54,7 @@ use core::num::NonZeroUsize; use crate::error::{ErrorKind, ParseError}; -use crate::lib::std::iter::{Copied, Enumerate}; +use crate::lib::std::iter::{Cloned, Enumerate}; use crate::lib::std::ops::{ Range, RangeFrom, RangeFull, RangeInclusive, RangeTo, RangeToInclusive, }; @@ -291,14 +291,14 @@ impl<'a, T> SliceLen for &'a [T] { } } -impl SliceLen for [u8; LEN] { +impl SliceLen for [T; LEN] { #[inline] fn slice_len(&self) -> usize { self.len() } } -impl<'a, const LEN: usize> SliceLen for &'a [u8; LEN] { +impl<'a, T, const LEN: usize> SliceLen for &'a [T; LEN] { #[inline] fn slice_len(&self) -> usize { self.len() @@ -362,15 +362,18 @@ pub trait Input: Clone { fn next_slice(&self, offset: usize) -> (Self, Self::Slice); } -impl<'i> Input for &'i [u8] { - type Token = u8; - type Slice = &'i [u8]; +impl<'i, T> Input for &'i [T] +where + T: Clone, +{ + type Token = T; + type Slice = &'i [T]; - type IterOffsets = Enumerate>>; + type IterOffsets = Enumerate>>; #[inline(always)] fn iter_offsets(&self) -> Self::IterOffsets { - self.iter().copied().enumerate() + self.iter().cloned().enumerate() } #[inline(always)] fn input_len(&self) -> usize { @@ -382,7 +385,7 @@ impl<'i> Input for &'i [u8] { if self.is_empty() { None } else { - Some((&self[1..], self[0])) + Some((&self[1..], self[0].clone())) } } @@ -391,7 +394,7 @@ impl<'i> Input for &'i [u8] { where P: Fn(Self::Token) -> bool, { - self.iter().position(|b| predicate(*b)) + self.iter().position(|b| predicate(b.clone())) } #[inline(always)] fn offset_at(&self, tokens: usize) -> Result { @@ -803,7 +806,7 @@ pub trait Offset { fn offset_to(&self, second: &Self) -> usize; } -impl<'a> Offset for &'a [u8] { +impl<'a, T> Offset for &'a [T] { fn offset_to(&self, second: &Self) -> usize { let fst = self.as_ptr(); let snd = second.as_ptr(); @@ -812,8 +815,8 @@ impl<'a> Offset for &'a [u8] { } } -/// Convenience implementation to accept `&[u8]` instead of `&&[u8]` as above -impl Offset for [u8] { +/// Convenience implementation to accept `&[T]` instead of `&&[T]` as above +impl Offset for [T] { fn offset_to(&self, second: &Self) -> usize { let fst = self.as_ptr(); let snd = second.as_ptr(); @@ -1218,7 +1221,10 @@ pub trait UpdateSlice: Input { fn update_slice(self, inner: Self::Slice) -> Self; } -impl<'a> UpdateSlice for &'a [u8] { +impl<'a, T> UpdateSlice for &'a [T] +where + T: Clone, +{ #[inline] fn update_slice(self, inner: Self::Slice) -> Self { inner