cacao/appkit/utils.rs

20 lines
764 B
Rust
Raw Normal View History

2020-02-28 13:34:34 +11:00
//! Utils is a dumping ground for various methods that don't really have a particular module they
//! belong to. These are typically internal, and if you rely on them... well, don't be surprised if
//! they go away one day.
2020-03-12 12:38:33 +11:00
use std::rc::Rc;
use std::cell::RefCell;
2020-02-28 13:34:34 +11:00
2020-03-12 12:38:33 +11:00
use objc::runtime::Object;
2020-02-28 13:34:34 +11:00
2020-03-12 12:38:33 +11:00
/// Used for moving a pointer back into an Rc, so we can work with the object held behind it. Note
/// that it's very important to make sure you reverse this when you're done (using
/// `Rc::into_raw()`) otherwise you'll cause problems due to the `Drop` logic.
pub fn load<T>(this: &Object, ptr: &str) -> Rc<RefCell<T>> {
unsafe {
let ptr: usize = *this.get_ivar(ptr);
let view_ptr = ptr as *const RefCell<T>;
Rc::from_raw(view_ptr)
}
}