Term-level type annotations for effectful operations.#1197
Open
dhil wants to merge 1 commit intolinks-lang:masterfrom
Open
Term-level type annotations for effectful operations.#1197dhil wants to merge 1 commit intolinks-lang:masterfrom
dhil wants to merge 1 commit intolinks-lang:masterfrom
Conversation
Member
Author
|
Closing and reopening to activate CI. |
This patch makes it possible to annotate effectful operations at the
term-level. Type annotations are crucial when operations are
polymorphic. Prior to this patch, it was only possible to annotate
polymorphic operations in signatures. As a consequence it was
impossible to make the following kind of program type-check.
```links
handle(do Throw) {
case ans -> Just(ans)
case <Throw> : (forall a. () => a) -> Nothing
}
```
The problem is that Links does not infer polymorphism (rightly so), so
the inferred type of `Throw` will fail to check against the pattern
type in the `Throw`-case. With this patch we can annotate the invocation to make the program type check.
```links
handle(do (Throw : forall a. () => a)) {
case ans -> Just(ans)
case <Throw> : (forall a. () => a) -> Nothing
}
```
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This patch makes it possible to annotate effectful operations at the term-level. Type annotations are crucial when operations are polymorphic. Prior to this patch, it was only possible to annotate polymorphic operations in signatures. As a consequence it was impossible to make the following kind of program type-check.
The problem is that Links does not infer polymorphism (rightly so), so the inferred type of
Throwwill fail to check against the pattern type in theThrow-case. With this patch we can annotate the invocation to make the program type check.