11 releases
0.2.8 | Oct 19, 2024 |
---|---|
0.2.4 | Aug 21, 2024 |
0.2.3 | Mar 23, 2024 |
0.2.2 | Mar 27, 2022 |
0.1.1 | Jul 10, 2020 |
#242 in Parser implementations
11,020 downloads per month
Used in 129 crates
(32 directly)
62KB
1.5K
SLoC
OxIRI
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
~165KB