Skip to main content

TraitMethodAttrs

Struct TraitMethodAttrs 

Source
struct TraitMethodAttrs {
Show 14 fields worker: bool, unsafe_main_thread: bool, coerce: bool, check_interrupt: bool, rng: bool, unwrap_in_r: bool, skip: bool, defaults: HashMap<String, String>, r_name: Option<String>, strict: bool, lifecycle: Option<LifecycleSpec>, r_entry: Option<String>, r_post_checks: Option<String>, r_on_exit: Option<ROnExit>,
}
Expand description

Parsed #[miniextendr(...)] attributes for a single trait method.

Extracted from method-level attributes to control C wrapper behavior, threading, and R wrapper generation.

Fields§

§worker: bool

Dispatch to worker thread. Set by explicit #[miniextendr(worker)] or default-worker feature.

§unsafe_main_thread: bool

Force execution on R’s main thread (overrides default worker thread for static methods).

§coerce: bool

Enable Rf_coerceVector for all parameters.

§check_interrupt: bool

Call R_CheckUserInterrupt before the method body.

§rng: bool

Wrap the call in GetRNGstate/PutRNGstate for reproducible random number generation.

§unwrap_in_r: bool

Return Result<T, E> to R without unwrapping (R wrapper receives the result variant).

§skip: bool

Exclude this method from all generated wrappers (C, R, vtable shims).

§defaults: HashMap<String, String>

Parameter default values: keys are parameter names, values are R expressions.

§r_name: Option<String>

Override the R-facing method name.

§strict: bool

Strict output conversion: panic instead of lossy widening for i64/u64/isize/usize.

§lifecycle: Option<LifecycleSpec>

Lifecycle specification for deprecation/experimental status.

§r_entry: Option<String>

R code to inject at the very top of the wrapper body.

§r_post_checks: Option<String>

R code to inject after all checks, immediately before .Call().

§r_on_exit: Option<ROnExit>

Register on.exit() cleanup code in the R wrapper.

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

Source§

#[doc(hidden)]
const SIZE: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const ALIGN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const ALIGNMENT: Alignment = _

🔬This is a nightly-only experimental API. (ptr_alignment_type)
Source§

#[doc(hidden)]
const IS_ZST: bool = _

🔬This is a nightly-only experimental API. (sized_type_properties)
true if this type requires no storage. false if its size is greater than zero. Read more
Source§

#[doc(hidden)]
const LAYOUT: Layout = _

🔬This is a nightly-only experimental API. (sized_type_properties)
Source§

#[doc(hidden)]
const MAX_SLICE_LEN: usize = _

🔬This is a nightly-only experimental API. (sized_type_properties)
The largest safe length for a [Self]. Read more
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.

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 288 bytes