MutableHandle

Struct MutableHandle 

Source
pub struct MutableHandle<'a, T: 'a> {
    pub(crate) ptr: NonNull<T>,
    anchor: PhantomData<&'a mut T>,
}

Fields§

§ptr: NonNull<T>§anchor: PhantomData<&'a mut T>

Implementations§

Source§

impl<'a, T> MutableHandle<'a, T>

Source

pub unsafe fn from_marked_location(ptr: *mut T) -> Self

Source

pub unsafe fn from_raw(handle: RawMutableHandle<T>) -> Self

Source

pub fn handle(&self) -> Handle<'a, T>

Source

pub fn get(&self) -> T
where T: Copy,

Source

pub fn set(&mut self, v: T)
where T: Copy,

Source

pub fn as_ref<'s: 'r, 'cx: 'r, 'r>(&'s self, _no_gc: &'cx NoGC) -> &'r T
where 'a: 's,

Obtains a reference to the value pointed to by this handle. While this reference is alive, no GC can occur, because of the _no_gc argument:

use mozjs::context::*;
use mozjs::jsapi::JSObject;
use mozjs::rooted;

fn gc(cx: &mut JSContext) {}

fn f(cx: &mut JSContext, obj: *mut JSObject) {
    rooted!(&in(cx) let mut root = obj);
    let handle = root.handle_mut();
    let r = handle.as_ref(cx);
    gc(cx); // cannot call gc while r (thus cx borrow) is alive
    drop(r); // otherwise rust automatically drops r before gc call
}
Source

pub fn as_mut_ref<'s: 'r, 'cx: 'r, 'r>( &'s mut self, _no_gc: &'cx NoGC, ) -> &'r mut T
where 'a: 's,

Obtains a reference to the value pointed to by this handle. While this reference is alive, no GC can occur, because of the _no_gc argument:

use mozjs::context::*;
use mozjs::jsapi::JSObject;
use mozjs::rooted;

fn gc(cx: &mut JSContext) {}

fn f(cx: &mut JSContext, obj: *mut JSObject) {
    rooted!(&in(cx) let mut root = obj);
    let mut handle = root.handle_mut();
    let r = handle.as_mut_ref(cx);
    gc(cx); // cannot call gc while r (thus cx borrow) is alive
    drop(r); // otherwise rust automatically drops r before gc call
}
Source

pub unsafe fn as_mut<'b>(&'b mut self) -> &'b mut T
where 'a: 'b,

Safety: GC must not run during the lifetime of the returned reference. Use MutableHandle::as_mut_ref instead.

Source

pub fn reborrow<'b>(&'b mut self) -> MutableHandle<'b, T>
where 'a: 'b,

Creates a copy of this object, with a shorter lifetime, that holds a mutable borrow on the original object. When you write code that wants to use a MutableHandle more than once, you will typically need to call reborrow on all but the last usage. The same way that you might naively clone a type to allow it to be passed to multiple functions.

This is the same thing that happens with regular mutable references, except there the compiler implicitly inserts the reborrow calls. Until rust gains a feature to implicitly reborrow other types, we have to do it by hand.

Source

pub(crate) fn raw(&mut self) -> RawMutableHandle<T>

Source§

impl<'a, T> MutableHandle<'a, Option<T>>

Source

pub fn take(&mut self) -> Option<T>

Trait Implementations§

Source§

impl<'a, T> Deref for MutableHandle<'a, T>

Source§

fn deref(&self) -> &T

This is unsound and will be removed eventually. Use MutableHandle::as_ref instead.

Source§

type Target = T

The resulting type after dereferencing.
Source§

impl<'a, T> IntoHandle for MutableHandle<'a, T>

Source§

type Target = T

The type of the handle
Source§

fn into_handle(self) -> RawHandle<T>

Convert this object to a handle.
Source§

impl<'a, T> IntoMutableHandle for MutableHandle<'a, T>

Source§

fn into_handle_mut(self) -> RawMutableHandle<T>

Convert this object to a mutable handle.

Auto Trait Implementations§

§

impl<'a, T> Freeze for MutableHandle<'a, T>

§

impl<'a, T> RefUnwindSafe for MutableHandle<'a, T>
where T: RefUnwindSafe,

§

impl<'a, T> !Send for MutableHandle<'a, T>

§

impl<'a, T> !Sync for MutableHandle<'a, T>

§

impl<'a, T> Unpin for MutableHandle<'a, T>

§

impl<'a, T> !UnwindSafe for MutableHandle<'a, T>

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

Source§

fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>

Creates a filterable data provider with the given name for debugging. 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.
Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T