-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Open
Labels
A-lintArea: New lintsArea: New lintsL-perfLint: Belongs in the perf lint groupLint: Belongs in the perf lint groupT-middleType: Probably requires verifiying typesType: Probably requires verifiying typesgood first issueThese issues are a good way to get started with ClippyThese issues are a good way to get started with Clippy
Description
Now that min_const_generics is stabilized, I suspect it won't be long for array_windows and array_chunks to be stabilized as well. It would be nice to have a lint ready when that comes. But for now we can check the feature gates.
What it does
Checks for usage of windows or chunks with a constant size. These may be replaced with array_windows and array_chunks respectively.
Categories (optional)
- Kind: perf
What is the advantage of the recommended code over the original code
It avoids heap allocation and should be more performant. Also it often simplifies the code since you can destructure the array.
Drawbacks
None.
Example
for window in slice.windows(2) {
println!("{} {}", w[0], w[1]);
}Could be written as:
for [a, b] in slice.array_windows() {
println!("{} {}", a, b);
}Maybe we should avoid linting if the array would be too big?
Metadata
Metadata
Assignees
Labels
A-lintArea: New lintsArea: New lintsL-perfLint: Belongs in the perf lint groupLint: Belongs in the perf lint groupT-middleType: Probably requires verifiying typesType: Probably requires verifiying typesgood first issueThese issues are a good way to get started with ClippyThese issues are a good way to get started with Clippy