Skip to content

Conversation

lcnr
Copy link

@lcnr lcnr commented Aug 20, 2025

cc #3

documents http://github.com/rust-lang/rust/pull/120752

would be nice for somebody to quickly skim over this to detect

  • things which still need to be defined
  • should be moved

how to talk about X

how to talk about relating higher ranked types. "instantiating the for of the subtype with inference variables and the for of the supertype with placeholders before relating them as normal" seems quite cumbersome. This is where using judgements/actual code is actually ncier than text.

concepts which I don't know how to avoid

rigid types: a type which cannot be normalized in teh current context, whose equality is implemented by equating the type constructor and then recursively their corresponding generic arguments

  • why useful: we normalize aliases until we encounter a rigid type constructor? either a rigid alias or an a non-alias

Copy link
Member

@joshtriplett joshtriplett left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A couple of nits and a question, but the overall structure and organization of this seems potentially reasonable.

@lcnr
Copy link
Author

lcnr commented Sep 17, 2025

🤷 idk how to make progress here, would be nice if someone could look over this again.

```

r[items.generics.instantiation]
When using an item its generic parameters have to get instantiated. This replaces all occurances of the parameter with either the explicitly provided argument or a new unconstrained inference variable.
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
When using an item its generic parameters have to get instantiated. This replaces all occurances of the parameter with either the explicitly provided argument or a new unconstrained inference variable.
When using an item its generic parameters have to get instantiated. This replaces all occurances of the parameter with either the explicitly provided argument or a new inference variable.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants