On Tue, Sep 11, 2018 at 1:39 PM, roger peppe <rogpe...@gmail.com> wrote:
> On 11 September 2018 at 18:04, roger peppe <rogpe...@gmail.com> wrote:
>> If it were not explicitly prohibited by the draft proposal, we could
>> also imagine this, a definition of a method foo on the type A that's
>> parameterised with type T; the method itself has a type parameter S:
>>
>>     func (a A(T)) foo(type S)(s S, t T)
>
> With respect to this, I wonder if the draft proposal isn't being a bit
> more restrictive than necessary.
>
> I suspect that type parameters on methods might turn out to be very
> nice to have (it's very useful to keep within a type's namespace) even
> if we can't use them in interfaces or in reflect.
>
> How about allowing them, but say that methods with type parameters
> never appear in any interface and cannot be accessed with reflect?

While methods can be a convenient way to organize code, their only
real semantic meaning is to satisfy interfaces.  Other than that, they
are just a funny way of writing functions.  Permitting methods that do
not satisfy interfaces seems like a fairly minor feature, and at least
at this point I don't think the benefit is worth the confusion.  It's
always something that can be added later.

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 golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to