Skip to main content

rustc_borrowck/type_check/
canonical.rs

1use std::fmt;
2
3use rustc_errors::ErrorGuaranteed;
4use rustc_infer::infer::canonical::Canonical;
5use rustc_infer::infer::outlives::env::RegionBoundPairs;
6use rustc_middle::bug;
7use rustc_middle::mir::{Body, ConstraintCategory};
8use rustc_middle::ty::{self, Ty, TyCtxt, TypeFoldable, Unnormalized, Upcast};
9use rustc_span::Span;
10use rustc_span::def_id::DefId;
11use rustc_trait_selection::traits::ObligationCause;
12use rustc_trait_selection::traits::query::type_op::{self, TypeOpOutput};
13use tracing::{debug, instrument};
14
15use super::{Locations, NormalizeLocation, TypeChecker};
16use crate::BorrowckInferCtxt;
17use crate::diagnostics::ToUniverseInfo;
18use crate::type_check::{MirTypeckRegionConstraints, constraint_conversion};
19use crate::universal_regions::UniversalRegions;
20
21#[allow(clippy :: suspicious_else_formatting)]
{
    let __tracing_attr_span;
    let __tracing_attr_guard;
    if ::tracing::Level::TRACE <= ::tracing::level_filters::STATIC_MAX_LEVEL
                &&
                ::tracing::Level::TRACE <=
                    ::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("fully_perform_op_raw",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::TRACE,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(21u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["body",
                                                    "universal_regions", "region_bound_pairs",
                                                    "known_type_outlives_obligations", "locations", "category"],
                                        ::tracing_core::callsite::Identifier(&__CALLSITE)),
                                    ::tracing::metadata::Kind::SPAN)
                            };
                        ::tracing::callsite::DefaultCallsite::new(&META)
                    };
                let mut interest = ::tracing::subscriber::Interest::never();
                if ::tracing::Level::TRACE <=
                                    ::tracing::level_filters::STATIC_MAX_LEVEL &&
                                ::tracing::Level::TRACE <=
                                    ::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(&body)
                                                            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(&universal_regions)
                                                            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(&region_bound_pairs)
                                                            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(&known_type_outlives_obligations)
                                                            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(&locations)
                                                            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(&category)
                                                            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<R, ErrorGuaranteed> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            let old_universe = infcx.universe();
            let TypeOpOutput {
                    output, constraints: query_constraints, error_info } =
                op.fully_perform(infcx, infcx.root_def_id,
                        locations.span(body))?;
            if true {
                let data = infcx.take_and_reset_region_constraints();
                if !data.is_empty() {
                    {
                        ::core::panicking::panic_fmt(format_args!("leftover region constraints: {0:#?}",
                                data));
                    };
                }
            }
            {
                use ::tracing::__macro_support::Callsite as _;
                static __CALLSITE: ::tracing::callsite::DefaultCallsite =
                    {
                        static META: ::tracing::Metadata<'static> =
                            {
                                ::tracing_core::metadata::Metadata::new("event compiler/rustc_borrowck/src/type_check/canonical.rs:48",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(48u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["output",
                                                    "query_constraints"],
                                        ::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(&debug(&output) as
                                                        &dyn Value)),
                                            (&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
                                                ::tracing::__macro_support::Option::Some(&debug(&query_constraints)
                                                        as &dyn Value))])
                        });
                } else { ; }
            };
            if let Some(data) = query_constraints {
                constraint_conversion::ConstraintConversion::new(infcx,
                        universal_regions, region_bound_pairs,
                        known_type_outlives_obligations, locations,
                        locations.span(body), category,
                        constraints).convert_all(data);
            }
            let universe = infcx.universe();
            if old_universe != universe && let Some(error_info) = error_info {
                let universe_info = error_info.to_universe_info(old_universe);
                for u in (old_universe + 1)..=universe {
                    constraints.universe_causes.insert(u,
                        universe_info.clone());
                }
            }
            Ok(output)
        }
    }
}#[instrument(skip(infcx, constraints, op), level = "trace")]
22pub(crate) fn fully_perform_op_raw<'tcx, R: fmt::Debug, Op>(
23    infcx: &BorrowckInferCtxt<'tcx>,
24    body: &Body<'tcx>,
25    universal_regions: &UniversalRegions<'tcx>,
26    region_bound_pairs: &RegionBoundPairs<'tcx>,
27    known_type_outlives_obligations: &[ty::PolyTypeOutlivesPredicate<'tcx>],
28    constraints: &mut MirTypeckRegionConstraints<'tcx>,
29    locations: Locations,
30    category: ConstraintCategory<'tcx>,
31    op: Op,
32) -> Result<R, ErrorGuaranteed>
33where
34    Op: type_op::TypeOp<'tcx, Output = R>,
35    Op::ErrorInfo: ToUniverseInfo<'tcx>,
36{
37    let old_universe = infcx.universe();
38
39    let TypeOpOutput { output, constraints: query_constraints, error_info } =
40        op.fully_perform(infcx, infcx.root_def_id, locations.span(body))?;
41    if cfg!(debug_assertions) {
42        let data = infcx.take_and_reset_region_constraints();
43        if !data.is_empty() {
44            panic!("leftover region constraints: {data:#?}");
45        }
46    }
47
48    debug!(?output, ?query_constraints);
49
50    if let Some(data) = query_constraints {
51        constraint_conversion::ConstraintConversion::new(
52            infcx,
53            universal_regions,
54            region_bound_pairs,
55            known_type_outlives_obligations,
56            locations,
57            locations.span(body),
58            category,
59            constraints,
60        )
61        .convert_all(data);
62    }
63
64    // If the query has created new universes and errors are going to be emitted, register the
65    // cause of these new universes for improved diagnostics.
66    let universe = infcx.universe();
67    if old_universe != universe
68        && let Some(error_info) = error_info
69    {
70        let universe_info = error_info.to_universe_info(old_universe);
71        for u in (old_universe + 1)..=universe {
72            constraints.universe_causes.insert(u, universe_info.clone());
73        }
74    }
75
76    Ok(output)
77}
78
79impl<'a, 'tcx> TypeChecker<'a, 'tcx> {
80    /// Given some operation `op` that manipulates types, proves
81    /// predicates, or otherwise uses the inference context, executes
82    /// `op` and then executes all the further obligations that `op`
83    /// returns. This will yield a set of outlives constraints amongst
84    /// regions which are extracted and stored as having occurred at
85    /// `locations`.
86    ///
87    /// **Any `rustc_infer::infer` operations that might generate region
88    /// constraints should occur within this method so that those
89    /// constraints can be properly localized!**
90    #[allow(clippy :: suspicious_else_formatting)]
{
    let __tracing_attr_span;
    let __tracing_attr_guard;
    if ::tracing::Level::TRACE <= ::tracing::level_filters::STATIC_MAX_LEVEL
                &&
                ::tracing::Level::TRACE <=
                    ::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("fully_perform_op",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::TRACE,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(90u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["locations",
                                                    "category"],
                                        ::tracing_core::callsite::Identifier(&__CALLSITE)),
                                    ::tracing::metadata::Kind::SPAN)
                            };
                        ::tracing::callsite::DefaultCallsite::new(&META)
                    };
                let mut interest = ::tracing::subscriber::Interest::never();
                if ::tracing::Level::TRACE <=
                                    ::tracing::level_filters::STATIC_MAX_LEVEL &&
                                ::tracing::Level::TRACE <=
                                    ::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(&locations)
                                                            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(&category)
                                                            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<R, ErrorGuaranteed> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            fully_perform_op_raw(self.infcx, self.body,
                self.universal_regions, self.region_bound_pairs,
                self.known_type_outlives_obligations, self.constraints,
                locations, category, op)
        }
    }
}#[instrument(skip(self, op), level = "trace")]
91    pub(super) fn fully_perform_op<R: fmt::Debug, Op>(
92        &mut self,
93        locations: Locations,
94        category: ConstraintCategory<'tcx>,
95        op: Op,
96    ) -> Result<R, ErrorGuaranteed>
97    where
98        Op: type_op::TypeOp<'tcx, Output = R>,
99        Op::ErrorInfo: ToUniverseInfo<'tcx>,
100    {
101        fully_perform_op_raw(
102            self.infcx,
103            self.body,
104            self.universal_regions,
105            self.region_bound_pairs,
106            self.known_type_outlives_obligations,
107            self.constraints,
108            locations,
109            category,
110            op,
111        )
112    }
113
114    pub(super) fn instantiate_canonical<T>(
115        &mut self,
116        span: Span,
117        canonical: &Canonical<'tcx, T>,
118    ) -> T
119    where
120        T: TypeFoldable<TyCtxt<'tcx>>,
121    {
122        let (instantiated, _) = self.infcx.instantiate_canonical(span, canonical);
123        instantiated
124    }
125
126    #[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("prove_trait_ref",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(126u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["trait_ref",
                                                    "locations", "category"],
                                        ::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(&trait_ref)
                                                            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(&locations)
                                                            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(&category)
                                                            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: () = loop {};
            return __tracing_attr_fake_return;
        }
        {
            self.prove_predicate(ty::Binder::dummy(ty::PredicateKind::Clause(ty::ClauseKind::Trait(ty::TraitPredicate {
                                trait_ref,
                                polarity: ty::PredicatePolarity::Positive,
                            }))), locations, category);
        }
    }
}#[instrument(skip(self), level = "debug")]
127    pub(super) fn prove_trait_ref(
128        &mut self,
129        trait_ref: ty::TraitRef<'tcx>,
130        locations: Locations,
131        category: ConstraintCategory<'tcx>,
132    ) {
133        self.prove_predicate(
134            ty::Binder::dummy(ty::PredicateKind::Clause(ty::ClauseKind::Trait(
135                ty::TraitPredicate { trait_ref, polarity: ty::PredicatePolarity::Positive },
136            ))),
137            locations,
138            category,
139        );
140    }
141
142    #[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("normalize_and_prove_instantiated_predicates",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(142u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["_def_id",
                                                    "instantiated_predicates", "locations"],
                                        ::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(&_def_id)
                                                            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(&instantiated_predicates)
                                                            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(&locations)
                                                            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: () = loop {};
            return __tracing_attr_fake_return;
        }
        {
            for (predicate, span) in instantiated_predicates {
                {
                    use ::tracing::__macro_support::Callsite as _;
                    static __CALLSITE: ::tracing::callsite::DefaultCallsite =
                        {
                            static META: ::tracing::Metadata<'static> =
                                {
                                    ::tracing_core::metadata::Metadata::new("event compiler/rustc_borrowck/src/type_check/canonical.rs:152",
                                        "rustc_borrowck::type_check::canonical",
                                        ::tracing::Level::DEBUG,
                                        ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                        ::tracing_core::__macro_support::Option::Some(152u32),
                                        ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                        ::tracing_core::field::FieldSet::new(&["span", "predicate"],
                                            ::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(&debug(&span) as
                                                            &dyn Value)),
                                                (&::tracing::__macro_support::Iterator::next(&mut iter).expect("FieldSet corrupted (this is a bug)"),
                                                    ::tracing::__macro_support::Option::Some(&debug(&predicate)
                                                            as &dyn Value))])
                            });
                    } else { ; }
                };
                let category = ConstraintCategory::Predicate(span);
                let predicate =
                    self.normalize_with_category(predicate, locations,
                        category);
                self.prove_predicate(predicate, locations, category);
            }
        }
    }
}#[instrument(level = "debug", skip(self))]
143    pub(super) fn normalize_and_prove_instantiated_predicates(
144        &mut self,
145        // Keep this parameter for now, in case we start using
146        // it in `ConstraintCategory` at some point.
147        _def_id: DefId,
148        instantiated_predicates: ty::InstantiatedPredicates<'tcx>,
149        locations: Locations,
150    ) {
151        for (predicate, span) in instantiated_predicates {
152            debug!(?span, ?predicate);
153            let category = ConstraintCategory::Predicate(span);
154            let predicate = self.normalize_with_category(predicate, locations, category);
155            self.prove_predicate(predicate, locations, category);
156        }
157    }
158
159    pub(super) fn prove_predicates(
160        &mut self,
161        predicates: impl IntoIterator<Item: Upcast<TyCtxt<'tcx>, ty::Predicate<'tcx>> + std::fmt::Debug>,
162        locations: Locations,
163        category: ConstraintCategory<'tcx>,
164    ) {
165        for predicate in predicates {
166            self.prove_predicate(predicate, locations, category);
167        }
168    }
169
170    #[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("prove_predicate",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(170u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["predicate",
                                                    "locations", "category"],
                                        ::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(&predicate)
                                                            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(&locations)
                                                            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(&category)
                                                            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: () = loop {};
            return __tracing_attr_fake_return;
        }
        {
            let param_env = self.infcx.param_env;
            let predicate = predicate.upcast(self.tcx());
            let _: Result<_, ErrorGuaranteed> =
                self.fully_perform_op(locations, category,
                    param_env.and(type_op::prove_predicate::ProvePredicate {
                            predicate,
                        }));
        }
    }
}#[instrument(skip(self), level = "debug")]
171    pub(super) fn prove_predicate(
172        &mut self,
173        predicate: impl Upcast<TyCtxt<'tcx>, ty::Predicate<'tcx>> + std::fmt::Debug,
174        locations: Locations,
175        category: ConstraintCategory<'tcx>,
176    ) {
177        let param_env = self.infcx.param_env;
178        let predicate = predicate.upcast(self.tcx());
179        let _: Result<_, ErrorGuaranteed> = self.fully_perform_op(
180            locations,
181            category,
182            param_env.and(type_op::prove_predicate::ProvePredicate { predicate }),
183        );
184    }
185
186    pub(super) fn normalize<T>(&mut self, value: T, location: impl NormalizeLocation) -> T
187    where
188        T: type_op::normalize::Normalizable<'tcx> + fmt::Display + Copy + 'tcx,
189    {
190        self.normalize_with_category(
191            Unnormalized::new_wip(value),
192            location,
193            ConstraintCategory::Boring,
194        )
195    }
196
197    pub(super) fn deeply_normalize<T>(&mut self, value: T, location: impl NormalizeLocation) -> T
198    where
199        T: type_op::normalize::Normalizable<'tcx> + fmt::Display + Copy + 'tcx,
200    {
201        let result: Result<_, ErrorGuaranteed> = self.fully_perform_op(
202            location.to_locations(),
203            ConstraintCategory::Boring,
204            self.infcx.param_env.and(type_op::normalize::DeeplyNormalize { value }),
205        );
206        result.unwrap_or(value)
207    }
208
209    #[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("normalize_with_category",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(209u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["value", "location",
                                                    "category"],
                                        ::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(&value)
                                                            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(&location)
                                                            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(&category)
                                                            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: T = loop {};
            return __tracing_attr_fake_return;
        }
        {
            let value = value.skip_normalization();
            let param_env = self.infcx.param_env;
            let result: Result<_, ErrorGuaranteed> =
                self.fully_perform_op(location.to_locations(), category,
                    param_env.and(type_op::normalize::Normalize { value }));
            result.unwrap_or(value)
        }
    }
}#[instrument(skip(self), level = "debug")]
210    pub(super) fn normalize_with_category<T>(
211        &mut self,
212        value: Unnormalized<'tcx, T>,
213        location: impl NormalizeLocation,
214        category: ConstraintCategory<'tcx>,
215    ) -> T
216    where
217        T: type_op::normalize::Normalizable<'tcx> + fmt::Display + Copy + 'tcx,
218    {
219        let value = value.skip_normalization();
220        let param_env = self.infcx.param_env;
221        let result: Result<_, ErrorGuaranteed> = self.fully_perform_op(
222            location.to_locations(),
223            category,
224            param_env.and(type_op::normalize::Normalize { value }),
225        );
226        result.unwrap_or(value)
227    }
228
229    #[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("struct_tail",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(229u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["ty", "location"],
                                        ::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(&ty)
                                                            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(&location)
                                                            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: Ty<'tcx> = loop {};
            return __tracing_attr_fake_return;
        }
        {
            let tcx = self.tcx();
            let body = self.body;
            let cause =
                ObligationCause::misc(location.to_locations().span(body),
                    body.source.def_id().expect_local());
            let mut normalize = |ty| self.normalize(ty, location);
            let tail = tcx.struct_tail_raw(ty, &cause, &mut normalize, || {});
            normalize(tail)
        }
    }
}#[instrument(skip(self), level = "debug")]
230    pub(super) fn struct_tail(
231        &mut self,
232        ty: Ty<'tcx>,
233        location: impl NormalizeLocation,
234    ) -> Ty<'tcx> {
235        let tcx = self.tcx();
236        let body = self.body;
237
238        let cause = ObligationCause::misc(
239            location.to_locations().span(body),
240            body.source.def_id().expect_local(),
241        );
242
243        let mut normalize = |ty| self.normalize(ty, location);
244        let tail = tcx.struct_tail_raw(ty, &cause, &mut normalize, || {});
245        normalize(tail)
246    }
247
248    #[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("ascribe_user_type",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(248u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["mir_ty", "user_ty",
                                                    "span"], ::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(&mir_ty)
                                                            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(&user_ty)
                                                            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(&span)
                                                            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: () = loop {};
            return __tracing_attr_fake_return;
        }
        {
            let _: Result<_, ErrorGuaranteed> =
                self.fully_perform_op(Locations::All(span),
                    ConstraintCategory::Boring,
                    self.infcx.param_env.and(type_op::ascribe_user_type::AscribeUserType {
                            mir_ty,
                            user_ty,
                        }));
        }
    }
}#[instrument(skip(self), level = "debug")]
249    pub(super) fn ascribe_user_type(
250        &mut self,
251        mir_ty: Ty<'tcx>,
252        user_ty: ty::UserType<'tcx>,
253        span: Span,
254    ) {
255        let _: Result<_, ErrorGuaranteed> = self.fully_perform_op(
256            Locations::All(span),
257            ConstraintCategory::Boring,
258            self.infcx
259                .param_env
260                .and(type_op::ascribe_user_type::AscribeUserType { mir_ty, user_ty }),
261        );
262    }
263
264    /// *Incorrectly* skips the WF checks we normally do in `ascribe_user_type`.
265    ///
266    /// FIXME(#104478, #104477): This is a hack for backward-compatibility.
267    #[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("ascribe_user_type_skip_wf",
                                    "rustc_borrowck::type_check::canonical",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_borrowck/src/type_check/canonical.rs"),
                                    ::tracing_core::__macro_support::Option::Some(267u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_borrowck::type_check::canonical"),
                                    ::tracing_core::field::FieldSet::new(&["mir_ty", "user_ty",
                                                    "span"], ::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(&mir_ty)
                                                            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(&user_ty)
                                                            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(&span)
                                                            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: () = loop {};
            return __tracing_attr_fake_return;
        }
        {
            let ty::UserTypeKind::Ty(user_ty) =
                user_ty.kind else {
                    ::rustc_middle::util::bug::bug_fmt(format_args!("impossible case reached"))
                };
            if let ty::Infer(_) = user_ty.kind() {
                self.eq_types(user_ty, mir_ty, Locations::All(span),
                        ConstraintCategory::Boring).unwrap();
                return;
            }
            let mir_ty =
                match self.infcx.next_trait_solver() {
                    true => mir_ty,
                    false => self.normalize(mir_ty, Locations::All(span)),
                };
            let cause = ObligationCause::dummy_with_span(span);
            let param_env = self.infcx.param_env;
            let _: Result<_, ErrorGuaranteed> =
                self.fully_perform_op(Locations::All(span),
                    ConstraintCategory::Boring,
                    type_op::custom::CustomTypeOp::new(|ocx|
                            {
                                let user_ty =
                                    ocx.normalize(&cause, param_env,
                                        Unnormalized::new_wip(user_ty));
                                ocx.eq(&cause, param_env, user_ty, mir_ty)?;
                                Ok(())
                            }, "ascribe_user_type_skip_wf"));
        }
    }
}#[instrument(skip(self), level = "debug")]
268    pub(super) fn ascribe_user_type_skip_wf(
269        &mut self,
270        mir_ty: Ty<'tcx>,
271        user_ty: ty::UserType<'tcx>,
272        span: Span,
273    ) {
274        let ty::UserTypeKind::Ty(user_ty) = user_ty.kind else { bug!() };
275
276        // A fast path for a common case with closure input/output types.
277        if let ty::Infer(_) = user_ty.kind() {
278            self.eq_types(user_ty, mir_ty, Locations::All(span), ConstraintCategory::Boring)
279                .unwrap();
280            return;
281        }
282
283        // This is a hack. `body.local_decls` are not necessarily normalized in the old
284        // solver due to not deeply normalizing in writeback. So we must re-normalize here.
285        //
286        // I am not sure of a test case where this actually matters. There is a similar
287        // hack in `equate_inputs_and_outputs` which does have associated test cases.
288        let mir_ty = match self.infcx.next_trait_solver() {
289            true => mir_ty,
290            false => self.normalize(mir_ty, Locations::All(span)),
291        };
292
293        let cause = ObligationCause::dummy_with_span(span);
294        let param_env = self.infcx.param_env;
295        let _: Result<_, ErrorGuaranteed> = self.fully_perform_op(
296            Locations::All(span),
297            ConstraintCategory::Boring,
298            type_op::custom::CustomTypeOp::new(
299                |ocx| {
300                    // The `AscribeUserType` query would normally emit a wf
301                    // obligation for the unnormalized user_ty here. This is
302                    // where the "incorrectly skips the WF checks we normally do"
303                    // happens
304                    let user_ty = ocx.normalize(&cause, param_env, Unnormalized::new_wip(user_ty));
305                    ocx.eq(&cause, param_env, user_ty, mir_ty)?;
306                    Ok(())
307                },
308                "ascribe_user_type_skip_wf",
309            ),
310        );
311    }
312}