icaparse 0.2.0

A tiny, safe, speedy ICAP/1.0 parser.
Documentation
  • Coverage
  • 100%
    48 out of 48 items documented4 out of 19 items with examples
  • Size
  • Source code size: 58.42 kB This is the summed size of all the files inside the crates.io package for this release.
  • Documentation size: 5.05 MB This is the summed size of all files generated by rustdoc for all configured targets
  • Ø build duration
  • this release: 11s Average build duration of successful builds.
  • all releases: 11s Average build duration of successful builds in releases after 2024-10-23.
  • Links
  • chills42/icaparse
    7 1 0
  • crates.io
  • Dependencies
  • Versions
  • Owners
  • chills42

httparse

crates.io

A push parser for the ICAP 1.0 protocol. Avoids allocations. Fast.

The goal of the library is to support the ICAP specification as defined in RFC 3507.

Documentation

Usage

let mut headers = [icaparse::EMPTY_HEADER; 16];
let mut req = icaparse::Request::new(&mut headers);

let buf = b"RESPMOD /index.html ICAP/1.0\r\nHost";
assert!(try!(req.parse(buf)).is_partial());

// a partial request, so we try again once we have more data

let buf = b"RESPMOD /index.html ICAP/1.0\r\nHost: example.domain\r\nEncapsulated:null-body=0\r\n\r\n";
assert!(try!(req.parse(buf)).is_complete());

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.