-
Notifications
You must be signed in to change notification settings - Fork 36
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
Experiment with normalizing defs during type checking #162
base: master
Are you sure you want to change the base?
Experiment with normalizing defs during type checking #162
Conversation
Makes it availale for evaluating an VApp
Note: This removes some whnf calls. It might be a regression
Not that this is not cached (but should be a simple oper
Personally, I feel that trying to patch the current type checker is a lost cause. You can patch something up and another problem will pop up somewhere else. If you really want a good type checker, look at Ulf Norel's thesis and try to replicate it. There are far too many corner cases that don't work in the current implementation. For type checking in the concrete syntax, an extension of: Simon Peyton Jones, Dimitrios Vytiniotis, Stephanie Weirich. Practical type inference for arbitrary-rank types. is a better starting point. Some changes are suspicious. For instance why does VApp take a list of arguments now? Why VCn takes a list of definitions? |
@krangelov This was more of an experiment than something intended to be merged (hence being a draft and "Experiment" in the title), but thank you for looking at it! I did it in response to a question about why the above program didn't type check. I mostly did things in the simplest possible way I could think of and at a later stage possibly clean things up and do them in a more sensible way. |
@krangelov To answer your concrete questions: But yes, reverting those changes would probably help with whatever caused the test failures. I only ever tested the type checker, so I apparently didn't notice that I broke the other parts of the compiler. |
This is mostly an experiment to see if it could be done.
This allows more dependently typed programs to typecheck. For example the commented out line here:
https://github.com/GrammaticalFramework/gf-contrib/blob/a9697fbecbf3320fdf7c4543d9f8478b0c92a9c2/typetheory/Types.gf#L69-L72
Here's a self-contained example:
Without this patch the program above gives the error:
with it it type checks