#iri #validation #relative #resolution #base #rfc #allocation

oxiri

Simple and fast implementation of IRI validation and relative IRI resolution

6 releases

0.2.3 Mar 23, 2024
0.2.3-alpha.1 Jan 2, 2024
0.2.2 Mar 27, 2022
0.2.1 Jan 10, 2022
0.1.0 May 1, 2020

#131 in Parser implementations

Download history 1570/week @ 2024-03-14 2299/week @ 2024-03-21 2637/week @ 2024-03-28 1374/week @ 2024-04-04 1415/week @ 2024-04-11 1261/week @ 2024-04-18 1426/week @ 2024-04-25 1558/week @ 2024-05-02 1409/week @ 2024-05-09 1487/week @ 2024-05-16 1811/week @ 2024-05-23 1905/week @ 2024-05-30 1859/week @ 2024-06-06 1840/week @ 2024-06-13 2072/week @ 2024-06-20 1752/week @ 2024-06-27

7,920 downloads per month
Used in 117 crates (29 directly)

MIT/Apache

53KB
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

~175KB