-
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
f*::NAN: guarantee that this is a quiet NaN #139483
base: master
Are you sure you want to change the base?
Conversation
@rfcbot merge |
Team member @m-ou-se has proposed to merge this. The next step is review by the rest of the tagged team members: No concerns currently listed. Once a majority of reviewers approve (and at most 2 approvals are outstanding), this will enter its final comment period. If you spot a major issue that hasn't been raised at any point in this process, please speak up! See this document for info about what commands tagged team members can give me. |
The Miri subtree was changed cc @rust-lang/miri |
🔔 This is now entering its final comment period, as per the review above. 🔔 |
Is it worth considering the alternative of making no guarantees about |
I think adding a |
I think we should guarantee that this is a quiet NaN. This then implies that programs not using
f*::from_bits
(or unsafe type conversions) are guaranteed to only work with quiet NaNs. It would be awkward if people start to write0.0 / 0.0
instead of using the constant just because they want to get a guaranteed-quiet NaN.This is a @rust-lang/libs-api change. The definition of this constant currently is
0.0 / 0.0
, which is already guaranteed to be a quiet NaN. So all this does is forward that guarantee to our users.