4 releases

Uses old Rust 2015

0.1.1 Jul 22, 2018
0.1.0 Mar 20, 2016
0.0.2 Sep 3, 2015
0.0.1 May 2, 2015

#178 in macOS and iOS APIs

Download history 67636/week @ 2024-10-30 64870/week @ 2024-11-06 58749/week @ 2024-11-13 55734/week @ 2024-11-20 58123/week @ 2024-11-27 57932/week @ 2024-12-04 58717/week @ 2024-12-11 50725/week @ 2024-12-18 42747/week @ 2024-12-25 44065/week @ 2025-01-01 55651/week @ 2025-01-08 53598/week @ 2025-01-15 53781/week @ 2025-01-22 55993/week @ 2025-01-29 63157/week @ 2025-02-05 54292/week @ 2025-02-12

236,099 downloads per month
Used in 1,116 crates (40 directly)

MIT license

11KB
151 lines

Rust smart pointers for Objective-C reference counting.

To ensure that Objective-C objects are retained and released at the proper times, we can use the Id struct.

To enforce aliasing rules, an Id can be either owned or shared; if it is owned, meaning the Id is the only reference to the object, it can be mutably dereferenced. An owned Id can be downgraded to a ShareId which can be cloned to allow multiple references.

Weak references may be created using the WeakId struct.

use objc::runtime::{Class, Object};
use objc_id::{Id, WeakId};

let cls = Class::get("NSObject").unwrap();
let obj: Id<Object> = unsafe {
    Id::from_retained_ptr(msg_send![cls, new])
};
// obj will be released when it goes out of scope

// share the object so we can clone it
let obj = obj.share();
let another_ref = obj.clone();
// dropping our other reference will decrement the retain count
drop(another_ref);

let weak = WeakId::new(&obj);
assert!(weak.load().is_some());
// After the object is deallocated, our weak pointer returns none
drop(obj);
assert!(weak.load().is_none());

Dependencies

~130KB