pear 0.2.9

A pear is a fruit.
Documentation
use pear::input::{Text, Pear};
use pear::{macros::*, parsers::*};

type Result<'a, T> = pear::input::Result<T, Text<'a>>;

#[parser(rewind)]
fn ab<'a>(input: &mut Pear<Text<'a>>) -> Result<'a, ()> {
    eat('a')?;
    eat('b')?;
    eof()?;
}

#[parser(rewind)]
fn abc<'a>(input: &mut Pear<Text<'a>>) -> Result<'a, ()> {
    eat('a')?;
    eat('b')?;
    eat('c')?;
    eof()?;
}

#[parser(rewind)]
fn abcd<'a>(input: &mut Pear<Text<'a>>) -> Result<'a, ()> {
    eat('a')?;
    eat('b')?;
    eat('c')?;
    eat('d')?;
    eof()?;
}

#[parser]
fn combo<'a>(input: &mut Pear<Text<'a>>) -> Result<'a, &'a str> {
    switch! {
        ab() => "ab",
        abc() => "abc",
        abcd() => "abcd",
        _ => parse_error!("not ab, abc, or abcd")?
    }
}

#[test]
fn test_rewinding_ab() {
    let result = parse!(combo: Text::from("ab")).unwrap();
    assert_eq!(result, "ab")
}

#[test]
fn test_rewinding_abc() {
    let result = parse!(combo: Text::from("abc")).unwrap();
    assert_eq!(result, "abc")
}

#[test]
fn test_rewinding_abcd() {
    let result = parse!(combo: Text::from("abcd")).unwrap();
    assert_eq!(result, "abcd")
}

#[test]
fn test_rewinding_fail() {
    let result = parse!(combo: Text::from("a"));
    assert!(result.is_err());

    let result = parse!(combo: Text::from("abcdef"));
    assert!(result.is_err());
}