-
-
Notifications
You must be signed in to change notification settings - Fork 2.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(tokio_util): Stabilise JoinMap #7075
base: master
Are you sure you want to change the base?
feat(tokio_util): Stabilise JoinMap #7075
Conversation
eb9f646
to
5155239
Compare
5155239
to
91695b2
Compare
@@ -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 } |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm. I'll have to think about what implications this has for our MSRV.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
hashbrown 0.14.0 has a rust-version = "1.64.0"
.
hashbrown 0.15.2 has a rust-version = "1.65.0"
.
It doesn't seem to have an explicit MSRV policy, but it is inline with tokio-util's 1.70.0
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm okay with this, but I don't want to require hashbrown if you're just using the TaskTracker
. Can you add a join_map
feature?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That seems reasonable. Will do
tokio-util/src/task/join_map.rs
Outdated
#[cfg_attr(docsrs, doc(cfg(all(feature = "rt", tokio_unstable))))] | ||
#[cfg_attr(docsrs, doc(cfg(feature = "rt")))] | ||
pub struct JoinMap<K, V, S = RandomState> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Once you add the join_map
feature, this annotation may not be necessary. Please try removing it and checking the docs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Overall LGTM.
|
||
net = ["tokio/net"] | ||
compat = ["futures-io",] | ||
codec = [] | ||
time = ["tokio/time","slab"] | ||
io = [] | ||
io-util = ["io", "tokio/rt", "tokio/io-util"] | ||
rt = ["tokio/rt", "tokio/sync", "futures-util", "hashbrown"] | ||
rt = ["tokio/rt", "tokio/sync", "futures-util"] | ||
join-map = ["rt", "hashbrown"] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Would this be sufficient?
join-map = ["rt", "hashbrown"] | |
join-map = ["tokio/rt", "hashbrown"] |
Motivation
The other day I saw someone asking for JoinMap to be stabalised. I happened to notice just now that the task ID system is now stable in tokio.
Solution
Removes the unstable config requirement for
tokio_util::JoinMap
.