1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
//! The core [`Task`] abstraction.
use crateContext;
use crateTaskError;
use async_trait;
use Arc;
/// The value a task produces on success.
pub type TaskOutput = Value;
/// A unit of work in the DAG.
///
/// Implementations must be `Send + Sync` because tasks are shared across worker
/// threads (`Arc<dyn Task>`) and executed concurrently. The default
/// [`Task::dependencies`] and [`Task::priority`] make leaf, normal-priority
/// tasks the zero-boilerplate case.