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

Rollup of 5 pull requests #117538

Merged
merged 86 commits into from
Nov 3, 2023
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
Show all changes
86 commits
Select commit Hold shift + click to select a range
5e17f9f
Skip if_not_else lint for '!= 0'-style checks
BenWiederhake Jun 25, 2023
438f934
suggest passing function instead of calling it in [`option_if_let_else`]
J-ZhengLi Sep 4, 2023
22ba792
Update clippy_lints/src/option_if_let_else.rs
J-ZhengLi Sep 12, 2023
fb4f603
Apply suggestions from code review
J-ZhengLi Sep 14, 2023
f4a8b12
Wrap with parenthesis if necessary
koka831 Sep 29, 2023
536114c
[`ignored_unit_patterns`]: check &(), &&(), ...
lengyijun Oct 15, 2023
4fc503e
Avoid a `track_errors` by bubbling up most errors from `check_well_fo…
oli-obk Oct 18, 2023
8e7d167
Merge commit '2b030eb03d9e5837440b1ee0b98c50b97c0c5889' into clippyup
flip1995 Oct 21, 2023
d6fc606
[`map_identity`]: recognize tuples
y21 Jun 13, 2023
56c8235
Auto merge of #10943 - y21:issue7189, r=llogiq
bors Oct 21, 2023
87d0ace
use visibility to check unused imports and delete some stmts
bvanjoi Oct 15, 2023
3c501e4
[`iter_without_into_iter`]: fix papercuts + only lint on pub types
y21 Oct 22, 2023
f942470
Auto merge of #11028 - BenWiederhake:dev-ifnotelse_neqzero, r=llogiq
bors Oct 23, 2023
350a682
Auto merge of #116849 - oli-obk:error_shenanigans, r=cjgillot
bors Oct 23, 2023
56ece10
Use `no_run` for doc-tests in new lints
Alexendoo Oct 23, 2023
9f5de66
Auto merge of #11460 - J-ZhengLi:issue11429, r=Centri3
bors Oct 23, 2023
7347c18
Set existing doc-tests to `no_run`
Alexendoo Oct 23, 2023
033c763
Auto merge of #11699 - Alexendoo:no-run-doctests, r=llogiq
bors Oct 23, 2023
e1b287c
Use multiple pushes in `vec_init_then_push` example
Alexendoo Oct 23, 2023
7ade24e
Fix stable feature names in tests
dtolnay Oct 15, 2023
4622203
Move configuration to new `clippy_config` crate
Alexendoo Oct 19, 2023
330d7fa
Auto merge of #116033 - bvanjoi:fix-116032, r=petrochenkov
bors Oct 23, 2023
f879096
Add a lint to check needless `Waker` clones
a1phyr Oct 23, 2023
7df1c8a
Hide config implementation details from public docs
Alexendoo Oct 19, 2023
4eb4192
Auto merge of #11685 - Alexendoo:clippy_config, r=flip1995
bors Oct 24, 2023
cd6ec97
Auto merge of #116773 - dtolnay:validatestable, r=compiler-errors
bors Oct 24, 2023
f4f5b05
Handle structured stable attribute 'since' version in clippy
dtolnay Oct 25, 2023
76d7af0
Expose a non-Symbol way to access current rustc version string
dtolnay Oct 25, 2023
ffc7419
Work around the fact that `check_mod_type_wf` may spuriously return `…
oli-obk Oct 25, 2023
0580080
Remove the `internal_warn` lint category
Alexendoo Oct 25, 2023
ebf6667
Apply suggestions
a1phyr Oct 25, 2023
c337899
Rename `AsyncCoroutineKind` to `CoroutineSource`
oli-obk Oct 23, 2023
7ce6e0d
Auto merge of #11670 - lengyijun:ignored_unit_pattern_ref, r=dswij
bors Oct 25, 2023
ebe63cd
Stop telling people to submit bugs for internal feature ICEs
Noratrieb Oct 16, 2023
5f19fac
Rollup merge of #117175 - oli-obk:gen_fn_split, r=compiler-errors
matthiaskrgr Oct 25, 2023
45f94c7
mention restriction to exported types as a limitation
y21 Oct 25, 2023
d914890
Auto merge of #116818 - Nilstrieb:stop-submitting-bug-reports, r=wesl…
bors Oct 26, 2023
3e05710
Auto merge of #117148 - dtolnay:sinceversion, r=cjgillot
bors Oct 26, 2023
0da4dab
Auto merge of #11584 - koka831:fix/11335, r=blyxyas
bors Oct 26, 2023
392b255
Auto merge of #11712 - Alexendoo:remove-internal-warn, r=dswij
bors Oct 26, 2023
2f0f4dd
Auto merge of #11698 - a1phyr:waker_clone_and_wake, r=y21
bors Oct 26, 2023
d736992
Parse rustc version at compile time
dtolnay Oct 27, 2023
0c8caee
Add gen blocks to ast and do some broken ast lowering
oli-obk Oct 20, 2023
f4b4e2c
Remove internal feature from clippy_utils
Alexendoo Oct 27, 2023
1ed1001
Fix missing parenthesis in suboptimal floating point help
llogiq Oct 27, 2023
58fe451
Expand docs on clippy::todo
Wilfred Oct 27, 2023
9a10d32
reword limitation section
y21 Oct 28, 2023
f8409ef
Auto merge of #11696 - y21:iter_without_into_iter_suggestion, r=xFrednet
bors Oct 28, 2023
5852ca8
Auto merge of #11724 - rust-lang:fix-11559, r=blyxyas
bors Oct 28, 2023
2fea83b
move `read_zero_byte_vec` to nursery
dswij Oct 28, 2023
f2a0776
Auto merge of #116447 - oli-obk:gen_fn, r=compiler-errors
bors Oct 29, 2023
2030c58
Fix some typos
cuishuang Oct 29, 2023
a40958a
Auto merge of #11730 - cuishuang:master, r=dswij
bors Oct 29, 2023
fa6fd8c
Auto merge of #11726 - Wilfred:todo_docs, r=dswij
bors Oct 29, 2023
c51e2a0
fix enum_variant_names depending lint depending on order
jonboh Sep 13, 2023
e6c804c
ignore lower-camel-case words in `doc_markdown`
llogiq Oct 29, 2023
739f9e2
Auto merge of #11727 - dswij:read-zero-byte-vec-nursery, r=Centri3
bors Oct 29, 2023
2e907aa
Rename Since -> StableSince in preparation for a DeprecatedSince
dtolnay Oct 26, 2023
e245f7c
Auto merge of #11735 - rust-lang:fix-11568, r=blyxyas
bors Oct 30, 2023
325e9fd
Auto merge of #11723 - Alexendoo:clippy-utils-internal, r=Jarcho
bors Oct 30, 2023
cdc4d56
Auto merge of #11701 - Alexendoo:vec-init-then-push-docs, r=Jarcho
bors Oct 30, 2023
69c3b9c
new lint: `unnecessary_fallible_conversions`
y21 Oct 14, 2023
3da80dc
Auto merge of #11498 - jonboh:issue11494_enumvariants_order_affects_l…
bors Oct 31, 2023
7d34406
Auto merge of #11669 - y21:issue11577, r=Jarcho
bors Oct 31, 2023
c872ccc
delegate box error provide
BugenZhao Oct 31, 2023
0b90f72
feat: unused_enumerate_index lint
dnbln Feb 26, 2023
14b8290
Apply suggestions from code review
dnbln Oct 12, 2023
bb9cc6d
refactor: extract common pat_is_wild to clippy_utils
dnbln Nov 1, 2023
919f698
Auto merge of #10404 - dnbln:feat/unused_enumerate_index, r=blyxyas
bors Nov 1, 2023
3b759bc
fix get_first false negative for VecDeque
matthri Nov 1, 2023
61c76dd
remove code duplication
matthri Nov 1, 2023
01a0a36
Auto merge of #11744 - matthri:get-first-deque-fix, r=Jarcho
bors Nov 2, 2023
95dc7be
Merge remote-tracking branch 'upstream/master' into rustup
flip1995 Nov 2, 2023
5eee19e
Bump nightly version -> 2023-11-02
flip1995 Nov 2, 2023
62a82b3
Format let-chains across the code base
flip1995 Nov 2, 2023
09ac14c
Auto merge of #11747 - flip1995:rustup, r=flip1995
bors Nov 2, 2023
257147a
Merge commit '09ac14c901abc43bd0d617ae4a44e8a4fed98d9c' into clippyup
flip1995 Nov 2, 2023
02562bf
Update Cargo.lock
flip1995 Nov 2, 2023
c5895c4
oli.pause()
compiler-errors Nov 2, 2023
9e7345b
Fix incorrect trait bound restriction suggestion
estebank Nov 2, 2023
fedfca7
Revert "bootstrap: do not purge docs on CI environment"
onur-ozkan Nov 3, 2023
958a6af
Rollup merge of #117434 - BugenZhao:box-error-provide, r=cuviper
matthiaskrgr Nov 3, 2023
6cb627b
Rollup merge of #117505 - estebank:issue-117501, r=TaKO8Ki
matthiaskrgr Nov 3, 2023
9028ce3
Rollup merge of #117520 - flip1995:clippyup, r=Manishearth
matthiaskrgr Nov 3, 2023
7a0df44
Rollup merge of #117523 - compiler-errors:oli-vacation, r=compiler-er…
matthiaskrgr Nov 3, 2023
c0fa97c
Rollup merge of #117533 - onur-ozkan:revert-117471, r=onur-ozkan
matthiaskrgr Nov 3, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
25 changes: 17 additions & 8 deletions clippy_utils/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2032,17 +2032,26 @@ pub fn is_must_use_func_call(cx: &LateContext<'_>, expr: &Expr<'_>) -> bool {
/// * `|x| return x`
/// * `|x| { return x }`
/// * `|x| { return x; }`
/// * `|(x, y)| (x, y)`
///
/// Consider calling [`is_expr_untyped_identity_function`] or [`is_expr_identity_function`] instead.
fn is_body_identity_function(cx: &LateContext<'_>, func: &Body<'_>) -> bool {
let id = if_chain! {
if let [param] = func.params;
if let PatKind::Binding(_, id, _, _) = param.pat.kind;
then {
id
} else {
return false;
fn check_pat(cx: &LateContext<'_>, pat: &Pat<'_>, expr: &Expr<'_>) -> bool {
match (pat.kind, expr.kind) {
(PatKind::Binding(_, id, _, _), _) => {
path_to_local_id(expr, id) && cx.typeck_results().expr_adjustments(expr).is_empty()
},
(PatKind::Tuple(pats, dotdot), ExprKind::Tup(tup))
if dotdot.as_opt_usize().is_none() && pats.len() == tup.len() =>
{
pats.iter().zip(tup).all(|(pat, expr)| check_pat(cx, pat, expr))
},
_ => false,
}
}

let [param] = func.params else {
return false;
};

let mut expr = func.value;
Expand Down Expand Up @@ -2075,7 +2084,7 @@ fn is_body_identity_function(cx: &LateContext<'_>, func: &Body<'_>) -> bool {
}
}
},
_ => return path_to_local_id(expr, id) && cx.typeck_results().expr_adjustments(expr).is_empty(),
_ => return check_pat(cx, param.pat, expr),
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion lintcheck/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -523,7 +523,7 @@ fn gather_stats(clippy_warnings: &[ClippyWarning]) -> (String, HashMap<&String,
.for_each(|wrn| *counter.entry(&wrn.lint_type).or_insert(0) += 1);

// collect into a tupled list for sorting
let mut stats: Vec<(&&String, &usize)> = counter.iter().map(|(lint, count)| (lint, count)).collect();
let mut stats: Vec<(&&String, &usize)> = counter.iter().collect();
// sort by "000{count} {clippy::lintname}"
// to not have a lint with 200 and 2 warnings take the same spot
stats.sort_by_key(|(lint, count)| format!("{count:0>4}, {lint}"));
Expand Down
24 changes: 24 additions & 0 deletions tests/ui/map_identity.fixed
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,30 @@ fn main() {
let _ = Ok(1).map_err(std::convert::identity::<u32>);
}

fn issue7189() {
// should lint
let x = [(1, 2), (3, 4)];
let _ = x.iter();
let _ = x.iter();
let _ = x.iter();

let y = [(1, 2, (3, (4,))), (5, 6, (7, (8,)))];
let _ = y.iter();

// should not lint
let _ = x.iter().map(|(x, y)| (x, y, y));
let _ = x.iter().map(|(x, _y)| (x,));
let _ = x.iter().map(|(x, _)| (x,));
let _ = x.iter().map(|(x, ..)| (x,));
let _ = y.iter().map(|(x, y, (z, _))| (x, y, (z, z)));
let _ = y
.iter()
.map(|(x, y, (z, _)): &(i32, i32, (i32, (i32,)))| (x, y, (z, z)));
let _ = y
.iter()
.map(|(x, y, (z, (w,))): &(i32, i32, (i32, (i32,)))| (x, y, (z, (w,))));
}

fn not_identity(x: &u16) -> u16 {
*x
}
26 changes: 26 additions & 0 deletions tests/ui/map_identity.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,32 @@ fn main() {
let _ = Ok(1).map_err(std::convert::identity::<u32>);
}

fn issue7189() {
// should lint
let x = [(1, 2), (3, 4)];
let _ = x.iter().map(|(x, y)| (x, y));
let _ = x.iter().map(|(x, y)| {
return (x, y);
});
let _ = x.iter().map(|(x, y)| return (x, y));

let y = [(1, 2, (3, (4,))), (5, 6, (7, (8,)))];
let _ = y.iter().map(|(x, y, (z, (w,)))| (x, y, (z, (w,))));

// should not lint
let _ = x.iter().map(|(x, y)| (x, y, y));
let _ = x.iter().map(|(x, _y)| (x,));
let _ = x.iter().map(|(x, _)| (x,));
let _ = x.iter().map(|(x, ..)| (x,));
let _ = y.iter().map(|(x, y, (z, _))| (x, y, (z, z)));
let _ = y
.iter()
.map(|(x, y, (z, _)): &(i32, i32, (i32, (i32,)))| (x, y, (z, z)));
let _ = y
.iter()
.map(|(x, y, (z, (w,))): &(i32, i32, (i32, (i32,)))| (x, y, (z, (w,))));
}

fn not_identity(x: &u16) -> u16 {
*x
}
29 changes: 28 additions & 1 deletion tests/ui/map_identity.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -40,5 +40,32 @@ error: unnecessary map of the identity function
LL | let _: Result<u32, u32> = Ok(1).map_err(|a| a);
| ^^^^^^^^^^^^^^^ help: remove the call to `map_err`

error: aborting due to 6 previous errors
error: unnecessary map of the identity function
--> $DIR/map_identity.rs:30:21
|
LL | let _ = x.iter().map(|(x, y)| (x, y));
| ^^^^^^^^^^^^^^^^^^^^^ help: remove the call to `map`

error: unnecessary map of the identity function
--> $DIR/map_identity.rs:31:21
|
LL | let _ = x.iter().map(|(x, y)| {
| _____________________^
LL | | return (x, y);
LL | | });
| |______^ help: remove the call to `map`

error: unnecessary map of the identity function
--> $DIR/map_identity.rs:34:21
|
LL | let _ = x.iter().map(|(x, y)| return (x, y));
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the call to `map`

error: unnecessary map of the identity function
--> $DIR/map_identity.rs:37:21
|
LL | let _ = y.iter().map(|(x, y, (z, (w,)))| (x, y, (z, (w,))));
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove the call to `map`

error: aborting due to 10 previous errors