Yes that too. To differentiate between MinFloat and MinInt for instance.

:)

On Thu, Mar 25, 2021, 8:18 AM Martin Leiser <leiser.1...@gmail.com> wrote:

>
>
> Ian Lance Taylor schrieb am Dienstag, 23. März 2021 um 23:22:51 UTC+1:
>
>> On Tue, Mar 23, 2021 at 3:19 PM atd...@gmail.com <atd...@gmail.com>
>> wrote:
>> >
>> > Since, we also know the type of v, It would be infered from it.
>> >
>> > There is no variance, no dependent type... Meaning that the type of a
>> Go variable does not change.
>> > So the constraints do not change midway through the program, including
>> type names/definitions.
>> >
>> > It does however require to have something that resemble a type
>> definition beforehand.
>> > A type parameter definition.
>>
>> In some cases it can be inferred.
>
>
> But even if it can be inferred it should be possible to annotate the type
> I do expect,
> to improve local readiblity and compile time error message quality:
> I assume that "x" is later used in a context requiring the type to be
> "int":
>           x := Min(someFunc(foo), someFunc(bar))
> Here i can use:
>           var x int = Min(someFunc(foo), someFunc(bar)))
> but using
>          x := Min[int]( someFunc(foo), someFunc(bar)))
> The three version yield different error message, if the called function
> "someFunc()" return a float instead of the expected int.
>
> But what about cases where it
>> can't? And what if I want to write
>>
>> // IntMin is a function with type func(int, int) int.
>> var IntMin = Min[int]
>>
> ?
>>
>> The constraints don't change midway through a program, but in your
>> example the meaning of T does change.
>>
>>
> hmmm... if all I need throughout my whole package is one binding e.g. to
> "int",
> or to the type parameter "MyParameterType" my function use for themselves
> it may get teadious to
> repeat the [MyParameter] all over the place.
> Type inferences helps, but weakens the quality of error messages.
> So please always allow for a explicit type parameter annotation even if
> inference is possible.
> (And doing so in a more global location may improve simplicity a lot;-)
>
> Martin
>
>> Ian
>>
>>
>> > On Tuesday, March 23, 2021 at 10:41:15 PM UTC+1 Ian Lance Taylor wrote:
>> >>
>> >> On Tue, Mar 23, 2021 at 2:17 PM atd...@gmail.com <atd...@gmail.com>
>> wrote:
>> >> >
>> >> > Quick question...
>> >> >
>> >> > Why do we need brackets to define a parametered function, struct
>> etc...?
>> >> >
>> >> > Why not change Go kinds to accept either a type (would produce a
>> regular, function, structs, etc) or a new type parameter object that would
>> implement the constraints (would produce a generic function definition)
>> >> >
>> >> > for instance,
>> >> >
>> >> > type parameter T
>> >> >
>> >> > // [...] some way to add constraint to T
>> >> >
>> >> > func Max(v T) T{...}
>> >> >
>> >> > What are the brackets for? Just an idea.
>> >>
>> >> Each call to Max can use a different value for T. We can call
>> >> Max[int] and Max[string]. How would we do that with this notation?
>> >>
>> >> A type parameter really is a parameter to the function. Making it
>> >> syntactically similar to other non-type parameters seems like a good
>> >> idea to me.
>> >>
>> >> 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...@googlegroups.com.
>> > To view this discussion on the web visit
>> https://groups.google.com/d/msgid/golang-nuts/5713130f-20c7-4b70-ba8f-2e9be22cb9c9n%40googlegroups.com.
>>
>>
> --
> You received this message because you are subscribed to a topic in the
> Google Groups "golang-nuts" group.
> To unsubscribe from this topic, visit
> https://groups.google.com/d/topic/golang-nuts/x3ZffZXHMyA/unsubscribe.
> To unsubscribe from this group and all its topics, 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/ba6f07e2-f89f-4d59-9f10-e0e2fcea004en%40googlegroups.com
> <https://groups.google.com/d/msgid/golang-nuts/ba6f07e2-f89f-4d59-9f10-e0e2fcea004en%40googlegroups.com?utm_medium=email&utm_source=footer>
> .
>

-- 
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/CAJcwgVq81_T8_A13o1P_%3D4Tk8WcLgotoZwxxs76Aw_03iZ%2BxSQ%40mail.gmail.com.

Reply via email to