-
Notifications
You must be signed in to change notification settings - Fork 13.2k
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
Fallback {float}
to f32
when f32: From<{float}>
and add impl From<f16> for f32
#139087
base: master
Are you sure you want to change the base?
Conversation
Some changes occurred in src/tools/clippy cc @rust-lang/clippy |
ef59666
to
bb79c28
Compare
This comment has been minimized.
This comment has been minimized.
bb79c28
to
afe5b7f
Compare
This comment has been minimized.
This comment has been minimized.
afe5b7f
to
f4cb5a7
Compare
@bors try |
Fallback `{float}` to `f32` when `f32: From<{float}>` and add `impl From<f16> for f32` Currently, the following code compiles: ```rust fn foo::<T: Into<f32>>(_: T) {} fn main() { foo(1.0); } ``` This is because the only `From<{float}>` impl for `f32` is currently `From<f32>`. However, once `impl From<f16> for f32` is added this is no longer the case. This would cause the float literal to fallback to `f64`, subsequently causing a type error as `f32` does not implement `From<f64>`. While this kind of change to type inference isn't technically a breaking change according to Rust's breaking change policy, the previous attempt to add `impl From<f16> for f32` was removed rust-lang#123830 due to the large number of crates affected (by my count, there were root regressions in 42 crates and 52 GitHub repos, not including duplicates). This PR solves this problem by using `f32` as the fallback type for `{float}` when there is a trait predicate of `f32: From<{float}>`. This allows adding `impl From<f16> for f32` without affecting the code that currently compiles (such as the example above; this PR shouldn't affect what is possible on stable). This PR also allows adding a future-incompatibility warning if the lang team wants one; alternatively this could be expanded in the future into something more general like `@tgross35` suggested in rust-lang#123831 (comment). I think it would be also possible to disallow the `f32` fallback in a future edition. This will need a crater check. For reference, I've based the implementation loosely on the existing `calculate_diverging_fallback`. This first commit adds the `f32` fallback and the second adds `impl From<f16> for f32`. I think this falls under the types team, so r? types Fixes: rust-lang#123831 Tracking issue: rust-lang#116909 `@rustbot` label +T-lang +T-types +T-libs-api +F-f16_and_f128 To decide on whether a future-incompatibility warning is desired or otherwise (see above): `@rustbot` label +I-lang-nominated
☀️ Try build successful - checks-actions |
@craterbot check |
👌 Experiment ℹ️ Crater is a tool to run experiments across parts of the Rust ecosystem. Learn more |
🚧 Experiment ℹ️ Crater is a tool to run experiments across parts of the Rust ecosystem. Learn more |
🚨 Report generation of 🆘 Can someone from the infra team check in on this? @rust-lang/infra |
@craterbot retry-report |
🛠️ Generation of the report for ℹ️ Crater is a tool to run experiments across parts of the Rust ecosystem. Learn more |
🎉 Experiment
|
As expected, all regressions are spurious:
|
.iter() | ||
.flat_map(|ty| ty.float_vid()) | ||
.filter(|vid| roots.contains(&self.root_float_var(*vid))) | ||
.collect(); |
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.
Why do the mapping from root to all unified infer vars here instead of looking at the root in fallback_if_possible
? Please add a comment
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've added a comment. I put that there because that's what calculate_diverging_fallback
does and there's a comment at the top of fallback_if_possible
stating that "we determine its fallback based solely on how it was created, not what other type variables it may have been unified with since then", saying it makes it easier to detect bugs.
Somewhat hacky, but that feels required unfortunately 😅 this PR looks good to me Unlike an additional general fallback mechanism, this is not a breaking change as I would like us to future compat warn here and to potentially remove this fallback in the future, or future editions. I think our current fallback rules are kinda iffy and could imagine us wanting to change our approach in more fundamental ways at some point in the future. |
f4cb5a7
to
7cf6e0c
Compare
I've added the future-incompatibility warning in the third commit. I've left the issue number as |
This comment has been minimized.
This comment has been minimized.
7cf6e0c
to
7cbd8ef
Compare
☔ The latest upstream changes (presumably #120706) made this pull request unmergeable. Please resolve the merge conflicts. |
7cbd8ef
to
b089102
Compare
Rebased |
Currently, the following code compiles:
This is because the only
From<{float}>
impl forf32
is currentlyFrom<f32>
. However, onceimpl From<f16> for f32
is added this is no longer the case. This would cause the float literal to fallback tof64
, subsequently causing a type error asf32
does not implementFrom<f64>
. While this kind of change to type inference isn't technically a breaking change according to Rust's breaking change policy, the previous attempt to addimpl From<f16> for f32
was removed #123830 due to the large number of crates affected (by my count, there were root regressions in 42 crates and 52 GitHub repos, not including duplicates). This PR solves this problem by usingf32
as the fallback type for{float}
when there is a trait predicate off32: From<{float}>
. This allows addingimpl From<f16> for f32
without affecting the code that currently compiles (such as the example above; this PR shouldn't affect what is possible on stable).This PR also allows adding a future-incompatibility warning for the fallback to
f32
(currently implemented in the third commit) if the lang team wants one (allowing thef32
fallback to be removed in the future); alternatively this could be expanded in the future into something more general like @tgross35 suggested in #123831 (comment). I think it would be also possible to disallow thef32
fallback in a future edition.As expected, a crater check showed no non-spurious regressions.
For reference, I've based the implementation loosely on the existing
calculate_diverging_fallback
. This first commit adds thef32
fallback, the second addsimpl From<f16> for f32
, and the third adds a FCW lint for thef32
fallback. I think this falls under the types team, sor? types
Fixes: #123831
Tracking issue: #116909
@rustbot label +T-lang +T-types +T-libs-api +F-f16_and_f128
To decide on whether a future-incompatibility warning is desired or otherwise (see above):
@rustbot label +I-lang-nominated