diff --git a/clippy_lints/src/len_zero.rs b/clippy_lints/src/len_zero.rs index 8a2f37e5aa1f..f2609dd57435 100644 --- a/clippy_lints/src/len_zero.rs +++ b/clippy_lints/src/len_zero.rs @@ -107,7 +107,7 @@ fn check_trait_items(cx: &LateContext, item: &Item, trait_items: &[TraitItemRef] if cx.access_levels.is_exported(i.id.node_id) { span_lint(cx, LEN_WITHOUT_IS_EMPTY, - i.span, + item.span, &format!("trait `{}` has a `len` method but no `is_empty` method", item.name)); } } @@ -146,7 +146,7 @@ fn check_impl_items(cx: &LateContext, item: &Item, impl_items: &[ImplItemRef]) { span_lint(cx, LEN_WITHOUT_IS_EMPTY, - i.span, + item.span, &format!("item `{}` has a public `len` method but {} `is_empty` method", ty, is_empty)); } } diff --git a/tests/ui/len_zero.rs b/tests/ui/len_zero.rs index a310eeef3846..9790f2c9fcb7 100644 --- a/tests/ui/len_zero.rs +++ b/tests/ui/len_zero.rs @@ -12,6 +12,30 @@ impl PubOne { } } +impl PubOne { // A second impl for this struct - the error span shouldn't mention this + pub fn irrelevant(self: &Self) -> bool { + false + } +} + +// Identical to PubOne, but with an allow attribute on the impl complaining len +pub struct PubAllowed; + +#[allow(len_without_is_empty)] +impl PubAllowed { + pub fn len(self: &Self) -> isize { + 1 + } +} + +// No allow attribute on this impl block, but that doesn't matter - we only require one on the +// impl containing len. +impl PubAllowed { + pub fn irrelevant(self: &Self) -> bool { + false + } +} + struct NotPubOne; impl NotPubOne { diff --git a/tests/ui/len_zero.stderr b/tests/ui/len_zero.stderr index 5aaaecf55cb7..9ebc5209a22e 100644 --- a/tests/ui/len_zero.stderr +++ b/tests/ui/len_zero.stderr @@ -1,11 +1,13 @@ error: item `PubOne` has a public `len` method but no corresponding `is_empty` method - --> $DIR/len_zero.rs:10:5 + --> $DIR/len_zero.rs:9:1 | -10 | pub fn len(self: &Self) -> isize { - | _____^ starting here... +9 | impl PubOne { + | _^ starting here... +10 | | pub fn len(self: &Self) -> isize { 11 | | 1 12 | | } - | |_____^ ...ending here +13 | | } + | |_^ ...ending here | note: lint level defined here --> $DIR/len_zero.rs:4:9 @@ -14,33 +16,48 @@ note: lint level defined here | ^^^^^^^^^^^^^^^^^^^^ error: trait `PubTraitsToo` has a `len` method but no `is_empty` method - --> $DIR/len_zero.rs:32:5 + --> $DIR/len_zero.rs:55:1 | -32 | fn len(self: &Self) -> isize; - | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ +55 | pub trait PubTraitsToo { + | _^ starting here... +56 | | fn len(self: &Self) -> isize; +57 | | } + | |_^ ...ending here error: item `HasIsEmpty` has a public `len` method but a private `is_empty` method - --> $DIR/len_zero.rs:66:5 + --> $DIR/len_zero.rs:89:1 | -66 | pub fn len(self: &Self) -> isize { - | _____^ starting here... -67 | | 1 -68 | | } - | |_____^ ...ending here +89 | impl HasIsEmpty { + | _^ starting here... +90 | | pub fn len(self: &Self) -> isize { +91 | | 1 +92 | | } +93 | | +94 | | fn is_empty(self: &Self) -> bool { +95 | | false +96 | | } +97 | | } + | |_^ ...ending here error: item `HasWrongIsEmpty` has a public `len` method but no corresponding `is_empty` method - --> $DIR/len_zero.rs:95:5 - | -95 | pub fn len(self: &Self) -> isize { - | _____^ starting here... -96 | | 1 -97 | | } - | |_____^ ...ending here + --> $DIR/len_zero.rs:118:1 + | +118 | impl HasWrongIsEmpty { + | _^ starting here... +119 | | pub fn len(self: &Self) -> isize { +120 | | 1 +121 | | } +122 | | +123 | | pub fn is_empty(self: &Self, x : u32) -> bool { +124 | | false +125 | | } +126 | | } + | |_^ ...ending here error: length comparison to zero - --> $DIR/len_zero.rs:106:8 + --> $DIR/len_zero.rs:130:8 | -106 | if x.len() == 0 { +130 | if x.len() == 0 { | ^^^^^^^^^^^^ | note: lint level defined here @@ -52,45 +69,45 @@ help: consider using `is_empty` | if x.is_empty() { error: length comparison to zero - --> $DIR/len_zero.rs:113:8 + --> $DIR/len_zero.rs:137:8 | -113 | if "".len() == 0 { +137 | if "".len() == 0 { | ^^^^^^^^^^^^^ | help: consider using `is_empty` | if "".is_empty() { error: length comparison to zero - --> $DIR/len_zero.rs:130:8 + --> $DIR/len_zero.rs:154:8 | -130 | if has_is_empty.len() == 0 { +154 | if has_is_empty.len() == 0 { | ^^^^^^^^^^^^^^^^^^^^^^^ | help: consider using `is_empty` | if has_is_empty.is_empty() { error: length comparison to zero - --> $DIR/len_zero.rs:136:8 + --> $DIR/len_zero.rs:160:8 | -136 | if has_is_empty.len() != 0 { +160 | if has_is_empty.len() != 0 { | ^^^^^^^^^^^^^^^^^^^^^^^ | help: consider using `is_empty` | if !has_is_empty.is_empty() { error: length comparison to zero - --> $DIR/len_zero.rs:142:8 + --> $DIR/len_zero.rs:166:8 | -142 | if has_is_empty.len() > 0 { +166 | if has_is_empty.len() > 0 { | ^^^^^^^^^^^^^^^^^^^^^^ | help: consider using `is_empty` | if !has_is_empty.is_empty() { error: length comparison to zero - --> $DIR/len_zero.rs:151:8 + --> $DIR/len_zero.rs:175:8 | -151 | if with_is_empty.len() == 0 { +175 | if with_is_empty.len() == 0 { | ^^^^^^^^^^^^^^^^^^^^^^^^ | help: consider using `is_empty`