summaryrefslogtreecommitdiffstats
path: root/src/go/doc/testdata/generics.go
blob: ba7187e4dd9f9d8f4dc04b401be57b474ad5d878 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
// 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 generics contains the new syntax supporting generic programming in
// Go.
package generics

// Variables with an instantiated type should be shown.
var X Type[int]

// Parameterized types should be shown.
type Type[P any] struct {
	Field P
}

// Constructors for parameterized types should be shown.
func Constructor[lowerCase any]() Type[lowerCase] {
	return Type[lowerCase]{}
}

// MethodA uses a different name for its receiver type parameter.
func (t Type[A]) MethodA(p A) {}

// MethodB has a blank receiver type parameter.
func (t Type[_]) MethodB() {}

// MethodC has a lower-case receiver type parameter.
func (t Type[c]) MethodC() {}

// Constraint is a constraint interface with two type parameters.
type Constraint[P, Q interface{ string | ~int | Type[int] }] interface {
	~int | ~byte | Type[string]
	M() P
}

// int16 shadows the predeclared type int16.
type int16 int

// NewEmbeddings demonstrates how we filter the new embedded elements.
type NewEmbeddings interface {
	string // should not be filtered
	int16
	struct{ f int }
	~struct{ f int }
	*struct{ f int }
	struct{ f int } | ~struct{ f int }
}

// Func has an instantiated constraint.
func Func[T Constraint[string, Type[int]]]() {}

// AnotherFunc has an implicit constraint interface.
//
// Neither type parameters nor regular parameters should be filtered.
func AnotherFunc[T ~struct{ f int }](_ struct{ f int }) {}

// AFuncType demonstrates filtering of parameters and type parameters. Here we
// don't filter type parameters (to be consistent with function declarations),
// but DO filter the RHS.
type AFuncType[T ~struct{ f int }] func(_ struct{ f int })

// See issue #49477: type parameters should not be interpreted as named types
// for the purpose of determining whether a function is a factory function.

// Slice is not a factory function.
func Slice[T any]() []T {
	return nil
}

// Single is not a factory function.
func Single[T any]() *T {
	return nil
}