1use std::ops::ControlFlow;
2
3use Determinacy::*;
4use Namespace::*;
5use rustc_ast::{self as ast, NodeId};
6use rustc_errors::ErrorGuaranteed;
7use rustc_hir::def::{DefKind, MacroKinds, Namespace, NonMacroAttrKind, PartialRes, PerNS};
8use rustc_middle::{bug, span_bug};
9use rustc_session::errors::feature_err;
10use rustc_session::lint::builtin::PROC_MACRO_DERIVE_RESOLUTION_FALLBACK;
11use rustc_span::edition::Edition;
12use rustc_span::hygiene::{ExpnId, ExpnKind, LocalExpnId, MacroKind, SyntaxContext};
13use rustc_span::{Ident, Span, kw, sym};
14use smallvec::SmallVec;
15use tracing::{debug, instrument};
16
17use crate::errors::{ParamKindInEnumDiscriminant, ParamKindInNonTrivialAnonConst};
18use crate::hygiene::Macros20NormalizedSyntaxContext;
19use crate::imports::{Import, NameResolution};
20use crate::late::{
21 ConstantHasGenerics, DiagMetadata, NoConstantGenericsReason, PathSource, Rib, RibKind,
22};
23use crate::macros::{MacroRulesScope, sub_namespace_match};
24use crate::{
25 AmbiguityError, AmbiguityKind, AmbiguityWarning, BindingKey, CmResolver, Decl, DeclKind,
26 Determinacy, Finalize, IdentKey, ImportKind, ImportSummary, LateDecl, LocalModule, Module,
27 ModuleKind, ModuleOrUniformRoot, ParentScope, PathResult, PrivacyError, Res, ResolutionError,
28 Resolver, Scope, ScopeSet, Segment, Stage, Symbol, Used, errors,
29};
30
31#[derive(#[automatically_derived]
impl ::core::marker::Copy for UsePrelude { }Copy, #[automatically_derived]
impl ::core::clone::Clone for UsePrelude {
#[inline]
fn clone(&self) -> UsePrelude { *self }
}Clone)]
32pub enum UsePrelude {
33 No,
34 Yes,
35}
36
37impl From<UsePrelude> for bool {
38 fn from(up: UsePrelude) -> bool {
39 #[allow(non_exhaustive_omitted_patterns)] match up {
UsePrelude::Yes => true,
_ => false,
}matches!(up, UsePrelude::Yes)
40 }
41}
42
43#[derive(#[automatically_derived]
impl ::core::fmt::Debug for Shadowing {
#[inline]
fn fmt(&self, f: &mut ::core::fmt::Formatter) -> ::core::fmt::Result {
::core::fmt::Formatter::write_str(f,
match self {
Shadowing::Restricted => "Restricted",
Shadowing::Unrestricted => "Unrestricted",
})
}
}Debug, #[automatically_derived]
impl ::core::cmp::PartialEq for Shadowing {
#[inline]
fn eq(&self, other: &Shadowing) -> bool {
let __self_discr = ::core::intrinsics::discriminant_value(self);
let __arg1_discr = ::core::intrinsics::discriminant_value(other);
__self_discr == __arg1_discr
}
}PartialEq, #[automatically_derived]
impl ::core::clone::Clone for Shadowing {
#[inline]
fn clone(&self) -> Shadowing { *self }
}Clone, #[automatically_derived]
impl ::core::marker::Copy for Shadowing { }Copy)]
44enum Shadowing {
45 Restricted,
46 Unrestricted,
47}
48
49impl<'ra, 'tcx> Resolver<'ra, 'tcx> {
50 pub(crate) fn visit_scopes<'r, T>(
54 mut self: CmResolver<'r, 'ra, 'tcx>,
55 scope_set: ScopeSet<'ra>,
56 parent_scope: &ParentScope<'ra>,
57 mut ctxt: Macros20NormalizedSyntaxContext,
58 orig_ident_span: Span,
59 derive_fallback_lint_id: Option<NodeId>,
60 mut visitor: impl FnMut(
61 CmResolver<'_, 'ra, 'tcx>,
62 Scope<'ra>,
63 UsePrelude,
64 Macros20NormalizedSyntaxContext,
65 ) -> ControlFlow<T>,
66 ) -> Option<T> {
67 let (ns, macro_kind) = match scope_set {
109 ScopeSet::All(ns)
110 | ScopeSet::Module(ns, _)
111 | ScopeSet::ModuleAndExternPrelude(ns, _) => (ns, None),
112 ScopeSet::ExternPrelude => (TypeNS, None),
113 ScopeSet::Macro(macro_kind) => (MacroNS, Some(macro_kind)),
114 };
115 let module = match scope_set {
116 ScopeSet::Module(_, module) | ScopeSet::ModuleAndExternPrelude(_, module) => module,
118 _ => parent_scope.module.nearest_item_scope(),
120 };
121 let module_only = #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::Module(..) => true,
_ => false,
}matches!(scope_set, ScopeSet::Module(..));
122 let module_and_extern_prelude = #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::ModuleAndExternPrelude(..) => true,
_ => false,
}matches!(scope_set, ScopeSet::ModuleAndExternPrelude(..));
123 let extern_prelude = #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::ExternPrelude => true,
_ => false,
}matches!(scope_set, ScopeSet::ExternPrelude);
124 let mut scope = match ns {
125 _ if module_only || module_and_extern_prelude => Scope::ModuleNonGlobs(module, None),
126 _ if extern_prelude => Scope::ExternPreludeItems,
127 TypeNS | ValueNS => Scope::ModuleNonGlobs(module, None),
128 MacroNS => Scope::DeriveHelpers(parent_scope.expansion),
129 };
130 let mut use_prelude = !module.no_implicit_prelude;
131
132 loop {
133 let visit = match scope {
134 Scope::DeriveHelpers(expn_id) => {
136 !(expn_id == parent_scope.expansion && macro_kind == Some(MacroKind::Derive))
137 }
138 Scope::DeriveHelpersCompat => true,
139 Scope::MacroRules(macro_rules_scope) => {
140 while let MacroRulesScope::Invocation(invoc_id) = macro_rules_scope.get() {
145 if let Some(next_scope) = self.output_macro_rules_scopes.get(&invoc_id) {
146 macro_rules_scope.set(next_scope.get());
147 } else {
148 break;
149 }
150 }
151 true
152 }
153 Scope::ModuleNonGlobs(..) | Scope::ModuleGlobs(..) => true,
154 Scope::MacroUsePrelude => use_prelude || orig_ident_span.is_rust_2015(),
155 Scope::BuiltinAttrs => true,
156 Scope::ExternPreludeItems | Scope::ExternPreludeFlags => {
157 use_prelude || module_and_extern_prelude || extern_prelude
158 }
159 Scope::ToolPrelude => use_prelude,
160 Scope::StdLibPrelude => use_prelude || ns == MacroNS,
161 Scope::BuiltinTypes => true,
162 };
163
164 if visit {
165 let use_prelude = if use_prelude { UsePrelude::Yes } else { UsePrelude::No };
166 if let ControlFlow::Break(break_result) =
167 visitor(self.reborrow(), scope, use_prelude, ctxt)
168 {
169 return Some(break_result);
170 }
171 }
172
173 scope = match scope {
174 Scope::DeriveHelpers(LocalExpnId::ROOT) => Scope::DeriveHelpersCompat,
175 Scope::DeriveHelpers(expn_id) => {
176 let expn_data = expn_id.expn_data();
178 match expn_data.kind {
179 ExpnKind::Root
180 | ExpnKind::Macro(MacroKind::Bang | MacroKind::Derive, _) => {
181 Scope::DeriveHelpersCompat
182 }
183 _ => Scope::DeriveHelpers(expn_data.parent.expect_local()),
184 }
185 }
186 Scope::DeriveHelpersCompat => Scope::MacroRules(parent_scope.macro_rules),
187 Scope::MacroRules(macro_rules_scope) => match macro_rules_scope.get() {
188 MacroRulesScope::Def(binding) => {
189 Scope::MacroRules(binding.parent_macro_rules_scope)
190 }
191 MacroRulesScope::Invocation(invoc_id) => {
192 Scope::MacroRules(self.invocation_parent_scopes[&invoc_id].macro_rules)
193 }
194 MacroRulesScope::Empty => Scope::ModuleNonGlobs(module, None),
195 },
196 Scope::ModuleNonGlobs(module, lint_id) => Scope::ModuleGlobs(module, lint_id),
197 Scope::ModuleGlobs(..) if module_only => break,
198 Scope::ModuleGlobs(..) if module_and_extern_prelude => match ns {
199 TypeNS => {
200 ctxt.update_unchecked(|ctxt| ctxt.adjust(ExpnId::root()));
201 Scope::ExternPreludeItems
202 }
203 ValueNS | MacroNS => break,
204 },
205 Scope::ModuleGlobs(module, prev_lint_id) => {
206 use_prelude = !module.no_implicit_prelude;
207 match self.hygienic_lexical_parent(module, &mut ctxt, derive_fallback_lint_id) {
208 Some((parent_module, lint_id)) => {
209 Scope::ModuleNonGlobs(parent_module, lint_id.or(prev_lint_id))
210 }
211 None => {
212 ctxt.update_unchecked(|ctxt| ctxt.adjust(ExpnId::root()));
213 match ns {
214 TypeNS => Scope::ExternPreludeItems,
215 ValueNS => Scope::StdLibPrelude,
216 MacroNS => Scope::MacroUsePrelude,
217 }
218 }
219 }
220 }
221 Scope::MacroUsePrelude => Scope::StdLibPrelude,
222 Scope::BuiltinAttrs => break, Scope::ExternPreludeItems => Scope::ExternPreludeFlags,
224 Scope::ExternPreludeFlags if module_and_extern_prelude || extern_prelude => break,
225 Scope::ExternPreludeFlags => Scope::ToolPrelude,
226 Scope::ToolPrelude => Scope::StdLibPrelude,
227 Scope::StdLibPrelude => match ns {
228 TypeNS => Scope::BuiltinTypes,
229 ValueNS => break, MacroNS => Scope::BuiltinAttrs,
231 },
232 Scope::BuiltinTypes => break, };
234 }
235
236 None
237 }
238
239 fn hygienic_lexical_parent(
240 &self,
241 module: Module<'ra>,
242 ctxt: &mut Macros20NormalizedSyntaxContext,
243 derive_fallback_lint_id: Option<NodeId>,
244 ) -> Option<(Module<'ra>, Option<NodeId>)> {
245 if !module.expansion.outer_expn_is_descendant_of(**ctxt) {
246 let expn_id = ctxt.update_unchecked(|ctxt| ctxt.remove_mark());
247 return Some((self.expn_def_scope(expn_id), None));
248 }
249
250 if let ModuleKind::Block = module.kind {
251 return Some((module.parent.unwrap().nearest_item_scope(), None));
252 }
253
254 if derive_fallback_lint_id.is_some()
266 && let Some(parent) = module.parent
267 && module.expansion != parent.expansion
269 && module.expansion.is_descendant_of(parent.expansion)
271 && let Some(def_id) = module.expansion.expn_data().macro_def_id
273 {
274 let ext = &self.get_macro_by_def_id(def_id).ext;
275 if ext.builtin_name.is_none()
276 && ext.macro_kinds() == MacroKinds::DERIVE
277 && parent.expansion.outer_expn_is_descendant_of(**ctxt)
278 {
279 return Some((parent, derive_fallback_lint_id));
280 }
281 }
282
283 None
284 }
285
286 #[allow(clippy :: suspicious_else_formatting)]
{
let __tracing_attr_span;
let __tracing_attr_guard;
if ::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() ||
{ false } {
__tracing_attr_span =
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("resolve_ident_in_lexical_scope",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(303u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["ident", "ns",
"parent_scope", "finalize", "ignore_decl", "diag_metadata"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::SPAN)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let mut interest = ::tracing::subscriber::Interest::never();
if ::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{ interest = __CALLSITE.interest(); !interest.is_never() }
&&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest) {
let meta = __CALLSITE.metadata();
::tracing::Span::new(meta,
&{
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = meta.fields().iter();
meta.fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ident)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ns)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&parent_scope)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&finalize)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ignore_decl)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&diag_metadata)
as &dyn Value))])
})
} else {
let span =
::tracing::__macro_support::__disabled_span(__CALLSITE.metadata());
{};
span
}
};
__tracing_attr_guard = __tracing_attr_span.enter();
}
#[warn(clippy :: suspicious_else_formatting)]
{
#[allow(unknown_lints, unreachable_code, clippy ::
diverging_sub_expression, clippy :: empty_loop, clippy ::
let_unit_value, clippy :: let_with_type_underscore, clippy ::
needless_return, clippy :: unreachable)]
if false {
let __tracing_attr_fake_return: Option<LateDecl<'ra>> = loop {};
return __tracing_attr_fake_return;
}
{
let orig_ident = ident;
let (general_span, normalized_span) =
if ident.name == kw::SelfUpper {
let empty_span =
ident.span.with_ctxt(SyntaxContext::root());
(empty_span, empty_span)
} else if ns == TypeNS {
let normalized_span = ident.span.normalize_to_macros_2_0();
(normalized_span, normalized_span)
} else {
(ident.span.normalize_to_macro_rules(),
ident.span.normalize_to_macros_2_0())
};
ident.span = general_span;
let normalized_ident = Ident { span: normalized_span, ..ident };
for (i, rib) in ribs.iter().enumerate().rev() {
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_resolve/src/ident.rs:330",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(330u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("walk rib\n{0:?}",
rib.bindings) as &dyn Value))])
});
} else { ; }
};
let rib_ident =
if rib.kind.contains_params() {
normalized_ident
} else { ident };
if let Some((original_rib_ident_def, res)) =
rib.bindings.get_key_value(&rib_ident) {
return Some(LateDecl::RibDef(self.validate_res_from_ribs(i,
rib_ident, *res, finalize.map(|_| general_span),
*original_rib_ident_def, ribs, diag_metadata)));
} else if let RibKind::Block(Some(module)) = rib.kind &&
let Ok(binding) =
self.cm().resolve_ident_in_scope_set(ident,
ScopeSet::Module(ns, module.to_module()), parent_scope,
finalize.map(|finalize|
Finalize { used: Used::Scope, ..finalize }), ignore_decl,
None) {
return Some(LateDecl::Decl(binding));
} else if let RibKind::Module(module) = rib.kind {
let parent_scope =
&ParentScope {
module: module.to_module(),
..*parent_scope
};
let finalize =
finalize.map(|f| Finalize { stage: Stage::Late, ..f });
return self.cm().resolve_ident_in_scope_set(orig_ident,
ScopeSet::All(ns), parent_scope, finalize, ignore_decl,
None).ok().map(LateDecl::Decl);
}
if let RibKind::MacroDefinition(def) = rib.kind &&
def == self.macro_def(ident.span.ctxt()) {
ident.span.remove_mark();
}
}
::core::panicking::panic("internal error: entered unreachable code")
}
}
}#[instrument(level = "debug", skip(self, ribs))]
304 pub(crate) fn resolve_ident_in_lexical_scope(
305 &mut self,
306 mut ident: Ident,
307 ns: Namespace,
308 parent_scope: &ParentScope<'ra>,
309 finalize: Option<Finalize>,
310 ribs: &[Rib<'ra>],
311 ignore_decl: Option<Decl<'ra>>,
312 diag_metadata: Option<&DiagMetadata<'_>>,
313 ) -> Option<LateDecl<'ra>> {
314 let orig_ident = ident;
315 let (general_span, normalized_span) = if ident.name == kw::SelfUpper {
316 let empty_span = ident.span.with_ctxt(SyntaxContext::root());
318 (empty_span, empty_span)
319 } else if ns == TypeNS {
320 let normalized_span = ident.span.normalize_to_macros_2_0();
321 (normalized_span, normalized_span)
322 } else {
323 (ident.span.normalize_to_macro_rules(), ident.span.normalize_to_macros_2_0())
324 };
325 ident.span = general_span;
326 let normalized_ident = Ident { span: normalized_span, ..ident };
327
328 for (i, rib) in ribs.iter().enumerate().rev() {
330 debug!("walk rib\n{:?}", rib.bindings);
331 let rib_ident = if rib.kind.contains_params() { normalized_ident } else { ident };
334 if let Some((original_rib_ident_def, res)) = rib.bindings.get_key_value(&rib_ident) {
335 return Some(LateDecl::RibDef(self.validate_res_from_ribs(
337 i,
338 rib_ident,
339 *res,
340 finalize.map(|_| general_span),
341 *original_rib_ident_def,
342 ribs,
343 diag_metadata,
344 )));
345 } else if let RibKind::Block(Some(module)) = rib.kind
346 && let Ok(binding) = self.cm().resolve_ident_in_scope_set(
347 ident,
348 ScopeSet::Module(ns, module.to_module()),
349 parent_scope,
350 finalize.map(|finalize| Finalize { used: Used::Scope, ..finalize }),
351 ignore_decl,
352 None,
353 )
354 {
355 return Some(LateDecl::Decl(binding));
357 } else if let RibKind::Module(module) = rib.kind {
358 let parent_scope = &ParentScope { module: module.to_module(), ..*parent_scope };
360 let finalize = finalize.map(|f| Finalize { stage: Stage::Late, ..f });
361 return self
362 .cm()
363 .resolve_ident_in_scope_set(
364 orig_ident,
365 ScopeSet::All(ns),
366 parent_scope,
367 finalize,
368 ignore_decl,
369 None,
370 )
371 .ok()
372 .map(LateDecl::Decl);
373 }
374
375 if let RibKind::MacroDefinition(def) = rib.kind
376 && def == self.macro_def(ident.span.ctxt())
377 {
378 ident.span.remove_mark();
381 }
382 }
383
384 unreachable!()
385 }
386
387 pub(crate) fn resolve_ident_in_scope_set<'r>(
389 self: CmResolver<'r, 'ra, 'tcx>,
390 orig_ident: Ident,
391 scope_set: ScopeSet<'ra>,
392 parent_scope: &ParentScope<'ra>,
393 finalize: Option<Finalize>,
394 ignore_decl: Option<Decl<'ra>>,
395 ignore_import: Option<Import<'ra>>,
396 ) -> Result<Decl<'ra>, Determinacy> {
397 self.resolve_ident_in_scope_set_inner(
398 IdentKey::new(orig_ident),
399 orig_ident.span,
400 scope_set,
401 parent_scope,
402 finalize,
403 ignore_decl,
404 ignore_import,
405 )
406 }
407
408 fn resolve_ident_in_scope_set_inner<'r>(
409 self: CmResolver<'r, 'ra, 'tcx>,
410 ident: IdentKey,
411 orig_ident_span: Span,
412 scope_set: ScopeSet<'ra>,
413 parent_scope: &ParentScope<'ra>,
414 finalize: Option<Finalize>,
415 ignore_decl: Option<Decl<'ra>>,
416 ignore_import: Option<Import<'ra>>,
417 ) -> Result<Decl<'ra>, Determinacy> {
418 if !#[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::Module(..) => true,
_ => false,
}matches!(scope_set, ScopeSet::Module(..)) && ident.name.is_path_segment_keyword() {
420 return Err(Determinacy::Determined);
421 }
422
423 let (ns, macro_kind) = match scope_set {
424 ScopeSet::All(ns)
425 | ScopeSet::Module(ns, _)
426 | ScopeSet::ModuleAndExternPrelude(ns, _) => (ns, None),
427 ScopeSet::ExternPrelude => (TypeNS, None),
428 ScopeSet::Macro(macro_kind) => (MacroNS, Some(macro_kind)),
429 };
430 let derive_fallback_lint_id = match finalize {
431 Some(Finalize { node_id, stage: Stage::Late, .. }) => Some(node_id),
432 _ => None,
433 };
434
435 let mut innermost_results: SmallVec<[(Decl<'_>, Scope<'_>); 2]> = SmallVec::new();
447 let mut determinacy = Determinacy::Determined;
448
449 let break_result = self.visit_scopes(
451 scope_set,
452 parent_scope,
453 ident.ctxt,
454 orig_ident_span,
455 derive_fallback_lint_id,
456 |mut this, scope, use_prelude, ctxt| {
457 let ident = IdentKey { name: ident.name, ctxt };
458 let res = match this.reborrow().resolve_ident_in_scope(
459 ident,
460 orig_ident_span,
461 ns,
462 scope,
463 use_prelude,
464 scope_set,
465 parent_scope,
466 if innermost_results.is_empty() { finalize } else { None },
468 ignore_decl,
469 ignore_import,
470 ) {
471 Ok(decl) => Ok(decl),
472 Err(ControlFlow::Break(determinacy)) if innermost_results.is_empty() => {
477 return ControlFlow::Break(Err(determinacy));
478 }
479 Err(determinacy) => Err(determinacy.into_value()),
480 };
481 match res {
482 Ok(decl) if sub_namespace_match(decl.macro_kinds(), macro_kind) => {
483 let import = match finalize {
488 None | Some(Finalize { stage: Stage::Late, .. }) => {
489 return ControlFlow::Break(Ok(decl));
490 }
491 Some(Finalize { import, .. }) => import,
492 };
493 this.get_mut().maybe_push_glob_vs_glob_vis_ambiguity(
494 ident,
495 orig_ident_span,
496 decl,
497 import,
498 );
499
500 if let Some(&(innermost_decl, _)) = innermost_results.first() {
501 if this.get_mut().maybe_push_ambiguity(
503 ident,
504 orig_ident_span,
505 ns,
506 scope_set,
507 parent_scope,
508 decl,
509 scope,
510 &innermost_results,
511 import,
512 ) {
513 return ControlFlow::Break(Ok(innermost_decl));
515 }
516 }
517
518 innermost_results.push((decl, scope));
519 }
520 Ok(_) | Err(Determinacy::Determined) => {}
521 Err(Determinacy::Undetermined) => determinacy = Determinacy::Undetermined,
522 }
523
524 ControlFlow::Continue(())
525 },
526 );
527
528 if let Some(break_result) = break_result {
530 return break_result;
531 }
532
533 match innermost_results.first() {
535 Some(&(decl, ..)) => Ok(decl),
536 None => Err(determinacy),
537 }
538 }
539
540 fn resolve_ident_in_scope<'r>(
541 mut self: CmResolver<'r, 'ra, 'tcx>,
542 ident: IdentKey,
543 orig_ident_span: Span,
544 ns: Namespace,
545 scope: Scope<'ra>,
546 use_prelude: UsePrelude,
547 scope_set: ScopeSet<'ra>,
548 parent_scope: &ParentScope<'ra>,
549 finalize: Option<Finalize>,
550 ignore_decl: Option<Decl<'ra>>,
551 ignore_import: Option<Import<'ra>>,
552 ) -> Result<Decl<'ra>, ControlFlow<Determinacy, Determinacy>> {
553 let ret = match scope {
554 Scope::DeriveHelpers(expn_id) => {
555 if let Some(decl) = self
556 .helper_attrs
557 .get(&expn_id)
558 .and_then(|attrs| attrs.iter().rfind(|(i, ..)| ident == *i).map(|(.., d)| *d))
559 {
560 Ok(decl)
561 } else {
562 Err(Determinacy::Determined)
563 }
564 }
565 Scope::DeriveHelpersCompat => {
566 let mut result = Err(Determinacy::Determined);
567 for derive in parent_scope.derives {
568 let parent_scope = &ParentScope { derives: &[], ..*parent_scope };
569 match self.reborrow().resolve_derive_macro_path(
570 derive,
571 parent_scope,
572 false,
573 ignore_import,
574 ) {
575 Ok((Some(ext), _)) => {
576 if ext.helper_attrs.contains(&ident.name) {
577 let decl = self.arenas.new_pub_def_decl(
578 Res::NonMacroAttr(NonMacroAttrKind::DeriveHelperCompat),
579 derive.span,
580 LocalExpnId::ROOT,
581 );
582 result = Ok(decl);
583 break;
584 }
585 }
586 Ok(_) | Err(Determinacy::Determined) => {}
587 Err(Determinacy::Undetermined) => result = Err(Determinacy::Undetermined),
588 }
589 }
590 result
591 }
592 Scope::MacroRules(macro_rules_scope) => match macro_rules_scope.get() {
593 MacroRulesScope::Def(macro_rules_def) if ident == macro_rules_def.ident => {
594 Ok(macro_rules_def.decl)
595 }
596 MacroRulesScope::Invocation(_) => Err(Determinacy::Undetermined),
597 _ => Err(Determinacy::Determined),
598 },
599 Scope::ModuleNonGlobs(module, derive_fallback_lint_id) => {
600 let (adjusted_parent_scope, adjusted_finalize) = if #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::Module(..) | ScopeSet::ModuleAndExternPrelude(..) => true,
_ => false,
}matches!(
601 scope_set,
602 ScopeSet::Module(..) | ScopeSet::ModuleAndExternPrelude(..)
603 ) {
604 (parent_scope, finalize)
605 } else {
606 (
607 &ParentScope { module, ..*parent_scope },
608 finalize.map(|f| Finalize { used: Used::Scope, ..f }),
609 )
610 };
611 let decl = self.reborrow().resolve_ident_in_module_non_globs_unadjusted(
612 module,
613 ident,
614 orig_ident_span,
615 ns,
616 adjusted_parent_scope,
617 if #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::Module(..) => true,
_ => false,
}matches!(scope_set, ScopeSet::Module(..)) {
618 Shadowing::Unrestricted
619 } else {
620 Shadowing::Restricted
621 },
622 adjusted_finalize,
623 ignore_decl,
624 ignore_import,
625 );
626 match decl {
627 Ok(decl) => {
628 if let Some(lint_id) = derive_fallback_lint_id {
629 self.get_mut().lint_buffer.buffer_lint(
630 PROC_MACRO_DERIVE_RESOLUTION_FALLBACK,
631 lint_id,
632 orig_ident_span,
633 errors::ProcMacroDeriveResolutionFallback {
634 span: orig_ident_span,
635 ns_descr: ns.descr(),
636 ident: ident.name,
637 },
638 );
639 }
640 Ok(decl)
641 }
642 Err(ControlFlow::Continue(determinacy)) => Err(determinacy),
643 Err(ControlFlow::Break(..)) => return decl,
644 }
645 }
646 Scope::ModuleGlobs(module, _)
647 if let ModuleKind::Def(_, def_id, _) = module.kind
648 && !def_id.is_local() =>
649 {
650 Err(Determined)
652 }
653 Scope::ModuleGlobs(module, derive_fallback_lint_id) => {
654 let (adjusted_parent_scope, adjusted_finalize) = if #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::Module(..) | ScopeSet::ModuleAndExternPrelude(..) => true,
_ => false,
}matches!(
655 scope_set,
656 ScopeSet::Module(..) | ScopeSet::ModuleAndExternPrelude(..)
657 ) {
658 (parent_scope, finalize)
659 } else {
660 (
661 &ParentScope { module, ..*parent_scope },
662 finalize.map(|f| Finalize { used: Used::Scope, ..f }),
663 )
664 };
665 let binding = self.reborrow().resolve_ident_in_module_globs_unadjusted(
666 module.expect_local(),
667 ident,
668 orig_ident_span,
669 ns,
670 adjusted_parent_scope,
671 if #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::Module(..) => true,
_ => false,
}matches!(scope_set, ScopeSet::Module(..)) {
672 Shadowing::Unrestricted
673 } else {
674 Shadowing::Restricted
675 },
676 adjusted_finalize,
677 ignore_decl,
678 ignore_import,
679 );
680 match binding {
681 Ok(binding) => {
682 if let Some(lint_id) = derive_fallback_lint_id {
683 self.get_mut().lint_buffer.buffer_lint(
684 PROC_MACRO_DERIVE_RESOLUTION_FALLBACK,
685 lint_id,
686 orig_ident_span,
687 errors::ProcMacroDeriveResolutionFallback {
688 span: orig_ident_span,
689 ns_descr: ns.descr(),
690 ident: ident.name,
691 },
692 );
693 }
694 Ok(binding)
695 }
696 Err(ControlFlow::Continue(determinacy)) => Err(determinacy),
697 Err(ControlFlow::Break(..)) => return binding,
698 }
699 }
700 Scope::MacroUsePrelude => match self.macro_use_prelude.get(&ident.name).cloned() {
701 Some(decl) => Ok(decl),
702 None => Err(Determinacy::determined(
703 self.graph_root.unexpanded_invocations.borrow().is_empty(),
704 )),
705 },
706 Scope::BuiltinAttrs => match self.builtin_attr_decls.get(&ident.name) {
707 Some(decl) => Ok(*decl),
708 None => Err(Determinacy::Determined),
709 },
710 Scope::ExternPreludeItems => {
711 match self.reborrow().extern_prelude_get_item(
712 ident,
713 orig_ident_span,
714 finalize.is_some(),
715 ) {
716 Some(decl) => Ok(decl),
717 None => Err(Determinacy::determined(
718 self.graph_root.unexpanded_invocations.borrow().is_empty(),
719 )),
720 }
721 }
722 Scope::ExternPreludeFlags => {
723 match self.extern_prelude_get_flag(ident, orig_ident_span, finalize.is_some()) {
724 Some(decl) => Ok(decl),
725 None => Err(Determinacy::Determined),
726 }
727 }
728 Scope::ToolPrelude => match self.registered_tool_decls.get(&ident) {
729 Some(decl) => Ok(*decl),
730 None => Err(Determinacy::Determined),
731 },
732 Scope::StdLibPrelude => {
733 let mut result = Err(Determinacy::Determined);
734 if let Some(prelude) = self.prelude
735 && let Ok(decl) = self.reborrow().resolve_ident_in_scope_set_inner(
736 ident,
737 orig_ident_span,
738 ScopeSet::Module(ns, prelude),
739 parent_scope,
740 None,
741 ignore_decl,
742 ignore_import,
743 )
744 && (#[allow(non_exhaustive_omitted_patterns)] match use_prelude {
UsePrelude::Yes => true,
_ => false,
}matches!(use_prelude, UsePrelude::Yes) || self.is_builtin_macro(decl.res()))
745 {
746 result = Ok(decl)
747 }
748
749 result
750 }
751 Scope::BuiltinTypes => match self.builtin_type_decls.get(&ident.name) {
752 Some(decl) => {
753 if #[allow(non_exhaustive_omitted_patterns)] match ident.name {
sym::f16 => true,
_ => false,
}matches!(ident.name, sym::f16)
754 && !self.tcx.features().f16()
755 && !orig_ident_span.allows_unstable(sym::f16)
756 && finalize.is_some()
757 {
758 feature_err(
759 self.tcx.sess,
760 sym::f16,
761 orig_ident_span,
762 "the type `f16` is unstable",
763 )
764 .emit();
765 }
766 if #[allow(non_exhaustive_omitted_patterns)] match ident.name {
sym::f128 => true,
_ => false,
}matches!(ident.name, sym::f128)
767 && !self.tcx.features().f128()
768 && !orig_ident_span.allows_unstable(sym::f128)
769 && finalize.is_some()
770 {
771 feature_err(
772 self.tcx.sess,
773 sym::f128,
774 orig_ident_span,
775 "the type `f128` is unstable",
776 )
777 .emit();
778 }
779 Ok(*decl)
780 }
781 None => Err(Determinacy::Determined),
782 },
783 };
784
785 ret.map_err(ControlFlow::Continue)
786 }
787
788 fn maybe_push_glob_vs_glob_vis_ambiguity(
789 &mut self,
790 ident: IdentKey,
791 orig_ident_span: Span,
792 decl: Decl<'ra>,
793 import: Option<ImportSummary>,
794 ) {
795 let Some(import) = import else { return };
796 let vis1 = self.import_decl_vis(decl, import);
797 let vis2 = self.import_decl_vis_ext(decl, import, true);
798 if vis1 != vis2 {
799 self.ambiguity_errors.push(AmbiguityError {
800 kind: AmbiguityKind::GlobVsGlob,
801 ambig_vis: Some((vis1, vis2)),
802 ident: ident.orig(orig_ident_span),
803 b1: decl.ambiguity_vis_max.get().unwrap_or(decl),
804 b2: decl.ambiguity_vis_min.get().unwrap_or(decl),
805 scope1: Scope::ModuleGlobs(decl.parent_module.unwrap(), None),
806 scope2: Scope::ModuleGlobs(decl.parent_module.unwrap(), None),
807 warning: Some(AmbiguityWarning::GlobImport),
808 });
809 }
810 }
811
812 fn maybe_push_ambiguity(
813 &mut self,
814 ident: IdentKey,
815 orig_ident_span: Span,
816 ns: Namespace,
817 scope_set: ScopeSet<'ra>,
818 parent_scope: &ParentScope<'ra>,
819 decl: Decl<'ra>,
820 scope: Scope<'ra>,
821 innermost_results: &[(Decl<'ra>, Scope<'ra>)],
822 import: Option<ImportSummary>,
823 ) -> bool {
824 let (innermost_decl, innermost_scope) = innermost_results[0];
825 let (res, innermost_res) = (decl.res(), innermost_decl.res());
826 let ambig_vis = if res != innermost_res {
827 None
828 } else if let Some(import) = import
829 && let vis1 = self.import_decl_vis(decl, import)
830 && let vis2 = self.import_decl_vis(innermost_decl, import)
831 && vis1 != vis2
832 {
833 Some((vis1, vis2))
834 } else {
835 return false;
836 };
837
838 let module_only = #[allow(non_exhaustive_omitted_patterns)] match scope_set {
ScopeSet::Module(..) => true,
_ => false,
}matches!(scope_set, ScopeSet::Module(..));
841 let is_builtin = |res| #[allow(non_exhaustive_omitted_patterns)] match res {
Res::NonMacroAttr(NonMacroAttrKind::Builtin(..)) => true,
_ => false,
}matches!(res, Res::NonMacroAttr(NonMacroAttrKind::Builtin(..)));
842 let derive_helper = Res::NonMacroAttr(NonMacroAttrKind::DeriveHelper);
843 let derive_helper_compat = Res::NonMacroAttr(NonMacroAttrKind::DeriveHelperCompat);
844
845 let ambiguity_error_kind = if is_builtin(innermost_res) || is_builtin(res) {
846 Some(AmbiguityKind::BuiltinAttr)
847 } else if innermost_res == derive_helper_compat {
848 Some(AmbiguityKind::DeriveHelper)
849 } else if res == derive_helper_compat && innermost_res != derive_helper {
850 ::rustc_middle::util::bug::span_bug_fmt(orig_ident_span,
format_args!("impossible inner resolution kind"))span_bug!(orig_ident_span, "impossible inner resolution kind")
851 } else if #[allow(non_exhaustive_omitted_patterns)] match innermost_scope {
Scope::MacroRules(_) => true,
_ => false,
}matches!(innermost_scope, Scope::MacroRules(_))
852 && #[allow(non_exhaustive_omitted_patterns)] match scope {
Scope::ModuleNonGlobs(..) | Scope::ModuleGlobs(..) => true,
_ => false,
}matches!(scope, Scope::ModuleNonGlobs(..) | Scope::ModuleGlobs(..))
853 && !self.disambiguate_macro_rules_vs_modularized(innermost_decl, decl)
854 {
855 Some(AmbiguityKind::MacroRulesVsModularized)
856 } else if #[allow(non_exhaustive_omitted_patterns)] match scope {
Scope::MacroRules(_) => true,
_ => false,
}matches!(scope, Scope::MacroRules(_))
857 && #[allow(non_exhaustive_omitted_patterns)] match innermost_scope {
Scope::ModuleNonGlobs(..) | Scope::ModuleGlobs(..) => true,
_ => false,
}matches!(innermost_scope, Scope::ModuleNonGlobs(..) | Scope::ModuleGlobs(..))
858 {
859 ::rustc_middle::util::bug::span_bug_fmt(orig_ident_span,
format_args!("ambiguous scoped macro resolutions with path-based scope resolution as first candidate"))span_bug!(
865 orig_ident_span,
866 "ambiguous scoped macro resolutions with path-based \
867 scope resolution as first candidate"
868 )
869 } else if innermost_decl.is_glob_import() {
870 Some(AmbiguityKind::GlobVsOuter)
871 } else if !module_only && innermost_decl.may_appear_after(parent_scope.expansion, decl) {
872 Some(AmbiguityKind::MoreExpandedVsOuter)
873 } else if innermost_decl.expansion != LocalExpnId::ROOT
874 && (!module_only || ns == MacroNS)
875 && let Scope::ModuleGlobs(m1, _) = scope
876 && let Scope::ModuleNonGlobs(m2, _) = innermost_scope
877 && m1 == m2
878 {
879 Some(AmbiguityKind::GlobVsExpanded)
883 } else {
884 None
885 };
886
887 if let Some(kind) = ambiguity_error_kind {
888 let issue_145575_hack = #[allow(non_exhaustive_omitted_patterns)] match scope {
Scope::ExternPreludeFlags => true,
_ => false,
}matches!(scope, Scope::ExternPreludeFlags)
892 && innermost_results[1..]
893 .iter()
894 .any(|(b, s)| #[allow(non_exhaustive_omitted_patterns)] match s {
Scope::ExternPreludeItems => true,
_ => false,
}matches!(s, Scope::ExternPreludeItems) && *b != innermost_decl);
895 let issue_149681_hack = match scope {
899 Scope::ModuleGlobs(m1, _)
900 if innermost_results[1..]
901 .iter()
902 .any(|(_, s)| #[allow(non_exhaustive_omitted_patterns)] match *s {
Scope::ModuleNonGlobs(m2, _) if m1 == m2 => true,
_ => false,
}matches!(*s, Scope::ModuleNonGlobs(m2, _) if m1 == m2)) =>
903 {
904 true
905 }
906 _ => false,
907 };
908
909 if issue_145575_hack || issue_149681_hack {
910 self.issue_145575_hack_applied = true;
911 } else {
912 let is_issue_147319_hack = orig_ident_span.edition() <= Edition::Edition2024
915 && #[allow(non_exhaustive_omitted_patterns)] match ident.name {
sym::panic => true,
_ => false,
}matches!(ident.name, sym::panic)
916 && #[allow(non_exhaustive_omitted_patterns)] match scope {
Scope::StdLibPrelude => true,
_ => false,
}matches!(scope, Scope::StdLibPrelude)
917 && #[allow(non_exhaustive_omitted_patterns)] match innermost_scope {
Scope::ModuleGlobs(_, _) => true,
_ => false,
}matches!(innermost_scope, Scope::ModuleGlobs(_, _))
918 && ((self.is_specific_builtin_macro(res, sym::std_panic)
919 && self.is_specific_builtin_macro(innermost_res, sym::core_panic))
920 || (self.is_specific_builtin_macro(res, sym::core_panic)
921 && self.is_specific_builtin_macro(innermost_res, sym::std_panic)));
922
923 let warning = if ambig_vis.is_some() {
924 Some(AmbiguityWarning::GlobImport)
925 } else if is_issue_147319_hack {
926 Some(AmbiguityWarning::PanicImport)
927 } else {
928 None
929 };
930
931 self.ambiguity_errors.push(AmbiguityError {
932 kind,
933 ambig_vis,
934 ident: ident.orig(orig_ident_span),
935 b1: innermost_decl,
936 b2: decl,
937 scope1: innermost_scope,
938 scope2: scope,
939 warning,
940 });
941 return true;
942 }
943 }
944
945 false
946 }
947
948 #[allow(clippy :: suspicious_else_formatting)]
{
let __tracing_attr_span;
let __tracing_attr_guard;
if ::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() ||
{ false } {
__tracing_attr_span =
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("maybe_resolve_ident_in_module",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(948u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["module", "ident",
"ns", "parent_scope", "ignore_import"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::SPAN)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let mut interest = ::tracing::subscriber::Interest::never();
if ::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{ interest = __CALLSITE.interest(); !interest.is_never() }
&&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest) {
let meta = __CALLSITE.metadata();
::tracing::Span::new(meta,
&{
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = meta.fields().iter();
meta.fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&module)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ident)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ns)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&parent_scope)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ignore_import)
as &dyn Value))])
})
} else {
let span =
::tracing::__macro_support::__disabled_span(__CALLSITE.metadata());
{};
span
}
};
__tracing_attr_guard = __tracing_attr_span.enter();
}
#[warn(clippy :: suspicious_else_formatting)]
{
#[allow(unknown_lints, unreachable_code, clippy ::
diverging_sub_expression, clippy :: empty_loop, clippy ::
let_unit_value, clippy :: let_with_type_underscore, clippy ::
needless_return, clippy :: unreachable)]
if false {
let __tracing_attr_fake_return: Result<Decl<'ra>, Determinacy> =
loop {};
return __tracing_attr_fake_return;
}
{
self.resolve_ident_in_module(module, ident, ns, parent_scope,
None, None, ignore_import)
}
}
}#[instrument(level = "debug", skip(self))]
949 pub(crate) fn maybe_resolve_ident_in_module<'r>(
950 self: CmResolver<'r, 'ra, 'tcx>,
951 module: ModuleOrUniformRoot<'ra>,
952 ident: Ident,
953 ns: Namespace,
954 parent_scope: &ParentScope<'ra>,
955 ignore_import: Option<Import<'ra>>,
956 ) -> Result<Decl<'ra>, Determinacy> {
957 self.resolve_ident_in_module(module, ident, ns, parent_scope, None, None, ignore_import)
958 }
959
960 fn resolve_super_in_module(
961 &self,
962 ident: Ident,
963 module: Option<Module<'ra>>,
964 parent_scope: &ParentScope<'ra>,
965 ) -> Option<Module<'ra>> {
966 let mut ctxt = ident.span.ctxt().normalize_to_macros_2_0();
967 module
968 .unwrap_or_else(|| self.resolve_self(&mut ctxt, parent_scope.module))
969 .parent
970 .map(|parent| self.resolve_self(&mut ctxt, parent))
971 }
972
973 pub(crate) fn path_root_is_crate_root(&self, ident: Ident) -> bool {
974 ident.name == kw::PathRoot && ident.span.is_rust_2015() && self.tcx.sess.is_rust_2015()
975 }
976
977 #[allow(clippy :: suspicious_else_formatting)]
{
let __tracing_attr_span;
let __tracing_attr_guard;
if ::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() ||
{ false } {
__tracing_attr_span =
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("resolve_ident_in_module",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(977u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["module", "ident",
"ns", "parent_scope", "finalize", "ignore_decl",
"ignore_import"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::SPAN)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let mut interest = ::tracing::subscriber::Interest::never();
if ::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{ interest = __CALLSITE.interest(); !interest.is_never() }
&&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest) {
let meta = __CALLSITE.metadata();
::tracing::Span::new(meta,
&{
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = meta.fields().iter();
meta.fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&module)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ident)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ns)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&parent_scope)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&finalize)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ignore_decl)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ignore_import)
as &dyn Value))])
})
} else {
let span =
::tracing::__macro_support::__disabled_span(__CALLSITE.metadata());
{};
span
}
};
__tracing_attr_guard = __tracing_attr_span.enter();
}
#[warn(clippy :: suspicious_else_formatting)]
{
#[allow(unknown_lints, unreachable_code, clippy ::
diverging_sub_expression, clippy :: empty_loop, clippy ::
let_unit_value, clippy :: let_with_type_underscore, clippy ::
needless_return, clippy :: unreachable)]
if false {
let __tracing_attr_fake_return: Result<Decl<'ra>, Determinacy> =
loop {};
return __tracing_attr_fake_return;
}
{
match module {
ModuleOrUniformRoot::Module(module) => {
if ns == TypeNS {
if ident.name == kw::SelfLower {
return Ok(module.self_decl.unwrap());
}
if ident.name == kw::Super &&
let Some(module) =
self.resolve_super_in_module(ident, Some(module),
parent_scope) {
return Ok(module.self_decl.unwrap());
}
}
let (ident_key, def) =
IdentKey::new_adjusted(ident, module.expansion);
let adjusted_parent_scope =
match def {
Some(def) =>
ParentScope {
module: self.expn_def_scope(def),
..*parent_scope
},
None => *parent_scope,
};
self.resolve_ident_in_scope_set_inner(ident_key, ident.span,
ScopeSet::Module(ns, module), &adjusted_parent_scope,
finalize, ignore_decl, ignore_import)
}
ModuleOrUniformRoot::OpenModule(sym) => {
let open_ns_name =
::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0}::{1}", sym.as_str(),
ident.name))
});
let ns_ident =
IdentKey::with_root_ctxt(Symbol::intern(&open_ns_name));
match self.extern_prelude_get_flag(ns_ident, ident.span,
finalize.is_some()) {
Some(decl) => Ok(decl),
None => Err(Determinacy::Determined),
}
}
ModuleOrUniformRoot::ModuleAndExternPrelude(module) =>
self.resolve_ident_in_scope_set(ident,
ScopeSet::ModuleAndExternPrelude(ns, module), parent_scope,
finalize, ignore_decl, ignore_import),
ModuleOrUniformRoot::ExternPrelude => {
if ns != TypeNS {
Err(Determined)
} else {
self.resolve_ident_in_scope_set_inner(IdentKey::new_adjusted(ident,
ExpnId::root()).0, ident.span, ScopeSet::ExternPrelude,
parent_scope, finalize, ignore_decl, ignore_import)
}
}
ModuleOrUniformRoot::CurrentScope => {
if ns == TypeNS {
if ident.name == kw::SelfLower {
let mut ctxt = ident.span.ctxt().normalize_to_macros_2_0();
let module =
self.resolve_self(&mut ctxt, parent_scope.module);
return Ok(module.self_decl.unwrap());
}
if ident.name == kw::Super &&
let Some(module) =
self.resolve_super_in_module(ident, None, parent_scope) {
return Ok(module.self_decl.unwrap());
}
if ident.name == kw::Crate || ident.name == kw::DollarCrate
|| self.path_root_is_crate_root(ident) {
let module = self.resolve_crate_root(ident);
return Ok(module.self_decl.unwrap());
} else if ident.name == kw::Super {}
}
self.resolve_ident_in_scope_set(ident, ScopeSet::All(ns),
parent_scope, finalize, ignore_decl, ignore_import)
}
}
}
}
}#[instrument(level = "debug", skip(self))]
978 pub(crate) fn resolve_ident_in_module<'r>(
979 self: CmResolver<'r, 'ra, 'tcx>,
980 module: ModuleOrUniformRoot<'ra>,
981 ident: Ident,
982 ns: Namespace,
983 parent_scope: &ParentScope<'ra>,
984 finalize: Option<Finalize>,
985 ignore_decl: Option<Decl<'ra>>,
986 ignore_import: Option<Import<'ra>>,
987 ) -> Result<Decl<'ra>, Determinacy> {
988 match module {
989 ModuleOrUniformRoot::Module(module) => {
990 if ns == TypeNS {
991 if ident.name == kw::SelfLower {
992 return Ok(module.self_decl.unwrap());
993 }
994 if ident.name == kw::Super
995 && let Some(module) =
996 self.resolve_super_in_module(ident, Some(module), parent_scope)
997 {
998 return Ok(module.self_decl.unwrap());
999 }
1000 }
1001
1002 let (ident_key, def) = IdentKey::new_adjusted(ident, module.expansion);
1003 let adjusted_parent_scope = match def {
1004 Some(def) => ParentScope { module: self.expn_def_scope(def), ..*parent_scope },
1005 None => *parent_scope,
1006 };
1007 self.resolve_ident_in_scope_set_inner(
1008 ident_key,
1009 ident.span,
1010 ScopeSet::Module(ns, module),
1011 &adjusted_parent_scope,
1012 finalize,
1013 ignore_decl,
1014 ignore_import,
1015 )
1016 }
1017 ModuleOrUniformRoot::OpenModule(sym) => {
1018 let open_ns_name = format!("{}::{}", sym.as_str(), ident.name);
1019 let ns_ident = IdentKey::with_root_ctxt(Symbol::intern(&open_ns_name));
1020 match self.extern_prelude_get_flag(ns_ident, ident.span, finalize.is_some()) {
1021 Some(decl) => Ok(decl),
1022 None => Err(Determinacy::Determined),
1023 }
1024 }
1025 ModuleOrUniformRoot::ModuleAndExternPrelude(module) => self.resolve_ident_in_scope_set(
1026 ident,
1027 ScopeSet::ModuleAndExternPrelude(ns, module),
1028 parent_scope,
1029 finalize,
1030 ignore_decl,
1031 ignore_import,
1032 ),
1033 ModuleOrUniformRoot::ExternPrelude => {
1034 if ns != TypeNS {
1035 Err(Determined)
1036 } else {
1037 self.resolve_ident_in_scope_set_inner(
1038 IdentKey::new_adjusted(ident, ExpnId::root()).0,
1039 ident.span,
1040 ScopeSet::ExternPrelude,
1041 parent_scope,
1042 finalize,
1043 ignore_decl,
1044 ignore_import,
1045 )
1046 }
1047 }
1048 ModuleOrUniformRoot::CurrentScope => {
1049 if ns == TypeNS {
1050 if ident.name == kw::SelfLower {
1051 let mut ctxt = ident.span.ctxt().normalize_to_macros_2_0();
1052 let module = self.resolve_self(&mut ctxt, parent_scope.module);
1053 return Ok(module.self_decl.unwrap());
1054 }
1055 if ident.name == kw::Super
1056 && let Some(module) =
1057 self.resolve_super_in_module(ident, None, parent_scope)
1058 {
1059 return Ok(module.self_decl.unwrap());
1060 }
1061 if ident.name == kw::Crate
1062 || ident.name == kw::DollarCrate
1063 || self.path_root_is_crate_root(ident)
1064 {
1065 let module = self.resolve_crate_root(ident);
1066 return Ok(module.self_decl.unwrap());
1067 } else if ident.name == kw::Super {
1068 }
1072 }
1073
1074 self.resolve_ident_in_scope_set(
1075 ident,
1076 ScopeSet::All(ns),
1077 parent_scope,
1078 finalize,
1079 ignore_decl,
1080 ignore_import,
1081 )
1082 }
1083 }
1084 }
1085
1086 fn resolve_ident_in_module_non_globs_unadjusted<'r>(
1088 mut self: CmResolver<'r, 'ra, 'tcx>,
1089 module: Module<'ra>,
1090 ident: IdentKey,
1091 orig_ident_span: Span,
1092 ns: Namespace,
1093 parent_scope: &ParentScope<'ra>,
1094 shadowing: Shadowing,
1095 finalize: Option<Finalize>,
1096 ignore_decl: Option<Decl<'ra>>,
1099 ignore_import: Option<Import<'ra>>,
1100 ) -> Result<Decl<'ra>, ControlFlow<Determinacy, Determinacy>> {
1101 let key = BindingKey::new(ident, ns);
1102 let resolution = &*self
1106 .resolution_or_default(module, key, orig_ident_span)
1107 .try_borrow_mut_unchecked()
1108 .map_err(|_| ControlFlow::Continue(Determined))?;
1109
1110 let binding = resolution.non_glob_decl.filter(|b| Some(*b) != ignore_decl);
1111
1112 if let Some(finalize) = finalize {
1113 return self.get_mut().finalize_module_binding(
1114 ident,
1115 orig_ident_span,
1116 binding,
1117 parent_scope,
1118 finalize,
1119 shadowing,
1120 );
1121 }
1122
1123 if let Some(binding) = binding {
1125 let accessible = self.is_accessible_from(binding.vis(), parent_scope.module);
1126 return if accessible { Ok(binding) } else { Err(ControlFlow::Break(Determined)) };
1127 }
1128
1129 if self.reborrow().single_import_can_define_name(
1131 &resolution,
1132 None,
1133 ns,
1134 ignore_import,
1135 ignore_decl,
1136 parent_scope,
1137 ) {
1138 return Err(ControlFlow::Break(Undetermined));
1139 }
1140
1141 if !module.unexpanded_invocations.borrow().is_empty() {
1143 return Err(ControlFlow::Continue(Undetermined));
1144 }
1145
1146 Err(ControlFlow::Continue(Determined))
1148 }
1149
1150 fn resolve_ident_in_module_globs_unadjusted<'r>(
1152 mut self: CmResolver<'r, 'ra, 'tcx>,
1153 module: LocalModule<'ra>,
1154 ident: IdentKey,
1155 orig_ident_span: Span,
1156 ns: Namespace,
1157 parent_scope: &ParentScope<'ra>,
1158 shadowing: Shadowing,
1159 finalize: Option<Finalize>,
1160 ignore_decl: Option<Decl<'ra>>,
1161 ignore_import: Option<Import<'ra>>,
1162 ) -> Result<Decl<'ra>, ControlFlow<Determinacy, Determinacy>> {
1163 let key = BindingKey::new(ident, ns);
1164 let resolution = &*self
1168 .resolution_or_default(module.to_module(), key, orig_ident_span)
1169 .try_borrow_mut_unchecked()
1170 .map_err(|_| ControlFlow::Continue(Determined))?;
1171
1172 let binding = resolution.glob_decl.filter(|b| Some(*b) != ignore_decl);
1173
1174 if let Some(finalize) = finalize {
1175 return self.get_mut().finalize_module_binding(
1176 ident,
1177 orig_ident_span,
1178 binding,
1179 parent_scope,
1180 finalize,
1181 shadowing,
1182 );
1183 }
1184
1185 if self.reborrow().single_import_can_define_name(
1188 &resolution,
1189 binding,
1190 ns,
1191 ignore_import,
1192 ignore_decl,
1193 parent_scope,
1194 ) {
1195 return Err(ControlFlow::Break(Undetermined));
1196 }
1197
1198 if let Some(binding) = binding {
1211 return if binding.determined() || ns == MacroNS || shadowing == Shadowing::Restricted {
1212 let accessible = self.is_accessible_from(binding.vis(), parent_scope.module);
1213 if accessible { Ok(binding) } else { Err(ControlFlow::Break(Determined)) }
1214 } else {
1215 Err(ControlFlow::Break(Undetermined))
1216 };
1217 }
1218
1219 if !module.unexpanded_invocations.borrow().is_empty() {
1227 return Err(ControlFlow::Continue(Undetermined));
1228 }
1229
1230 for glob_import in module.globs.borrow().iter() {
1233 if ignore_import == Some(*glob_import) {
1234 continue;
1235 }
1236 if !self.is_accessible_from(glob_import.vis, parent_scope.module) {
1237 continue;
1238 }
1239 let module = match glob_import.imported_module.get() {
1240 Some(ModuleOrUniformRoot::Module(module)) => module,
1241 Some(_) => continue,
1242 None => return Err(ControlFlow::Continue(Undetermined)),
1243 };
1244 let tmp_parent_scope;
1245 let (mut adjusted_parent_scope, mut adjusted_ident) = (parent_scope, ident);
1246 match adjusted_ident
1247 .ctxt
1248 .update_unchecked(|ctxt| ctxt.glob_adjust(module.expansion, glob_import.span))
1249 {
1250 Some(Some(def)) => {
1251 tmp_parent_scope =
1252 ParentScope { module: self.expn_def_scope(def), ..*parent_scope };
1253 adjusted_parent_scope = &tmp_parent_scope;
1254 }
1255 Some(None) => {}
1256 None => continue,
1257 };
1258 let result = self.reborrow().resolve_ident_in_scope_set_inner(
1259 adjusted_ident,
1260 orig_ident_span,
1261 ScopeSet::Module(ns, module),
1262 adjusted_parent_scope,
1263 None,
1264 ignore_decl,
1265 ignore_import,
1266 );
1267
1268 match result {
1269 Err(Determined) => continue,
1270 Ok(binding)
1271 if !self.is_accessible_from(binding.vis(), glob_import.parent_scope.module) =>
1272 {
1273 continue;
1274 }
1275 Ok(_) | Err(Undetermined) => return Err(ControlFlow::Continue(Undetermined)),
1276 }
1277 }
1278
1279 Err(ControlFlow::Continue(Determined))
1281 }
1282
1283 fn finalize_module_binding(
1284 &mut self,
1285 ident: IdentKey,
1286 orig_ident_span: Span,
1287 binding: Option<Decl<'ra>>,
1288 parent_scope: &ParentScope<'ra>,
1289 finalize: Finalize,
1290 shadowing: Shadowing,
1291 ) -> Result<Decl<'ra>, ControlFlow<Determinacy, Determinacy>> {
1292 let Finalize { path_span, report_private, used, root_span, .. } = finalize;
1293
1294 let Some(binding) = binding else {
1295 return Err(ControlFlow::Continue(Determined));
1296 };
1297
1298 let ident = ident.orig(orig_ident_span);
1299 if !self.is_accessible_from(binding.vis(), parent_scope.module) {
1300 if report_private {
1301 self.privacy_errors.push(PrivacyError {
1302 ident,
1303 decl: binding,
1304 dedup_span: path_span,
1305 outermost_res: None,
1306 source: None,
1307 parent_scope: *parent_scope,
1308 single_nested: path_span != root_span,
1309 });
1310 } else {
1311 return Err(ControlFlow::Break(Determined));
1312 }
1313 }
1314
1315 if shadowing == Shadowing::Unrestricted
1316 && binding.expansion != LocalExpnId::ROOT
1317 && let DeclKind::Import { import, .. } = binding.kind
1318 && #[allow(non_exhaustive_omitted_patterns)] match import.kind {
ImportKind::MacroExport => true,
_ => false,
}matches!(import.kind, ImportKind::MacroExport)
1319 {
1320 self.macro_expanded_macro_export_errors.insert((path_span, binding.span));
1321 }
1322
1323 self.record_use(ident, binding, used);
1324 return Ok(binding);
1325 }
1326
1327 fn single_import_can_define_name<'r>(
1330 mut self: CmResolver<'r, 'ra, 'tcx>,
1331 resolution: &NameResolution<'ra>,
1332 binding: Option<Decl<'ra>>,
1333 ns: Namespace,
1334 ignore_import: Option<Import<'ra>>,
1335 ignore_decl: Option<Decl<'ra>>,
1336 parent_scope: &ParentScope<'ra>,
1337 ) -> bool {
1338 for single_import in &resolution.single_imports {
1339 if let Some(decl) = resolution.non_glob_decl
1340 && let DeclKind::Import { import, .. } = decl.kind
1341 && import == *single_import
1342 {
1343 continue;
1346 }
1347 if ignore_import == Some(*single_import) {
1348 continue;
1349 }
1350 if !self.is_accessible_from(single_import.vis, parent_scope.module) {
1351 continue;
1352 }
1353 if let Some(ignored) = ignore_decl
1354 && let DeclKind::Import { import, .. } = ignored.kind
1355 && import == *single_import
1356 {
1357 continue;
1358 }
1359
1360 let Some(module) = single_import.imported_module.get() else {
1361 return true;
1362 };
1363 let ImportKind::Single { source, target, decls, .. } = &single_import.kind else {
1364 ::core::panicking::panic("internal error: entered unreachable code");unreachable!();
1365 };
1366 if source != target {
1367 if decls.iter().all(|d| d.get().decl().is_none()) {
1368 return true;
1369 } else if decls[ns].get().decl().is_none() && binding.is_some() {
1370 return true;
1371 }
1372 }
1373
1374 match self.reborrow().resolve_ident_in_module(
1375 module,
1376 *source,
1377 ns,
1378 &single_import.parent_scope,
1379 None,
1380 ignore_decl,
1381 None,
1382 ) {
1383 Err(Determined) => continue,
1384 Ok(binding)
1385 if !self
1386 .is_accessible_from(binding.vis(), single_import.parent_scope.module) =>
1387 {
1388 continue;
1389 }
1390 Ok(_) | Err(Undetermined) => return true,
1391 }
1392 }
1393
1394 false
1395 }
1396
1397 #[allow(clippy :: suspicious_else_formatting)]
{
let __tracing_attr_span;
let __tracing_attr_guard;
if ::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() ||
{ false } {
__tracing_attr_span =
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("validate_res_from_ribs",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(1398u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["rib_index",
"rib_ident", "res", "finalize", "original_rib_ident_def",
"diag_metadata"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::SPAN)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let mut interest = ::tracing::subscriber::Interest::never();
if ::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{ interest = __CALLSITE.interest(); !interest.is_never() }
&&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest) {
let meta = __CALLSITE.metadata();
::tracing::Span::new(meta,
&{
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = meta.fields().iter();
meta.fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&rib_index as
&dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&rib_ident)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&res)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&finalize)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&original_rib_ident_def)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&diag_metadata)
as &dyn Value))])
})
} else {
let span =
::tracing::__macro_support::__disabled_span(__CALLSITE.metadata());
{};
span
}
};
__tracing_attr_guard = __tracing_attr_span.enter();
}
#[warn(clippy :: suspicious_else_formatting)]
{
#[allow(unknown_lints, unreachable_code, clippy ::
diverging_sub_expression, clippy :: empty_loop, clippy ::
let_unit_value, clippy :: let_with_type_underscore, clippy ::
needless_return, clippy :: unreachable)]
if false {
let __tracing_attr_fake_return: Res = loop {};
return __tracing_attr_fake_return;
}
{
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_resolve/src/ident.rs:1409",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(1409u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("validate_res_from_ribs({0:?})",
res) as &dyn Value))])
});
} else { ; }
};
let ribs = &all_ribs[rib_index + 1..];
if let RibKind::ForwardGenericParamBan(reason) =
all_ribs[rib_index].kind {
if let Some(span) = finalize {
let res_error =
if rib_ident.name == kw::SelfUpper {
ResolutionError::ForwardDeclaredSelf(reason)
} else {
ResolutionError::ForwardDeclaredGenericParam(rib_ident.name,
reason)
};
self.report_error(span, res_error);
}
match (&res, &Res::Err) {
(left_val, right_val) => {
if !(*left_val == *right_val) {
let kind = ::core::panicking::AssertKind::Eq;
::core::panicking::assert_failed(kind, &*left_val,
&*right_val, ::core::option::Option::None);
}
}
};
return Res::Err;
}
match res {
Res::Local(_) => {
use ResolutionError::*;
let mut res_err = None;
for rib in ribs {
match rib.kind {
RibKind::Normal | RibKind::Block(..) |
RibKind::FnOrCoroutine | RibKind::Module(..) |
RibKind::MacroDefinition(..) |
RibKind::ForwardGenericParamBan(_) => {}
RibKind::Item(..) | RibKind::AssocItem => {
if let Some(span) = finalize {
res_err =
Some((span, CannotCaptureDynamicEnvironmentInFnItem));
}
}
RibKind::ConstantItem(_, item) => {
if let Some(span) = finalize {
let (span, resolution_error) =
match item {
None if rib_ident.name == kw::SelfLower => {
(span, LowercaseSelf)
}
None => {
let sm = self.tcx.sess.source_map();
let type_span =
match sm.span_followed_by(original_rib_ident_def.span, ":")
{
None => { Some(original_rib_ident_def.span.shrink_to_hi()) }
Some(_) => None,
};
(rib_ident.span,
AttemptToUseNonConstantValueInConstant {
ident: original_rib_ident_def,
suggestion: "const",
current: "let",
type_span,
})
}
Some((ident, kind)) =>
(span,
AttemptToUseNonConstantValueInConstant {
ident,
suggestion: "let",
current: kind.as_str(),
type_span: None,
}),
};
self.report_error(span, resolution_error);
}
return Res::Err;
}
RibKind::ConstParamTy => {
if let Some(span) = finalize {
self.report_error(span,
ParamInTyOfConstParam { name: rib_ident.name });
}
return Res::Err;
}
RibKind::InlineAsmSym => {
if let Some(span) = finalize {
self.report_error(span, InvalidAsmSym);
}
return Res::Err;
}
}
}
if let Some((span, res_err)) = res_err {
self.report_error(span, res_err);
return Res::Err;
}
}
Res::Def(DefKind::TyParam, _) | Res::SelfTyParam { .. } |
Res::SelfTyAlias { .. } => {
for rib in ribs {
let (has_generic_params, def_kind) =
match rib.kind {
RibKind::Normal | RibKind::Block(..) |
RibKind::FnOrCoroutine | RibKind::Module(..) |
RibKind::MacroDefinition(..) | RibKind::InlineAsmSym |
RibKind::AssocItem | RibKind::ForwardGenericParamBan(_) => {
continue;
}
RibKind::ConstParamTy => {
if !self.tcx.features().generic_const_parameter_types() {
if let Some(span) = finalize {
self.report_error(span,
ResolutionError::ParamInTyOfConstParam {
name: rib_ident.name,
});
}
return Res::Err;
} else { continue; }
}
RibKind::ConstantItem(trivial, _) => {
if let ConstantHasGenerics::No(cause) = trivial &&
!#[allow(non_exhaustive_omitted_patterns)] match res {
Res::SelfTyAlias { .. } => true,
_ => false,
} {
if let Some(span) = finalize {
let error =
match cause {
NoConstantGenericsReason::IsEnumDiscriminant => {
ResolutionError::ParamInEnumDiscriminant {
name: rib_ident.name,
param_kind: ParamKindInEnumDiscriminant::Type,
}
}
NoConstantGenericsReason::NonTrivialConstArg => {
ResolutionError::ParamInNonTrivialAnonConst {
is_gca: self.tcx.features().generic_const_args(),
name: rib_ident.name,
param_kind: ParamKindInNonTrivialAnonConst::Type,
}
}
};
let _: ErrorGuaranteed = self.report_error(span, error);
}
return Res::Err;
}
continue;
}
RibKind::Item(has_generic_params, def_kind) => {
(has_generic_params, def_kind)
}
};
if let Some(span) = finalize {
let item =
if let Some(diag_metadata) = diag_metadata &&
let Some(current_item) = diag_metadata.current_item {
let label_span =
current_item.kind.ident().map(|i|
i.span).unwrap_or(current_item.span);
Some((label_span, current_item.span,
current_item.kind.clone()))
} else { None };
self.report_error(span,
ResolutionError::GenericParamsFromOuterItem {
outer_res: res,
has_generic_params,
def_kind,
inner_item: item,
current_self_ty: diag_metadata.and_then(|m|
m.current_self_type.as_ref()).and_then(|ty|
{
self.tcx.sess.source_map().span_to_snippet(ty.span).ok()
}),
});
}
return Res::Err;
}
}
Res::Def(DefKind::ConstParam, _) => {
for rib in ribs {
let (has_generic_params, def_kind) =
match rib.kind {
RibKind::Normal | RibKind::Block(..) |
RibKind::FnOrCoroutine | RibKind::Module(..) |
RibKind::MacroDefinition(..) | RibKind::InlineAsmSym |
RibKind::AssocItem | RibKind::ForwardGenericParamBan(_) =>
continue,
RibKind::ConstParamTy => {
if !self.tcx.features().generic_const_parameter_types() {
if let Some(span) = finalize {
self.report_error(span,
ResolutionError::ParamInTyOfConstParam {
name: rib_ident.name,
});
}
return Res::Err;
} else { continue; }
}
RibKind::ConstantItem(trivial, _) => {
if let ConstantHasGenerics::No(cause) = trivial {
if let Some(span) = finalize {
let error =
match cause {
NoConstantGenericsReason::IsEnumDiscriminant => {
ResolutionError::ParamInEnumDiscriminant {
name: rib_ident.name,
param_kind: ParamKindInEnumDiscriminant::Const,
}
}
NoConstantGenericsReason::NonTrivialConstArg => {
ResolutionError::ParamInNonTrivialAnonConst {
is_gca: self.tcx.features().generic_const_args(),
name: rib_ident.name,
param_kind: ParamKindInNonTrivialAnonConst::Const {
name: rib_ident.name,
},
}
}
};
self.report_error(span, error);
}
return Res::Err;
}
continue;
}
RibKind::Item(has_generic_params, def_kind) => {
(has_generic_params, def_kind)
}
};
if let Some(span) = finalize {
let item =
if let Some(diag_metadata) = diag_metadata &&
let Some(current_item) = diag_metadata.current_item {
let label_span =
current_item.kind.ident().map(|i|
i.span).unwrap_or(current_item.span);
Some((label_span, current_item.span,
current_item.kind.clone()))
} else { None };
self.report_error(span,
ResolutionError::GenericParamsFromOuterItem {
outer_res: res,
has_generic_params,
def_kind,
inner_item: item,
current_self_ty: diag_metadata.and_then(|m|
m.current_self_type.as_ref()).and_then(|ty|
{
self.tcx.sess.source_map().span_to_snippet(ty.span).ok()
}),
});
}
return Res::Err;
}
}
_ => {}
}
res
}
}
}#[instrument(level = "debug", skip(self, all_ribs))]
1399 fn validate_res_from_ribs(
1400 &mut self,
1401 rib_index: usize,
1402 rib_ident: Ident,
1403 res: Res,
1404 finalize: Option<Span>,
1405 original_rib_ident_def: Ident,
1406 all_ribs: &[Rib<'ra>],
1407 diag_metadata: Option<&DiagMetadata<'_>>,
1408 ) -> Res {
1409 debug!("validate_res_from_ribs({:?})", res);
1410 let ribs = &all_ribs[rib_index + 1..];
1411
1412 if let RibKind::ForwardGenericParamBan(reason) = all_ribs[rib_index].kind {
1415 if let Some(span) = finalize {
1416 let res_error = if rib_ident.name == kw::SelfUpper {
1417 ResolutionError::ForwardDeclaredSelf(reason)
1418 } else {
1419 ResolutionError::ForwardDeclaredGenericParam(rib_ident.name, reason)
1420 };
1421 self.report_error(span, res_error);
1422 }
1423 assert_eq!(res, Res::Err);
1424 return Res::Err;
1425 }
1426
1427 match res {
1428 Res::Local(_) => {
1429 use ResolutionError::*;
1430 let mut res_err = None;
1431
1432 for rib in ribs {
1433 match rib.kind {
1434 RibKind::Normal
1435 | RibKind::Block(..)
1436 | RibKind::FnOrCoroutine
1437 | RibKind::Module(..)
1438 | RibKind::MacroDefinition(..)
1439 | RibKind::ForwardGenericParamBan(_) => {
1440 }
1442 RibKind::Item(..) | RibKind::AssocItem => {
1443 if let Some(span) = finalize {
1447 res_err = Some((span, CannotCaptureDynamicEnvironmentInFnItem));
1452 }
1453 }
1454 RibKind::ConstantItem(_, item) => {
1455 if let Some(span) = finalize {
1457 let (span, resolution_error) = match item {
1458 None if rib_ident.name == kw::SelfLower => {
1459 (span, LowercaseSelf)
1460 }
1461 None => {
1462 let sm = self.tcx.sess.source_map();
1468 let type_span = match sm
1469 .span_followed_by(original_rib_ident_def.span, ":")
1470 {
1471 None => {
1472 Some(original_rib_ident_def.span.shrink_to_hi())
1473 }
1474 Some(_) => None,
1475 };
1476 (
1477 rib_ident.span,
1478 AttemptToUseNonConstantValueInConstant {
1479 ident: original_rib_ident_def,
1480 suggestion: "const",
1481 current: "let",
1482 type_span,
1483 },
1484 )
1485 }
1486 Some((ident, kind)) => (
1487 span,
1488 AttemptToUseNonConstantValueInConstant {
1489 ident,
1490 suggestion: "let",
1491 current: kind.as_str(),
1492 type_span: None,
1493 },
1494 ),
1495 };
1496 self.report_error(span, resolution_error);
1497 }
1498 return Res::Err;
1499 }
1500 RibKind::ConstParamTy => {
1501 if let Some(span) = finalize {
1502 self.report_error(
1503 span,
1504 ParamInTyOfConstParam { name: rib_ident.name },
1505 );
1506 }
1507 return Res::Err;
1508 }
1509 RibKind::InlineAsmSym => {
1510 if let Some(span) = finalize {
1511 self.report_error(span, InvalidAsmSym);
1512 }
1513 return Res::Err;
1514 }
1515 }
1516 }
1517 if let Some((span, res_err)) = res_err {
1518 self.report_error(span, res_err);
1519 return Res::Err;
1520 }
1521 }
1522 Res::Def(DefKind::TyParam, _) | Res::SelfTyParam { .. } | Res::SelfTyAlias { .. } => {
1523 for rib in ribs {
1524 let (has_generic_params, def_kind) = match rib.kind {
1525 RibKind::Normal
1526 | RibKind::Block(..)
1527 | RibKind::FnOrCoroutine
1528 | RibKind::Module(..)
1529 | RibKind::MacroDefinition(..)
1530 | RibKind::InlineAsmSym
1531 | RibKind::AssocItem
1532 | RibKind::ForwardGenericParamBan(_) => {
1533 continue;
1535 }
1536
1537 RibKind::ConstParamTy => {
1538 if !self.tcx.features().generic_const_parameter_types() {
1539 if let Some(span) = finalize {
1540 self.report_error(
1541 span,
1542 ResolutionError::ParamInTyOfConstParam {
1543 name: rib_ident.name,
1544 },
1545 );
1546 }
1547 return Res::Err;
1548 } else {
1549 continue;
1550 }
1551 }
1552
1553 RibKind::ConstantItem(trivial, _) => {
1554 if let ConstantHasGenerics::No(cause) = trivial
1555 && !matches!(res, Res::SelfTyAlias { .. })
1556 {
1557 if let Some(span) = finalize {
1558 let error = match cause {
1559 NoConstantGenericsReason::IsEnumDiscriminant => {
1560 ResolutionError::ParamInEnumDiscriminant {
1561 name: rib_ident.name,
1562 param_kind: ParamKindInEnumDiscriminant::Type,
1563 }
1564 }
1565 NoConstantGenericsReason::NonTrivialConstArg => {
1566 ResolutionError::ParamInNonTrivialAnonConst {
1567 is_gca: self.tcx.features().generic_const_args(),
1568 name: rib_ident.name,
1569 param_kind: ParamKindInNonTrivialAnonConst::Type,
1570 }
1571 }
1572 };
1573 let _: ErrorGuaranteed = self.report_error(span, error);
1574 }
1575
1576 return Res::Err;
1577 }
1578
1579 continue;
1580 }
1581
1582 RibKind::Item(has_generic_params, def_kind) => {
1584 (has_generic_params, def_kind)
1585 }
1586 };
1587
1588 if let Some(span) = finalize {
1589 let item = if let Some(diag_metadata) = diag_metadata
1590 && let Some(current_item) = diag_metadata.current_item
1591 {
1592 let label_span = current_item
1593 .kind
1594 .ident()
1595 .map(|i| i.span)
1596 .unwrap_or(current_item.span);
1597 Some((label_span, current_item.span, current_item.kind.clone()))
1598 } else {
1599 None
1600 };
1601 self.report_error(
1602 span,
1603 ResolutionError::GenericParamsFromOuterItem {
1604 outer_res: res,
1605 has_generic_params,
1606 def_kind,
1607 inner_item: item,
1608 current_self_ty: diag_metadata
1609 .and_then(|m| m.current_self_type.as_ref())
1610 .and_then(|ty| {
1611 self.tcx.sess.source_map().span_to_snippet(ty.span).ok()
1612 }),
1613 },
1614 );
1615 }
1616 return Res::Err;
1617 }
1618 }
1619 Res::Def(DefKind::ConstParam, _) => {
1620 for rib in ribs {
1621 let (has_generic_params, def_kind) = match rib.kind {
1622 RibKind::Normal
1623 | RibKind::Block(..)
1624 | RibKind::FnOrCoroutine
1625 | RibKind::Module(..)
1626 | RibKind::MacroDefinition(..)
1627 | RibKind::InlineAsmSym
1628 | RibKind::AssocItem
1629 | RibKind::ForwardGenericParamBan(_) => continue,
1630
1631 RibKind::ConstParamTy => {
1632 if !self.tcx.features().generic_const_parameter_types() {
1633 if let Some(span) = finalize {
1634 self.report_error(
1635 span,
1636 ResolutionError::ParamInTyOfConstParam {
1637 name: rib_ident.name,
1638 },
1639 );
1640 }
1641 return Res::Err;
1642 } else {
1643 continue;
1644 }
1645 }
1646
1647 RibKind::ConstantItem(trivial, _) => {
1648 if let ConstantHasGenerics::No(cause) = trivial {
1649 if let Some(span) = finalize {
1650 let error = match cause {
1651 NoConstantGenericsReason::IsEnumDiscriminant => {
1652 ResolutionError::ParamInEnumDiscriminant {
1653 name: rib_ident.name,
1654 param_kind: ParamKindInEnumDiscriminant::Const,
1655 }
1656 }
1657 NoConstantGenericsReason::NonTrivialConstArg => {
1658 ResolutionError::ParamInNonTrivialAnonConst {
1659 is_gca: self.tcx.features().generic_const_args(),
1660 name: rib_ident.name,
1661 param_kind: ParamKindInNonTrivialAnonConst::Const {
1662 name: rib_ident.name,
1663 },
1664 }
1665 }
1666 };
1667 self.report_error(span, error);
1668 }
1669
1670 return Res::Err;
1671 }
1672
1673 continue;
1674 }
1675
1676 RibKind::Item(has_generic_params, def_kind) => {
1677 (has_generic_params, def_kind)
1678 }
1679 };
1680
1681 if let Some(span) = finalize {
1683 let item = if let Some(diag_metadata) = diag_metadata
1684 && let Some(current_item) = diag_metadata.current_item
1685 {
1686 let label_span = current_item
1687 .kind
1688 .ident()
1689 .map(|i| i.span)
1690 .unwrap_or(current_item.span);
1691 Some((label_span, current_item.span, current_item.kind.clone()))
1692 } else {
1693 None
1694 };
1695 self.report_error(
1696 span,
1697 ResolutionError::GenericParamsFromOuterItem {
1698 outer_res: res,
1699 has_generic_params,
1700 def_kind,
1701 inner_item: item,
1702 current_self_ty: diag_metadata
1703 .and_then(|m| m.current_self_type.as_ref())
1704 .and_then(|ty| {
1705 self.tcx.sess.source_map().span_to_snippet(ty.span).ok()
1706 }),
1707 },
1708 );
1709 }
1710 return Res::Err;
1711 }
1712 }
1713 _ => {}
1714 }
1715
1716 res
1717 }
1718
1719 #[allow(clippy :: suspicious_else_formatting)]
{
let __tracing_attr_span;
let __tracing_attr_guard;
if ::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() ||
{ false } {
__tracing_attr_span =
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("maybe_resolve_path",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(1719u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["path", "opt_ns",
"parent_scope", "ignore_import"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::SPAN)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let mut interest = ::tracing::subscriber::Interest::never();
if ::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{ interest = __CALLSITE.interest(); !interest.is_never() }
&&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest) {
let meta = __CALLSITE.metadata();
::tracing::Span::new(meta,
&{
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = meta.fields().iter();
meta.fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&path)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&opt_ns)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&parent_scope)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ignore_import)
as &dyn Value))])
})
} else {
let span =
::tracing::__macro_support::__disabled_span(__CALLSITE.metadata());
{};
span
}
};
__tracing_attr_guard = __tracing_attr_span.enter();
}
#[warn(clippy :: suspicious_else_formatting)]
{
#[allow(unknown_lints, unreachable_code, clippy ::
diverging_sub_expression, clippy :: empty_loop, clippy ::
let_unit_value, clippy :: let_with_type_underscore, clippy ::
needless_return, clippy :: unreachable)]
if false {
let __tracing_attr_fake_return: PathResult<'ra> = loop {};
return __tracing_attr_fake_return;
}
{
self.resolve_path_with_ribs(path, opt_ns, parent_scope, None,
None, None, None, ignore_import, None)
}
}
}#[instrument(level = "debug", skip(self))]
1720 pub(crate) fn maybe_resolve_path<'r>(
1721 self: CmResolver<'r, 'ra, 'tcx>,
1722 path: &[Segment],
1723 opt_ns: Option<Namespace>, parent_scope: &ParentScope<'ra>,
1725 ignore_import: Option<Import<'ra>>,
1726 ) -> PathResult<'ra> {
1727 self.resolve_path_with_ribs(
1728 path,
1729 opt_ns,
1730 parent_scope,
1731 None,
1732 None,
1733 None,
1734 None,
1735 ignore_import,
1736 None,
1737 )
1738 }
1739 #[allow(clippy :: suspicious_else_formatting)]
{
let __tracing_attr_span;
let __tracing_attr_guard;
if ::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() ||
{ false } {
__tracing_attr_span =
{
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("resolve_path",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(1739u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["path", "opt_ns",
"parent_scope", "finalize", "ignore_decl", "ignore_import"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::SPAN)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let mut interest = ::tracing::subscriber::Interest::never();
if ::tracing::Level::DEBUG <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{ interest = __CALLSITE.interest(); !interest.is_never() }
&&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest) {
let meta = __CALLSITE.metadata();
::tracing::Span::new(meta,
&{
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = meta.fields().iter();
meta.fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&path)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&opt_ns)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&parent_scope)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&finalize)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ignore_decl)
as &dyn Value)),
(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&::tracing::field::debug(&ignore_import)
as &dyn Value))])
})
} else {
let span =
::tracing::__macro_support::__disabled_span(__CALLSITE.metadata());
{};
span
}
};
__tracing_attr_guard = __tracing_attr_span.enter();
}
#[warn(clippy :: suspicious_else_formatting)]
{
#[allow(unknown_lints, unreachable_code, clippy ::
diverging_sub_expression, clippy :: empty_loop, clippy ::
let_unit_value, clippy :: let_with_type_underscore, clippy ::
needless_return, clippy :: unreachable)]
if false {
let __tracing_attr_fake_return: PathResult<'ra> = loop {};
return __tracing_attr_fake_return;
}
{
self.resolve_path_with_ribs(path, opt_ns, parent_scope, None,
finalize, None, ignore_decl, ignore_import, None)
}
}
}#[instrument(level = "debug", skip(self))]
1740 pub(crate) fn resolve_path<'r>(
1741 self: CmResolver<'r, 'ra, 'tcx>,
1742 path: &[Segment],
1743 opt_ns: Option<Namespace>, parent_scope: &ParentScope<'ra>,
1745 finalize: Option<Finalize>,
1746 ignore_decl: Option<Decl<'ra>>,
1747 ignore_import: Option<Import<'ra>>,
1748 ) -> PathResult<'ra> {
1749 self.resolve_path_with_ribs(
1750 path,
1751 opt_ns,
1752 parent_scope,
1753 None,
1754 finalize,
1755 None,
1756 ignore_decl,
1757 ignore_import,
1758 None,
1759 )
1760 }
1761
1762 pub(crate) fn resolve_path_with_ribs<'r>(
1763 mut self: CmResolver<'r, 'ra, 'tcx>,
1764 path: &[Segment],
1765 opt_ns: Option<Namespace>, parent_scope: &ParentScope<'ra>,
1767 source: Option<PathSource<'_, '_, '_>>,
1768 finalize: Option<Finalize>,
1769 ribs: Option<&PerNS<Vec<Rib<'ra>>>>,
1770 ignore_decl: Option<Decl<'ra>>,
1771 ignore_import: Option<Import<'ra>>,
1772 diag_metadata: Option<&DiagMetadata<'_>>,
1773 ) -> PathResult<'ra> {
1774 let mut module = None;
1775 let mut module_had_parse_errors = !self.mods_with_parse_errors.is_empty()
1776 && self.mods_with_parse_errors.contains(&parent_scope.module.nearest_parent_mod());
1777 let mut allow_super = true;
1778 let mut second_binding = None;
1779
1780 let privacy_errors_len = self.privacy_errors.len();
1782 fn record_segment_res<'r, 'ra, 'tcx>(
1783 mut this: CmResolver<'r, 'ra, 'tcx>,
1784 finalize: Option<Finalize>,
1785 res: Res,
1786 id: Option<NodeId>,
1787 ) {
1788 if finalize.is_some()
1789 && let Some(id) = id
1790 && !this.partial_res_map.contains_key(&id)
1791 {
1792 if !(id != ast::DUMMY_NODE_ID) {
{
::core::panicking::panic_fmt(format_args!("Trying to resolve dummy id"));
}
};assert!(id != ast::DUMMY_NODE_ID, "Trying to resolve dummy id");
1793 this.get_mut().record_partial_res(id, PartialRes::new(res));
1794 }
1795 }
1796
1797 for (segment_idx, &Segment { ident, id, .. }) in path.iter().enumerate() {
1798 {
use ::tracing::__macro_support::Callsite as _;
static __CALLSITE: ::tracing::callsite::DefaultCallsite =
{
static META: ::tracing::Metadata<'static> =
{
::tracing_core::metadata::Metadata::new("event compiler/rustc_resolve/src/ident.rs:1798",
"rustc_resolve::ident", ::tracing::Level::DEBUG,
::tracing_core::__macro_support::Option::Some("compiler/rustc_resolve/src/ident.rs"),
::tracing_core::__macro_support::Option::Some(1798u32),
::tracing_core::__macro_support::Option::Some("rustc_resolve::ident"),
::tracing_core::field::FieldSet::new(&["message"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::EVENT)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let enabled =
::tracing::Level::DEBUG <= ::tracing::level_filters::STATIC_MAX_LEVEL
&&
::tracing::Level::DEBUG <=
::tracing::level_filters::LevelFilter::current() &&
{
let interest = __CALLSITE.interest();
!interest.is_never() &&
::tracing::__macro_support::__is_enabled(__CALLSITE.metadata(),
interest)
};
if enabled {
(|value_set: ::tracing::field::ValueSet|
{
let meta = __CALLSITE.metadata();
::tracing::Event::dispatch(meta, &value_set);
;
})({
#[allow(unused_imports)]
use ::tracing::field::{debug, display, Value};
let mut iter = __CALLSITE.metadata().fields().iter();
__CALLSITE.metadata().fields().value_set(&[(&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
::tracing::__macro_support::Option::Some(&format_args!("resolve_path ident {0} {1:?} {2:?}",
segment_idx, ident, id) as &dyn Value))])
});
} else { ; }
};debug!("resolve_path ident {} {:?} {:?}", segment_idx, ident, id);
1799
1800 let is_last = segment_idx + 1 == path.len();
1801 let ns = if is_last { opt_ns.unwrap_or(TypeNS) } else { TypeNS };
1802 let name = ident.name;
1803
1804 allow_super &= ns == TypeNS && (name == kw::SelfLower || name == kw::Super);
1805
1806 if ns == TypeNS {
1807 if allow_super && name == kw::Super {
1808 let parent = if segment_idx == 0 {
1809 self.resolve_super_in_module(ident, None, parent_scope)
1810 } else if let Some(ModuleOrUniformRoot::Module(module)) = module {
1811 self.resolve_super_in_module(ident, Some(module), parent_scope)
1812 } else {
1813 None
1814 };
1815 if let Some(parent) = parent {
1816 module = Some(ModuleOrUniformRoot::Module(parent));
1817 continue;
1818 }
1819 return PathResult::failed(
1820 ident,
1821 false,
1822 finalize.is_some(),
1823 module_had_parse_errors,
1824 module,
1825 || {
1826 (
1827 "too many leading `super` keywords".to_string(),
1828 "there are too many leading `super` keywords".to_string(),
1829 None,
1830 None,
1831 )
1832 },
1833 );
1834 }
1835 if segment_idx == 0 {
1836 if name == kw::SelfLower {
1837 let mut ctxt = ident.span.ctxt().normalize_to_macros_2_0();
1838 let self_mod = self.resolve_self(&mut ctxt, parent_scope.module);
1839 if let Some(res) = self_mod.res() {
1840 record_segment_res(self.reborrow(), finalize, res, id);
1841 }
1842 module = Some(ModuleOrUniformRoot::Module(self_mod));
1843 continue;
1844 }
1845 if name == kw::PathRoot && ident.span.at_least_rust_2018() {
1846 module = Some(ModuleOrUniformRoot::ExternPrelude);
1847 continue;
1848 }
1849 if name == kw::PathRoot
1850 && ident.span.is_rust_2015()
1851 && self.tcx.sess.at_least_rust_2018()
1852 {
1853 let crate_root = self.resolve_crate_root(ident);
1855 module = Some(ModuleOrUniformRoot::ModuleAndExternPrelude(crate_root));
1856 continue;
1857 }
1858 if name == kw::PathRoot || name == kw::Crate || name == kw::DollarCrate {
1859 let crate_root = self.resolve_crate_root(ident);
1861 if let Some(res) = crate_root.res() {
1862 record_segment_res(self.reborrow(), finalize, res, id);
1863 }
1864 module = Some(ModuleOrUniformRoot::Module(crate_root));
1865 continue;
1866 }
1867 }
1868 }
1869
1870 let allow_trailing_self = is_last && name == kw::SelfLower;
1871
1872 if ident.is_path_segment_keyword() && segment_idx != 0 && !allow_trailing_self {
1874 return PathResult::failed(
1875 ident,
1876 false,
1877 finalize.is_some(),
1878 module_had_parse_errors,
1879 module,
1880 || {
1881 let name_str = if name == kw::PathRoot {
1882 "the crate root".to_string()
1883 } else {
1884 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("`{0}`", name))
})format!("`{name}`")
1885 };
1886 let (message, label) = if segment_idx == 1
1887 && path[0].ident.name == kw::PathRoot
1888 {
1889 (
1890 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("global paths cannot start with {0}",
name_str))
})format!("global paths cannot start with {name_str}"),
1891 "cannot start with this".to_string(),
1892 )
1893 } else if name == kw::SelfLower {
1894 (
1895 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("`self` in paths can only be used in start position or last position"))
})format!(
1896 "`self` in paths can only be used in start position or last position"
1897 ),
1898 "can only be used in path start position or last position"
1899 .to_string(),
1900 )
1901 } else {
1902 (
1903 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("{0} in paths can only be used in start position",
name_str))
})format!("{name_str} in paths can only be used in start position"),
1904 "can only be used in path start position".to_string(),
1905 )
1906 };
1907 (message, label, None, None)
1908 },
1909 );
1910 }
1911
1912 let binding = if let Some(module) = module {
1913 self.reborrow().resolve_ident_in_module(
1914 module,
1915 ident,
1916 ns,
1917 parent_scope,
1918 finalize,
1919 ignore_decl,
1920 ignore_import,
1921 )
1922 } else if let Some(ribs) = ribs
1923 && let Some(TypeNS | ValueNS) = opt_ns
1924 {
1925 if !ignore_import.is_none() {
::core::panicking::panic("assertion failed: ignore_import.is_none()")
};assert!(ignore_import.is_none());
1926 match self.get_mut().resolve_ident_in_lexical_scope(
1927 ident,
1928 ns,
1929 parent_scope,
1930 finalize,
1931 &ribs[ns],
1932 ignore_decl,
1933 diag_metadata,
1934 ) {
1935 Some(LateDecl::Decl(binding)) => Ok(binding),
1937 Some(LateDecl::RibDef(res)) => {
1939 record_segment_res(self.reborrow(), finalize, res, id);
1940 return PathResult::NonModule(PartialRes::with_unresolved_segments(
1941 res,
1942 path.len() - 1,
1943 ));
1944 }
1945 _ => Err(Determinacy::determined(finalize.is_some())),
1946 }
1947 } else {
1948 self.reborrow().resolve_ident_in_scope_set(
1949 ident,
1950 ScopeSet::All(ns),
1951 parent_scope,
1952 finalize,
1953 ignore_decl,
1954 ignore_import,
1955 )
1956 };
1957
1958 match binding {
1959 Ok(binding) => {
1960 if segment_idx == 1 {
1961 second_binding = Some(binding);
1962 }
1963 let res = binding.res();
1964
1965 if finalize.is_some() {
1969 for error in &mut self.get_mut().privacy_errors[privacy_errors_len..] {
1970 error.outermost_res = Some((res, ident));
1971 error.source = match source {
1972 Some(PathSource::Struct(Some(expr)))
1973 | Some(PathSource::Expr(Some(expr))) => Some(expr.clone()),
1974 _ => None,
1975 };
1976 }
1977 }
1978
1979 let maybe_assoc = opt_ns != Some(MacroNS) && PathSource::Type.is_expected(res);
1980 if let Res::OpenMod(sym) = binding.res() {
1981 module = Some(ModuleOrUniformRoot::OpenModule(sym));
1982 record_segment_res(self.reborrow(), finalize, res, id);
1983 } else if let Some(def_id) = binding.res().module_like_def_id() {
1984 if self.mods_with_parse_errors.contains(&def_id) {
1985 module_had_parse_errors = true;
1986 }
1987 module = Some(ModuleOrUniformRoot::Module(self.expect_module(def_id)));
1988 record_segment_res(self.reborrow(), finalize, res, id);
1989 } else if res == Res::ToolMod && !is_last && opt_ns.is_some() {
1990 if binding.is_import() {
1991 self.dcx().emit_err(errors::ToolModuleImported {
1992 span: ident.span,
1993 import: binding.span,
1994 });
1995 }
1996 let res = Res::NonMacroAttr(NonMacroAttrKind::Tool);
1997 return PathResult::NonModule(PartialRes::new(res));
1998 } else if res == Res::Err {
1999 return PathResult::NonModule(PartialRes::new(Res::Err));
2000 } else if opt_ns.is_some() && (is_last || maybe_assoc) {
2001 if let Some(finalize) = finalize {
2002 self.get_mut().lint_if_path_starts_with_module(
2003 finalize,
2004 path,
2005 second_binding,
2006 );
2007 }
2008 record_segment_res(self.reborrow(), finalize, res, id);
2009 return PathResult::NonModule(PartialRes::with_unresolved_segments(
2010 res,
2011 path.len() - segment_idx - 1,
2012 ));
2013 } else {
2014 return PathResult::failed(
2015 ident,
2016 is_last,
2017 finalize.is_some(),
2018 module_had_parse_errors,
2019 module,
2020 || {
2021 let import_inherent_item_error_flag =
2022 self.tcx.features().import_trait_associated_functions()
2023 && #[allow(non_exhaustive_omitted_patterns)] match res {
Res::Def(DefKind::Struct | DefKind::Enum | DefKind::Union |
DefKind::ForeignTy, _) => true,
_ => false,
}matches!(
2024 res,
2025 Res::Def(
2026 DefKind::Struct
2027 | DefKind::Enum
2028 | DefKind::Union
2029 | DefKind::ForeignTy,
2030 _
2031 )
2032 );
2033 let label = ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("`{3}` is {0} {1}, not a module{2}",
res.article(), res.descr(),
if import_inherent_item_error_flag {
" or a trait"
} else { "" }, ident))
})format!(
2035 "`{ident}` is {} {}, not a module{}",
2036 res.article(),
2037 res.descr(),
2038 if import_inherent_item_error_flag {
2039 " or a trait"
2040 } else {
2041 ""
2042 }
2043 );
2044 let scope = match &path[..segment_idx] {
2045 [.., prev] => {
2046 if prev.ident.name == kw::PathRoot {
2047 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("the crate root"))
})format!("the crate root")
2048 } else {
2049 ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("`{0}`", prev.ident))
})format!("`{}`", prev.ident)
2050 }
2051 }
2052 _ => ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("this scope"))
})format!("this scope"),
2053 };
2054 let message = ::alloc::__export::must_use({
::alloc::fmt::format(format_args!("cannot find module `{0}` in {1}",
ident, scope))
})format!("cannot find module `{ident}` in {scope}");
2057 let note = if import_inherent_item_error_flag {
2058 Some(
2059 "cannot import inherent associated items, only trait associated items".to_string(),
2060 )
2061 } else {
2062 None
2063 };
2064 (message, label, None, note)
2065 },
2066 );
2067 }
2068 }
2069 Err(Undetermined) if finalize.is_none() => return PathResult::Indeterminate,
2070 Err(Determined | Undetermined) => {
2071 if let Some(ModuleOrUniformRoot::Module(module)) = module
2072 && opt_ns.is_some()
2073 && !module.is_normal()
2074 {
2075 return PathResult::NonModule(PartialRes::with_unresolved_segments(
2076 module.res().unwrap(),
2077 path.len() - segment_idx,
2078 ));
2079 }
2080
2081 let mut this = self.reborrow();
2082 return PathResult::failed(
2083 ident,
2084 is_last,
2085 finalize.is_some(),
2086 module_had_parse_errors,
2087 module,
2088 || {
2089 let (message, label, suggestion) =
2090 this.get_mut().report_path_resolution_error(
2091 path,
2092 opt_ns,
2093 parent_scope,
2094 ribs,
2095 ignore_decl,
2096 ignore_import,
2097 module,
2098 segment_idx,
2099 ident,
2100 diag_metadata,
2101 );
2102 (message, label, suggestion, None)
2103 },
2104 );
2105 }
2106 }
2107 }
2108
2109 if let Some(finalize) = finalize {
2110 self.get_mut().lint_if_path_starts_with_module(finalize, path, second_binding);
2111 }
2112
2113 PathResult::Module(match module {
2114 Some(module) => module,
2115 None if path.is_empty() => ModuleOrUniformRoot::CurrentScope,
2116 _ => ::rustc_middle::util::bug::bug_fmt(format_args!("resolve_path: non-empty path `{0:?}` has no module",
path))bug!("resolve_path: non-empty path `{:?}` has no module", path),
2117 })
2118 }
2119}