On Sat, Sep 8, 2018 at 6:10 PM, Rob Pike <r...@golang.org> wrote:
> "A contract is a compile-time description of which types are permitted
> for a polymorphic function or type."
>
> No, it's not. It's a collection of statement-like operations that must be
> legally compilable, under restricted circumstances, by the type at the point
> of instantiation, plus some special rules for cases that are hard to handle
> that way. It's more of an illustration, an example, than a description. It's
> implicit, roundabout, a little magical.
>
> I'm not criticizing the design, although it might sound like that, but there
> is a certain lack of precision, of indirection, that makes this harder than
> I hope it might be. And the first place to be precise is in the language
> that defines what these new concepts are.

I said what a contract is, and I think I meant it.  You are discussing
how a contract is implemented.   So perhaps the problem is that the
implementation doesn't match the description.

I guess that by special rules you mean the fact that == permits !=,
and that < permits other comparison operators.  Are there other
special rules you mean?  These rules seem to confuse people and I'm
increasingly inclined to think that we should just drop them.  But
those rules aren't for cases that are hard to handle, they are just a
shorthand, so perhaps I misunderstand what you are referring to.

To me contracts aren't implicit or roundabout at all, at least not
when it comes to which types they permit.  They are very direct and
straightforward, and they really could not be simpler.  But clearly
many people disagree.  Perhaps we need to make them more complex by
turning them into a list of explicit constraints.

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