-
Notifications
You must be signed in to change notification settings - Fork 62
Type inference keyword for lambda parameters #4497
Comments
[@gavinking] @Zambonifofex do you have any usecases for annotating a parameter of an anonymous function? |
[@Zambonifofex] @gavinking well, you can annotate it |
[@gavinking] Well a As for ceylondoc annotations I don't think they belong on the parameters of an anonymous function at all because (1) they would be ignored by ceylondoc (there is no doc generated for an anon function) and (2) adding doc strings and annotations in the middle of an expression seems just a bit awful. There are lots of other uses for annotations, but they're uses that only really apply to APIs, not to anonymous functions which are fundamentally internal implementation details of a body of something. So I guess I just don't see this. |
[@Zambonifofex] No, I mean documentate it for people reading the source code. For example: Someone might make a You don't do: foo = bar; Instead, you do: value foo = bar; Similarly, you don't do: foo(function(bar) => baz)); Instead, you do: foo(function(value bar) => baz)); |
Well that's what comments are for, no? :) Annotations are for tools and frameworks. |
Ah I see. But:
is a shortcut for:
It's already regular :-) |
[@Zambonifofex] Sure, but in my opinion, it's better to be explicit about the fact that you are declaring a new thing... At least allowing people to use a keyword can't be a bad thing, can it? :-P As well as allowing them to use the keyword if it's declared in the function body: foo(function(bar) { value bar; return baz; }); I don't know... I just don't like seeing |
[@luolong] The way I see this, it adding this little extra bit of explicit annotation is certainly more regular but that regularity does not buy us anything that would warrant the cost of more verbosity. Ceylon has so far managed to strike a pretty good balance between verbose keyword heavy declarative syntax and concise expressive code. I would argue that adding more verbose syntax to anonymous functions would tip that balance to the point where using anonymous functions becomes almost as verbose as declaring those functions on the top level explicitly and using function references explicitly. This is undesirable in my mind, as this will encourage wrong style of programming -- the code that makes sense only in the context of an anonymous function call site, will be divorced of it's context. I'd say, the anonymous function syntax in Ceylon is really just as light weight as it needs to be and no lighter than it has to be. |
[@Zambonifofex] I agree, but as I said,
Not forcing, but allowing. Similar to for(Character character in "Hello")
{} for(character in "Hello")
{} for(value character in "Hello")
{} |
I feel like this becomes even more needed in times of destructuring: foo(function(value [a, b]) => a + b); See #6446. |
as suggested by @Zambonifofex in #4497 (requires hack to backend to preserve BC)
I have changed the spec and typechecker to tolerate the syntax |
[@Zambonifofex] Currently, the following is allowed:
I think that instead it should be:
And also:
This would allow us to annotate a parameter and simultaneously have its type inferred, which is impossible today as far as I know, besides being more regular...
[Migrated from ceylon/ceylon-spec#1391]
The text was updated successfully, but these errors were encountered: