Struct OperatorSetWithContext

Source
pub struct OperatorSetWithContext<R, A> { /* private fields */ }
Available on crate feature filter only.
Expand description

A collection of filters for a type that requires a context object.

An OperatorSetWithContext can be created for any type which implements FilterableWithContext. Its constructor supplies a visitor to the type’s Meta type, and constructs the necessary FilterClass objects. It can be used directly to convert incoming query pairs from Django-style query URLs into appropriate Filter objects.

Note that the context object provided on construction may be stored within the resulting object, and may also be cloned into the Meta for other types.

Implementations§

Source§

impl<'a, A: Clone + 'a, R: FilterableWithContext<'a, A>> OperatorSetWithContext<R, A>

Source

pub fn new(access: A) -> Self

Create a new OperatorSetWithContext, using the Meta record from the target type, which will be initialized from the provided context object access.

Source

pub fn create_filter( &self, field: &str, operator: Option<&str>, rhs: &str, ) -> Result<Box<dyn Filter<R> + 'a>, FilterError>

Create a new filter from a decomposed URL. Note that the decomposition is ambiguous, so create_filter_from_query_pair is often preferable. The ambiguity arises because there may be no operator part, and the field part may have arbitrarily many parts. Since everything is separated with double underscores there is no way without additional information to distinguish an expression with an explicit operator from an expression on a nested field with an implicit operator. Here - field is the field specification part of the string, including any nested fields. - operator is the operator specification, if any. - rhs is the argument part, after the = in the URL section.

Source

pub fn create_filter_from_query_pair( &self, lhs: &str, rhs: &str, ) -> Result<Box<dyn Filter<R> + 'a>, FilterError>

Create a new filter from a fragment of query URL. The expected input is a lhs=rhs pair from a query string, with lhs and rhs given separately. The output will either be an error, or a Filter which can apply the specified test to objects of the target type, returning either true (include) or false (exclude).

Source

pub fn create_filter_from_query( &self, expr: &str, ) -> Result<Box<dyn Filter<R> + 'a>, FilterError>

Create a new filter from a fragment of query URL. The expected input is a lhs=rhs pair from a query string, with lhs and rhs given together in a single string. The output will either be an error, or a Filter which can apply the specified test to objects of the target type, returning either true (include) or false (exclude).

Auto Trait Implementations§

§

impl<R, A> Freeze for OperatorSetWithContext<R, A>
where A: Freeze,

§

impl<R, A> RefUnwindSafe for OperatorSetWithContext<R, A>

§

impl<R, A> Send for OperatorSetWithContext<R, A>
where A: Send, R: Send,

§

impl<R, A> Sync for OperatorSetWithContext<R, A>
where A: Sync, R: Sync,

§

impl<R, A> Unpin for OperatorSetWithContext<R, A>
where A: Unpin, R: Unpin,

§

impl<R, A> UnwindSafe for OperatorSetWithContext<R, A>
where A: UnwindSafe, R: UnwindSafe,

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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, 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

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,