mirror of
https://github.com/golang/go
synced 2024-11-17 18:04:48 -07:00
a91d0b649c
We may revisit this decision in a future release. By disallowing this for Go 1.18 we are ensuring that we don't lock in the generics design in a place that may need to change later. (Type declarations are the primary construct where it crucially matters what the underlying type of a type parameter is.) Comment out all tests that rely on this feature; add comments referring to issue so we can find all places easily should we change our minds. Fixes #45639. Change-Id: I730510e4da66d3716d455a9071c7778a1e4a1152 Reviewed-on: https://go-review.googlesource.com/c/go/+/359177 Trust: Robert Griesemer <gri@golang.org> Trust: Dan Scales <danscales@google.com> Reviewed-by: Dan Scales <danscales@google.com>
38 lines
948 B
Go
38 lines
948 B
Go
// run -gcflags=-G=3
|
|
|
|
// Copyright 2021 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package main
|
|
|
|
type FooType[T any] interface {
|
|
Foo(BarType[T]) string
|
|
}
|
|
type BarType[T any] interface {
|
|
Bar(FooType[T]) string
|
|
}
|
|
|
|
// For now, a lone type parameter is not permitted as RHS in a type declaration (issue #45639).
|
|
// type Baz[T any] T
|
|
// func (l Baz[T]) Foo(v BarType[T]) string {
|
|
// return v.Bar(l)
|
|
// }
|
|
// type Bob[T any] T
|
|
// func (l Bob[T]) Bar(v FooType[T]) string {
|
|
// if v,ok := v.(Baz[T]);ok{
|
|
// return fmt.Sprintf("%v%v",v,l)
|
|
// }
|
|
// return ""
|
|
// }
|
|
|
|
func main() {
|
|
// For now, a lone type parameter is not permitted as RHS in a type declaration (issue #45639).
|
|
// var baz Baz[int] = 123
|
|
// var bob Bob[int] = 456
|
|
//
|
|
// if got, want := baz.Foo(bob), "123456"; got != want {
|
|
// panic(fmt.Sprintf("got %s want %s", got, want))
|
|
// }
|
|
}
|