pub struct DataContext<Vertex> { /* private fields */ }
Expand description

A partial result of a Trustfall query within the interpreter defined in this module.

Implementations§

source§

impl<Vertex> DataContext<Vertex>

source

pub fn active_vertex<V>(&self) -> Option<&V>where Vertex: AsVertex<V>,

The vertex currently being processed.

For contexts passed to an Adapter resolver method, this is the vertex whose data needs to be resolved.

The active vertex may be None when processing an @optional part of a Trustfall query whose data did not exist. In that case:

source

pub fn map<Other>( self, mapper: &mut impl FnMut(Vertex) -> Other ) -> DataContext<Other>

Converts DataContext<Vertex> to DataContext<Other> by mapping each Vertex to Other.

If you are implementing an Adapter for a data source, you almost certainly should not be using this function. You’re probably looking for DataContext::active_vertex() instead.

source

pub fn flat_map<T>( self, mapper: &mut impl FnMut(Vertex) -> Option<T> ) -> DataContext<T>

Map each Vertex to Option<Other>, thus converting Self to DataContext<Other>.

This is the DataContext equivalent of Option::and_then, which is also referred to as “flat-map” in some languages.

If you are implementing an Adapter for a data source, you almost certainly should not be using this function. You’re probably looking for DataContext::active_vertex() instead.

source§

impl<Vertex: Clone + Debug> DataContext<Vertex>

source

pub fn new(vertex: Option<Vertex>) -> DataContext<Vertex>

Trait Implementations§

source§

impl<Vertex: Clone> Clone for DataContext<Vertex>

source§

fn clone(&self) -> DataContext<Vertex>

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<Vertex: Debug> Debug for DataContext<Vertex>

source§

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

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

impl<'de, Vertex> Deserialize<'de> for DataContext<Vertex>where Vertex: Debug + Clone + Serialize + DeserializeOwned,

source§

fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl<Vertex: PartialEq> PartialEq for DataContext<Vertex>

source§

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

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<Vertex> Serialize for DataContext<Vertex>where Vertex: Debug + Clone + Serialize + DeserializeOwned,

source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>where S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl<Vertex: Eq> Eq for DataContext<Vertex>

Auto Trait Implementations§

§

impl<Vertex> RefUnwindSafe for DataContext<Vertex>where Vertex: RefUnwindSafe,

§

impl<Vertex> Send for DataContext<Vertex>where Vertex: Send,

§

impl<Vertex> Sync for DataContext<Vertex>where Vertex: Sync,

§

impl<Vertex> Unpin for DataContext<Vertex>where Vertex: Unpin,

§

impl<Vertex> UnwindSafe for DataContext<Vertex>where Vertex: UnwindSafe + RefUnwindSafe,

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<V> AsVertex<V> for Vwhere V: Debug + Clone,

source§

fn as_vertex(&self) -> Option<&V>

Dereference this value into a &V, if the value happens to contain a V. Read more
source§

fn into_vertex(self) -> Option<V>

Consume self and produce the contained V, if one was indeed present. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere 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 Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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<T> DeserializeOwned for Twhere T: for<'de> Deserialize<'de>,