Struct futures_core::task::Context [−][src]
pub struct Context<'a> { /* fields omitted */ }
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Information about the currently-running task.
Contexts are always tied to the stack, since they are set up specifically
when performing a single poll
step on a task.
Methods
impl<'a> Context<'a>
[src]
impl<'a> Context<'a>
pub fn new(
local_waker: &'a LocalWaker,
executor: &'a mut (Executor + 'a)
) -> Context<'a>
[src]
pub fn new(
local_waker: &'a LocalWaker,
executor: &'a mut (Executor + 'a)
) -> Context<'a>
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Create a new task Context
with the provided local_waker
, waker
, and executor
.
pub fn local_waker(&self) -> &'a LocalWaker
[src]
pub fn local_waker(&self) -> &'a LocalWaker
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Get the LocalWaker
associated with the current task.
pub fn waker(&self) -> &'a Waker
[src]
pub fn waker(&self) -> &'a Waker
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Get the Waker
associated with the current task.
pub fn executor(&mut self) -> &mut Executor
[src]
pub fn executor(&mut self) -> &mut Executor
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Get the default executor associated with this task.
This method is useful primarily if you want to explicitly handle spawn failures.
pub fn with_waker(&'b mut self, local_waker: &'b LocalWaker) -> Context<'b>
[src]
pub fn with_waker(&'b mut self, local_waker: &'b LocalWaker) -> Context<'b>
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Produce a context like the current one, but using the given waker instead.
This advanced method is primarily used when building "internal schedulers" within a task, where you want to provide some customized wakeup logic.
pub fn with_executor<E>(&'b mut self, executor: &'b mut E) -> Context<'b> where
E: Executor,
[src]
pub fn with_executor<E>(&'b mut self, executor: &'b mut E) -> Context<'b> where
E: Executor,
🔬 This is a nightly-only experimental API. (futures_api
)
futures in libcore are unstable
Produce a context like the current one, but using the given executor instead.
This advanced method is primarily used when building "internal schedulers" within a task.