#iri

oxiri

Simple and fast implementation of IRI validation and relative IRI resolution

4 releases

0.2.2 Mar 27, 2022
0.2.1 Jan 10, 2022
0.2.0 Jan 6, 2022
0.1.1 Jul 10, 2020
0.1.0 May 1, 2020

#167 in Parser implementations

Download history 853/week @ 2022-08-08 653/week @ 2022-08-15 554/week @ 2022-08-22 816/week @ 2022-08-29 735/week @ 2022-09-05 880/week @ 2022-09-12 695/week @ 2022-09-19 930/week @ 2022-09-26 827/week @ 2022-10-03 704/week @ 2022-10-10 820/week @ 2022-10-17 785/week @ 2022-10-24 1124/week @ 2022-10-31 779/week @ 2022-11-07 1465/week @ 2022-11-14 776/week @ 2022-11-21

4,211 downloads per month
Used in 44 crates (10 directly)

MIT/Apache

47KB
1K SLoC

OxIRI

actions status Latest Version Released API docs

OxIRI is a simple and fast implementation of IRIs based on RFC 3987.

It allows zero stack allocation IRI validation and resolution.

Example:

use oxiri::Iri;

// Parse and validate base IRI
let base_iri = Iri::parse("http://foo.com/bar/baz").unwrap();

// Validate and resolve relative IRI
let iri = base_iri.resolve("bat#foo").unwrap();
assert_eq!("http://foo.com/bar/bat#foo", iri.as_str());

// Extract IRI components
assert_eq!(iri.scheme(), "http");
assert_eq!(iri.authority(), Some("foo.com"));
assert_eq!(iri.path(), "/bar/bat");
assert_eq!(iri.query(), None);
assert_eq!(iri.fragment(), Some("foo"));

If serde is available, Iri and IriRef implement the Serialize and Deserialize traits and encode the IRI as a string.

License

This project is licensed under either of

  • Apache License, Version 2.0, (LICENSE-APACHE or <http://www.apache.org/licenses/LICENSE-2.0>)
  • MIT license (LICENSE-MIT or <http://opensource.org/licenses/MIT>)

at your option.

Contribution

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

Dependencies

~64KB