Skip to content
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

Tidy up asm! usage in libstd #10021

Merged
merged 1 commit into from
Oct 23, 2013

Conversation

alexcrichton
Copy link
Member

We got a snapshot, taking care of a note to myself.

bors added a commit that referenced this pull request Oct 23, 2013
…r=luqmana

We got a snapshot, taking care of a note to myself.
@bors bors closed this Oct 23, 2013
@bors bors merged commit e6d8f06 into rust-lang:master Oct 23, 2013
flip1995 pushed a commit to flip1995/rust that referenced this pull request Dec 8, 2022
flip1995 pushed a commit to flip1995/rust that referenced this pull request Dec 17, 2022
flip1995 pushed a commit to flip1995/rust that referenced this pull request Dec 17, 2022
flip1995 pushed a commit to flip1995/rust that referenced this pull request Dec 17, 2022
Fix 10021

This PR proposes a fix for rust-lang#10021.

The problem is similar to the one that `@mikerite` described in rust-lang#9505. The compiler is generating an empty substitution for a call, even though the type of `Self` seems to be needed for a predicate. In `@mikerite's` case, the call was to [`IntoFuture::into_future`](https://doc.rust-lang.org/std/future/trait.IntoFuture.html#tymethod.into_future). In this case, the call is to [`Try::branch`](https://doc.rust-lang.org/std/ops/trait.Try.html#tymethod.branch).

The proposed fix is to verify that the parameter whose type is changing has an index within the substitution. The strikes me as a reasonable approach, since if the check were to fail, the following code would be a no-op:

https://github.com/rust-lang/rust-clippy/blob/4c123a06ba3c2ec17d3a4dfa251dccdc5368b712/clippy_lints/src/methods/unnecessary_to_owned.rs#L420-L428

Like `@mikerite's` original solution, this solution turns ICEs into false negatives.

changelog: fix `unnecessary_to_owned` false positive involving `Try::branch`
flip1995 pushed a commit to flip1995/rust that referenced this pull request Dec 17, 2022
blyxyas pushed a commit to blyxyas/rust that referenced this pull request Jan 3, 2024
… r=Jarcho

Remove mitigations for incorrect node args

This change https://github.com/rust-lang/rust/pull/118420/files#r1419874371 adds a missing `write_args` to properly record node args for lang-item calls.

Thus, in the `unnecessary_to_owned` lint, this ensures that the `call_generic_args` extracted by `get_callee_generic_args_and_args` are always correct, and we can remove the mitigation for rust-lang#9504 and rust-lang#10021 since the root cause has been fixed.

I'm not sure if there is other now-unnecessary code that can be removed, but this is the one I found when investigating rust-lang/rust-clippy#11965 (comment).

changelog: none
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