-
-
Notifications
You must be signed in to change notification settings - Fork 783
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
Suggest wrapping value in Ok
or Error
if it makes sense
#3663
base: main
Are you sure you want to change the base?
Suggest wrapping value in Ok
or Error
if it makes sense
#3663
Conversation
Looks like you forgot to accept the snapshot again :) |
Ah yeah this time it's intentional, I'm not really satisfied with how the error looks for case expressions 😆 |
4069083
to
9560d6c
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice! Left 1 comment inline.
Could we have some tests for in use
and returned from a function annotated as being result? Those will be the most common I think.
Hey! 💜 I tried your
The last one means that your new hint doesn't work for these cases for example: pub fn wibble() -> Result(List(String), Nil) {
[] // List(a) `same_as` List(String)
}
pub fn wobble() -> Result(List(b), Nil) {
[] // List(a) `same_as` List(b)
} I feel like it would be more useful if unbound type variables where allowed to match any type on the right-hand side; Something like ~ yoshi |
Hello! Are you still working on this one? Thanks |
Oh my I hadn't noticed the conflicts, once those are solved I think this is ready for review! |
bcc7a89
to
134eb59
Compare
This is ready now! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wonderful, thank you! Left a few small notes
compiler-core/src/type_.rs
Outdated
( | ||
TypeVar::Unbound { .. }, | ||
Type::Named { .. } | Type::Fn { .. } | Type::Tuple { .. }, | ||
) => false, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How come this is false?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I thought an unbound variable is never meant to survive the type inference process, so I chose a safe default there
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's only in the interface, there can be many unbound variables within.
3ecd9c9
to
d280253
Compare
This should be ready now! |
error: Type mismatch | ||
┌─ /src/one/two.gleam:5:5 | ||
│ | ||
5 │ [first, ..rest] -> first | ||
│ ^^^^^^^^^^^^^^^^^^^^^^^^ | ||
│ │ | ||
│ Did you mean to wrap this in an `Ok`? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This error is wrong! Ok([first, ..rest] -> first)
would not be valid.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The message is referring to the first
bit but the way the two overlapping spans are rendered it's not very clear; do you think we should stop highlighting the entire case branch in this case? However that would mean that the error message is not very precise now:
[first, ..rest] -> first
^^^^^ Did you mean to wrap this in an `Ok`?
This case clause was found to return a different type than the previous
one, but all case clauses must return the same type.
And it would be more confusing when the part on the right of ->
is on its own line as the clause would not be displayed in the error!
first
^^^^^ Did you mean to wrap this in an `Ok`?
This case clause was found to return a different type than the previous
one, but all case clauses must return the same type.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we should continue to highlight the entire cause as the source of the type error, but a label about wrapping an expression should only point to the code that is to be wrapped.
If this is a lot of work then another option could be to not have this suggestion for case clauses.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The tricky thing is it is already pointing to just the code that needs to be wrapped but the way the library renders it it's not immediately obvious. If the then clause were not on the same line what you'd see is this:
case wibble {
A -> Error("a")
-> wobble ->
| 1
| ^ Did you mean to wrap this ...
|
incorrect branch
But when the two are on the same line the two look like this
wobble -> 1
^^^^^^^^^^^
|
Did you mean to wrap this
incorrect branch
The way it gets rendered is not the best, maybe I could try and remove it for branches when the then clause is on the same line or for case matches entirely
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, I see, that is annoying. Sounds good to me- changing printing sounds like it would be irritating.
compiler-core/src/error.rs
Outdated
ExtraLabel { | ||
src_info: None, | ||
label: Label { | ||
text: Some(hint), | ||
span: *location, | ||
} | ||
}, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm finding this quite hard to read with all the nesting, it's easy to miss that it's returning a tuple. Could you assign this bit to a variable pleaes
ffbca4f
to
dfa7d2e
Compare
As suggested by @GearsDatapacks the compiler can now suggest to wrap a value into an
Ok
/Error
if it would make the types line up:This is a WIP because I still have to figure out how to pretty print this information in pattern matching branches, right now it looks quite bad 😁