#[repr(C)]pub struct spa_loop_methods {
pub version: u32,
pub add_source: Option<unsafe extern "C" fn(object: *mut c_void, source: *mut spa_source) -> c_int>,
pub update_source: Option<unsafe extern "C" fn(object: *mut c_void, source: *mut spa_source) -> c_int>,
pub remove_source: Option<unsafe extern "C" fn(object: *mut c_void, source: *mut spa_source) -> c_int>,
pub invoke: Option<unsafe extern "C" fn(object: *mut c_void, func: spa_invoke_func_t, seq: u32, data: *const c_void, size: usize, block: bool, user_data: *mut c_void) -> c_int>,
}
Expand description
Register sources and work items to an event loop
Fields§
§version: u32
§add_source: Option<unsafe extern "C" fn(object: *mut c_void, source: *mut spa_source) -> c_int>
Add a source to the loop. Must be called from the loop’s own thread.
\param[in] object The callbacks data. \param[in] source The source. \return 0 on success, negative errno-style value on failure.
update_source: Option<unsafe extern "C" fn(object: *mut c_void, source: *mut spa_source) -> c_int>
Update the source io mask. Must be called from the loop’s own thread.
\param[in] object The callbacks data. \param[in] source The source. \return 0 on success, negative errno-style value on failure.
remove_source: Option<unsafe extern "C" fn(object: *mut c_void, source: *mut spa_source) -> c_int>
Remove a source from the loop. Must be called from the loop’s own thread.
\param[in] object The callbacks data. \param[in] source The source. \return 0 on success, negative errno-style value on failure.
invoke: Option<unsafe extern "C" fn(object: *mut c_void, func: spa_invoke_func_t, seq: u32, data: *const c_void, size: usize, block: bool, user_data: *mut c_void) -> c_int>
Invoke a function in the context of this loop. May be called from any thread and multiple threads at the same time. If called from the loop’s thread, all callbacks previously queued with invoke() will be run synchronously, which might cause unexpected reentrancy problems.
\param[in] object The callbacks data.
\param func The function to be invoked.
\param seq An opaque sequence number. This will be made
available to func.
\param[in] data Data that will be copied into the internal ring buffer and made
available to func. Because this data is copied, it is okay to
pass a pointer to a local variable, but do not pass a pointer to
an object that has identity.
\param size The size of data to copy.
\param block If \true, do not return until func has been called. Otherwise,
returns immediately. Passing \true does not risk a deadlock because
the data thread is never allowed to wait on any other thread.
It the loop requires some locking, it must be acquired before
calling this function because a blocking invoke will release
the lock while blocking.
\param user_data An opaque pointer passed to func.
\return -EPIPE
if the internal ring buffer filled up,
if block is \false, 0 if seq was SPA_ID_INVALID or
seq with the ASYNC flag set
or the return value of func otherwise.
Trait Implementations§
Source§impl Clone for spa_loop_methods
impl Clone for spa_loop_methods
Source§fn clone(&self) -> spa_loop_methods
fn clone(&self) -> spa_loop_methods
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more