diff options
| author | JohnTitor <huyuumi.dev@gmail.com> | 2021-03-29 17:12:03 +0900 |
|---|---|---|
| committer | JohnTitor <huyuumi.dev@gmail.com> | 2021-03-29 17:12:03 +0900 |
| commit | 960b6992d60aa21ed5d3c5f4eabe20ad3acc77d2 (patch) | |
| tree | d2a5ef9055ec3a7fdbc9b3b87e013e9d59a4178b /compiler/rustc_resolve | |
| parent | cc4103089f40a163f6d143f06359cba7043da29b (diff) | |
| download | rust-960b6992d60aa21ed5d3c5f4eabe20ad3acc77d2.tar.gz rust-960b6992d60aa21ed5d3c5f4eabe20ad3acc77d2.zip | |
Do not emit the advanced diagnostics on macros
Diffstat (limited to 'compiler/rustc_resolve')
| -rw-r--r-- | compiler/rustc_resolve/src/late/diagnostics.rs | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/compiler/rustc_resolve/src/late/diagnostics.rs b/compiler/rustc_resolve/src/late/diagnostics.rs index 1fb07bdae9d..6fae6921fc9 100644 --- a/compiler/rustc_resolve/src/late/diagnostics.rs +++ b/compiler/rustc_resolve/src/late/diagnostics.rs @@ -456,12 +456,14 @@ impl<'a: 'ast, 'ast> LateResolutionVisitor<'a, '_, 'ast> { } } + let is_macro = base_span.from_expansion() && base_span.desugaring_kind().is_none(); if !self.type_ascription_suggestion(&mut err, base_span) { let mut fallback = false; if let ( PathSource::Trait(AliasPossibility::Maybe), Some(Res::Def(DefKind::Struct | DefKind::Enum | DefKind::Union, _)), - ) = (source, res) + false, + ) = (source, res, is_macro) { if let Some(bounds @ [_, .., _]) = self.diagnostic_metadata.current_trait_object { fallback = true; |
