- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
address clippy formatting nits #143423
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
address clippy formatting nits #143423
Conversation
| Some changes occurred to the intrinsics. Make sure the CTFE / Miri interpreter cc @rust-lang/miri, @RalfJung, @oli-obk, @lcnr Some changes occurred to the platform-builtins intrinsics. Make sure the cc @antoyo, @GuillaumeGomez, @bjorn3, @calebzulawski, @programmerjake | 
679953e    to
    1e803f0      
    Compare
  
    | do we run a subset of clippy lints in CI? Is there some overarching issue tracking this work? | 
| regarding overarching issue, see #143367 (comment) | 
| @oli-obk I don't know if any clippy lints run in CI, but I do know that many don't, given the amount of warnings generated by clippy atm. Given the volume of warnings it is very hard to know if there is anything useful in there. Clippy can be a very useful tool in my experience, so I'd like to slowly cut down on the noise. If that succeeds then it seems a good idea to enable clippy in CI to keep the warnings down. @jhpratt has suggested that I should obtain some support/approval for this. I've started my work on core, with std and the compiler possibly after. So @rust-lang/libs, @rust-lang/compiler , can I ask that you consider this? | 
| Clippy is run in CI https://github.com/rust-lang/rust/blob/master/src/bootstrap/src/core/build_steps/clippy.rs. Not member, but if some documentation clean is probably ok, changes like 819d4a3 not immediately obviously (for me) better, they (mostly) miss codegen tests and fixing clippy lint can instead make code slower. | 
| 
 This is true, so there is always the alternative of allowing (or expecting) the lint to silence clippy. | 
| I asked about this on zulip a while back, | 
| @yotamofek thanks for the link. Personally I found the discussion there quite encouraging and I feel supported in working on this. It was very useful to learn about where clippy is already applied in CI, which gives the precise list of lints that are currently enabled. I am not at all proposing to enable all default lints. Right now, all I really need is that it is deemed acceptable to allow lints locally. This would also prevent future bad PRs from people mindlessly following clippy, which was one of the things that were brought up as clippy negatives. This could make it possible to at some point change the global list. Another point brought up was that the default list changes (too much) with each clippy update to enable all lints from the default list. My hope is that more interaction between clippy and rustc will make both better. One example of clippy getting better is: rust-lang/rust-clippy#15200. That change alone prevents hundreds of false positives in rustc, once the next clippy update is merged. And maybe we can get to a point where changes to the default lint list will be checked against rustc before being made. rustc could be a lithmus test for clippy, improving its quality, while at the same time we can try to take more and more advantage of clippy where it works for rustc. Anyway, my current plan is to work through what clippy reports for core. Make changes where appropriate, but also allow lints where they seem bad or don't apply, and report false positives upstream. Along the way I hope to get a better sense of what's possible. | 
| @hkBst Could you please update your PR initial comment with a recap of the lints you added, possibly with a little bit of context about the reasoning? That could help casual reviewers of this patch get a quick summary. Thanks 🙂 | 
| @apiraino I tried to separate out the different parts into separate commits, which name the thing that clippy complains about, but I will mention that in the summary. I think that would help with most of them, except for one which I will try and explain a bit more. I ended up listing the commits with a small explanation for each. | 
| 
 Personally (and my opinion really shouldn't matter that much to anyone 😝) I don't like seeing  Other than that, yeah, I'm happy to see lints being fixed in the codebase. | 
1e803f0    to
    76d9775      
    Compare
  
    | @yotamofek the  | 
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'm not a library reviewer, but speaking as a reviewer generally. I feel like instead of shotgun-applying a bunch of clippy lints, I would strongly encourage the approach of #general > Running clippy on the rustc repo @ 💬:
fwiw when i made
x clippywork i very intentionally did not try to fix any of the lints, because i think it would be a shame if we blindly applied them all.i suspect you are right that there are maybe 5-15 lints we could turn on that would be useful and worth the time to fix. but i would be strongly against just doing
RUSTFLAGS=-Dwarnings x clippybecause most of them are just not that importantfiguring out what those 5-15 lints are would be a good use of time though :) "i think this lint should be on because X" is much more useful than "cargo fix changed the code and i made a pr with the diff"
And if these subset of clippy lints reviewers find generally applicable and materially improves readability (or some other metric), we should include them into the ./x clippy ci subset so that they're actually CI-checked.
I don't subscribe to the argument of
the
allow(..)annotations do add a tiny bit of noise, but what we get in return is fewer PRs from people trying to fix what is not broken, and potentially making it possible to enable these lints later.
I'll take changes which I find materially better, and having a lot of #[allow(clippy::*)] unchecked in CI I don't find is materially better, they just seem noisy...
Even
deemed acceptable to allow lints locally
I don't think justifies having a lot of #[allow(clippy::*)] in the codebase, especially if the allowed clippy lints are non-considerations.
        
          
                library/core/src/mem/mod.rs
              
                Outdated
          
        
      | #[inline] | ||
