From 339c4ff9f92bbe84619d71cc43d0b39021c4ca7b Mon Sep 17 00:00:00 2001 From: GnomedDev Date: Sun, 27 Oct 2024 21:20:47 +0000 Subject: [PATCH] Explain why clippy's HIR const eval exists --- clippy_utils/src/consts.rs | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/clippy_utils/src/consts.rs b/clippy_utils/src/consts.rs index a1cfb7be6473..17b76330a447 100644 --- a/clippy_utils/src/consts.rs +++ b/clippy_utils/src/consts.rs @@ -1,3 +1,8 @@ +//! A simple const eval API, for use on arbitrary HIR expressions. +//! +//! This cannot use rustc's const eval, aka miri, as arbitrary HIR expressions cannot be lowered to +//! executable MIR bodies, so we have to do this instead. If HIR expressions gain the ability to be +//! lowered to executable MIR bodies, this should be removed. #![allow(clippy::float_cmp)] use crate::macros::HirNode; @@ -379,6 +384,8 @@ impl Ord for FullInt { /// The context required to evaluate a constant expression. /// /// This is currently limited to constant folding and reading the value of named constants. +/// +/// See the module level documentation for some context. pub struct ConstEvalCtxt<'tcx> { tcx: TyCtxt<'tcx>, param_env: ParamEnv<'tcx>,