I also like this proposal, and have a related proposal with a somewhat different syntax that is even simpler and is essentially identical to existing Go code, just with “Generic Native Types” (GNT). Here’s a couple of side-by-side comparisons:
/////////////////// // Min Michal’s: func Min(x, y type T ord) T { if x < y { return x } return y } GNT: func Min(x, y number) type(x) { … } /////////////////// // SyncMap Michal’s: type SyncMap(type K eq, type V) struct { mu sync.Mutex m map[K]V } func (sm *SyncMap(type K eq, type V)) Store(key K, value V) { sm.mu.Lock() sm.m[key] = value sm.mu.Unlock() } GNT: type SyncMap struct interface { mu sync.RWMutex m map // a generic map } func (m *SyncMap) Store(k key(m.Map), v elem(m.Map)) { … } A struct interface is like an interface, specialized for struct -- any struct with the specified fields gets the generic methods, instantiated for the concrete type, e.g.,: // MySyncMap instantiates the SyncMap struct interface... type MySyncMap struct { mu sync.RWMutex m map[string]string } Here’s a significantly improved version of the proposal originally posted a few weeks ago: https://gist.github.com/rcoreilly/bfbee2add03c76ada82810423d81e53d This proposal also specifies a complete set of *fixed* “contracts” that are isomorphic to the existing native types, so it might appeal to people who prefer more explicit semantics for the generic args, compared to more generic generics. Cheers, - Randy > On Jun 27, 2019, at 8:13 PM, Ben Hoyt <benh...@gmail.com> wrote: > > I really, really like this. I liked the original proposal, but using the > "type" keyword seems very natural. And I like the 80/20 constraints thing > with eq/ord/num. Good work -- I hope this gets turned into an official > proposal and debated. > > -Ben > > > On Thursday, June 27, 2019 at 10:29:03 AM UTC-4, Michal Strba wrote: > Hey everybody! > > A few weeks ago, I posted about my proposal for generics in Go 2. You can > find it here. > > Today, I finished a proof-of-concept implementation. It was a lot of fun and > I learned a lot about the internals of Go. > > The implementation is a program that takes a Go file that uses generics and > translates it to a regular Go file that you can run. > > Try it out here :) > > I'm looking forwad to all your feedback! > > Michal Štrba > > -- > 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/199bad6c-ed62-44a6-960b-86503242537a%40googlegroups.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. To view this discussion on the web visit https://groups.google.com/d/msgid/golang-nuts/655EEB98-6928-48E9-84C4-24C259660E7D%40gmail.com. For more options, visit https://groups.google.com/d/optout.