3 unstable releases

0.2.0 Aug 21, 2021
0.1.1 Aug 6, 2021
0.1.0 Aug 4, 2021

#383 in Parser tooling

Download history 30/week @ 2024-08-25 18/week @ 2024-09-01 12/week @ 2024-09-08 36/week @ 2024-09-15 86/week @ 2024-09-22 17/week @ 2024-09-29 9/week @ 2024-10-06 15/week @ 2024-10-13 14/week @ 2024-10-20 22/week @ 2024-10-27 67/week @ 2024-11-03 2/week @ 2024-11-10 18/week @ 2024-11-17 88/week @ 2024-11-24 27/week @ 2024-12-01 43/week @ 2024-12-08

176 downloads per month
Used in sie4

MIT license

39KB
558 lines

nom-bufreader, adapters for BufReader around nom

*/!\Work in progress, if you put it in production, you fix it/!*

With this crate, you can assemble a nom parser with a BufReader alternative, synchronous or asynchronous. Due to incompatible buffering strategies, std::io::BufReader and futures::io::BufReader cannot be used directly. This crate proovide compatible forks instead, in the bufreader and async_bufreader modules.

It will hide for you the Incomplete handling in nom for streaming parsers, retrying and refilling buffers automatically.

Examples

sync

use nom_bufreader::bufreader::BufReader;
use nom_bufreader::{Error, Parse};
use std::{net::TcpListener, str::from_utf8};

fn main() -> Result<(), Error<()>> {
    let listener = TcpListener::bind("127.0.0.1:8080")?;
    let mut i = BufReader::new(listener.incoming().next().unwrap()?);

    // method, space and path are nom parsers
    let m = i.parse(method)?;
    let _ = i.parse(space)?;
    let p = i.parse(path)?;
    println!("got method {}, path {}", m, p);
    Ok(())
}

async

tokio

use nom_bufreader::async_bufreader::BufReader;
use nom_bufreader::{AsyncParse, Error};
use std::str::from_utf8;
use tokio_util::compat::TokioAsyncReadCompatExt;
use tokio::net::TcpListener;

#[tokio::main]
async fn main() -> Result<(), Error<()>> {
    let listener = TcpListener::bind("127.0.0.1:8080").await?;
    let mut i = BufReader::new(listener.accept().await?.0.compat());

    let m = i.parse(method).await?;
    let _ = i.parse(space).await?;
    let p = i.parse(path).await?;
    println!("got method {}, path {}", m, p);
    Ok(())
}

async-std

use nom_bufreader::async_bufreader::BufReader;
use nom_bufreader::{AsyncParse, Error};
use std::str::from_utf8;
use async_std::net::TcpListener;

#[async_std::main]
async fn main() -> Result<(), Error<()>> {
    let listener = TcpListener::bind("127.0.0.1:8080").await?;
    let mut i = BufReader::new(listener.accept().await?.0);

    let m = i.parse(method).await?;
    let _ = i.parse(space).await?;
    let p = i.parse(path).await?;
    println!("got method {}, path {}", m, p);
    Ok(())
}

Dependencies

~0.8–1.3MB
~23K SLoC