Skip to main content

Schema

Struct Schema 

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

An abstract representation of a JDDF schema.

This struct is meant for use by validators, code generators, or other high-level processors of schemas. For serialization and deserialization of schemas, instead use Serde.

Implementations§

Source§

impl Schema

Source

pub fn from_parts( defs: Option<HashMap<String, Schema>>, form: Box<Form>, extra: HashMap<String, Value>, ) -> Schema

Construct a new schema from its constituent parts.

defs should be present (i.e. not None) if and only if the constructed schema is a root one. This invariant is not enforced, but many users of this crate will presume that root schemas have definitions they can unwrap. Likewise, some tooling will assume that any schema which has non-None definitions are root schemas.

Source

pub fn from_serde(serde_schema: Serde) -> Result<Self, Error>

Construct a new, root schema from a Serde.

Source

pub fn into_serde(self) -> Serde

Convert this schema into a Serde.

Source

pub fn is_root(&self) -> bool

Is this schema a root schema?

Under the hood, this is entirely equivalent to checking whether definitions().is_some().

Source

pub fn definitions(&self) -> &Option<HashMap<String, Schema>>

Get the definitions associated with this schema.

If this schema is non-root, this returns None.

Source

pub fn form(&self) -> &Form

Get the form of the schema.

Source

pub fn extra(&self) -> &HashMap<String, Value>

Get extra data associated with this schema.

Essentially, this function returns a JSON object of properties that aren’t JDDF keywords, but which were included in the schema’s JSON. You might use these nonstandard fields to implement custom behavior.

Trait Implementations§

Source§

impl Clone for Schema

Source§

fn clone(&self) -> Schema

Returns a duplicate 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 Debug for Schema

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for Schema

Source§

fn eq(&self, other: &Schema) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl StructuralPartialEq for Schema

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.