Skip to main content

OwnedProtect

Struct OwnedProtect 

Source
pub struct OwnedProtect {
    sexp: SEXP,
    armed: bool,
    _nosend: PhantomData<Rc<()>>,
}
Expand description

A single-object RAII guard: PROTECT on create, UNPROTECT(1) on drop.

Use this for simple cases where you’re protecting a single value and don’t need the batching benefits of ProtectScope.

§Example

unsafe fn allocate_and_fill() -> SEXP {
    let guard = OwnedProtect::new(Rf_allocVector(REALSXP, 10));
    fill_vector(guard.get());
    // Return the SEXP - guard drops and unprotects on this line.
    // This is safe because no GC can occur between unprotect and return.
    guard.get()
}

§Warning: Stack Ordering

OwnedProtect uses UNPROTECT(1), which removes the top of the protection stack. If you have nested protections from other sources, the drop order matters!

For complex scenarios, prefer ProtectScope which unprotects all its values at once when dropped.

Fields§

§sexp: SEXP§armed: bool§_nosend: PhantomData<Rc<()>>

Implementations§

Source§

impl OwnedProtect

Source

pub unsafe fn new(x: SEXP) -> Self

Create a new protection guard for x.

Calls Rf_protect(x) immediately.

§Safety
  • Must be called from the R main thread
  • x must be a valid SEXP
Source

pub fn get(&self) -> SEXP

Get the protected SEXP.

Source

pub unsafe fn forget(self)

Escape hatch: do not UNPROTECT(1) on drop.

§Safety

Leaks one protection entry unless unprotected elsewhere.

Trait Implementations§

Source§

impl Deref for OwnedProtect

Source§

type Target = SEXP

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl Drop for OwnedProtect

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
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.