1 unstable release
| 0.1.9 | Aug 23, 2022 |
|---|
#11 in #iri
52 downloads per month
Used in 7 crates
(6 directly)
140KB
2K
SLoC
RDFtk: IRI
This crate provides an implementation of the
IRI and URI specifications.
As with the rest of the RDFtk project the aim of this crate is usability over optimization and so it may perform
more clones than necessary and parse more slowly than could be the case. For the most part clients should use the
IRIRef type that is an Arc reference and so can be reused without cloning the whole IRI value.
Example
The most common use is the parsing of an IRI value from a string.
use field33_rdftk_iri_temporary_fork::IRI;
use std::convert::from_str;
let result = IRI::from_str(
"https://john.doe@www.example.com:123/forum/questions/?tag=networking&order=newest#top",
);
The builder module allows for more programmatic construction of IRIs.
use field33_rdftk_iri_temporary_fork::{IRI, Scheme};
use field33_rdftk_iri_temporary_fork::builder::IriBuilder;
let mut builder = IriBuilder::default();
let result: IriResult<IRI> = builder
.scheme(&Scheme::https())
.user_name("john.doe")
.host("www.example.com")?
.port(123.into())
.path_str("/forum/questions/")?
.query_str("tag=networking&order=newest")?
.fragment_str("top")?
.try_into();
Note also the use of Scheme::https(), both the Scheme and Port types include associated functions
to construct well-known values.
Features
The following features are present in this crate.
builder[default] -- include thebuildermodule, which in turn includes theIriBuildertype.genid[default] -- includes a constructor to create"genid"well-known IRI values.path_iri[default] -- provides an implementation ofTryFrom<&PathBuf>andTryFrom<PathBuf>forIRI.uuid_iri[default] -- provides an implementation ofTryFrom<&Uuid>andTryFrom<Uuid>forIRI.
Changes
Version 0.1.9
- Added a feature to enable genid creation.
- Made IRI PartialOrd + Ord, it can now be sorted.
- Added PercentEncoding trait for percent encoding components.
Version 0.1.8
- Minor fix to parser to fix some precedence rules.
- Some documentation fixes.
Version 0.1.7
- Added support for well-known IRIs to the Path and IRI types.
Version 0.1.6
- Applied a lot more warnings in lib.rs
- Applied more Clippy suggestions.
Version 0.1.5
- Applied all Clippy suggestions.
Version 0.1.4
- A lot more testing, and local coverage reporting.
- Fixed a bug where separator missing in
UserInfo::to_string. - Fixed a parsing bug
IpvFuture::from_str. - Added
host,path_root,pathmethods toIriBuilder. - Changes
with_new_queryandwith_new_fragmentonIRIto not takeOption. - Added
blobknown value toScheme.
Version 0.1.3
- Mostly testing
- Moved any tests out of the main code if they only use the public API.
- Added a set of files for gathering whole
IRIexamples. - Added proptest for
Scheme, will add for more.
- Fixed bug in
IRI::is_absolute, to ignore authority and take the fragment into account. - Added
IRI::is_relative_reference.
Version 0.1.2
- Mostly documentation additions.
- Adding test cases where possible.
- Added helper functions and API shortcuts where they make sense.
- Added
path_irianduuid_irifeatures.
Version 0.1.1
- Added
IRIReftype.
Version 0.1.0
- First release.
TODO
Dependencies
~5–11MB
~129K SLoC