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

oxiri

Simple and fast implementation of IRI validation and relative IRI resolution

12 releases

0.2.9 Dec 21, 2024
0.2.8 Oct 19, 2024
0.2.4 Aug 21, 2024
0.2.3 Mar 23, 2024
0.1.1 Jul 10, 2020

#212 in Parser implementations

Download history 2382/week @ 2024-09-19 2141/week @ 2024-09-26 2254/week @ 2024-10-03 2366/week @ 2024-10-10 3507/week @ 2024-10-17 2622/week @ 2024-10-24 3212/week @ 2024-10-31 1902/week @ 2024-11-07 2108/week @ 2024-11-14 2006/week @ 2024-11-21 2926/week @ 2024-11-28 2992/week @ 2024-12-05 3124/week @ 2024-12-12 2476/week @ 2024-12-19 1389/week @ 2024-12-26 1572/week @ 2025-01-02

8,957 downloads per month
Used in 143 crates (32 directly)

MIT/Apache

62KB
1.5K 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

~160KB