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

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

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

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

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

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

Implementations§

source§

impl HookArgs

source

pub fn transform_item_fn(self, item_fn: ItemFn) -> (ItemFn, Option<Error>)

source

pub fn transform_item_fn_in_place(self, item_fn: &mut ItemFn) -> Option<Error>

source

pub fn from_punctuated_meta_list( meta_list: Punctuated<NestedMeta, Comma> ) -> Result<Self>

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

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

§

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
§

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
§

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

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

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
§

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

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

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

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

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 Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · 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.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.