Skip to content
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

Structural equality #29

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

Structural equality #29

lcnr opened this issue Mar 23, 2022 · 0 comments
Labels
A-param-types Const parameter types A-unification Unifying constants in the type system C-design-docs Category: This is part of our design documentation K-behavior Document Kind: regarding user visible behavior K-impl Document Kind: regarding implementation 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

Structural equality describes what is necessary for two constants to be considered equal.
The lower bound is that we at least consider constants equal to themselves, while we must not consider two constants to be equal if their differences can be observed in any way during CTFE. Types for which this cannot be guaranteed must not be used as const parameter types.

TODO: explore what exactly this means, reasoning about references and what not, strongly related to #24. Requires us to find a solution for #20

Using the above definition of structural equality, we ended up with a better representation for constants used in the type system, valtrees.

TODO: explain valtrees

@lcnr lcnr added C-design-docs Category: This is part of our design documentation K-impl Document Kind: regarding implementation P-necessary Priority: will be needed at some point S-active A-param-types Const parameter types A-unification Unifying constants in the type system labels Mar 23, 2022
@rust-lang rust-lang locked and limited conversation to collaborators Mar 23, 2022
@lcnr lcnr changed the title Using valtrees Structural equality Mar 23, 2022
@lcnr lcnr added the K-behavior Document Kind: regarding user visible behavior label Mar 23, 2022
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
A-param-types Const parameter types A-unification Unifying constants in the type system C-design-docs Category: This is part of our design documentation K-behavior Document Kind: regarding user visible behavior K-impl Document Kind: regarding implementation P-necessary Priority: will be needed at some point S-active
Projects
None yet
Development

No branches or pull requests

1 participant