On Friday, February 2, 2018 at 11:39:44 AM UTC-5, Axel Wagner wrote: > > I did end up asking git, why this was done and it gave this answer > <https://github.com/golang/go/commit/2d9378c7f6dfbbe82d1bbd806093c2dfe57d7e17>, > > which links to this discussion <https://github.com/golang/go/issues/6398>. > > Hope that helps >
Thanks for the links. I still think allowing untyped expressions in switch would make programming more convenient, though it will bring much complexities to the implementation. > > On Fri, Feb 2, 2018 at 5:18 PM, <di...@veryhaha.com <javascript:>> wrote: > >> >> >> On Friday, February 2, 2018 at 10:45:58 AM UTC-5, Axel Wagner wrote: >>> >>> From the spec: >>> >>> >>>> If the switch expression evaluates to an untyped constant, it is first >>>> converted to its default type; if it is an untyped boolean value, it is >>>> first converted to type bool. The predeclared untyped value nil cannot be >>>> used as a switch expression. >>> >>> >>> The current behavior is still as specified. Given that there is an >>> explicit statement about how this is handled makes it less convincing, >>> however, that the spec would be more complicated with a different behavior. >>> So you might still file a language change request, if you want. >>> >> >> but, why design as such? Isn't untyped bool more convenient? >> >> >>> >>> On Fri, Feb 2, 2018 at 4:39 PM, <di...@veryhaha.com> wrote: >>> >>>> >>>> >>>> On Friday, February 2, 2018 at 10:37:24 AM UTC-5, di...@veryhaha.com >>>> wrote: >>>> >>>>> >>>>> >>>>> On Friday, February 2, 2018 at 10:27:04 AM UTC-5, Ian Lance Taylor >>>>> wrote: >>>>>> >>>>>> On Fri, Feb 2, 2018 at 7:10 AM, <di...@veryhaha.com> wrote: >>>>>> > >>>>>> > Why not make it untyped? >>>>>> > >>>>>> > package main >>>>>> > >>>>>> > type T bool >>>>>> > >>>>>> > func f() T {return T(false)} >>>>>> > >>>>>> > func main() { >>>>>> > switch { >>>>>> > case f(): // invalid case f() in switch (mismatched types T and >>>>>> bool) >>>>>> > } >>>>>> > } >>>>>> >>>>>> The current language spec says that omitting the switch expression is >>>>>> equivalent to writing `true`. If you actually write `true`, then, >>>>>> following the usual rules for untyped constant expressions, it will >>>>>> receive the type `bool`, and you would get the same mismatched type >>>>>> error. You will see a similar case if you write `switch 0` and try >>>>>> to >>>>>> compare with a named version of `int`. So the compiler is following >>>>>> the language spec as currently written. >>>>>> >>>>>> We could change the language spec to say that omitting the switch >>>>>> expression is not equivalent to writing `true`, but instead, as you >>>>>> suggest, compares each case to an untyped `true` value. I think the >>>>>> main argument against that is that it makes the spec slightly more >>>>>> complicated while bringing very little benefit. You could write it >>>>>> up >>>>>> as a language change proposal if you like. >>>>>> >>>>>> Ian >>>>>> >>>>> >>>>> > If you actually write `true`, then, >>>>> > following the usual rules for untyped constant expressions, >>>>> > it will receive the type `bool`, >>>>> >>>>> But, in my expression, the result of a constant expression is still >>>>> untyped. >>>>> And "true" is a per-declared untyped boolean value. >>>>> >>>>> And, here is another example to should the untyped result is converted >>>>> to type "bool": >>>>> >>>> and sorry again, here "should", I mean "show". >>>> >>>> >>>>> >>>>> package main >>>>> >>>>> type T bool >>>>> >>>>> func f() T {return T(false)} >>>>> >>>>> func main() { >>>>> switch true == true { >>>>> case f(): // invalid case f() in switch (mismatched types T and >>>>> bool) >>>>> } >>>>> } >>>>> >>>>> >>>>> -- >>>> 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.