Correction: I think it is much more important that Go remains internally consistent in its use of "square" brackets.
On Wednesday, July 15, 2020 at 8:54:58 PM UTC+2 Hein Meling wrote: > When you refer to beginners, I think you mean developers from other > languages (Java/C#/C++...) that already know the concept of generics. I > don't think they will have problems adapting to a square brackets > notation... they are smart people, and after all they have to learn many > other syntactical differences as well, so one more difference is not going > to be the deal breaker. And if they make <mistakes>, the compiler will > [surely] tell them ;-) > > In fact, the square bracket notation is already adopted for declaring the > type of maps and slices. So switching to angle brackets will make Go's > generics implementation internally inconsistent, since you must declare a > map[string]int with angle brackets and then elsewhere, you will be using > <int> for the same concept. I think it is much more important that Go > remains internally consistent in its use of angle brackets. > > Best, > :) Hein > > > > On Wednesday, July 15, 2020 at 7:03:40 PM UTC+2 dmar...@gmail.com wrote: > >> On Tuesday, July 14, 2020 at 9:45:41 PM UTC-7, robert engels wrote: >>> >>> My opinion is that every major language (no flames please… lots of >>> developers write lots of programs and make money doing it) that supports >>> generics uses < > for generic types, so Go should too - since there is no >>> reason to deviate from this other than to avoid changes to the parser. >>> Seems better to pay this cost once - rather than every Go program that uses >>> generics being harder to read for eternity (especially for those readers >>> that use a lot of languages). >>> >> >> This really captures my feeling perfectly, the parser changes have to be >> less man hours to build and maintain going forward than the man hours of >> all the existing and new developers. All options have a downsides at least >> <T> is as "standard" as one can get when talking about generics. >> >> Some version of <T> will help beginners in reducing the cognitive load >> when learning and using Go. >> >> Thanks, >> -Dan >> >> >> >> >>> > On Jul 14, 2020, at 11:13 PM, Ian Lance Taylor <ia...@golang.org> >>> wrote: >>> > >>> > On Tue, Jul 14, 2020 at 8:21 PM Ahmed (OneOfOne) W. <oneo...@gmail.com> >>> wrote: >>> >> >>> >> This feels a little better, but honestly I'm still all for angle >>> brackets or like Watson suggested, guillamets. >>> >> >>> >> fn(T1)(fn2(T2)(fn3(T3)(v))) // 1 >>> >> fn[T1](fn2[T2](fn3[T3](v))) // 2 >>> >> fn<T1>(fn2<T2>(fn3<T3>(v))) // 3 >>> >> fn«T1»(fn2«T2»(fn3«T3»v))) // 4 >>> >> >>> >> To me, with a background in C++ and Typescript and a little bit of >>> Rust, #3 and #4 are just natural and easier to read. >>> > >>> >> > The advantage of parentheses is that the language already uses >>> > parentheses for lists in various places. Of course that is also the >>> > disadvantage. >>> > >>> > When considering something other than parentheses, I encourage people >>> > to look for objective reasons why one syntax is better than another. >>> > It's going to be different from other aspects of the language. So >>> > what reason would we have for preferring one syntax over another? >>> > >>> > For example: >>> > >>> > Robert already gave reasons why square brackets are better than angle >>> brackets. >>> > >>> > The disadvantage of guillemets is that they are hard to type on many >>> > keyboards. So to me either square brackets or angle brackets would be >>> > better than guillemets. >>> > >>> > The disadvantage of a two character sequence such as <: :> is that it >>> > is more typing. So again either square brackets or angle brackets >>> > seem to me to be better. >>> > >>> > An example of a reason that square brackets might be a poor choice >>> > would be ambiguous parsing, or cases where the code is harder to read. >>> > >>> > It's true that some other languages use angle brackets, but Go already >>> > does many things differently. That is only a minor advantage for >>> > angle brackets. To me at least it does not outweigh the >>> > disadvantages. >>> > >>> > In short, please try to provide reasons for a different syntax. "It >>> > looks good" is a valid reason, but please try to explain why it looks >>> > better than square brackets or parentheses. >>> > >>> > Thanks. >>> > >>> > Ian >>> > >>> > -- >>> > You received this message because you are subscribed to the Google >>> Groups "golang-nuts" group. >>> >> > To unsubscribe from this group and stop receiving emails from it, send >>> an email to golan...@googlegroups.com. >>> > To view this discussion on the web visit >>> https://groups.google.com/d/msgid/golang-nuts/CAOyqgcX-OXktNtUs0G4Ns0iEr3R2qLPpU7q1%3DrOY93%3DAO16a3g%40mail.gmail.com. >>> >>> >>> >>> -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/golang-nuts/5d25bceb-6c52-4fd0-b731-a1e6b4efc790n%40googlegroups.com.