Struct SRObject

Source
pub struct SRObject<T>(/* private fields */);
Expand description

Wrapper for arbitrary NSObject types.

When returning an NSObject, its Rust type must be wrapped in SRObject. The type must also be annotated with #[repr(C)] to ensure its memory layout is identical to its Swift counterpart’s.

use swift_rs::{swift, SRObject, Int, Bool};

#[repr(C)]
struct CustomObject {
    a: Int,
    b: Bool
}

swift!(fn get_custom_object() -> SRObject<CustomObject>);

let value = unsafe { get_custom_object() };

let reference: &CustomObject = value.as_ref();

corresponding Swift code

Trait Implementations§

Source§

impl<T> AsRef<T> for SRObject<T>

Source§

fn as_ref(&self) -> &T

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T> Deref for SRObject<T>

Source§

type Target = T

The resulting type after dereferencing.
Source§

fn deref(&self) -> &T

Dereferences the value.
Source§

impl<T> Drop for SRObject<T>

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more
Source§

impl<T> Serialize for SRObject<T>
where T: Serialize,

Source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl<'a, T: 'a> SwiftArg<'a> for SRObject<T>

Source§

type ArgType = SwiftRef<'a, SRObject<T>>

Source§

unsafe fn as_arg(&'a self) -> Self::ArgType

Creates a swift-compatible version of the argument. For primitives this just returns self, but for SwiftObject types it wraps them in SwiftRef. Read more
Source§

impl<T> SwiftObject for SRObject<T>

Source§

type Shape = T

Source§

fn get_object(&self) -> &SRObject<Self::Shape>

Gets a reference to the SRObject at the root of a SwiftObject
Source§

unsafe fn swift_ref(&self) -> SwiftRef<'_, Self>
where Self: Sized,

Creates a SwiftRef for an object which can be used when calling a Swift function. This function should never be called manually, instead you should rely on the swift! macro to call it for you. Read more
Source§

unsafe fn retain(&self)
where Self: Sized,

Adds a retain to an object. Read more

Auto Trait Implementations§

§

impl<T> Freeze for SRObject<T>

§

impl<T> RefUnwindSafe for SRObject<T>
where T: RefUnwindSafe,

§

impl<T> !Send for SRObject<T>

§

impl<T> !Sync for SRObject<T>

§

impl<T> Unpin for SRObject<T>

§

impl<T> UnwindSafe for SRObject<T>
where T: RefUnwindSafe,

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> SwiftRet for T
where T: SwiftObject,

Source§

unsafe fn retain(&self)

Adds a retain to the value if possible 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.