pub fn resolve_normalize<S: Spec>(
    reference: impl AsRef<RiReferenceStr<S>>,
    base: impl AsRef<RiAbsoluteStr<S>>
) -> Result<RiString<S>, Error>
Expand description

Resolves and normalizes the IRI reference.

It is recommended to use methods such as RiReferenceStr::resolve_normalize_against() and RiRelativeStr::resolve_normalize_against(), rather than this freestanding function.

If you are going to resolve multiple references against the common base, consider using FixedBaseResolver.

Enabled by alloc or std feature.

Failures

This fails if

  • memory allocation failed, or
  • the IRI referernce is unresolvable against the base.

To see examples of unresolvable IRIs, visit the module documentation.

Examples

use iri_string::resolve::{resolve_normalize, FixedBaseResolver};
use iri_string::types::{IriAbsoluteStr, IriReferenceStr};

let base = IriAbsoluteStr::new("http://example.com/base/")?;
let reference = IriReferenceStr::new("../there")?;

// Resolve and normalize `reference` against `base`.
let resolved = resolve_normalize(reference, base)?;
assert_eq!(resolved, "http://example.com/there");

// These two produces the same result with the same type.
assert_eq!(
    FixedBaseResolver::new(base).resolve(reference)?,
    "http://example.com/there"
);
assert_eq!(
    FixedBaseResolver::new(base)
        .create_normalizing_task(reference)
        .allocate_and_write()?,
    "http://example.com/there"
);