-
Notifications
You must be signed in to change notification settings - Fork 12.9k
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
Don't mark generators as !Send
if a Copy + !Send
value is dropped across a yield
#99105
Conversation
r? @lcnr (rust-highfive has picked a reviewer for you, use r? to override) |
Would be worth adding a test for a non-copy but non-dropping type being dropped across a yield, like It should still be fine, though. But I think this would mean going from "this definitely doesn't need drop" to "this might need drop" is a breaking change, whereas bounding it on Copy is fine since removing a copy impl is already a breaking change. |
… across a yield Copy types can neither read nor write their values when dropped (the language guarantees Drop is a no-op). So it doesn't make sense for them to make the generator non-Send.
Oh excellent catch, thank you. I changed it to use I'm not sure how to do this while taking lifetimes into account - |
The job Click to see the possible cause of the failure (guessed by this bot)
|
(the exact way I implemented this seems to not be correct, since it's not picking up items that are copied after a yield - going to wait to fix that until I hear back about whether we want to do this at all) |
impl !Send for S {} | ||
|
||
fn main() { | ||
println!("{}", std::mem::needs_drop::<S>()); |
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.
println!("{}", std::mem::needs_drop::<S>()); |
It is fine here. Actually considering lifetimes when making decisions based on whether a trait is implemented is pretty difficult (if not impossible in rust). But considering that having any |
@@ -51,6 +52,19 @@ impl<'a, 'tcx> InteriorVisitor<'a, 'tcx> { | |||
ty, hir_id, scope, expr, source_span, self.expr_count, | |||
); | |||
|
|||
if self.fcx.type_is_copy_modulo_regions(self.fcx.param_env, ty, source_span) { | |||
// This is only used because it's dropped after the yield. |
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.
How does the code know this?
@tmandry @eholk fyi this code is not correct at all, see #99105 (comment). I suspect getting it to work is going to be kind of tricky. It sounds like you've agreed this is a good idea so I'll try and put in some time to fixing it after RustConf. |
☔ The latest upstream changes (presumably #101239) made this pull request unmergeable. Please resolve the merge conflicts. |
Switching to waiting on author. Also S-blocked to signal that it needs an FCP. @rustbot author |
Copy types can neither read nor write their values when dropped (the language guarantees Drop is a no-op).
So it doesn't make sense for them to make the generator non-Send.
Fixes #99104.
This may need a T-lang FCP.
cc @eholk - maybe we want to feature-gate this behind
-Zdrop-tracking
? I don't think this is related to building the control-flow-graph, though, it also applies even when we naively assume the value is always dropped at the end of the lexical scope.