| 1 | use std::fmt; |
| 2 | use std::sync::Arc; |
| 3 | |
| 4 | use crate::task::TaskId; |
| 5 | |
| 6 | /// A handle to a task. |
| 7 | #[derive (Clone)] |
| 8 | pub struct Task { |
| 9 | /// The task ID. |
| 10 | id: TaskId, |
| 11 | |
| 12 | /// The optional task name. |
| 13 | name: Option<Arc<String>>, |
| 14 | } |
| 15 | |
| 16 | impl Task { |
| 17 | /// Creates a new task handle. |
| 18 | #[inline ] |
| 19 | pub(crate) fn new(name: Option<Arc<String>>) -> Task { |
| 20 | Task { |
| 21 | id: TaskId::generate(), |
| 22 | name, |
| 23 | } |
| 24 | } |
| 25 | |
| 26 | /// Gets the task's unique identifier. |
| 27 | #[inline ] |
| 28 | pub fn id(&self) -> TaskId { |
| 29 | self.id |
| 30 | } |
| 31 | |
| 32 | /// Returns the name of this task. |
| 33 | /// |
| 34 | /// The name is configured by [`Builder::name`] before spawning. |
| 35 | /// |
| 36 | /// [`Builder::name`]: struct.Builder.html#method.name |
| 37 | pub fn name(&self) -> Option<&str> { |
| 38 | self.name.as_ref().map(|s| s.as_str()) |
| 39 | } |
| 40 | } |
| 41 | |
| 42 | impl fmt::Debug for Task { |
| 43 | fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { |
| 44 | f&mut DebugStruct<'_, '_>.debug_struct("Task" ) |
| 45 | .field("id" , &self.id()) |
| 46 | .field(name:"name" , &self.name()) |
| 47 | .finish() |
| 48 | } |
| 49 | } |
| 50 | |