Skip to content

Conversation

@lnicola
Copy link
Member

@lnicola lnicola commented May 3, 2020

@matklad do you want to merge this? I'd make it opt-out, but it's fine to test it more.

@lnicola lnicola force-pushed the optin-incremental branch from 5e62e23 to 87a18b1 Compare May 3, 2020 17:58
@matklad
Copy link
Contributor

matklad commented May 3, 2020

bors r+

Yeah, let's make this opt-in, and next week switch it to opt-out if we fail to find the issue ourselves.

bors bot added a commit that referenced this pull request May 3, 2020
4286: Make incremental sync opt-in r=matklad a=lnicola

@matklad do you want to merge this? I'd make it opt-out, but it's fine to test it more.

Co-authored-by: Laurențiu Nicola <[email protected]>
bors bot added a commit that referenced this pull request May 3, 2020
4286: Make incremental sync opt-in r=matklad a=lnicola

@matklad do you want to merge this? I'd make it opt-out, but it's fine to test it more.

4287: Update debugging.md r=matklad a=lonesometraveler



Co-authored-by: Laurențiu Nicola <[email protected]>
Co-authored-by: KENTARO OKUDA <[email protected]>
@edwin0cheng
Copy link
Contributor

bors retry

@bors
Copy link
Contributor

bors bot commented May 4, 2020

@bors bors bot merged commit 57ec813 into rust-lang:master May 4, 2020
@lnicola lnicola deleted the optin-incremental branch May 4, 2020 05:51
@lnicola
Copy link
Member Author

lnicola commented May 4, 2020

@matklad you should probably retrigger the nightly build.

@matklad
Copy link
Contributor

matklad commented May 4, 2020

Hm, I haven't seen panics after the utf16 fix, and I now have a hypothesis that that might actually be a real fix:

  • I've wrote that the code I worked on when I hit the panic didn't contain non-ascii characters
  • I also wrote that the moment we hit a panic is not necessary the moment the error happens
  • And I do sometimes type Rust code in Кирилица, by accident

So let's hope that everything is fine. We'll know for sure later today :D We need to enjoy the last opportunities to break things.

Though, we still need to revert the opt-in, and we also need to implement "iterrate every char" test for line index.

@lnicola
Copy link
Member Author

lnicola commented May 4, 2020

There might still be a bug in the tracking of line index validity range. I can't check right now, but I think we invalidate the lines below the edited range. The UTF-16 character list for the current line might also become invalid. I'll fix that when enabling it again.

And I do sometimes type Rust code in Кирилица, by accident

XD. That's why I prefer per-window, not global, IME config.

@matklad
Copy link
Contributor

matklad commented May 4, 2020

XD. That's why I prefer per-window, not global, IME config.

Hm, I think I should try this out -- originally I disliked it, because I was always confused about which language I am using right now, as the tray indication would just change when flipping the windows. However as of couple of years ago, I am using a custom layout, which just doesn't work with the tray indicator, so I got used to not knowing which layout is active at the moment :D

lnicola pushed a commit to lnicola/rust-analyzer that referenced this pull request Jun 18, 2025
…RalfJung

Enable Non-determinism of float operations in Miri and change std tests

Links to [rust-lang#4208](rust-lang/miri#4208) and [rust-lang#3555](rust-lang/miri#3555) in Miri.

Non-determinism of floating point operations was disabled in rust-lang/rust#137594 because it breaks the tests and doc-tests in core/coretests and std. This PR enables some of them.

This pr includes the following changes:

- Enables the float non-determinism but with a lower relative error of 4ULP instead of 16ULP
- These operations now have a fixed output based on the C23 standard, except the pow operations, this is tracked in [rust-lang#4286](rust-lang/miri#4286 (comment))
- Changes tests that made incorrect assumptions about the operations, not to make that assumption anymore (from `assert_eq!` to `assert_approx_eq!`.
- Changed the doctests of the stdlib of these operations to compare against fixed constants instead of `f*::EPSILON`, which now succeed with Miri and `-Zmiri-many-seeds`
- Added a constant `APPROX_DELTA` in `std/tests/floats/f32.rs` which is used for approximation tests, but with a different value when run in Miri. This is to make these tests succeed.
- Added tests in the float tests of Miri to test the C23 behaviour.

Fixes rust-lang/miri#4208
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants