Skip to content

Requirements for const evaluation #24

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Open
lcnr opened this issue Mar 23, 2022 · 0 comments
Open

Requirements for const evaluation #24

lcnr opened this issue Mar 23, 2022 · 0 comments
Labels
A-generic-exprs Generic const expressions C-design-docs Category: This is part of our design documentation K-behavior Document Kind: regarding user visible behavior P-necessary Priority: will be needed at some point S-active

Comments

@lcnr
Copy link
Contributor

lcnr commented Mar 23, 2022

What is this

This is a design document for const generics. Any discussions about its content should be on zulip. The conclusions of these discussions should then be edited back into this issue. Please do not post any comments directly in this issue.

Content

For generic constants in the type system to be sound, const evaluation must
not be able to differentiate between values considered equal by the type system.
Const evaluation must also be fully deterministic and must not depend on any external state
when used in the type system.

Floats

Using floats during CTFE is fully determinstic. So using
them inside of the type system is fine. CTFE can however
produce different results than what would happen on real hardware,
but this is not a concern for const generics.

Dealing with references and allocations

Other sources of non-determinism are allocations. This non-determinism
must however not be observed during const-evaluation (TODO: link to const-eval).

Any references used in a constant are considered equal if their targets are equal, which is also determistic. This is needed by valtrees. The specific design of valtrees also adds some other additional constraints to const evaluation which are listed on its page.

@lcnr lcnr added C-design-docs Category: This is part of our design documentation A-const-param-types K-behavior Document Kind: regarding user visible behavior P-necessary Priority: will be needed at some point labels Mar 23, 2022
@rust-lang rust-lang locked and limited conversation to collaborators Mar 23, 2022
@lcnr lcnr added A-generic-exprs Generic const expressions S-active and removed A-const-param-types labels Mar 23, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
A-generic-exprs Generic const expressions C-design-docs Category: This is part of our design documentation K-behavior Document Kind: regarding user visible behavior P-necessary Priority: will be needed at some point S-active
Projects
None yet
Development

No branches or pull requests

1 participant