use std;
use std::os::raw::c_void;
use std::rc::Rc;
use super::super::api::{MainloopApi, MainloopInnerType};
pub use capi::pa_defer_event as DeferEventInternal;
pub struct DeferEvent<T>
where T: MainloopInnerType
{
ptr: *mut DeferEventInternal,
owner: Rc<T>,
_saved_cb: EventCb,
}
pub struct DeferEventRef<T: 'static>
where T: MainloopInnerType
{
ptr: *mut DeferEventInternal,
owner: Rc<T>,
}
pub(crate) type EventCb = ::callbacks::MultiUseCallback<dyn FnMut(*mut DeferEventInternal),
extern "C" fn(a: *const MainloopApi, e: *mut DeferEventInternal, userdata: *mut c_void)>;
impl<T> DeferEvent<T>
where T: MainloopInnerType
{
#[inline]
pub(crate) fn from_raw(ptr: *mut DeferEventInternal, mainloop_inner: Rc<T>, callback: EventCb)
-> Self
{
assert_eq!(false, ptr.is_null());
Self { ptr: ptr, owner: mainloop_inner, _saved_cb: callback }
}
#[inline]
pub fn enable(&mut self) {
let fn_ptr = (*self.owner).get_api().defer_enable.unwrap();
fn_ptr(self.ptr, 1);
}
#[inline]
pub fn disable(&mut self) {
let fn_ptr = (*self.owner).get_api().defer_enable.unwrap();
fn_ptr(self.ptr, 0);
}
}
impl<T> DeferEventRef<T>
where T: MainloopInnerType
{
#[inline]
pub(crate) fn from_raw(ptr: *mut DeferEventInternal, mainloop_inner: Rc<T>) -> Self {
assert_eq!(false, ptr.is_null());
Self { ptr: ptr, owner: mainloop_inner }
}
#[inline]
pub fn enable(&mut self) {
let fn_ptr = (*self.owner).get_api().defer_enable.unwrap();
fn_ptr(self.ptr, 1);
}
#[inline]
pub fn disable(&mut self) {
let fn_ptr = (*self.owner).get_api().defer_enable.unwrap();
fn_ptr(self.ptr, 0);
}
}
impl<T> Drop for DeferEvent<T>
where T: MainloopInnerType
{
fn drop(&mut self) {
let fn_ptr = (*self.owner).get_api().defer_free.unwrap();
fn_ptr(self.ptr);
}
}
pub(crate)
extern "C"
fn event_cb_proxy(_: *const MainloopApi, e: *mut DeferEventInternal, userdata: *mut c_void) {
let _ = std::panic::catch_unwind(|| {
let callback = EventCb::get_callback(userdata);
(callback)(e);
});
}