Hacker News new | ask | show | jobs
by exceptione 171 days ago

  > fn foo(n i32, m i32) (i32, i32) {}
But now consider returning a function with type¹

  Foo<T<string, T2>> -> (bool -> IDictionary<string, T3> -> i32 -> T3) where T2 : T3
even if you leave out the latter type constraint, I think it is hard to avoid undecidable ambiguity.

  fn foo(n i32, m T2) (????) {}

You quickly get ambiguity due to type parameters / generics, functions as arguments, and tuples if you don't syntactically separate them.

Even if you your context-depended parser can recognize it, does the user? I agree that a language designer should minimize the amount of muscle damage, but he shouldn't forget that readability is perhaps even more critical.

____

1. Note, even if the parser can recognize this, for humans the '>' is confusing unless syntax highlighting takes care of it. One time it delimits a generic type argument, the other time it is part of '->'. This is also an argument for rendering these things as ligatures.

1 comments

This is pointless discussion as Go has all of these things already implemented, so there is no point in going backwards.
The point is that a (new) syntax for any language needs to support any such implementation. The language implementation itself is not the point.
Yes, and I am saying Go has already solved all of this and it makes little sense to deviate too much from its syntax.