Struct HookArgs

Source
#[non_exhaustive]
pub struct HookArgs { pub hooks_core_path: Option<PathOrLit<Path>>, pub bounds: Option<Punctuated<TypeParamBound, Plus>>, }

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§hooks_core_path: Option<PathOrLit<Path>>

Defaults to ::hooks::core

§bounds: Option<Punctuated<TypeParamBound, Plus>>

When a hook fn borrows from a lifetime, this bound might need to be explicitly specified.

Note that all lifetimes declared in fn generics are auto captured by #[hook]. Thus, #[hook(bounds = "...")] is only required for elided lifetimes and outer lifetimes.

#[hook]
fn use_borrow(v: &str) -> usize {
    v.len()
}
#[hook(bounds = "'_")]
fn use_borrow(v: &str) -> usize {
    v.len()
}

This is equivalent to type Bounds = impl ... in hook_fn!(...);

hook_fn!(
    type Bounds = impl '_;
    fn use_borrow(v: &str) -> usize {
        v.len()
    }
);

Implementations§

Trait Implementations§

Source§

impl Debug for HookArgs

Source§

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

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

impl Default for HookArgs

Source§

fn default() -> HookArgs

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

impl FromMeta for HookArgs

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.