pub struct Dispatcher(/* private fields */);
Expand description
An owned handle for a dispatcher managed by the driver runtime.
Implementations§
Source§impl Dispatcher
impl Dispatcher
Sourcepub unsafe fn from_raw(handle: NonNull<fdf_dispatcher>) -> Dispatcher
pub unsafe fn from_raw(handle: NonNull<fdf_dispatcher>) -> Dispatcher
Creates a dispatcher ref from a raw handle.
§Safety
Caller is responsible for ensuring that the given handle is valid and not owned by any other wrapper that will free it at an arbitrary time.
Sourcepub fn is_unsynchronized(&self) -> bool
pub fn is_unsynchronized(&self) -> bool
Whether this dispatcher’s tasks and futures can run on multiple threads at the same time.
Sourcepub fn allows_thread_blocking(&self) -> bool
pub fn allows_thread_blocking(&self) -> bool
Whether this dispatcher is allowed to call blocking functions or not
Sourcepub fn post_task_sync(&self, p: impl TaskCallback) -> Result<(), Status>
pub fn post_task_sync(&self, p: impl TaskCallback) -> Result<(), Status>
Schedules the callback [p
] to be run on this dispatcher later.
Sourcepub fn release(self) -> DispatcherRef<'static>
pub fn release(self) -> DispatcherRef<'static>
Releases ownership over this dispatcher and returns a DispatcherRef
that can be used to access it. The lifetime of this reference is static because it will
exist so long as this current driver is loaded, but the driver runtime will shut it down
when the driver is unloaded.
Sourcepub fn as_dispatcher_ref(&self) -> DispatcherRef<'_>
pub fn as_dispatcher_ref(&self) -> DispatcherRef<'_>
Returns a DispatcherRef
that references this dispatcher with a lifetime constrained by
self
.
Trait Implementations§
Source§impl Debug for Dispatcher
impl Debug for Dispatcher
Source§impl Drop for Dispatcher
impl Drop for Dispatcher
Source§impl<'a> OnDispatcher for &'a Dispatcher
impl<'a> OnDispatcher for &'a Dispatcher
Source§fn on_dispatcher<R>(&self, f: impl FnOnce(Option<DispatcherRef<'_>>) -> R) -> R
fn on_dispatcher<R>(&self, f: impl FnOnce(Option<DispatcherRef<'_>>) -> R) -> R
f
with a lifetime-bound DispatcherRef
for this object’s dispatcher.
If the dispatcher is no longer valid, the callback will be given None
.Source§fn on_maybe_dispatcher<R, E>(
&self,
f: impl FnOnce(DispatcherRef<'_>) -> Result<R, E>,
) -> Result<R, E>where
E: From<Status>,
fn on_maybe_dispatcher<R, E>(
&self,
f: impl FnOnce(DispatcherRef<'_>) -> Result<R, E>,
) -> Result<R, E>where
E: From<Status>,
OnDispatcher::on_dispatcher
that translates an invalidated dispatcher
handle into a [Status::BAD_STATE
] error instead of giving the callback None
.Source§fn spawn_task(
&self,
future: impl Future<Output = ()> + Send + 'static,
) -> Result<(), Status>where
Self: 'static,
fn spawn_task(
&self,
future: impl Future<Output = ()> + Send + 'static,
) -> Result<(), Status>where
Self: 'static,
Ok
then the task
has successfully been scheduled and will run or be cancelled and dropped when the dispatcher
shuts down.