#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

#317 in Parser implementations

Download history 1402/week @ 2022-11-30 724/week @ 2022-12-07 621/week @ 2022-12-14 802/week @ 2022-12-21 772/week @ 2022-12-28 767/week @ 2023-01-04 596/week @ 2023-01-11 649/week @ 2023-01-18 654/week @ 2023-01-25 692/week @ 2023-02-01 675/week @ 2023-02-08 750/week @ 2023-02-15 1584/week @ 2023-02-22 728/week @ 2023-03-01 628/week @ 2023-03-08 645/week @ 2023-03-15

3,730 downloads per month
Used in 49 crates (11 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

~63KB