On Monday, September 10, 2018 at 4:17:57 PM UTC-4, Axel Wagner wrote:
>
> On Mon, Sep 10, 2018 at 8:57 PM Jonathan Amsterdam <jbams...@gmail.com 
> <javascript:>> wrote:
>
>> FWIW, I think Ian's criticism of not wanting a list of new identifiers to 
>>> express operator constraints is fair. It is a genuine roadblock to c) and 
>>> if we're dead set of setting that as a baseline requirement, I agree that a 
>>> declarative/interface-based approach won't work. 
>>>
>>
>> I don't understand. Why are names so important? Why couldn't you use "T 
>> == T" to mean "T is comparable"? Or "To(From)" to mean "From is convertible 
>> to To"?
>>
>
> It's not the name that is important, it's the declarative nature. I and 
> other people have already gone into detail with the problems we are having 
> with using imperative constructs to define constraints (mainly that they 
> are ambiguous and that it's hard both to enumerate the sets allowed by a 
> contract and to define a suitable contract for an intended set of 
> constraints).
>

I completely agree with you there (although I find the 
declarative/imperative terminology confusing). I think that except for 
interface-like constraints, we should be constraining by broad properties 
of types like comparable, ordered and numeric, rather than specific 
operations.

>  
>
I don't care if the declarative instruction is called "flooglehorn" or 
> "comparable". But I do care that it's an an actual declaration, mapping 1:1 
> in a clear way to intent. Not an ambiguous statement from Go's current 
> Grammar.
>

It wouldn't be ambiguous. The spec would say "in type constraints, `T == T` 
means that T is comparable". I think people would learn to understand that, 
just as they understand that for a type T, `*T` means "pointer to T," not 
"dereference T".


 

>  
>

> Personally, I don't think that should be a requirement. Personally I think 
>>> it's worth adding extra identifiers, if we get declarative constraint-specs 
>>> for that - but that's just my opinion and everyone has one of those.
>>>
>>> But the issues you are bringing up are IMO not "fundamental'. a) to c) 
>>> from above aren't really touched by your criticism, AIUI. To me, they seem 
>>> like issues of syntax and how to phrase the spec.
>>>
>>> But if generics are to have operator constraints like T == T, then 
>>>> something in the language has to change. Either not all interfaces are 
>>>> types, or some interfaces have methods that can't be called, or Go 
>>>> operators can have operands of different types. These changes are not 
>>>> minor 
>>>> tweaks: they alter fundamental aspects of the language.
>>>>
>>>> Contracts, on the other hand, are purely additive. They only come into 
>>>> play when writing generic code. If I'm not mistaken, the draft design 
>>>> doesn't change or even add anything to non-generic Go. There is something 
>>>> attractive about that orthogonality.
>>>>
>>>
>>> I agree. I think that's fair. I don't think for that they need to be 
>>> imperative specifications though.
>>>
>>>  (or, allow embedding interfaces into contract-declarations, remove the 
>>>>> "type-checking function body" idea and instead define a set of 
>>>>> base-contracts you can use for operators) and you'd end up with pretty 
>>>>> much 
>>>>> my design.
>>>>>
>>>>
>>>> That doesn't sound like your original design at all.
>>>>
>>>
>>> You need to squint harder :) From the rest of your mail, ISTM that we 
>>> are putting emphasis on different aspects of my description and the 
>>> contracts design. What I was trying to say is that IMO the things about my 
>>> design I like and the things about the contract design you like can 
>>> probably be reconciled.
>>>
>>> The first seems problematic, because for multi-parameter contracts you 
>>>> wouldn't know which type the parameter referred to. 
>>>>
>>>
>>> FWIW (we are now getting lost in ifs-and-buts and it's no longer clear 
>>> what the specific ideas are we are talking about), in my original design as 
>>> well as that ad-how handwaving you're quoting, constraints always apply to 
>>> a single type and you'd use parametric interfaces (or… interfaces+) to 
>>> express simultaneous restrictions.
>>>
>>> But FTR, I did not intend to start an actual discussion around that, its 
>>> far too underspecified for that. I was sincere when I said your criticism 
>>> is fair and that I had to think about it. My handwaving was just to explain 
>>> why I don't think it can justifiable be called a *fundamental* issue.
>>>  
>>>
>>>> The second seems reasonable to me. Now we can talk about issues like 
>>>> whether this adds too many names to the language, or whether you've 
>>>> described all the important constraints (I think conversion and 
>>>> assignability are important, for instance).
>>>>
>>>
>>> Again, the caveat of handwaving still applies (IMO we should constrain 
>>> ourselves to talk about sufficiently spelled out designs - Ian's contract 
>>> design qualifies and I'd also feel fine with the thing I wrote down in my 
>>> blog, as long as we agree that its conditional on polishing the "are 
>>> pseudo-interfaces usable as types" question), but: Given that we have 
>>> type-parameters, adding that is fairly straightforward in the form of (in 
>>> the words of my blog post) parametric pseudo-interfaces 
>>> "convertible{To,From}(T)" and "assignable{To,From}(T)".
>>>
>>> But yeah, talking about in too much depth here would IMO constitute 
>>> high-jacking of threads about Ian's design. I'm also totally cool to start 
>>> a new thread about this after I had time to incorporate your feedback. 
>>> Unfortunately this isn't my job, so I have to find time between other 
>>> things :)
>>>
>>> Anyway. I think I've been ranty enough for today :)
>>>
>>> On Sunday, September 9, 2018 at 5:21:28 PM UTC-4, Axel Wagner wrote:
>>>>>
>>>>> I don't think saying that is is productive. contracts are more than 
>>>>> just "identifiers used as constraints", they are also a syntactic 
>>>>> construct 
>>>>> to specify those. I specifically don't allow that and that's the whole 
>>>>> point I'm making. So this doesn't seem like a particularly nice way to 
>>>>> have 
>>>>> a discussion.
>>>>>
>>>>> But yes, if it makes you happier, we can call them "contracts", allow 
>>>>> to embed them into interfaces and remove contract declarations from the 
>>>>> design (or, allow embedding interfaces into contract-declarations, remove 
>>>>> the "type-checking function body" idea and instead define a set of 
>>>>> base-contracts you can use for operators) and you'd end up with pretty 
>>>>> much 
>>>>> my design.
>>>>>
>>>>> On Sun, Sep 9, 2018 at 11:17 PM Jonathan Amsterdam <jbams...@gmail.com> 
>>>>> wrote:
>>>>>
>>>>>>
>>>>>>
>>>>>> On Sunday, September 9, 2018 at 3:19:16 PM UTC-4, Axel Wagner wrote:
>>>>>>>
>>>>>>> On Sun, Sep 9, 2018 at 8:49 PM Jonathan Amsterdam <
>>>>>>> jbams...@gmail.com> wrote:
>>>>>>>
>>>>>>>> The problem is that this program seems to type-check, but it is 
>>>>>>>> invalid. The == operator is specified to work on operands of the same 
>>>>>>>> type, 
>>>>>>>> and it is being used on operands of different types.
>>>>>>>>
>>>>>>>
>>>>>>> Good point. I have to think about it. An ad-hoc solution, FWIW, 
>>>>>>> would be to only take into account (or allow) pseudo-interfaces for 
>>>>>>> type-constraints.
>>>>>>>
>>>>>>
>>>>>> The draft design has a name for those: contracts.
>>>>>>
>>>>>> -- 
>>>>>> 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 <javascript:>.
>> 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.

Reply via email to