From e4ce969beae7870653b549ace671c624df31f53c Mon Sep 17 00:00:00 2001 From: lcnr Date: Mon, 9 May 2022 02:19:43 +0200 Subject: [PATCH] mention `WithOptConstParam` (#1346) --- src/constants.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/constants.md b/src/constants.md index 0b3becec3..4f1027b98 100644 --- a/src/constants.md +++ b/src/constants.md @@ -4,6 +4,14 @@ Constants used in the type system are represented as [`ty::Const`]. The variants of their [`ty::ConstKind`] mostly mirror the variants of [`ty::TyKind`] with the two *additional* variants being `ConstKind::Value` and `ConstKind::Unevaluated`. +## `WithOptConstParam` and dealing with the query system + +To typecheck constants used in the type system, we have to know their expected type. +For const arguments in type dependent paths, e.g. `x.foo::<{ 3 + 4 }>()`, we don't know +the expected type for `{ 3 + 4 }` until we are typechecking the containing function. + +As we may however have to evaluate that constant during this typecheck, we would get a cycle error. +For more details, you can look at [this document](https://hackmd.io/@rust-const-generics/Bk5GHW-Iq). ## Unevaluated constants