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

Update Clippy #100419

Merged
merged 94 commits into from
Aug 12, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
94 commits
Select commit Hold shift + click to select a range
4c43aa7
Fix suggestion for `async` in redundant_closure_call
AaronC81 Jun 25, 2022
c990e29
Don't suggest using auto deref for block expressions
Jarcho Jul 5, 2022
9ce0f82
Include the borrow in the suggestion for `explicit_auto_deref`
Jarcho Jul 6, 2022
84e03b6
Don't lint `explicit_auto_deref` on `dyn Trait` return
Jarcho Jul 10, 2022
d602ab1
Don't lint `exlipicit_auto_deref` when other adjustments are needed
Jarcho Jul 17, 2022
6ee03e2
unwrap_used: Stop recommending using `expect` when the `expect_used` …
sgued Jul 21, 2022
3e52031
unwrap_used: Fix help, "an `None`" -> "`None`"
sgued Jul 22, 2022
af8ae10
Generate correct suggestion with named arguments used positionally
PrestonFrom Jul 16, 2022
08e7ec4
Read and use deprecated configuration (as well as emitting a warning)
flip1995 Jul 27, 2022
38e8013
Enable test empty_loop_no_std on windows
alex-semenyuk Jul 28, 2022
67c405c
Merge commit '3c7e7dbc1583a0b06df5bd7623dd354a4debd23d' into clippyup
flip1995 Jul 28, 2022
307b800
unwrap_used: Fix doc to not recommend expect when expect_used is not …
sgued Jul 28, 2022
1fd9f2d
Fix tests
sgued Jul 28, 2022
ea25ef1
Harden duplicates checking and add tests
bossmc Jul 28, 2022
53a09d4
Auto merge of #9252 - Metaswitch:use-deprecated-config, r=Jarcho
bors Jul 29, 2022
61c6d16
Auto merge of #99660 - PrestonFrom:issue_99265, r=compiler-errors
bors Jul 29, 2022
1a6f02b
Remove `TreeAndSpacing`.
nnethercote Jul 28, 2022
2f48257
Rename "blacklisted name" to "disallowed name" throughout
bossmc Jun 8, 2022
66b4674
Change lint name to plural
bossmc Jun 8, 2022
56c9cc4
Add deprecation test for old configuration entry
bossmc Jun 9, 2022
a0ed687
Auto merge of #8974 - Metaswitch:remove-blacklist-terminology, r=Mani…
bors Jul 29, 2022
ca0996e
Change maybe_body_owned_by to take local def id
kckeiks Jul 16, 2022
29a0f69
Rename local_did to def_id
kckeiks Jul 19, 2022
ce5fa10
Change enclosing_body_owner to return LocalDefId
kckeiks Jul 19, 2022
6c1110e
Avoid ICE when fetching LocalDefId
kckeiks Jul 20, 2022
23b4fe6
Apply suggestions from code review
sgued Jul 30, 2022
ab7e555
Auto merge of #99887 - nnethercote:rm-TreeAndSpacing, r=petrochenkov
bors Jul 30, 2022
3641b0c
Auto merge of #99948 - Dylan-DPC:rollup-ed5136t, r=Dylan-DPC
bors Jul 30, 2022
6290772
Use LocalDefId for closures more
camsteffen Jul 12, 2022
72649cf
Rollup merge of #99186 - camsteffen:closure-localdefid, r=cjgillot
Dylan-DPC Jul 31, 2022
cd13574
Always include a position span in rustc_parse_format::Argument
Alexendoo Jul 31, 2022
09f9ace
Shrink `Token`.
nnethercote Jul 27, 2022
a591e72
Auto merge of #9223 - sgued:unwrap-expect-used, r=giraffate
bors Aug 1, 2022
e00ceb9
move [`assertions_on_result_states`] to restriction
tabokie Aug 1, 2022
72e7064
Make it easier to find the developer guide
schubart Jul 31, 2022
7c427f0
Auto merge of #9270 - schubart:link_to_developer_guide, r=xFrednet
bors Aug 1, 2022
48ad9d8
do not apply [`assertions_on_result_states`] to unwrap unit type
tabokie Aug 1, 2022
a5a6c95
Auto merge of #9273 - tabokie:assert_ok_fp, r=flip1995
bors Aug 1, 2022
80a5687
Auto merge of #99884 - nnethercote:lexer-improvements, r=matklad
bors Aug 1, 2022
d17a30a
Store associated item defaultness in impl_defaultness.
cjgillot Mar 12, 2022
119247a
Remove DefId from AssocItemContainer.
cjgillot Mar 12, 2022
0696624
Add `elapsed_instant` lint
guerinoni Jul 30, 2022
367d09f
Auto merge of #9254 - alex-semenyuk:enable_empty_loop_no_std_on_windo…
bors Aug 2, 2022
2fcaac7
move [`assertions_on_result_states`] to restriction
tabokie Aug 1, 2022
9ab6146
simplify unit type check
tabokie Aug 2, 2022
ac7a91e
use slice match more often
tabokie Aug 2, 2022
4914833
Auto merge of #9279 - tabokie:weight-loss, r=flip1995
bors Aug 2, 2022
00e59cd
Auto merge of #9264 - guerinoni:instant-elapsed, r=Alexendoo
bors Aug 2, 2022
05e7d54
Auto merge of #9053 - AaronC81:fix-9052, r=flip1995
bors Aug 2, 2022
4546f5d
Rollup merge of #99987 - Alexendoo:parse-format-position-span, r=fee1…
matthiaskrgr Aug 2, 2022
7aaeee7
Rollup merge of #100053 - flip1995:clippy_backport, r=xFrednet
matthiaskrgr Aug 2, 2022
145ebb1
add paren before '?' when suggesting deref
macovedj Aug 2, 2022
503c03c
clean up
macovedj Aug 2, 2022
b50ba06
fix typo in tests/ui/redundant_allocation.rs
lengyijun Aug 3, 2022
5dc90a1
Auto merge of #9282 - macovedj:clone-on-copy-try-precedence, r=flip1995
bors Aug 3, 2022
f232402
Warn about dead tuple struct fields
FabianWolff Jul 25, 2022
7177746
Auto merge of #9284 - lengyijun:typo, r=dswij
bors Aug 3, 2022
ccbc965
Add `traits::fully_solve_obligation` that acts like `traits::fully_no…
compiler-errors Aug 2, 2022
7062a01
Fix some typos
alex-semenyuk Aug 4, 2022
0e1d658
Fix cast_abs_to_unsigned generates non-compiling code when original c…
alex-semenyuk Jul 30, 2022
2dc7d2f
Auto merge of #9266 - alex-semenyuk:cast_abs_to_unsigned_paren_fix, r…
bors Aug 4, 2022
f63b324
Fix some typos
alex-semenyuk Aug 4, 2022
57731f1
Auto merge of #9292 - alex-semenyuk:typos_fixed, r=Alexendoo
bors Aug 5, 2022
1e1193f
Enable test for def_id_nocore for windows
alex-semenyuk Aug 5, 2022
5721ca9
Auto merge of #9294 - alex-semenyuk:enable_def_id_nocore_on_windows, …
bors Aug 5, 2022
f719599
Auto merge of #99743 - compiler-errors:fulfillment-context-cleanups, …
bors Aug 6, 2022
aa0b0af
Move `significant_drop_in_scrutinee` into `nursey`
Jarcho Aug 8, 2022
2ae8b30
Don't lint `unit_arg` when expanded from a proc-macro
Jarcho Apr 13, 2022
37e838f
Use new util function in `suspicious_else_formatting`
Jarcho Apr 13, 2022
4ae582e
Don't lint `missing_docs_in_private_items` on proc-macro output
Jarcho Apr 13, 2022
670efd5
Don't lint `default_trait_access` in proc-macro expansions
Jarcho Apr 13, 2022
8dda974
Add note to the docs on `is_from_proc_macro`
Jarcho Apr 24, 2022
745b194
Small cleanup for `check_proc_macro.rs`
Jarcho Aug 8, 2022
99abd4a
Fix ICE when reading literals with weird proc-macro spans
Jarcho Aug 8, 2022
97a0cf2
Auto merge of #9302 - Jarcho:sig_drop_nursery, r=flip1995
bors Aug 8, 2022
10853f7
Auto merge of #8694 - Jarcho:check_proc_macro, r=xFrednet
bors Aug 8, 2022
0ee7025
Auto merge of #9303 - Jarcho:ice_9297, r=Alexendoo
bors Aug 8, 2022
5285928
Fix ICE when checking the HIR ty of closure args.
Jarcho Aug 8, 2022
ecb51fe
Lint `explicit_auto_deref` in implicit return positions for closures
Jarcho Aug 8, 2022
4912c0e
Auto merge of #9126 - Jarcho:auto_deref_sugg, r=Manishearth
bors Aug 8, 2022
f6cab94
Rename `logic_bug` to `overly_complex_bool_expr`
guerinoni Aug 8, 2022
8f39061
Auto merge of #9306 - guerinoni:rename-logic-bug, r=llogiq,xFrednet
bors Aug 8, 2022
657b0da
Add partialeq_to_none lint
lukaslueg Aug 3, 2022
3af9072
Auto merge of #9288 - lukaslueg:partialeqnone, r=Jarcho
bors Aug 9, 2022
8d4f2ac
Use `check_proc_macro` for `missing_const_for_fn`
daxpedda Aug 9, 2022
6f5d648
Address review
daxpedda Aug 9, 2022
fd60581
Address review take 2
daxpedda Aug 9, 2022
f7e2cb4
Auto merge of #9308 - daxpedda:missing-const-for-fn, r=Jarcho
bors Aug 9, 2022
879855b
Merge remote-tracking branch 'upstream/master' into rustup
flip1995 Aug 11, 2022
eda0b00
Bump nightly version -> 2022-08-11
flip1995 Aug 11, 2022
280b527
Bump Clippy version -> 0.1.65
flip1995 Aug 11, 2022
2b2190c
Auto merge of #9323 - flip1995:rustup, r=flip1995
bors Aug 11, 2022
ad76883
Merge commit '2b2190cb5667cdd276a24ef8b9f3692209c54a89' into clippyup
flip1995 Aug 11, 2022
ea90d4b
Update Cargo.lock
flip1995 Aug 11, 2022
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
6 changes: 3 additions & 3 deletions Cargo.lock
Original file line number Diff line number Diff line change
Expand Up @@ -661,7 +661,7 @@ dependencies = [

[[package]]
name = "clippy"
version = "0.1.64"
version = "0.1.65"
dependencies = [
"clippy_lints",
"clippy_utils",
Expand Down Expand Up @@ -704,7 +704,7 @@ dependencies = [

[[package]]
name = "clippy_lints"
version = "0.1.64"
version = "0.1.65"
dependencies = [
"cargo_metadata 0.14.0",
"clippy_utils",
Expand All @@ -726,7 +726,7 @@ dependencies = [

[[package]]
name = "clippy_utils"
version = "0.1.64"
version = "0.1.65"
dependencies = [
"arrayvec",
"if_chain",
Expand Down
8 changes: 6 additions & 2 deletions src/tools/clippy/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -965,7 +965,7 @@ Released 2021-09-09
[#7407](https://github.com/rust-lang/rust-clippy/pull/7407)
* [`redundant_allocation`]: Now additionally supports the `Arc<>` type
[#7308](https://github.com/rust-lang/rust-clippy/pull/7308)
* [`blacklisted_name`]: Now allows blacklisted names in test code
* [`disallowed_names`]: Now allows disallowed names in test code
[#7379](https://github.com/rust-lang/rust-clippy/pull/7379)
* [`redundant_closure`]: Suggests `&mut` for `FnMut`
[#7437](https://github.com/rust-lang/rust-clippy/pull/7437)
Expand Down Expand Up @@ -2066,7 +2066,7 @@ Released 2020-08-27
[#5692](https://github.com/rust-lang/rust-clippy/pull/5692)
* [`if_same_then_else`]: Don't assume multiplication is always commutative
[#5702](https://github.com/rust-lang/rust-clippy/pull/5702)
* [`blacklisted_name`]: Remove `bar` from the default configuration
* [`disallowed_names`]: Remove `bar` from the default configuration
[#5712](https://github.com/rust-lang/rust-clippy/pull/5712)
* [`redundant_pattern_matching`]: Avoid suggesting non-`const fn` calls in const contexts
[#5724](https://github.com/rust-lang/rust-clippy/pull/5724)
Expand Down Expand Up @@ -3522,6 +3522,7 @@ Released 2018-09-13
[`derive_partial_eq_without_eq`]: https://rust-lang.github.io/rust-clippy/master/index.html#derive_partial_eq_without_eq
[`disallowed_method`]: https://rust-lang.github.io/rust-clippy/master/index.html#disallowed_method
[`disallowed_methods`]: https://rust-lang.github.io/rust-clippy/master/index.html#disallowed_methods
[`disallowed_names`]: https://rust-lang.github.io/rust-clippy/master/index.html#disallowed_names
[`disallowed_script_idents`]: https://rust-lang.github.io/rust-clippy/master/index.html#disallowed_script_idents
[`disallowed_type`]: https://rust-lang.github.io/rust-clippy/master/index.html#disallowed_type
[`disallowed_types`]: https://rust-lang.github.io/rust-clippy/master/index.html#disallowed_types
Expand Down Expand Up @@ -3685,6 +3686,7 @@ Released 2018-09-13
[`manual_find`]: https://rust-lang.github.io/rust-clippy/master/index.html#manual_find
[`manual_find_map`]: https://rust-lang.github.io/rust-clippy/master/index.html#manual_find_map
[`manual_flatten`]: https://rust-lang.github.io/rust-clippy/master/index.html#manual_flatten
[`manual_instant_elapsed`]: https://rust-lang.github.io/rust-clippy/master/index.html#manual_instant_elapsed
[`manual_map`]: https://rust-lang.github.io/rust-clippy/master/index.html#manual_map
[`manual_memcpy`]: https://rust-lang.github.io/rust-clippy/master/index.html#manual_memcpy
[`manual_non_exhaustive`]: https://rust-lang.github.io/rust-clippy/master/index.html#manual_non_exhaustive
Expand Down Expand Up @@ -3816,11 +3818,13 @@ Released 2018-09-13
[`or_then_unwrap`]: https://rust-lang.github.io/rust-clippy/master/index.html#or_then_unwrap
[`out_of_bounds_indexing`]: https://rust-lang.github.io/rust-clippy/master/index.html#out_of_bounds_indexing
[`overflow_check_conditional`]: https://rust-lang.github.io/rust-clippy/master/index.html#overflow_check_conditional
[`overly_complex_bool_expr`]: https://rust-lang.github.io/rust-clippy/master/index.html#overly_complex_bool_expr
[`panic`]: https://rust-lang.github.io/rust-clippy/master/index.html#panic
[`panic_in_result_fn`]: https://rust-lang.github.io/rust-clippy/master/index.html#panic_in_result_fn
[`panic_params`]: https://rust-lang.github.io/rust-clippy/master/index.html#panic_params
[`panicking_unwrap`]: https://rust-lang.github.io/rust-clippy/master/index.html#panicking_unwrap
[`partialeq_ne_impl`]: https://rust-lang.github.io/rust-clippy/master/index.html#partialeq_ne_impl
[`partialeq_to_none`]: https://rust-lang.github.io/rust-clippy/master/index.html#partialeq_to_none
[`path_buf_push_overwrite`]: https://rust-lang.github.io/rust-clippy/master/index.html#path_buf_push_overwrite
[`pattern_type_mismatch`]: https://rust-lang.github.io/rust-clippy/master/index.html#pattern_type_mismatch
[`possible_missing_comma`]: https://rust-lang.github.io/rust-clippy/master/index.html#possible_missing_comma
Expand Down
6 changes: 3 additions & 3 deletions src/tools/clippy/CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,10 +30,10 @@ All contributors are expected to follow the [Rust Code of Conduct].
## The Clippy book

If you're new to Clippy and don't know where to start the [Clippy book] includes
a developer guide and is a good place to start your journey.
a [developer guide] and is a good place to start your journey.

<!-- FIXME: Link to the deployed book, once it is deployed through CI -->
[Clippy book]: book/src
[Clippy book]: https://doc.rust-lang.org/nightly/clippy/index.html
[developer guide]: https://doc.rust-lang.org/nightly/clippy/development/index.html

## High level approach

Expand Down
2 changes: 1 addition & 1 deletion src/tools/clippy/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "clippy"
version = "0.1.64"
version = "0.1.65"
description = "A bunch of helpful lints to avoid common pitfalls in Rust"
repository = "https://github.com/rust-lang/rust-clippy"
readme = "README.md"
Expand Down
2 changes: 1 addition & 1 deletion src/tools/clippy/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ value` mapping e.g.

