Rollup merge of #93061 - estebank:macr-suggestion, r=cjgillot
Only suggest adding `!` to expressions that can be macro invocation
This commit is contained in:
commit
dc393b2ecc
@ -2517,6 +2517,10 @@ fn resolve_expr(&mut self, expr: &'ast Expr, parent: Option<&'ast Expr>) {
|
||||
self.visit_expr(elem);
|
||||
self.resolve_anon_const(ct, IsRepeatExpr::Yes);
|
||||
}
|
||||
ExprKind::Index(ref elem, ref idx) => {
|
||||
self.resolve_expr(elem, Some(expr));
|
||||
self.visit_expr(idx);
|
||||
}
|
||||
_ => {
|
||||
visit::walk_expr(self, expr);
|
||||
}
|
||||
|
@ -970,7 +970,13 @@ fn smart_resolve_context_dependent_help(
|
||||
};
|
||||
|
||||
match (res, source) {
|
||||
(Res::Def(DefKind::Macro(MacroKind::Bang), _), _) => {
|
||||
(
|
||||
Res::Def(DefKind::Macro(MacroKind::Bang), _),
|
||||
PathSource::Expr(Some(Expr {
|
||||
kind: ExprKind::Index(..) | ExprKind::Call(..), ..
|
||||
}))
|
||||
| PathSource::Struct,
|
||||
) => {
|
||||
err.span_label(span, fallback_label);
|
||||
err.span_suggestion_verbose(
|
||||
span.shrink_to_hi(),
|
||||
@ -982,6 +988,9 @@ fn smart_resolve_context_dependent_help(
|
||||
err.note("if you want the `try` keyword, you need Rust 2018 or later");
|
||||
}
|
||||
}
|
||||
(Res::Def(DefKind::Macro(MacroKind::Bang), _), _) => {
|
||||
err.span_label(span, fallback_label);
|
||||
}
|
||||
(Res::Def(DefKind::TyAlias, def_id), PathSource::Trait(_)) => {
|
||||
err.span_label(span, "type aliases cannot be used as traits");
|
||||
if self.r.session.is_nightly_build() {
|
||||
|
@ -11,16 +11,10 @@ LL | struct SemiTransparent;
|
||||
| ----------------------- similarly named unit struct `SemiTransparent` defined here
|
||||
...
|
||||
LL | semitransparent;
|
||||
| ^^^^^^^^^^^^^^^ not a value
|
||||
|
|
||||
help: use `!` to invoke the macro
|
||||
|
|
||||
LL | semitransparent!;
|
||||
| +
|
||||
help: a unit struct with a similar name exists
|
||||
|
|
||||
LL | SemiTransparent;
|
||||
| ~~~~~~~~~~~~~~~
|
||||
| ^^^^^^^^^^^^^^^
|
||||
| |
|
||||
| not a value
|
||||
| help: a unit struct with a similar name exists: `SemiTransparent`
|
||||
|
||||
error[E0423]: expected value, found macro `opaque`
|
||||
--> $DIR/rustc-macro-transparency.rs:30:5
|
||||
@ -29,16 +23,10 @@ LL | struct Opaque;
|
||||
| -------------- similarly named unit struct `Opaque` defined here
|
||||
...
|
||||
LL | opaque;
|
||||
| ^^^^^^ not a value
|
||||
|
|
||||
help: use `!` to invoke the macro
|
||||
|
|
||||
LL | opaque!;
|
||||
| +
|
||||
help: a unit struct with a similar name exists
|
||||
|
|
||||
LL | Opaque;
|
||||
| ~~~~~~
|
||||
| ^^^^^^
|
||||
| |
|
||||
| not a value
|
||||
| help: a unit struct with a similar name exists (notice the capitalization): `Opaque`
|
||||
|
||||
error: aborting due to 3 previous errors
|
||||
|
||||
|
11
src/test/ui/resolve/resolve-hint-macro.fixed
Normal file
11
src/test/ui/resolve/resolve-hint-macro.fixed
Normal file
@ -0,0 +1,11 @@
|
||||
// run-rustfix
|
||||
fn main() {
|
||||
assert_eq!(1, 1);
|
||||
//~^ ERROR expected function, found macro `assert_eq`
|
||||
assert_eq! { 1, 1 };
|
||||
//~^ ERROR expected struct, variant or union type, found macro `assert_eq`
|
||||
//~| ERROR expected identifier, found `1`
|
||||
//~| ERROR expected identifier, found `1`
|
||||
assert![true];
|
||||
//~^ ERROR expected value, found macro `assert`
|
||||
}
|
@ -1,4 +1,11 @@
|
||||
// run-rustfix
|
||||
fn main() {
|
||||
assert_eq(1, 1);
|
||||
//~^ ERROR expected function, found macro `assert_eq`
|
||||
assert_eq { 1, 1 };
|
||||
//~^ ERROR expected struct, variant or union type, found macro `assert_eq`
|
||||
//~| ERROR expected identifier, found `1`
|
||||
//~| ERROR expected identifier, found `1`
|
||||
assert[true];
|
||||
//~^ ERROR expected value, found macro `assert`
|
||||
}
|
||||
|
@ -1,5 +1,21 @@
|
||||
error: expected identifier, found `1`
|
||||
--> $DIR/resolve-hint-macro.rs:5:17
|
||||
|
|
||||
LL | assert_eq { 1, 1 };
|
||||
| --------- ^ expected identifier
|
||||
| |
|
||||
| while parsing this struct
|
||||
|
||||
error: expected identifier, found `1`
|
||||
--> $DIR/resolve-hint-macro.rs:5:20
|
||||
|
|
||||
LL | assert_eq { 1, 1 };
|
||||
| --------- ^ expected identifier
|
||||
| |
|
||||
| while parsing this struct
|
||||
|
||||
error[E0423]: expected function, found macro `assert_eq`
|
||||
--> $DIR/resolve-hint-macro.rs:2:5
|
||||
--> $DIR/resolve-hint-macro.rs:3:5
|
||||
|
|
||||
LL | assert_eq(1, 1);
|
||||
| ^^^^^^^^^ not a function
|
||||
@ -9,6 +25,29 @@ help: use `!` to invoke the macro
|
||||
LL | assert_eq!(1, 1);
|
||||
| +
|
||||
|
||||
error: aborting due to previous error
|
||||
error[E0574]: expected struct, variant or union type, found macro `assert_eq`
|
||||
--> $DIR/resolve-hint-macro.rs:5:5
|
||||
|
|
||||
LL | assert_eq { 1, 1 };
|
||||
| ^^^^^^^^^ not a struct, variant or union type
|
||||
|
|
||||
help: use `!` to invoke the macro
|
||||
|
|
||||
LL | assert_eq! { 1, 1 };
|
||||
| +
|
||||
|
||||
For more information about this error, try `rustc --explain E0423`.
|
||||
error[E0423]: expected value, found macro `assert`
|
||||
--> $DIR/resolve-hint-macro.rs:9:5
|
||||
|
|
||||
LL | assert[true];
|
||||
| ^^^^^^ not a value
|
||||
|
|
||||
help: use `!` to invoke the macro
|
||||
|
|
||||
LL | assert![true];
|
||||
| +
|
||||
|
||||
error: aborting due to 5 previous errors
|
||||
|
||||
Some errors have detailed explanations: E0423, E0574.
|
||||
For more information about an error, try `rustc --explain E0423`.
|
||||
|
Loading…
Reference in New Issue
Block a user