Struct JsonLdSerializer

Source
pub struct JsonLdSerializer { /* private fields */ }
Expand description

A JSON-LD serializer.

Returns Streaming JSON-LD.

It does not implement exactly the RDF as JSON-LD Algorithm to be a streaming serializer but aims at being close to it. Features like @json and @list generation are not implemented.

use oxrdf::{GraphNameRef, LiteralRef, NamedNodeRef, QuadRef};
use oxrdf::vocab::rdf;
use oxjsonld::JsonLdSerializer;

let mut serializer = JsonLdSerializer::new().with_prefix("schema", "http://schema.org/")?.for_writer(Vec::new());
serializer.serialize_quad(QuadRef::new(
    NamedNodeRef::new("http://example.com#me")?,
    rdf::TYPE,
    NamedNodeRef::new("http://schema.org/Person")?,
    GraphNameRef::DefaultGraph
))?;
serializer.serialize_quad(QuadRef::new(
    NamedNodeRef::new("http://example.com#me")?,
    NamedNodeRef::new("http://schema.org/name")?,
    LiteralRef::new_language_tagged_literal_unchecked("Foo Bar", "en"),
    GraphNameRef::DefaultGraph
))?;
assert_eq!(
    b"{\"@context\":{\"schema\":\"http://schema.org/\"},\"@graph\":[{\"@id\":\"http://example.com#me\",\"http://www.w3.org/1999/02/22-rdf-syntax-ns#type\":[{\"@id\":\"http://schema.org/Person\"}],\"http://schema.org/name\":[{\"@language\":\"en\",\"@value\":\"Foo Bar\"}]}]}",
    serializer.finish()?.as_slice()
);

Implementations§

Source§

impl JsonLdSerializer

Source

pub fn new() -> Self

Builds a new JsonLdSerializer.

Source

pub fn with_prefix( self, prefix_name: impl Into<String>, prefix_iri: impl Into<String>, ) -> Result<Self, IriParseError>

Source

pub fn with_base_iri( self, base_iri: impl Into<String>, ) -> Result<Self, IriParseError>

Allows to set the base IRI for serialization.

Corresponds to the base option from the algorithm specification.

use oxrdf::{GraphNameRef, NamedNodeRef, QuadRef};
use oxjsonld::JsonLdSerializer;

let mut serializer = JsonLdSerializer::new()
    .with_base_iri("http://example.com")?
    .with_prefix("ex", "http://example.com/ns#")?
    .for_writer(Vec::new());
serializer.serialize_quad(QuadRef::new(
    NamedNodeRef::new("http://example.com#me")?,
    NamedNodeRef::new("http://www.w3.org/1999/02/22-rdf-syntax-ns#type")?,
    NamedNodeRef::new("http://example.com/ns#Person")?,
    GraphNameRef::DefaultGraph
))?;
serializer.serialize_quad(QuadRef::new(
    NamedNodeRef::new("http://example.com#me")?,
    NamedNodeRef::new("http://example.com/ns#parent")?,
    NamedNodeRef::new("http://example.com#other")?,
    GraphNameRef::DefaultGraph
))?;
assert_eq!(
    b"{\"@context\":{\"@base\":\"http://example.com\",\"ex\":\"http://example.com/ns#\"},\"@graph\":[{\"@id\":\"#me\",\"http://www.w3.org/1999/02/22-rdf-syntax-ns#type\":[{\"@id\":\"/ns#Person\"}],\"http://example.com/ns#parent\":[{\"@id\":\"#other\"}]}]}",
    serializer.finish()?.as_slice()
);
Source

pub fn for_writer<W: Write>(self, writer: W) -> WriterJsonLdSerializer<W>

Serializes a JSON-LD file to a Write implementation.

This writer does unbuffered writes.

use oxrdf::{GraphNameRef, LiteralRef, NamedNodeRef, QuadRef};
use oxrdf::vocab::rdf;
use oxjsonld::JsonLdSerializer;

let mut serializer = JsonLdSerializer::new().with_prefix("schema", "http://schema.org/")?.for_writer(Vec::new());
serializer.serialize_quad(QuadRef::new(
    NamedNodeRef::new("http://example.com#me")?,
    rdf::TYPE,
    NamedNodeRef::new("http://schema.org/Person")?,
    GraphNameRef::DefaultGraph
))?;
serializer.serialize_quad(QuadRef::new(
    NamedNodeRef::new("http://example.com#me")?,
    NamedNodeRef::new("http://schema.org/name")?,
    LiteralRef::new_language_tagged_literal_unchecked("Foo Bar", "en"),
    GraphNameRef::DefaultGraph
))?;
assert_eq!(
    b"{\"@context\":{\"schema\":\"http://schema.org/\"},\"@graph\":[{\"@id\":\"http://example.com#me\",\"http://www.w3.org/1999/02/22-rdf-syntax-ns#type\":[{\"@id\":\"http://schema.org/Person\"}],\"http://schema.org/name\":[{\"@language\":\"en\",\"@value\":\"Foo Bar\"}]}]}",
    serializer.finish()?.as_slice()
);

Trait Implementations§

Source§

impl Clone for JsonLdSerializer

Source§

fn clone(&self) -> JsonLdSerializer

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Default for JsonLdSerializer

Source§

fn default() -> JsonLdSerializer

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V