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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/// Waits for a shutdown signal and then shuts down each task in order.
///
/// `run!` accepts one or more expressions that implement [`Task`](crate::runtime::Task).
/// It returns an `async` block that, when `.await`ed:
///
/// 1. Calls [`wait_for_shutdown_signal`](crate::runtime::wait_for_shutdown_signal)
/// and blocks until `SIGINT` or `SIGTERM` is received.
/// 2. Iterates through each supplied task **in declaration order**, calling
/// [`Task::shutdown`](crate::runtime::Task::shutdown) on each one.
/// 3. Logs a tracing `info` event for each step and an `error` event for any
/// task that returns `Err`.
/// 4. Returns `Ok::<(), modo::Error>(())`.
///
/// # Example
///
/// ```rust,no_run
/// use modo::runtime::Task;
/// use modo::Result;
///
/// struct Worker;
/// struct HttpServer;
///
/// impl Task for Worker {
/// async fn shutdown(self) -> Result<()> { Ok(()) }
/// }
///
/// impl Task for HttpServer {
/// async fn shutdown(self) -> Result<()> { Ok(()) }
/// }
///
/// #[tokio::main]
/// async fn main() -> Result<()> {
/// let worker = Worker;
/// let server = HttpServer;
/// modo::run!(worker, server).await
/// }
/// ```