Skip to main content

SIBinder

Struct SIBinder 

Source
pub struct SIBinder { /* private fields */ }
Expand description

Strong reference to a binder object.

Implementations§

Source§

impl SIBinder

Source

pub fn new(data: Arc<dyn IBinder>) -> Result<Self>

Wrap an Arc<dyn IBinder> in an SIBinder.

Drives inc_strong on the inner binder. For native binders this advances the local RefCounter.strong; for proxies it is a no-op (proxy ref-count is owned by the cache-pin model — see proxy::ProxyHandle).

Source

pub fn downgrade(this: &Self) -> WIBinder

Construct a weak reference to this binder.

Pure Arc::downgrade — no kernel command, no trait dispatch.

For proxies, the resulting WIBinder snapshots (handle, stability, generation) so a later WIBinder::upgrade() can route through the process-wide proxy cache. As long as the cache pin is alive (no obituary yet), upgrade() succeeds via case-(b) resurrection — matching Android wp<BpBinder>::promote() semantics. If the cache entry was removed (obituary) or the handle id was recycled to a different binder_node (generation mismatch), upgrade() returns Err(DeadObject).

For native binders, the WIBinder is a plain sync::Weak<dyn IBinder>upgrade() succeeds iff some Arc<dyn IBinder> to the inner binder is still alive.

Source

pub fn stability(&self) -> Stability

Retrieve the stability level of the underlying binder object.

Source

pub fn into_interface<I: FromIBinder + Interface + ?Sized>( self, ) -> Result<Strong<I>>

Try to convert this Binder object into a trait object for the given Binder interface.

If this object does not implement the expected interface, the error StatusCode::BadType is returned.

Methods from Deref<Target = dyn IBinder>§

Source

pub fn as_proxy(&self) -> Option<&ProxyHandle>

Convert this binder object into a proxy binder object.

Trait Implementations§

Source§

impl Clone for SIBinder

Source§

fn clone(&self) -> Self

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for SIBinder

Source§

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

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

impl Deref for SIBinder

Source§

type Target = dyn IBinder

The resulting type after dereferencing.
Source§

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

Dereferences the value.
Source§

impl Deserialize for SIBinder

Source§

fn deserialize(parcel: &mut Parcel) -> Result<Self>

Deserialize an instance from the given Parcel.
Source§

fn deserialize_from(&mut self, parcel: &mut Parcel) -> Result<()>

Deserialize an instance from the given Parcel onto the current object. This operation will overwrite the old value partially or completely, depending on how much data is available.
Source§

impl DeserializeArray for SIBinder

Source§

fn deserialize_array(parcel: &mut Parcel) -> Result<Option<Vec<Self>>>

Deserialize an array of type from the given parcel.
Source§

impl DeserializeOption for SIBinder

Source§

fn deserialize_option(parcel: &mut Parcel) -> Result<Option<Self>>

Deserialize an Option of this type from the given parcel.
Source§

fn deserialize_option_from( this: &mut Option<Self>, parcel: &mut Parcel, ) -> Result<()>

Deserialize an Option of this type from the given parcel onto the current object. This operation will overwrite the current value partially or completely, depending on how much data is available.
Source§

impl Drop for SIBinder

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

fn pin_drop(self: Pin<&mut Self>)

🔬This is a nightly-only experimental API. (pin_ergonomics)
Execute the destructor for this type, but different to Drop::drop, it requires self to be pinned. Read more
Source§

impl PartialEq for SIBinder

Source§

fn eq(&self, other: &Self) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for SIBinder

Source§

fn serialize(&self, parcel: &mut Parcel) -> Result<()>

Serialize this instance into the given Parcel.
Source§

impl SerializeArray for SIBinder

Source§

fn serialize_array(slice: &[Self], parcel: &mut Parcel) -> Result<()>

Serialize an array of this type into the given parcel.
Source§

impl SerializeOption for SIBinder

Source§

fn serialize_option(this: Option<&Self>, parcel: &mut Parcel) -> Result<()>

Serialize an Option of this type into the given parcel.
Source§

impl<B: Remotable + 'static> TryFrom<SIBinder> for Binder<B>

Source§

type Error = StatusCode

The type returned in the event of a conversion error.
Source§

fn try_from(ibinder: SIBinder) -> Result<Self>

Performs the conversion.
Source§

impl Eq for SIBinder

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Converts Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Converts &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Converts &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSend for T
where T: Any + Send,

Source§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Sync + Send>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be downcast into Arc<ConcreteType> where ConcreteType implements Trait.
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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.