aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/compile/internal/types2/object.go
diff options
context:
space:
mode:
authorRob Findley <rfindley@google.com>2021-07-21 12:12:22 -0400
committerRobert Findley <rfindley@google.com>2021-07-28 19:15:09 +0000
commit473e493d18c277d69e40a4930af045d474ff2be4 (patch)
tree38f5d91931d924e17229c82d4152d61dc5b292a4 /src/cmd/compile/internal/types2/object.go
parente00a6ec084605b773cdb87971de5b5536c0cc13e (diff)
downloadgo-473e493d18c277d69e40a4930af045d474ff2be4.tar.gz
go-473e493d18c277d69e40a4930af045d474ff2be4.zip
[dev.typeparams] cmd/compile/internal/types2: merge instance and Named to eliminate sanitization
This is a port of CL 335929 to types2. It differs significantly from that CL to handle lazy loading, which wasn't tested in go/types. Additionally, the *Checker field was moved out of instance and back onto Named. This way we can tell whether a Named type is uninstantiated simply by checking whether Named.instance is non-nil, which simplified the code considerably. Fixes #46151 Change-Id: I617263bcfaa768ac5442213cecad8d567c2749fc Reviewed-on: https://go-review.googlesource.com/c/go/+/336252 Trust: Robert Findley <rfindley@google.com> Trust: Robert Griesemer <gri@golang.org> Run-TryBot: Robert Findley <rfindley@google.com> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Robert Griesemer <gri@golang.org>
Diffstat (limited to 'src/cmd/compile/internal/types2/object.go')
-rw-r--r--src/cmd/compile/internal/types2/object.go3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/cmd/compile/internal/types2/object.go b/src/cmd/compile/internal/types2/object.go
index 82297ff17f..48fd1e44de 100644
--- a/src/cmd/compile/internal/types2/object.go
+++ b/src/cmd/compile/internal/types2/object.go
@@ -475,6 +475,9 @@ func writeObject(buf *bytes.Buffer, obj Object, qf Qualifier) {
if _, ok := typ.(*Basic); ok {
return
}
+ if named, _ := typ.(*Named); named != nil && len(named.tparams) > 0 {
+ writeTParamList(buf, named.tparams, qf, nil)
+ }
if tname.IsAlias() {
buf.WriteString(" =")
} else {