Struct bevy_tasks::Scope

source ·
pub struct Scope<'scope, 'env: 'scope, T> { /* private fields */ }
Expand description

A TaskPool scope for running one or more non-'static futures.

For more information, see TaskPool::scope.

Implementations§

source§

impl<'scope, 'env, T: Send + 'scope> Scope<'scope, 'env, T>

source

pub fn spawn<Fut: Future<Output = T> + 'scope + Send>(&self, f: Fut)

Spawns a scoped future onto the thread pool. The scope must outlive the provided future. The results of the future will be returned as a part of TaskPool::scope’s return value.

For futures that should run on the thread scope is called on Scope::spawn_on_scope should be used instead.

For more information, see TaskPool::scope.

source

pub fn spawn_on_scope<Fut: Future<Output = T> + 'scope + Send>(&self, f: Fut)

Spawns a scoped future onto the thread the scope is run on. The scope must outlive the provided future. The results of the future will be returned as a part of TaskPool::scope’s return value. Users should generally prefer to use Scope::spawn instead, unless the provided future needs to run on the scope’s thread.

For more information, see TaskPool::scope.

source

pub fn spawn_on_external<Fut: Future<Output = T> + 'scope + Send>(&self, f: Fut)

Spawns a scoped future onto the thread of the external thread executor. This is typically the main thread. The scope must outlive the provided future. The results of the future will be returned as a part of TaskPool::scope’s return value. Users should generally prefer to use Scope::spawn instead, unless the provided future needs to run on the external thread.

For more information, see TaskPool::scope.

Trait Implementations§

source§

impl<'scope, 'env: 'scope, T: Debug> Debug for Scope<'scope, 'env, T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'scope, 'env, T> Drop for Scope<'scope, 'env, T>where T: 'scope,

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<'scope, 'env, T> RefUnwindSafe for Scope<'scope, 'env, T>

§

impl<'scope, 'env, T> Send for Scope<'scope, 'env, T>where T: Send,

§

impl<'scope, 'env, T> Sync for Scope<'scope, 'env, T>where T: Send,

§

impl<'scope, 'env, T> Unpin for Scope<'scope, 'env, T>

§

impl<'scope, 'env, T> !UnwindSafe for Scope<'scope, 'env, T>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.