```toml
avoid-breaking-exported-api = false
blacklisted-names = ["toto", "tata", "titi"]
disallowed-names = ["toto", "tata", "titi"]
cognitive-complexity-threshold = 30
```

Expand Down
2 changes: 1 addition & 1 deletion src/tools/clippy/book/src/configuration.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ basic `variable = value` mapping eg.

```toml
avoid-breaking-exported-api = false
blacklisted-names = ["toto", "tata", "titi"]
disallowed-names = ["toto", "tata", "titi"]
cognitive-complexity-threshold = 30
```

Expand Down
2 changes: 1 addition & 1 deletion src/tools/clippy/clippy_dev/src/new_lint.rs
Original file line number Diff line number Diff line change
Expand Up @@ -438,7 +438,7 @@ fn setup_mod_file(path: &Path, lint: &LintData<'_>) -> io::Result<&'static str>
let mut lint_context = None;

let mut iter = rustc_lexer::tokenize(&file_contents).map(|t| {
let range = offset..offset + t.len;
let range = offset..offset + t.len as usize;
offset = range.end;

LintDeclSearchResult {
Expand Down
6 changes: 3 additions & 3 deletions src/tools/clippy/clippy_dev/src/update_lints.rs
Original file line number Diff line number Diff line change
Expand Up @@ -836,7 +836,7 @@ pub(crate) struct LintDeclSearchResult<'a> {
fn parse_contents(contents: &str, module: &str, lints: &mut Vec<Lint>) {
let mut offset = 0usize;
let mut iter = tokenize(contents).map(|t| {
let range = offset..offset + t.len;
let range = offset..offset + t.len as usize;
offset = range.end;

LintDeclSearchResult {
Expand Down Expand Up @@ -899,7 +899,7 @@ fn parse_contents(contents: &str, module: &str, lints: &mut Vec<Lint>) {
fn parse_deprecated_contents(contents: &str, lints: &mut Vec<DeprecatedLint>) {
let mut offset = 0usize;
let mut iter = tokenize(contents).map(|t| {
let range = offset..offset + t.len;
let range = offset..offset + t.len as usize;
offset = range.end;

LintDeclSearchResult {
Expand Down Expand Up @@ -946,7 +946,7 @@ fn parse_renamed_contents(contents: &str, lints: &mut Vec<RenamedLint>) {
for line in contents.lines() {
let mut offset = 0usize;
let mut iter = tokenize(line).map(|t| {
let range = offset..offset + t.len;
let range = offset..offset + t.len as usize;
offset = range.end;

LintDeclSearchResult {
Expand Down
2 changes: 1 addition & 1 deletion src/tools/clippy/clippy_lints/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "clippy_lints"
version = "0.1.64"
version = "0.1.65"
description = "A bunch of helpful lints to avoid common pitfalls in Rust"
repository = "https://github.com/rust-lang/rust-clippy"
readme = "README.md"
Expand Down
11 changes: 8 additions & 3 deletions src/tools/clippy/clippy_lints/src/assertions_on_result_states.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,13 +53,14 @@ impl<'tcx> LateLintPass<'tcx> for AssertionsOnResultStates {
if result_type_with_refs != result_type {
return;
} else if let Res::Local(binding_id) = path_res(cx, recv)
&& local_used_after_expr(cx, binding_id, recv) {
&& local_used_after_expr(cx, binding_id, recv)
{
return;
}
}
let mut app = Applicability::MachineApplicable;
match method_segment.ident.as_str() {
"is_ok" if has_debug_impl(cx, substs.type_at(1)) => {
"is_ok" if type_suitable_to_unwrap(cx, substs.type_at(1)) => {
span_lint_and_sugg(
cx,
ASSERTIONS_ON_RESULT_STATES,
Expand All @@ -73,7 +74,7 @@ impl<'tcx> LateLintPass<'tcx> for AssertionsOnResultStates {
app,
);
}
"is_err" if has_debug_impl(cx, substs.type_at(0)) => {
"is_err" if type_suitable_to_unwrap(cx, substs.type_at(0)) => {
span_lint_and_sugg(
cx,
ASSERTIONS_ON_RESULT_STATES,
Expand All @@ -99,3 +100,7 @@ fn has_debug_impl<'tcx>(cx: &LateContext<'tcx>, ty: Ty<'tcx>) -> bool {
.get_diagnostic_item(sym::Debug)
.map_or(false, |debug| implements_trait(cx, ty, debug, &[]))
}

fn type_suitable_to_unwrap<'tcx>(cx: &LateContext<'tcx>, ty: Ty<'tcx>) -> bool {
has_debug_impl(cx, ty) && !ty.is_unit() && !ty.is_never()
}
6 changes: 3 additions & 3 deletions src/tools/clippy/clippy_lints/src/booleans.rs
Original file line number Diff line number Diff line change
Expand Up @@ -64,15 +64,15 @@ declare_clippy_lint! {
/// if a {}
/// ```
#[clippy::version = "pre 1.29.0"]
pub LOGIC_BUG,
pub OVERLY_COMPLEX_BOOL_EXPR,
correctness,
"boolean expressions that contain terminals which can be eliminated"
}

// For each pairs, both orders are considered.
const METHODS_WITH_NEGATION: [(&str, &str); 2] = [("is_some", "is_none"), ("is_err", "is_ok")];

declare_lint_pass!(NonminimalBool => [NONMINIMAL_BOOL, LOGIC_BUG]);
declare_lint_pass!(NonminimalBool => [NONMINIMAL_BOOL, OVERLY_COMPLEX_BOOL_EXPR]);

impl<'tcx> LateLintPass<'tcx> for NonminimalBool {
fn check_fn(
Expand Down Expand Up @@ -396,7 +396,7 @@ impl<'a, 'tcx> NonminimalBoolVisitor<'a, 'tcx> {
if stats.terminals[i] != 0 && simplified_stats.terminals[i] == 0 {
span_lint_hir_and_then(
self.cx,
LOGIC_BUG,
OVERLY_COMPLEX_BOOL_EXPR,
e.hir_id,
e.span,
"this boolean expression contains a logic bug",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ pub(super) fn check(
span,
&format!("casting the result of `{cast_from}::abs()` to {cast_to}"),
"replace with",
format!("{}.unsigned_abs()", Sugg::hir(cx, &args[0], "..")),
format!("{}.unsigned_abs()", Sugg::hir(cx, &args[0], "..").maybe_par()),
Applicability::MachineApplicable,
);
}
Expand Down
5 changes: 1 addition & 4 deletions src/tools/clippy/clippy_lints/src/checked_conversions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -270,10 +270,7 @@ fn get_types_from_cast<'a>(
let limit_from: Option<(&Expr<'_>, &str)> = call_from_cast.or_else(|| {
if_chain! {
// `from_type::from, to_type::max_value()`
if let ExprKind::Call(from_func, args) = &expr.kind;
// `to_type::max_value()`
if args.len() == 1;
if let limit = &args[0];
if let ExprKind::Call(from_func, [limit]) = &expr.kind;
// `from_type::from`
if let ExprKind::Path(ref path) = &from_func.kind;
if let Some(from_sym) = get_implementing_type(path, INTS, "from");
Expand Down
4 changes: 2 additions & 2 deletions src/tools/clippy/clippy_lints/src/create_dir.rs
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ declare_lint_pass!(CreateDir => [CREATE_DIR]);
impl LateLintPass<'_> for CreateDir {
fn check_expr(&mut self, cx: &LateContext<'_>, expr: &Expr<'_>) {
if_chain! {
if let ExprKind::Call(func, args) = expr.kind;
if let ExprKind::Call(func, [arg, ..]) = expr.kind;
if let ExprKind::Path(ref path) = func.kind;
if let Some(def_id) = cx.qpath_res(path, func.hir_id).opt_def_id();
if match_def_path(cx, def_id, &paths::STD_FS_CREATE_DIR);
Expand All @@ -45,7 +45,7 @@ impl LateLintPass<'_> for CreateDir {
expr.span,
"calling `std::fs::create_dir` where there may be a better way",
"consider calling `std::fs::create_dir_all` instead",
format!("create_dir_all({})", snippet(cx, args[0].span, "..")),
format!("create_dir_all({})", snippet(cx, arg.span, "..")),
Applicability::MaybeIncorrect,
)
}
Expand Down
5 changes: 4 additions & 1 deletion src/tools/clippy/clippy_lints/src/default.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
use clippy_utils::diagnostics::{span_lint_and_note, span_lint_and_sugg};
use clippy_utils::source::snippet_with_macro_callsite;
use clippy_utils::ty::{has_drop, is_copy};
use clippy_utils::{any_parent_is_automatically_derived, contains_name, get_parent_expr, match_def_path, paths};
use clippy_utils::{
any_parent_is_automatically_derived, contains_name, get_parent_expr, is_from_proc_macro, match_def_path, paths,
};
use if_chain::if_chain;
use rustc_data_structures::fx::FxHashSet;
use rustc_errors::Applicability;
Expand Down Expand Up @@ -94,6 +96,7 @@ impl<'tcx> LateLintPass<'tcx> for Default {
if let QPath::Resolved(None, _path) = qpath;
let expr_ty = cx.typeck_results().expr_ty(expr);
if let ty::Adt(def, ..) = expr_ty.kind();
if !is_from_proc_macro(cx, expr);
then {
// TODO: Work out a way to put "whatever the imported way of referencing
// this type in this file" rather than a fully-qualified type.
Expand Down
Loading