iri_s/lib.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
//! IRI simple wrapper
//!
//! This module contains a simple wrapper to work with IRIs
//! The main goal is that we can use a simple interface to work with IRIs
//! which could be adapted to different implementations in the future if needed.
//!
//! The library provides the macro [`iri`] to create IRIs from strings.
//!
// pub mod iri;
pub mod iris;
pub mod iris_error;
// pub use iri::*;
pub use iris::*;
pub use iris_error::*;
/// ```
///
/// #[macro_use]
/// use iri_s::{IriS, iri};
///
/// let iri = iri!("http://example.org/");
///
/// assert_eq!(iri.as_str(), "http://example.org/");
/// ```
///
/// At this moment the implementation leverages on [`oxrdf::NamedNode`](https://docs.rs/oxrdf/latest/oxrdf/struct.NamedNode.html)
///
///
///
/// Example
///
/// ```
/// use iri_s::IriS;
/// use std::str::FromStr;
///
/// let iri = IriS::from_str("http://example.org/").unwrap();
///
/// assert_eq!(iri.as_str(), "http://example.org/")
/// ```
///
#[macro_export]
macro_rules! iri {
(
$lit: tt
) => {
$crate::IriS::new_unchecked($lit)
};
}
#[cfg(test)]
mod tests {
use super::*;
use std::str::FromStr;
#[test]
fn iri_s_test() {
let iri1: IriS = IriS::from_str("http://example.org/iri").unwrap();
let iri2 = IriS::from_str("http://example.org/iri").unwrap();
assert_eq!(iri1, iri2);
}
#[test]
fn test_macro() {
let iri = iri!("http://example.org/");
assert_eq!(iri.as_str(), "http://example.org/")
}
}