| #[stable(feature = "mem_take", since = "1.40.0")] | ||
| pub fn take<T: Default>(dest: &mut T) -> T { | ||
| #[allow(clippy::mem_replace_with_default)] // exempt by being the one true definition | 
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.
Remark: or having a lot of #[allow(clippy::*)] that we don't run in CI
        
          
                library/core/src/num/fmt.rs
              
                Outdated
          
        
      | } else if v < 10_000 { | ||
| 4 | ||
| } else { | ||
| if v < 10_000 { 4 } else { 5 } | ||
| 5 | ||
| } | 
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.
Remark: and debatable, but IMO this isn't materially better either.
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.
IMO the vertical spacing is unfortunate, but eliminating extra braces seems worthwhile, no?
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.
This is open-coding a log10 operation, cleaned this up here: #143540
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.
@yotamofek good move! I can't wait to see perf results.
| if you are looking for approval to insert allow directives for clippy, consider opening a compiler MCP: https://forge.rust-lang.org/triagebot/major-changes.html | 
| .. wait these are library changes. so a library MCP or something. sorry im on mobile | 
| When doing library work, clippy admonishing me about implementing something by-hand that is available in std is useless noise. I do not wish for these lints to be enabled for std, as we often must by-hand reimplement parts of std in order to guarantee good performance. | 
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.
        
          
                library/core/src/num/f32.rs
              
                Outdated
          
        
      | pub const NAN: f32 = 0.0_f32 / 0.0_f32; | ||
| /// Infinity (∞). | ||
| #[stable(feature = "assoc_int_consts", since = "1.43.0")] | ||
| #[allow(clippy::zero_divided_by_zero)] | 
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.
The dividend isn't even zero. Why is clippy's "zero_divided_by_zero" lint firing on a division of not-zero by zero?
        
          
                library/core/src/num/fmt.rs
              
                Outdated
          
        
      |  | ||
