Struct Modifiers

Source
pub(crate) struct Modifiers {
    is_monotone: Option<Expr>,
    sqlname: Option<SqlName>,
    preserves_uniqueness: Option<Expr>,
    inverse: Option<Expr>,
    negate: Option<Expr>,
    is_infix_op: Option<Expr>,
    output_type: Option<Path>,
    output_type_expr: Option<Expr>,
    could_error: Option<Expr>,
    propagates_nulls: Option<Expr>,
    introduces_nulls: Option<Expr>,
}
Expand description

Modifiers passed as key-value pairs to the #[sqlfunc] macro.

Fields§

§is_monotone: Option<Expr>

An optional expression that evaluates to a boolean indicating whether the function is monotone with respect to its arguments. Defined for unary and binary functions.

§sqlname: Option<SqlName>

The SQL name for the function. Applies to all functions.

§preserves_uniqueness: Option<Expr>

Whether the function preserves uniqueness. Applies to unary functions.

§inverse: Option<Expr>

The inverse of the function, if it exists. Applies to unary functions.

§negate: Option<Expr>

The negated function, if it exists. Applies to binary functions.

§is_infix_op: Option<Expr>

Whether the function is an infix operator. Applies to binary functions, and needs to be specified.

§output_type: Option<Path>

The output type of the function, if it cannot be inferred. Applies to all functions.

§output_type_expr: Option<Expr>

The output type of the function as an expression. Applies to binary functions.

§could_error: Option<Expr>

Optional expression evaluating to a boolean indicating whether the function could error. Applies to all functions.

§propagates_nulls: Option<Expr>

Whether the function propagates nulls. Applies to binary functions.

§introduces_nulls: Option<Expr>

Whether the function introduces nulls. Applies to all functions.

Trait Implementations§

Source§

impl Debug for Modifiers

Source§

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

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

impl Default for Modifiers

Source§

fn default() -> Modifiers

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

impl FromMeta for Modifiers

Source§

fn from_list(__items: &[NestedMeta]) -> Result<Self>

Create an instance from a list of nested meta items.
Source§

fn from_nested_meta(item: &NestedMeta) -> Result<Self, Error>

Source§

fn from_meta(item: &Meta) -> Result<Self, Error>

Create an instance from a syn::Meta by dispatching to the format-appropriate trait function. This generally should not be overridden by implementers. Read more
Source§

fn from_none() -> Option<Self>

When a field is omitted from a parent meta-item, from_none is used to attempt recovery before a missing field error is generated. Read more
Source§

fn from_word() -> Result<Self, Error>

Create an instance from the presence of the word in the attribute with no additional options specified.
Source§

fn from_value(value: &Lit) -> Result<Self, Error>

Create an instance from a literal value of either foo = "bar" or foo("bar"). This dispatches to the appropriate method based on the type of literal encountered, and generally should not be overridden by implementers. Read more
Source§

fn from_expr(expr: &Expr) -> Result<Self, Error>

Source§

fn from_char(value: char) -> Result<Self, Error>

Create an instance from a char literal in a value position.
Source§

fn from_string(value: &str) -> Result<Self, Error>

Create an instance from a string literal in a value position.
Source§

fn from_bool(value: bool) -> Result<Self, Error>

Create an instance from a bool literal in a value position.

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> 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, 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.