rustc_next_trait_solver/solve/normalizes_to/
opaque_types.rs1use rustc_type_ir::inherent::*;
5use rustc_type_ir::solve::{GoalSource, QueryResultOrRerunNonErased, RerunReason};
6use rustc_type_ir::{self as ty, Interner, MayBeErased, TypingMode, fold_regions};
7
8use crate::delegate::SolverDelegate;
9use crate::solve::{Certainty, EvalCtxt, Goal};
10
11impl<D, I> EvalCtxt<'_, D>
12where
13 D: SolverDelegate<Interner = I>,
14 I: Interner,
15{
16 #[allow(clippy :: suspicious_else_formatting)]
{
let __tracing_attr_span;
let __tracing_attr_guard;
if ::tracing::Level::INFO <= ::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::INFO <=
::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("normalize_opaque_type",
"rustc_next_trait_solver::solve::normalizes_to::opaque_types",
::tracing::Level::INFO,
::tracing_core::__macro_support::Option::Some("compiler/rustc_next_trait_solver/src/solve/normalizes_to/opaque_types.rs"),
::tracing_core::__macro_support::Option::Some(16u32),
::tracing_core::__macro_support::Option::Some("rustc_next_trait_solver::solve::normalizes_to::opaque_types"),
::tracing_core::field::FieldSet::new(&["goal"],
::tracing_core::callsite::Identifier(&__CALLSITE)),
::tracing::metadata::Kind::SPAN)
};
::tracing::callsite::DefaultCallsite::new(&META)
};
let mut interest = ::tracing::subscriber::Interest::never();
if ::tracing::Level::INFO <=
::tracing::level_filters::STATIC_MAX_LEVEL &&
::tracing::Level::INFO <=
::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(&goal)
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: QueryResultOrRerunNonErased<I> =
loop {};
return __tracing_attr_fake_return;
}
{
let cx = self.cx();
let opaque_ty = goal.predicate.alias;
let expected =
goal.predicate.term.as_type().expect("no such thing as an opaque const");
let def_id = opaque_ty.expect_opaque_ty_def_id();
match self.typing_mode() {
TypingMode::Coherence => {
self.add_item_bounds_for_hidden_type(def_id, opaque_ty.args,
goal.param_env, expected);
self.add_goal(GoalSource::Misc,
goal.with(cx, ty::PredicateKind::Ambiguous));
self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes).map_err(Into::into)
}
TypingMode::Typeck {
defining_opaque_types_and_generators: defining_opaque_types
} | TypingMode::PostTypeckUntilBorrowck {
defining_opaque_types } => {
let Some(def_id) =
def_id.as_local().filter(|&def_id|
defining_opaque_types.contains(&def_id.into())) else {
self.structurally_instantiate_normalizes_to_term(goal,
goal.predicate.alias);
return self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes).map_err(Into::into);
};
let normalized_args =
cx.mk_args_from_iter(opaque_ty.args.iter().map(|arg|
match arg.kind() {
ty::GenericArgKind::Lifetime(lt) => Ok(lt.into()),
ty::GenericArgKind::Type(ty) => {
self.structurally_normalize_ty(goal.param_env,
ty).map(Into::into)
}
ty::GenericArgKind::Const(ct) => {
self.structurally_normalize_const(goal.param_env,
ct).map(Into::into)
}
}))?;
let opaque_type_key =
ty::OpaqueTypeKey { def_id, args: normalized_args };
if let Some(prev) =
self.register_hidden_type_in_storage(opaque_type_key,
expected) {
self.eq(goal.param_env, expected, prev)?;
} else {
match self.typing_mode().assert_not_erased() {
TypingMode::Typeck { .. } => {}
TypingMode::PostTypeckUntilBorrowck { .. } => {
let actual =
cx.type_of_opaque_hir_typeck(def_id).instantiate(cx,
opaque_ty.args).skip_norm_wip();
let actual =
fold_regions(cx, actual,
|re, _dbi|
match re.kind() {
ty::ReErased => self.next_region_var(),
_ => re,
});
self.eq(goal.param_env, expected, actual)?;
}
TypingMode::Coherence | TypingMode::PostBorrowck { .. } |
TypingMode::PostAnalysis | TypingMode::Codegen =>
::core::panicking::panic("internal error: entered unreachable code"),
}
}
self.add_item_bounds_for_hidden_type(def_id.into(),
normalized_args, goal.param_env, expected);
self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes).map_err(Into::into)
}
TypingMode::PostBorrowck { defined_opaque_types } => {
let Some(def_id) =
def_id.as_local().filter(|&def_id|
defined_opaque_types.contains(&def_id.into())) else {
self.structurally_instantiate_normalizes_to_term(goal,
goal.predicate.alias);
return self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes).map_err(Into::into);
};
let actual =
cx.type_of(def_id.into()).instantiate(cx,
opaque_ty.args).skip_norm_wip();
let actual =
fold_regions(cx, actual,
|re, _dbi|
match re.kind() {
ty::ReErased => self.next_region_var(),
_ => re,
});
self.eq(goal.param_env, expected, actual)?;
self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes).map_err(Into::into)
}
TypingMode::PostAnalysis | TypingMode::Codegen => {
let actual =
cx.type_of(def_id.into()).instantiate(cx,
opaque_ty.args).skip_norm_wip();
self.eq(goal.param_env, expected, actual)?;
self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes).map_err(Into::into)
}
TypingMode::ErasedNotCoherence(MayBeErased) => {
if let Some(def_id) = def_id.as_local() {
self.opaque_accesses.rerun_if_opaque_in_opaque_type_storage(RerunReason::NormalizeOpaqueType,
def_id)?;
} else {
self.opaque_accesses.rerun_if_in_post_analysis(RerunReason::NormalizeOpaqueTypeRemoteCrate)?;
}
self.structurally_instantiate_normalizes_to_term(goal,
goal.predicate.alias);
self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes).map_err(Into::into)
}
}
}
}
}#[tracing::instrument(skip(self))]
17 pub(super) fn normalize_opaque_type(
18 &mut self,
19 goal: Goal<I, ty::NormalizesTo<I>>,
20 ) -> QueryResultOrRerunNonErased<I> {
21 let cx = self.cx();
22 let opaque_ty = goal.predicate.alias;
23 let expected = goal.predicate.term.as_type().expect("no such thing as an opaque const");
24 let def_id = opaque_ty.expect_opaque_ty_def_id();
25
26 match self.typing_mode() {
27 TypingMode::Coherence => {
28 self.add_item_bounds_for_hidden_type(
31 def_id,
32 opaque_ty.args,
33 goal.param_env,
34 expected,
35 );
36 self.add_goal(GoalSource::Misc, goal.with(cx, ty::PredicateKind::Ambiguous));
41 self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes)
42 .map_err(Into::into)
43 }
44 TypingMode::Typeck { defining_opaque_types_and_generators: defining_opaque_types }
45 | TypingMode::PostTypeckUntilBorrowck { defining_opaque_types } => {
46 let Some(def_id) = def_id
47 .as_local()
48 .filter(|&def_id| defining_opaque_types.contains(&def_id.into()))
49 else {
50 self.structurally_instantiate_normalizes_to_term(goal, goal.predicate.alias);
52 return self
53 .evaluate_added_goals_and_make_canonical_response(Certainty::Yes)
54 .map_err(Into::into);
55 };
56
57 let normalized_args =
68 cx.mk_args_from_iter(opaque_ty.args.iter().map(|arg| match arg.kind() {
69 ty::GenericArgKind::Lifetime(lt) => Ok(lt.into()),
70 ty::GenericArgKind::Type(ty) => {
71 self.structurally_normalize_ty(goal.param_env, ty).map(Into::into)
72 }
73 ty::GenericArgKind::Const(ct) => {
74 self.structurally_normalize_const(goal.param_env, ct).map(Into::into)
75 }
76 }))?;
77
78 let opaque_type_key = ty::OpaqueTypeKey { def_id, args: normalized_args };
79 if let Some(prev) = self.register_hidden_type_in_storage(opaque_type_key, expected)
80 {
81 self.eq(goal.param_env, expected, prev)?;
82 } else {
83 match self.typing_mode().assert_not_erased() {
87 TypingMode::Typeck { .. } => {}
88 TypingMode::PostTypeckUntilBorrowck { .. } => {
89 let actual = cx
90 .type_of_opaque_hir_typeck(def_id)
91 .instantiate(cx, opaque_ty.args)
92 .skip_norm_wip();
93 let actual = fold_regions(cx, actual, |re, _dbi| match re.kind() {
94 ty::ReErased => self.next_region_var(),
95 _ => re,
96 });
97 self.eq(goal.param_env, expected, actual)?;
98 }
99 TypingMode::Coherence
100 | TypingMode::PostBorrowck { .. }
101 | TypingMode::PostAnalysis
102 | TypingMode::Codegen => unreachable!(),
103 }
104 }
105
106 self.add_item_bounds_for_hidden_type(
107 def_id.into(),
108 normalized_args,
109 goal.param_env,
110 expected,
111 );
112 self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes)
113 .map_err(Into::into)
114 }
115 TypingMode::PostBorrowck { defined_opaque_types } => {
116 let Some(def_id) = def_id
117 .as_local()
118 .filter(|&def_id| defined_opaque_types.contains(&def_id.into()))
119 else {
120 self.structurally_instantiate_normalizes_to_term(goal, goal.predicate.alias);
121 return self
122 .evaluate_added_goals_and_make_canonical_response(Certainty::Yes)
123 .map_err(Into::into);
124 };
125
126 let actual =
127 cx.type_of(def_id.into()).instantiate(cx, opaque_ty.args).skip_norm_wip();
128 let actual = fold_regions(cx, actual, |re, _dbi| match re.kind() {
132 ty::ReErased => self.next_region_var(),
133 _ => re,
134 });
135 self.eq(goal.param_env, expected, actual)?;
136 self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes)
137 .map_err(Into::into)
138 }
139 TypingMode::PostAnalysis | TypingMode::Codegen => {
140 let actual =
142 cx.type_of(def_id.into()).instantiate(cx, opaque_ty.args).skip_norm_wip();
143 self.eq(goal.param_env, expected, actual)?;
144 self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes)
145 .map_err(Into::into)
146 }
147 TypingMode::ErasedNotCoherence(MayBeErased) => {
148 if let Some(def_id) = def_id.as_local() {
155 self.opaque_accesses.rerun_if_opaque_in_opaque_type_storage(
156 RerunReason::NormalizeOpaqueType,
157 def_id,
158 )?;
159 } else {
160 self.opaque_accesses
161 .rerun_if_in_post_analysis(RerunReason::NormalizeOpaqueTypeRemoteCrate)?;
162 }
163
164 self.structurally_instantiate_normalizes_to_term(goal, goal.predicate.alias);
166 self.evaluate_added_goals_and_make_canonical_response(Certainty::Yes)
167 .map_err(Into::into)
168 }
169 }
170 }
171}