| impl<'a> Part<'a> { | ||
| /// Returns the exact byte length of given part. | ||
| #[allow(clippy::len_without_is_empty)] | 
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.
No, I do not want this lint on internals of std.
        
          
                library/core/src/num/flt2dec/mod.rs
              
                Outdated
          
        
      | None | ||
| } | ||
| None if d.len() > 0 => { | ||
| None if !d.is_empty() => { | 
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 do not find !x.is_empty() easier to read than d.len() > 0, frankly.
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 sympathize with that statement, but is_empty is in std, presumably because it makes it easier to express intent and thus be clearer and thus also easier to read. If the not is a problem, then this branch can always be switched with the next, I suppose.
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.
Swapping their positions is a reasonable solution.
| // explanations of rounding for positive exponents, see | ||
| // <https://arxiv.org/pdf/2101.11408.pdf#section.8>. | ||
| let inside_safe_exponent = (q >= -27) && (q <= 55); | ||
| let inside_safe_exponent = (-27..=55).contains(&q); | 
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.
It is extremely unlikely this is equivalent codegen in such a sensitive case.
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.
We have #45222 as the classic example of inclusive ranges being optimized worse. I would hope that since the range bounds are constant this use gets optimized well. But I appreciate the caution because the range types are quite complicated now.
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.
Was curious so I checked, and it seems both variations optimize down to the same 3 instructions: https://godbolt.org/z/6WP87jPK9
(that, though, doesn't necessarily mean it will codegen the same in this context, inside a larger function, obviously...)
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.
Given the specifics, this can easily be switched to (-27..56).contains(&q). I was just trying to be conservative.
| While Jubilee took over assignment, I would still prefer that T-libs weigh in before there are numerous PRs like this merged. That was the reason I had explicitly not reviewed any of ones already open. Per asking on Zulip, nominating for the general case of whether we want clippy on the standard library. If so, which ones and/or how should reviewers determine what is appropriate and what PRs to close? | 
| Yes, that's why I singled out the commits that are formatting-only changes. I do not think a few indentation fixups are worth larger discussion. | 
| fn copied<'a, T: Copy + 'a>(self) -> Copied<Self> | ||
| where | ||
| Self: Sized + Iterator<Item = &'a T>, | 
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 did mean for the comment I made about where clauses to generalize, because the where is not easy to elide here. Please move the bound of T into the where.
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.
Sure. The clippy lint is specifically about the bounds on a single variable being split, but I'm happy to collect them all in the where clause.
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.
Done.
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.
Thank you. I realize that but I just prefer that if we're moving them anywhere we move them towards the where, generally.
| fn cloned<'a, T: 'a>(self) -> Cloned<Self> | ||
| fn cloned<'a, T: Clone + 'a>(self) -> Cloned<Self> | ||
| where | ||
| Self: Sized + Iterator<Item = &'a T>, | ||
| T: Clone, | 
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 did mean for the comment I made about where clauses to generalize, because the where is not easy to elide here. Please move the bound of T into the where.
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.
Done.
dc23317    to
    c79f62d      
    Compare
  
    
      
        
              This comment has been minimized.
        
        
      
    
  This comment has been minimized.
| Finished benchmarking commit (e20a673): comparison URL. Overall result: no relevant changes - no action neededBenchmarking this pull request means it may be perf-sensitive – we'll automatically label it not fit for rolling up. You can override this, but we strongly advise not to, due to possible changes in compiler perf. @bors rollup=never Instruction countThis benchmark run did not return any relevant results for this metric. Max RSS (memory usage)Results (secondary -4.9%)A less reliable metric. May be of interest, but not used to determine the overall result above. 
 CyclesResults (primary 0.6%, secondary 2.2%)A less reliable metric. May be of interest, but not used to determine the overall result above. 
 Binary sizeThis benchmark run did not return any relevant results for this metric. Bootstrap: 465.935s -> 466.739s (0.17%) | 
| I updated the description slightly, I hope it is satisfactory. I omitted the flt2dec change from the PR description because it got lost in one of the rebases, though it seems it would be fine for it to also ride? Unclear. Conflicting runtime perf reports in smaller programs. Please feel free to open that as a followup if necessary. @bors r+ rollup | 
| Thanks @workingjubilee, I put the lost commit here #144205. | 
address clippy formatting nits - int_log10.rs: change top level doc comments to outer - collect.rs: remove empty line after doc comment - clippy fix: markdown indentation for indented items after line break: a markdown list item continued over multiples lines, but those following lines which are part of the same item are not indented - clippy fix: bound in one place: when there is a bound in angle brackets and another bound on the same variable in a where clause
Rollup of 9 pull requests Successful merges: - #143282 (Add `uX::strict_sub_signed`) - #143423 (address clippy formatting nits) - #143720 (Allow `Rvalue::Repeat` to return true in `rvalue_creates_operand` too) - #144011 (bootstrap: Don't trigger an unnecessary LLVM build from check builds) - #144112 (bootstrap: Ignore `rust.debuginfo-level-tests` for codegen tests) - #144125 (Add new `ignore-backends` and `needs-backends` tests annotations) - #144143 (Fix `-Ctarget-feature`s getting ignored after `crt-static`) - #144150 (tests: assembly: cstring-merging: Disable GlobalMerge pass) - #144190 (Give a message with a span on MIR validation error) r? `@ghost` `@rustbot` modify labels: rollup
Rollup merge of #143423 - hkBst:clippy-fix-1, r=workingjubilee address clippy formatting nits - int_log10.rs: change top level doc comments to outer - collect.rs: remove empty line after doc comment - clippy fix: markdown indentation for indented items after line break: a markdown list item continued over multiples lines, but those following lines which are part of the same item are not indented - clippy fix: bound in one place: when there is a bound in angle brackets and another bound on the same variable in a where clause
Rollup of 9 pull requests Successful merges: - rust-lang/rust#143282 (Add `uX::strict_sub_signed`) - rust-lang/rust#143423 (address clippy formatting nits) - rust-lang/rust#143720 (Allow `Rvalue::Repeat` to return true in `rvalue_creates_operand` too) - rust-lang/rust#144011 (bootstrap: Don't trigger an unnecessary LLVM build from check builds) - rust-lang/rust#144112 (bootstrap: Ignore `rust.debuginfo-level-tests` for codegen tests) - rust-lang/rust#144125 (Add new `ignore-backends` and `needs-backends` tests annotations) - rust-lang/rust#144143 (Fix `-Ctarget-feature`s getting ignored after `crt-static`) - rust-lang/rust#144150 (tests: assembly: cstring-merging: Disable GlobalMerge pass) - rust-lang/rust#144190 (Give a message with a span on MIR validation error) r? `@ghost` `@rustbot` modify labels: rollup
Rollup of 9 pull requests Successful merges: - rust-lang/rust#143282 (Add `uX::strict_sub_signed`) - rust-lang/rust#143423 (address clippy formatting nits) - rust-lang/rust#143720 (Allow `Rvalue::Repeat` to return true in `rvalue_creates_operand` too) - rust-lang/rust#144011 (bootstrap: Don't trigger an unnecessary LLVM build from check builds) - rust-lang/rust#144112 (bootstrap: Ignore `rust.debuginfo-level-tests` for codegen tests) - rust-lang/rust#144125 (Add new `ignore-backends` and `needs-backends` tests annotations) - rust-lang/rust#144143 (Fix `-Ctarget-feature`s getting ignored after `crt-static`) - rust-lang/rust#144150 (tests: assembly: cstring-merging: Disable GlobalMerge pass) - rust-lang/rust#144190 (Give a message with a span on MIR validation error) r? `@ghost` `@rustbot` modify labels: rollup
address clippy formatting nits - int_log10.rs: change top level doc comments to outer - collect.rs: remove empty line after doc comment - clippy fix: markdown indentation for indented items after line break: a markdown list item continued over multiples lines, but those following lines which are part of the same item are not indented - clippy fix: bound in one place: when there is a bound in angle brackets and another bound on the same variable in a where clause
…llaumeGomez Rollup of 9 pull requests Successful merges: - rust-lang#143282 (Add `uX::strict_sub_signed`) - rust-lang#143423 (address clippy formatting nits) - rust-lang#143720 (Allow `Rvalue::Repeat` to return true in `rvalue_creates_operand` too) - rust-lang#144011 (bootstrap: Don't trigger an unnecessary LLVM build from check builds) - rust-lang#144112 (bootstrap: Ignore `rust.debuginfo-level-tests` for codegen tests) - rust-lang#144125 (Add new `ignore-backends` and `needs-backends` tests annotations) - rust-lang#144143 (Fix `-Ctarget-feature`s getting ignored after `crt-static`) - rust-lang#144150 (tests: assembly: cstring-merging: Disable GlobalMerge pass) - rust-lang#144190 (Give a message with a span on MIR validation error) r? `@ghost` `@rustbot` modify labels: rollup
address clippy formatting nits - int_log10.rs: change top level doc comments to outer - collect.rs: remove empty line after doc comment - clippy fix: markdown indentation for indented items after line break: a markdown list item continued over multiples lines, but those following lines which are part of the same item are not indented - clippy fix: bound in one place: when there is a bound in angle brackets and another bound on the same variable in a where clause
Uh oh!
There was an error while loading. Please reload this page.