From 91695b2570f74904a43c3fbb1bb631cfc290f09e Mon Sep 17 00:00:00 2001 From: Conrad Ludgate Date: Mon, 6 Jan 2025 15:31:38 +0000 Subject: [PATCH] feat: Stabalise JoinMap --- tokio-util/Cargo.toml | 2 -- tokio-util/src/task/join_map.rs | 7 +------ tokio-util/src/task/mod.rs | 5 +---- tokio-util/tests/task_join_map.rs | 2 +- 4 files changed, 3 insertions(+), 13 deletions(-) diff --git a/tokio-util/Cargo.toml b/tokio-util/Cargo.toml index d215590d9f2..e4123270db7 100644 --- a/tokio-util/Cargo.toml +++ b/tokio-util/Cargo.toml @@ -43,8 +43,6 @@ futures-util = { version = "0.3.0", optional = true } pin-project-lite = "0.2.11" slab = { version = "0.4.4", optional = true } # Backs `DelayQueue` tracing = { version = "0.1.29", default-features = false, features = ["std"], optional = true } - -[target.'cfg(tokio_unstable)'.dependencies] hashbrown = { version = "0.14.0", default-features = false, optional = true } [dev-dependencies] diff --git a/tokio-util/src/task/join_map.rs b/tokio-util/src/task/join_map.rs index 13e27bb670b..c3ab3958a97 100644 --- a/tokio-util/src/task/join_map.rs +++ b/tokio-util/src/task/join_map.rs @@ -29,10 +29,6 @@ use tokio::task::{AbortHandle, Id, JoinError, JoinSet, LocalSet}; /// /// When the `JoinMap` is dropped, all tasks in the `JoinMap` are immediately aborted. /// -/// **Note**: This type depends on Tokio's [unstable API][unstable]. See [the -/// documentation on unstable features][unstable] for details on how to enable -/// Tokio's unstable features. -/// /// # Examples /// /// Spawn multiple tasks and wait for them: @@ -96,11 +92,10 @@ use tokio::task::{AbortHandle, Id, JoinError, JoinSet, LocalSet}; /// ``` /// /// [`JoinSet`]: tokio::task::JoinSet -/// [unstable]: tokio#unstable-features /// [abort]: fn@Self::abort /// [abort_matching]: fn@Self::abort_matching /// [contains]: fn@Self::contains_key -#[cfg_attr(docsrs, doc(cfg(all(feature = "rt", tokio_unstable))))] +#[cfg_attr(docsrs, doc(cfg(feature = "rt")))] pub struct JoinMap { /// A map of the [`AbortHandle`]s of the tasks spawned on this `JoinMap`, /// indexed by their keys and task IDs. diff --git a/tokio-util/src/task/mod.rs b/tokio-util/src/task/mod.rs index 6d0c379fe20..cad3f434cb8 100644 --- a/tokio-util/src/task/mod.rs +++ b/tokio-util/src/task/mod.rs @@ -1,12 +1,9 @@ //! Extra utilities for spawning tasks -#[cfg(tokio_unstable)] -mod join_map; mod spawn_pinned; pub use spawn_pinned::LocalPoolHandle; -#[cfg(tokio_unstable)] -#[cfg_attr(docsrs, doc(cfg(all(tokio_unstable, feature = "rt"))))] +mod join_map; pub use join_map::{JoinMap, JoinMapKeys}; pub mod task_tracker; diff --git a/tokio-util/tests/task_join_map.rs b/tokio-util/tests/task_join_map.rs index 8757f8b5c6e..e83036dec33 100644 --- a/tokio-util/tests/task_join_map.rs +++ b/tokio-util/tests/task_join_map.rs @@ -1,6 +1,6 @@ #![allow(unknown_lints, unexpected_cfgs)] #![warn(rust_2018_idioms)] -#![cfg(all(feature = "rt", tokio_unstable))] +#![cfg(feature = "rt")] use tokio::sync::oneshot; use tokio::time::Duration;