Skip to main content

rustc_middle/mir/interpret/
queries.rs

1use rustc_hir::def::DefKind;
2use rustc_hir::def_id::DefId;
3use rustc_session::lint;
4use rustc_span::{DUMMY_SP, Span};
5use tracing::{debug, instrument};
6
7use super::{
8    ErrorHandled, EvalToAllocationRawResult, EvalToConstValueResult, GlobalId, ReportedErrorInfo,
9};
10use crate::mir::interpret::ValTreeCreationError;
11use crate::ty::{self, ConstToValTreeResult, GenericArgs, TyCtxt, TypeVisitableExt};
12use crate::{error, mir};
13
14impl<'tcx> TyCtxt<'tcx> {
15    /// Evaluates a constant without providing any generic parameters. This is useful to evaluate consts
16    /// that can't take any generic arguments like const items or enum discriminants. If a
17    /// generic parameter is used within the constant `ErrorHandled::TooGeneric` will be returned.
18    #[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("const_eval_poly",
                                    "rustc_middle::mir::interpret::queries",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_middle/src/mir/interpret/queries.rs"),
                                    ::tracing_core::__macro_support::Option::Some(18u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_middle::mir::interpret::queries"),
                                    ::tracing_core::field::FieldSet::new(&["def_id"],
                                        ::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))])
                            })
                } 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: EvalToConstValueResult<'tcx> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            let args = GenericArgs::identity_for_item(self, def_id);
            let instance = ty::Instance::new_raw(def_id, args);
            let cid = GlobalId { instance, promoted: None };
            let typing_env = ty::TypingEnv::post_analysis(self, def_id);
            self.const_eval_global_id(typing_env, cid, DUMMY_SP)
        }
    }
}#[instrument(skip(self), level = "debug")]
19    pub fn const_eval_poly(self, def_id: DefId) -> EvalToConstValueResult<'tcx> {
20        // In some situations def_id will have generic parameters within scope, but they aren't allowed
21        // to be used. So we can't use `Instance::mono`, instead we feed unresolved generic parameters
22        // into `const_eval` which will return `ErrorHandled::TooGeneric` if any of them are
23        // encountered.
24        let args = GenericArgs::identity_for_item(self, def_id);
25        let instance = ty::Instance::new_raw(def_id, args);
26        let cid = GlobalId { instance, promoted: None };
27        let typing_env = ty::TypingEnv::post_analysis(self, def_id);
28        self.const_eval_global_id(typing_env, cid, DUMMY_SP)
29    }
30
31    /// Evaluates a constant without providing any generic parameters. This is useful to evaluate consts
32    /// that can't take any generic arguments like const items or enum discriminants. If a
33    /// generic parameter is used within the constant `ErrorHandled::TooGeneric` will be returned.
34    #[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("const_eval_poly_to_alloc",
                                    "rustc_middle::mir::interpret::queries",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_middle/src/mir/interpret/queries.rs"),
                                    ::tracing_core::__macro_support::Option::Some(34u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_middle::mir::interpret::queries"),
                                    ::tracing_core::field::FieldSet::new(&["def_id"],
                                        ::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))])
                            })
                } 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: EvalToAllocationRawResult<'tcx> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            let args = GenericArgs::identity_for_item(self, def_id);
            let instance = ty::Instance::new_raw(def_id, args);
            let cid = GlobalId { instance, promoted: None };
            let typing_env = ty::TypingEnv::post_analysis(self, def_id);
            let inputs =
                self.erase_and_anonymize_regions(typing_env.as_query_input(cid));
            self.eval_to_allocation_raw(inputs)
        }
    }
}#[instrument(skip(self), level = "debug")]
35    pub fn const_eval_poly_to_alloc(self, def_id: DefId) -> EvalToAllocationRawResult<'tcx> {
36        // In some situations def_id will have generic parameters within scope, but they aren't allowed
37        // to be used. So we can't use `Instance::mono`, instead we feed unresolved generic parameters
38        // into `const_eval` which will return `ErrorHandled::TooGeneric` if any of them are
39        // encountered.
40        let args = GenericArgs::identity_for_item(self, def_id);
41        let instance = ty::Instance::new_raw(def_id, args);
42        let cid = GlobalId { instance, promoted: None };
43        let typing_env = ty::TypingEnv::post_analysis(self, def_id);
44        let inputs = self.erase_and_anonymize_regions(typing_env.as_query_input(cid));
45        self.eval_to_allocation_raw(inputs)
46    }
47
48    /// Resolves and evaluates a constant.
49    ///
50    /// The constant can be located on a trait like `<A as B>::C`, in which case the given
51    /// generic parameters and environment are used to resolve the constant. Alternatively if the
52    /// constant has generic parameters in scope the generic parameters are used to evaluate the value of
53    /// the constant. For example in `fn foo<T>() { let _ = [0; bar::<T>()]; }` the repeat count
54    /// constant `bar::<T>()` requires a instantiation for `T`, if the instantiation for `T` is still
55    /// too generic for the constant to be evaluated then `Err(ErrorHandled::TooGeneric)` is
56    /// returned.
57    #[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("const_eval_resolve",
                                    "rustc_middle::mir::interpret::queries",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_middle/src/mir/interpret/queries.rs"),
                                    ::tracing_core::__macro_support::Option::Some(57u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_middle::mir::interpret::queries"),
                                    ::tracing_core::field::FieldSet::new(&["typing_env", "ct",
                                                    "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(&typing_env)
                                                            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(&ct)
                                                            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: EvalToConstValueResult<'tcx> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            if ct.args.has_non_region_infer() {
                crate::util::bug::bug_fmt(format_args!("did not expect inference variables here"));
            }
            match ty::Instance::try_resolve(self, typing_env, ct.def, ct.args)
                {
                Ok(Some(instance)) => {
                    let cid = GlobalId { instance, promoted: ct.promoted };
                    self.const_eval_global_id(typing_env, cid, span)
                }
                Ok(None) => Err(ErrorHandled::TooGeneric(DUMMY_SP)),
                Err(err) => {
                    Err(ErrorHandled::Reported(ReportedErrorInfo::non_const_eval_error(err),
                            DUMMY_SP))
                }
            }
        }
    }
}#[instrument(level = "debug", skip(self))]
58    pub fn const_eval_resolve(
59        self,
60        typing_env: ty::TypingEnv<'tcx>,
61        ct: mir::UnevaluatedConst<'tcx>,
62        span: Span,
63    ) -> EvalToConstValueResult<'tcx> {
64        // Cannot resolve `Unevaluated` constants that contain inference
65        // variables. We reject those here since `resolve`
66        // would fail otherwise.
67        //
68        // When trying to evaluate constants containing inference variables,
69        // use `Infcx::const_eval_resolve` instead.
70        if ct.args.has_non_region_infer() {
71            bug!("did not expect inference variables here");
72        }
73
74        // FIXME: maybe have a separate version for resolving mir::UnevaluatedConst?
75        match ty::Instance::try_resolve(self, typing_env, ct.def, ct.args) {
76            Ok(Some(instance)) => {
77                let cid = GlobalId { instance, promoted: ct.promoted };
78                self.const_eval_global_id(typing_env, cid, span)
79            }
80            // For errors during resolution, we deliberately do not point at the usage site of the constant,
81            // since for these errors the place the constant is used shouldn't matter.
82            Ok(None) => Err(ErrorHandled::TooGeneric(DUMMY_SP)),
83            Err(err) => {
84                Err(ErrorHandled::Reported(ReportedErrorInfo::non_const_eval_error(err), DUMMY_SP))
85            }
86        }
87    }
88
89    #[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("const_eval_resolve_for_typeck",
                                    "rustc_middle::mir::interpret::queries",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_middle/src/mir/interpret/queries.rs"),
                                    ::tracing_core::__macro_support::Option::Some(89u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_middle::mir::interpret::queries"),
                                    ::tracing_core::field::FieldSet::new(&["typing_env", "ct",
                                                    "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(&typing_env)
                                                            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(&ct)
                                                            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: ConstToValTreeResult<'tcx> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            if ct.args.has_non_region_infer() {
                crate::util::bug::bug_fmt(format_args!("did not expect inference variables here"));
            }
            let cid =
                match ty::Instance::try_resolve(self, typing_env, ct.def,
                        ct.args) {
                    Ok(Some(instance)) => GlobalId { instance, promoted: None },
                    Ok(None) =>
                        return Err(ErrorHandled::TooGeneric(DUMMY_SP).into()),
                    Err(err) => {
                        return Err(ErrorHandled::Reported(ReportedErrorInfo::non_const_eval_error(err),
                                        DUMMY_SP).into());
                    }
                };
            self.const_eval_global_id_for_typeck(typing_env, cid,
                    span).inspect(|_|
                    {
                        if !self.features().generic_const_exprs() &&
                                        ct.args.has_non_region_param() &&
                                    self.def_kind(cid.instance.def_id()) == DefKind::AnonConst
                                && !self.is_trivial_const(cid.instance.def_id()) {
                            let mir_body = self.mir_for_ctfe(cid.instance.def_id());
                            if mir_body.is_polymorphic {
                                let Some(local_def_id) = ct.def.as_local() else { return };
                                self.node_span_lint(lint::builtin::CONST_EVALUATABLE_UNCHECKED,
                                    self.local_def_id_to_hir_id(local_def_id),
                                    self.def_span(ct.def),
                                    |lint|
                                        {
                                            lint.primary_message("cannot use constants which depend on generic parameters in types");
                                        })
                            }
                        }
                    })
        }
    }
}#[instrument(level = "debug", skip(self))]
90    pub fn const_eval_resolve_for_typeck(
91        self,
92        typing_env: ty::TypingEnv<'tcx>,
93        ct: ty::UnevaluatedConst<'tcx>,
94        span: Span,
95    ) -> ConstToValTreeResult<'tcx> {
96        // Cannot resolve `Unevaluated` constants that contain inference
97        // variables. We reject those here since `resolve`
98        // would fail otherwise.
99        //
100        // When trying to evaluate constants containing inference variables,
101        // use `Infcx::const_eval_resolve` instead.
102        if ct.args.has_non_region_infer() {
103            bug!("did not expect inference variables here");
104        }
105
106        let cid = match ty::Instance::try_resolve(self, typing_env, ct.def, ct.args) {
107            Ok(Some(instance)) => GlobalId { instance, promoted: None },
108            // For errors during resolution, we deliberately do not point at the usage site of the constant,
109            // since for these errors the place the constant is used shouldn't matter.
110            Ok(None) => return Err(ErrorHandled::TooGeneric(DUMMY_SP).into()),
111            Err(err) => {
112                return Err(ErrorHandled::Reported(
113                    ReportedErrorInfo::non_const_eval_error(err),
114                    DUMMY_SP,
115                )
116                .into());
117            }
118        };
119
120        self.const_eval_global_id_for_typeck(typing_env, cid, span).inspect(|_| {
121            // We are emitting the lint here instead of in `is_const_evaluatable`
122            // as we normalize obligations before checking them, and normalization
123            // uses this function to evaluate this constant.
124            //
125            // @lcnr believes that successfully evaluating even though there are
126            // used generic parameters is a bug of evaluation, so checking for it
127            // here does feel somewhat sensible.
128            if !self.features().generic_const_exprs()
129                && ct.args.has_non_region_param()
130                // We only FCW for anon consts as repeat expr counts with anon consts are the only place
131                // that we have a back compat hack for. We don't need to check this is a const argument
132                // as only anon consts as const args should get evaluated "for the type system".
133                //
134                // If we don't *only* FCW anon consts we can wind up incorrectly FCW'ing uses of assoc
135                // consts in pattern positions. #140447
136                && self.def_kind(cid.instance.def_id()) == DefKind::AnonConst
137                && !self.is_trivial_const(cid.instance.def_id())
138            {
139                let mir_body = self.mir_for_ctfe(cid.instance.def_id());
140                if mir_body.is_polymorphic {
141                    let Some(local_def_id) = ct.def.as_local() else { return };
142                    self.node_span_lint(
143                        lint::builtin::CONST_EVALUATABLE_UNCHECKED,
144                        self.local_def_id_to_hir_id(local_def_id),
145                        self.def_span(ct.def),
146                        |lint| {
147                            lint.primary_message(
148                                "cannot use constants which depend on generic parameters in types",
149                            );
150                        },
151                    )
152                }
153            }
154        })
155    }
156
157    pub fn const_eval_instance(
158        self,
159        typing_env: ty::TypingEnv<'tcx>,
160        instance: ty::Instance<'tcx>,
161        span: Span,
162    ) -> EvalToConstValueResult<'tcx> {
163        self.const_eval_global_id(typing_env, GlobalId { instance, promoted: None }, span)
164    }
165
166    /// Evaluate a constant to a `ConstValue`.
167    #[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("const_eval_global_id",
                                    "rustc_middle::mir::interpret::queries",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_middle/src/mir/interpret/queries.rs"),
                                    ::tracing_core::__macro_support::Option::Some(167u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_middle::mir::interpret::queries"),
                                    ::tracing_core::field::FieldSet::new(&["typing_env", "cid",
                                                    "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(&typing_env)
                                                            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(&cid)
                                                            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: EvalToConstValueResult<'tcx> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            let inputs =
                self.erase_and_anonymize_regions(typing_env.with_post_analysis_normalized(self).as_query_input(cid));
            if !span.is_dummy() {
                self.at(span).eval_to_const_value_raw(inputs).map_err(|e|
                        e.with_span(span))
            } else { self.eval_to_const_value_raw(inputs) }
        }
    }
}#[instrument(skip(self), level = "debug")]
168    pub fn const_eval_global_id(
169        self,
170        typing_env: ty::TypingEnv<'tcx>,
171        cid: GlobalId<'tcx>,
172        span: Span,
173    ) -> EvalToConstValueResult<'tcx> {
174        // Const-eval shouldn't depend on lifetimes at all, so we can erase them, which should
175        // improve caching of queries.
176        let inputs = self.erase_and_anonymize_regions(
177            typing_env.with_post_analysis_normalized(self).as_query_input(cid),
178        );
179        if !span.is_dummy() {
180            // The query doesn't know where it is being invoked, so we need to fix the span.
181            self.at(span).eval_to_const_value_raw(inputs).map_err(|e| e.with_span(span))
182        } else {
183            self.eval_to_const_value_raw(inputs)
184        }
185    }
186
187    /// Evaluate a constant to a type-level constant.
188    #[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("const_eval_global_id_for_typeck",
                                    "rustc_middle::mir::interpret::queries",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_middle/src/mir/interpret/queries.rs"),
                                    ::tracing_core::__macro_support::Option::Some(188u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_middle::mir::interpret::queries"),
                                    ::tracing_core::field::FieldSet::new(&["typing_env", "cid",
                                                    "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(&typing_env)
                                                            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(&cid)
                                                            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: ConstToValTreeResult<'tcx> =
                loop {};
            return __tracing_attr_fake_return;
        }
        {
            let inputs =
                self.erase_and_anonymize_regions(typing_env.with_post_analysis_normalized(self).as_query_input(cid));
            {
                use ::tracing::__macro_support::Callsite as _;
                static __CALLSITE: ::tracing::callsite::DefaultCallsite =
                    {
                        static META: ::tracing::Metadata<'static> =
                            {
                                ::tracing_core::metadata::Metadata::new("event compiler/rustc_middle/src/mir/interpret/queries.rs:200",
                                    "rustc_middle::mir::interpret::queries",
                                    ::tracing::Level::DEBUG,
                                    ::tracing_core::__macro_support::Option::Some("compiler/rustc_middle/src/mir/interpret/queries.rs"),
                                    ::tracing_core::__macro_support::Option::Some(200u32),
                                    ::tracing_core::__macro_support::Option::Some("rustc_middle::mir::interpret::queries"),
                                    ::tracing_core::field::FieldSet::new(&["inputs"],
                                        ::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(&inputs) as
                                                        &dyn Value))])
                        });
                } else { ; }
            };
            let res =
                if !span.is_dummy() {
                    self.at(span).eval_to_valtree(inputs).map_err(|e|
                            e.with_span(span))
                } else { self.eval_to_valtree(inputs) };
            match res {
                Ok(valtree) => Ok(Ok(valtree)),
                Err(err) => {
                    match err {
                        ValTreeCreationError::NonSupportedType(ty) => Ok(Err(ty)),
                        ValTreeCreationError::NodesOverflow => {
                            let handled =
                                self.dcx().emit_err(error::MaxNumNodesInValtree {
                                        span,
                                        global_const_id: cid.display(self),
                                    });
                            Err(ReportedErrorInfo::allowed_in_infallible(handled).into())
                        }
                        ValTreeCreationError::InvalidConst => {
                            let handled =
                                self.dcx().emit_err(error::InvalidConstInValtree {
                                        span,
                                        global_const_id: cid.display(self),
                                    });
                            Err(ReportedErrorInfo::allowed_in_infallible(handled).into())
                        }
                        ValTreeCreationError::ErrorHandled(handled) => Err(handled),
                    }
                }
            }
        }
    }
}#[instrument(skip(self), level = "debug")]
189    pub fn const_eval_global_id_for_typeck(
190        self,
191        typing_env: ty::TypingEnv<'tcx>,
192        cid: GlobalId<'tcx>,
193        span: Span,
194    ) -> ConstToValTreeResult<'tcx> {
195        // Const-eval shouldn't depend on lifetimes at all, so we can erase them, which should
196        // improve caching of queries.
197        let inputs = self.erase_and_anonymize_regions(
198            typing_env.with_post_analysis_normalized(self).as_query_input(cid),
199        );
200        debug!(?inputs);
201        let res = if !span.is_dummy() {
202            // The query doesn't know where it is being invoked, so we need to fix the span.
203            self.at(span).eval_to_valtree(inputs).map_err(|e| e.with_span(span))
204        } else {
205            self.eval_to_valtree(inputs)
206        };
207        match res {
208            Ok(valtree) => Ok(Ok(valtree)),
209            Err(err) => {
210                match err {
211                    // Let the caller decide how to handle this.
212                    ValTreeCreationError::NonSupportedType(ty) => Ok(Err(ty)),
213                    // Report the others.
214                    ValTreeCreationError::NodesOverflow => {
215                        let handled = self.dcx().emit_err(error::MaxNumNodesInValtree {
216                            span,
217                            global_const_id: cid.display(self),
218                        });
219                        Err(ReportedErrorInfo::allowed_in_infallible(handled).into())
220                    }
221                    ValTreeCreationError::InvalidConst => {
222                        let handled = self.dcx().emit_err(error::InvalidConstInValtree {
223                            span,
224                            global_const_id: cid.display(self),
225                        });
226                        Err(ReportedErrorInfo::allowed_in_infallible(handled).into())
227                    }
228                    ValTreeCreationError::ErrorHandled(handled) => Err(handled),
229                }
230            }
231        }
232    }
233}