Skip to content

Commit

Permalink
remove function body from "too many args" span
Browse files Browse the repository at this point in the history
  • Loading branch information
euclio committed May 1, 2019
1 parent 5162ea5 commit d15d23e
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 15 deletions.
16 changes: 15 additions & 1 deletion clippy_lints/src/functions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ use rustc::ty;
use rustc::{declare_tool_lint, impl_lint_pass};
use rustc_data_structures::fx::FxHashSet;
use rustc_target::spec::abi::Abi;
use syntax::source_map::Span;
use syntax::source_map::{BytePos, Span};

declare_clippy_lint! {
/// **What it does:** Checks for functions with too many parameters.
Expand Down Expand Up @@ -162,6 +162,20 @@ impl<'a, 'tcx> LateLintPass<'a, 'tcx> for Functions {

impl<'a, 'tcx> Functions {
fn check_arg_number(self, cx: &LateContext<'_, '_>, decl: &hir::FnDecl, span: Span) {
// Remove the function body from the span. We can't use `SourceMap::def_span` because the
// argument list might span multiple lines.
let span = match cx.sess().source_map().span_to_snippet(span) {
Ok(snippet) => {
let snippet = snippet.split('{').nth(0).unwrap_or("").trim_end();
if !snippet.is_empty() {
span.with_hi(BytePos(span.lo().0 + snippet.len() as u32))
} else {
span
}
},
_ => span,
};

let args = decl.inputs.len() as u64;
if args > self.threshold {
span_lint(
Expand Down
19 changes: 19 additions & 0 deletions tests/ui/functions.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,25 @@ fn good(_one: u32, _two: u32, _three: &str, _four: bool, _five: f32, _six: f32,

fn bad(_one: u32, _two: u32, _three: &str, _four: bool, _five: f32, _six: f32, _seven: bool, _eight: ()) {}

fn bad_multiline(
one: u32,
two: u32,
three: &str,
four: bool,
five: f32,
six: f32,
seven: bool,
eight: ()
) {
let _one = one;
let _two = two;
let _three = three;
let _four = four;
let _five = five;
let _six = six;
let _seven = seven;
}

// don't lint extern fns
extern "C" fn extern_fn(
_one: u32,
Expand Down
40 changes: 26 additions & 14 deletions tests/ui/functions.stderr
Original file line number Diff line number Diff line change
Expand Up @@ -2,77 +2,89 @@ error: this function has too many arguments (8/7)
--> $DIR/functions.rs:8:1
|
LL | fn bad(_one: u32, _two: u32, _three: &str, _four: bool, _five: f32, _six: f32, _seven: bool, _eight: ()) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
= note: `-D clippy::too-many-arguments` implied by `-D warnings`

error: this function has too many arguments (8/7)
--> $DIR/functions.rs:25:5
--> $DIR/functions.rs:10:1
|
LL | / fn bad_multiline(
LL | | one: u32,
LL | | two: u32,
LL | | three: &str,
... |
LL | | eight: ()
LL | | ) {
| |_^

error: this function has too many arguments (8/7)
--> $DIR/functions.rs:44:5
|
LL | fn bad(_one: u32, _two: u32, _three: &str, _four: bool, _five: f32, _six: f32, _seven: bool, _eight: ());
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

error: this function has too many arguments (8/7)
--> $DIR/functions.rs:34:5
--> $DIR/functions.rs:53:5
|
LL | fn bad_method(_one: u32, _two: u32, _three: &str, _four: bool, _five: f32, _six: f32, _seven: bool, _eight: ()) {}
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:43:34
--> $DIR/functions.rs:62:34
|
LL | println!("{}", unsafe { *p });
| ^
|
= note: `-D clippy::not-unsafe-ptr-arg-deref` implied by `-D warnings`

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:44:35
--> $DIR/functions.rs:63:35
|
LL | println!("{:?}", unsafe { p.as_ref() });
| ^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:45:33
--> $DIR/functions.rs:64:33
|
LL | unsafe { std::ptr::read(p) };
| ^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:56:30
--> $DIR/functions.rs:75:30
|
LL | println!("{}", unsafe { *p });
| ^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:57:31
--> $DIR/functions.rs:76:31
|
LL | println!("{:?}", unsafe { p.as_ref() });
| ^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:58:29
--> $DIR/functions.rs:77:29
|
LL | unsafe { std::ptr::read(p) };
| ^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:67:34
--> $DIR/functions.rs:86:34
|
LL | println!("{}", unsafe { *p });
| ^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:68:35
--> $DIR/functions.rs:87:35
|
LL | println!("{:?}", unsafe { p.as_ref() });
| ^

error: this public function dereferences a raw pointer but is not marked `unsafe`
--> $DIR/functions.rs:69:33
--> $DIR/functions.rs:88:33
|
LL | unsafe { std::ptr::read(p) };
| ^

error: aborting due to 12 previous errors
error: aborting due to 13 previous errors

0 comments on commit d15d23e

Please sign in to comment.