I agree with Tristan in regards to orthogonality. Seeing the draft with all those complexities added to the language made me quite uneasy about this proposal. When I first started learning Go I was one of the first people to raise a hand and complain about the lack of generics in the language. Now, a year later, after learning about Go proper idioms, I strongly regret my previous stance. I was trying to make Go another language that was not Go. I didn't want to learn to write idiomatic Go code, I wanted to write Go in the same way I used to write C++ (for instance). That was wrong on so many levels.
I'm now sitting in the fence in regards to the generics addition to the language. My previous arguments don't hold anymore. I like how the current Go language forces our intentions to be explicit rather than hiding the real code under some clever abstractions that few people understand. I feel that I became a better programmer that way, thinking about the collective before trying to please myself showing how smart I am. I feel it also encourages collaboration since it's really easy to get an overall understanding of the language. It's accessible for junior developers and enthusiasts since there are fewer concepts to learn, yet they provide some powerful abstractions. Look at the things that were built with Go... Kubernetes, Docker... it's a really powerful language while still being truthful to its simplified flow control, simplified (yet verbose) error handling, simplified data structures... I strongly wish that a generics proposal would stay true to the Go's simplicity principle, but I somehow don't feel this proposal does meet that requirement at it's current state. Sorry to hijack the thread! Best, Dani Em sex, 31 de ago de 2018 às 10:54, Tristan Colgate <tcolg...@gmail.com> escreveu: > Also, and I think this probably applies to the existing syntax in the > design. > This example seems like a pathological use of generics. What would be the > advantage over just declaring the function takes a Stringer? Am I missing > something (presumably this is potentially avoids the interface call > allocation?). > This is a good example of my gut feeling about generics, I realise they'll > be valuable, but do they devalue interfaces? They do not seem like an > orthogonal feature. Of the two, interfaces feel like they encourage me to > write better structured code. > This could also just be fear of change. > > > On Fri, 31 Aug 2018 at 14:34 'Axel Wagner' via golang-nuts < > golang-nuts@googlegroups.com> wrote: > >> A contract can include multiple type parameters: >> https://go.googlesource.com/proposal/+/master/design/go2draft-contracts.md#mutually-referential-type-parameters >> AIUI your syntax can't cover that. And FWIW, I find the syntax of >> contracts in the doc far less "magic" than yours, but YMMV of course. >> >> On Fri, Aug 31, 2018 at 6:43 AM Manlio Perillo <manlio.peri...@gmail.com> >> wrote: >> >>> I just read the "official" proposal for Go2 generics and contracts. >>> The current proposal makes the function syntax more complex, and the >>> syntax for the contract is a bit magic. >>> >>> What about something like: >>> >>> >>> type stringer template >>> >>> contract (x stringer) { >>> var s string = x.String() >>> } >>> >>> func Stringify(s []stringer) (ret []string) { >>> for _, v := range s { >>> ret = append(ret, v.String()) >>> } >>> return ret >>> } >>> >>> instead of >>> >>> >>> contract stringer(x T) { >>> var s string = x.String() >>> } >>> >>> func Stringify(type T stringer)(s []T) (ret []string) { >>> for _, v := range s { >>> ret = append(ret, v.String()) >>> } >>> return ret >>> } >>> >>> >>> Thanks >>> Manlio >>> >>> -- >>> 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. >>> For more options, visit https://groups.google.com/d/optout. >>> >> -- >> 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. >> For more options, visit https://groups.google.com/d/optout. >> > -- > 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. > For more options, visit https://groups.google.com/d/optout. > -- 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. For more options, visit https://groups.google.com/d/optout.