| Crates.io | oxiri |
| lib.rs | oxiri |
| version | 0.2.11 |
| created_at | 2020-05-01 17:15:23.513369+00 |
| updated_at | 2025-01-19 13:49:23.138809+00 |
| description | Simple and fast implementation of IRI validation and relative IRI resolution |
| homepage | |
| repository | https://github.com/oxigraph/oxiri |
| max_upload_size | |
| id | 236299 |
| size | 150,447 |
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.
This project is licensed under either of
<http://www.apache.org/licenses/LICENSE-2.0>)<http://opensource.org/licenses/MIT>)at your option.
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.