Merge pull request #1559 from theotherphil/master

Use span of impl/trait in len_without_is_empty error message, rather …
This commit is contained in:
Oliver Schneider 2017-02-21 09:13:11 +01:00 committed by GitHub
commit 3900223762
3 changed files with 75 additions and 34 deletions

View File

@ -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));
}
}

View File

@ -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 {

View File

@ -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`