On Saturday, 1 September 2018 19:26:00 UTC+2, Scott Cotton wrote: > > > > On Saturday, 1 September 2018 18:26:29 UTC+2, Axel Wagner wrote: >> >> On Fri, Aug 31, 2018 at 6:57 PM Scott Cotton <w...@iri-labs.com> wrote: >> >>> My intuition is that interfaces would be obsolete -- and that's a very >>> good thing. >>> >> >> They wouldn't. You can't have heterogeneous lists with contracts. For >> example, say you have a Reader contract: >> >> contract Reader(r R) { >> var ( >> n int >> err error >> p []byte >> ) >> n, err = r.Read(p) >> } >> >> You can't use that to implement, say, io.MultiReader: >> >> func MultiReader(type R Reader) (readers ...R) R { >> return &multiReader{readers} // Type error: Must return R, not >> *multiReader >> } >> > > I don't think there would be a type error as follows: > > fun MultiReader(type R Reader) (readers ...R) Reader { > return &multiReader{readers} > } > > >> >> func Foo() { >> r1 := bytes.NewReader([]byte("Hello ")) >> r2 := strings.NewReader("world") >> r3 := MultiReader(r1, r2) // Type error: Uses different types in >> places of R >> } >> > Forgot to give an example for unifying this:
contract Reader(r Reader, rs ...Reader) ..... which would allow heterogenous arguments. This example is certainly not posed as a global solution to heterogenous type arguments, but just to give another example that it could work. > >> Saying that contracts subsume interface is a bit like saying that generic >> functions in Haskell subsume type classes. They are different things with >> different (but overlapping) uses. >> > > They are different things so far as Haskell is concerned, and probably > traditionally w.r.t. type theory. But a little thinking outside the box > and a tweak of allowed syntax (together with whatever rabbit holes that > might force a type checker into) such as the above may unify them... > > > I don't think examples of it not working constitute valid arguments that > they aren't unifiable in a practical or theoretical way. > > My type theory definitely could use a refresher for discussing this in > formal detail. As the idea of unifying interfaces and contracts is not > formalised, just some intuitions of at least one so far, I don't think one > could even legitimately arrive at a proof that they are not unifiable, > since there is no agreed upon a priori formal framework to arrive at such > conclusions. > > Scott > > > > > >> >> You could implement interface >>> in terms of contract as some sort of bridge for compatibility. But if >>> the proposal could come up with a way to extend the interface syntax with >>> contract-like semantics, perhaps the overlap between the two could just >>> disappear. >>> >>> As for the question in the proposal about implementation by interface or >>> not (compilation speed >>> vs execution speed), my own use cases often require re-thinking >>> something without interfaces >>> (like the heap in my sat solver) for performance. Here's a thumbs up >>> for execution speed and >>> hearty "go for it" for compiler writers to make it fast :) >>> >>> Nice work on the proposal. >>> >>> Scott >>> >>> On Friday, 31 August 2018 18:47:45 UTC+2, Daniela Petruzalek wrote: >>>> >>>> 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 <tcol...@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 < >>>>> golan...@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....@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...@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...@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...@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...@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.