use crate::prelude::*;
use std::num::NonZero;
pub use input::{ Input, Needle };
pub use stateful::ParserStateful;
pub use stateless::Parser;
pub mod input;
pub mod stateful;
pub mod stateless;
pub mod util;
pub struct Success<I, O> {
pub output: O,
pub remaining_input: I,
}
#[derive(Debug)]
pub enum Error<E> {
NotEnoughData { missing: Option<NonZero<usize>> },
Error { error: E },
Fatal { error: E }
}
pub type Result<I, O, E = ()> = std::result::Result<Success<I, O>, Error<E>>;
pub type ParserPhantom<I, O, E = ()> = PhantomData<ParserPhantomImpl<I, O, E>>;
#[doc(hidden)]
pub struct ParserPhantomImpl<I, O, E>
where
I: Input
{
__inner: fn(I) -> Result<I, O, E>
}
impl<E> Error<E> {
#[inline]
fn from<EFrom>(error: Error<EFrom>) -> Self
where
EFrom: Into<E>
{
use self::Error::*;
match error {
NotEnoughData { missing } => { NotEnoughData { missing } }
Error { error } => { Error { error: error.into() } }
Fatal { error } => { Fatal { error: error.into() } }
}
}
#[inline]
fn into<EInto>(self) -> Error<EInto>
where
E: Into<EInto>
{
Error::from(self)
}
}
#[inline]
const fn max_init_cap<T>() -> usize {
const MAX_BYTES: usize = 1024 * 1024;
if size_of::<T>() == 0 {
MAX_BYTES
} else {
MAX_BYTES / size_of::<T>()
}
}