mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 21:54:42 +00:00
minor: Shorten spans of mismatched_arg_count diag
This commit is contained in:
parent
4691a0647b
commit
045014c17e
1 changed files with 22 additions and 24 deletions
|
@ -2,7 +2,7 @@ use ide_db::base_db::{FileRange, SourceDatabase};
|
||||||
use syntax::{
|
use syntax::{
|
||||||
algo::find_node_at_range,
|
algo::find_node_at_range,
|
||||||
ast::{self, HasArgList},
|
ast::{self, HasArgList},
|
||||||
AstNode,
|
AstNode, TextRange,
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::{Diagnostic, DiagnosticsContext};
|
use crate::{Diagnostic, DiagnosticsContext};
|
||||||
|
@ -16,22 +16,16 @@ pub(crate) fn mismatched_arg_count(
|
||||||
) -> Diagnostic {
|
) -> Diagnostic {
|
||||||
let s = if d.expected == 1 { "" } else { "s" };
|
let s = if d.expected == 1 { "" } else { "s" };
|
||||||
let message = format!("expected {} argument{}, found {}", d.expected, s, d.found);
|
let message = format!("expected {} argument{}, found {}", d.expected, s, d.found);
|
||||||
Diagnostic::new(
|
Diagnostic::new("mismatched-arg-count", message, invalid_args_range(ctx, d))
|
||||||
"mismatched-arg-count",
|
|
||||||
message,
|
|
||||||
invalid_args_range(ctx, d).unwrap_or_else(|it| it).range,
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn invalid_args_range(
|
fn invalid_args_range(ctx: &DiagnosticsContext<'_>, d: &hir::MismatchedArgCount) -> TextRange {
|
||||||
ctx: &DiagnosticsContext<'_>,
|
let FileRange { file_id, range } =
|
||||||
d: &hir::MismatchedArgCount,
|
ctx.sema.diagnostics_display_range(d.call_expr.clone().map(|it| it.into()));
|
||||||
) -> Result<FileRange, FileRange> {
|
|
||||||
let full_range = ctx.sema.diagnostics_display_range(d.call_expr.clone().map(|it| it.into()));
|
|
||||||
|
|
||||||
let source_file = ctx.sema.db.parse(full_range.file_id);
|
let source_file = ctx.sema.db.parse(file_id);
|
||||||
let expr = find_node_at_range::<ast::Expr>(&source_file.syntax_node(), full_range.range)
|
let expr = find_node_at_range::<ast::Expr>(&source_file.syntax_node(), range)
|
||||||
.filter(|it| it.syntax().text_range() == full_range.range);
|
.filter(|it| it.syntax().text_range() == range);
|
||||||
let arg_list = match expr {
|
let arg_list = match expr {
|
||||||
Some(ast::Expr::CallExpr(call)) => call.arg_list(),
|
Some(ast::Expr::CallExpr(call)) => call.arg_list(),
|
||||||
Some(ast::Expr::MethodCallExpr(call)) => call.arg_list(),
|
Some(ast::Expr::MethodCallExpr(call)) => call.arg_list(),
|
||||||
|
@ -39,23 +33,27 @@ fn invalid_args_range(
|
||||||
};
|
};
|
||||||
let arg_list = match arg_list {
|
let arg_list = match arg_list {
|
||||||
Some(it) => it,
|
Some(it) => it,
|
||||||
None => return Err(full_range),
|
None => return range,
|
||||||
};
|
};
|
||||||
let arg_list_range =
|
|
||||||
FileRange { file_id: full_range.file_id, range: arg_list.syntax().text_range() };
|
|
||||||
if d.found < d.expected {
|
if d.found < d.expected {
|
||||||
if d.found == 0 {
|
if d.found == 0 {
|
||||||
return Ok(arg_list_range);
|
return arg_list.syntax().text_range();
|
||||||
}
|
}
|
||||||
if let Some(r_paren) = arg_list.r_paren_token() {
|
if let Some(r_paren) = arg_list.r_paren_token() {
|
||||||
return Ok(FileRange { file_id: full_range.file_id, range: r_paren.text_range() });
|
return r_paren.text_range();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if d.expected < d.found {
|
if d.expected < d.found {
|
||||||
return Ok(arg_list_range);
|
if d.expected == 0 {
|
||||||
|
return arg_list.syntax().text_range();
|
||||||
|
}
|
||||||
|
let zip = arg_list.args().nth(d.expected).zip(arg_list.r_paren_token());
|
||||||
|
if let Some((arg, r_paren)) = zip {
|
||||||
|
return arg.syntax().text_range().cover(r_paren.text_range());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Err(full_range)
|
range
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
@ -204,7 +202,7 @@ impl Foo {
|
||||||
fn new() {
|
fn new() {
|
||||||
Foo::Bar(0);
|
Foo::Bar(0);
|
||||||
Foo::Bar(0, 1);
|
Foo::Bar(0, 1);
|
||||||
//^^^^^^ error: expected 1 argument, found 2
|
//^^ error: expected 1 argument, found 2
|
||||||
Foo::Bar();
|
Foo::Bar();
|
||||||
//^^ error: expected 1 argument, found 0
|
//^^ error: expected 1 argument, found 0
|
||||||
}
|
}
|
||||||
|
@ -227,7 +225,7 @@ fn f() {
|
||||||
unsafe {
|
unsafe {
|
||||||
fixed(0);
|
fixed(0);
|
||||||
fixed(0, 1);
|
fixed(0, 1);
|
||||||
//^^^^^^ error: expected 1 argument, found 2
|
//^^ error: expected 1 argument, found 2
|
||||||
varargs(0);
|
varargs(0);
|
||||||
varargs(0, 1);
|
varargs(0, 1);
|
||||||
varargs2();
|
varargs2();
|
||||||
|
@ -249,7 +247,7 @@ fn main() {
|
||||||
//^^ error: expected 1 argument, found 0
|
//^^ error: expected 1 argument, found 0
|
||||||
f(());
|
f(());
|
||||||
f((), ());
|
f((), ());
|
||||||
//^^^^^^^^ error: expected 1 argument, found 2
|
//^^^ error: expected 1 argument, found 2
|
||||||
}
|
}
|
||||||
"#,
|
"#,
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue