aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/compile/internal/types/type.go
diff options
context:
space:
mode:
authorKeith Randall <khr@golang.org>2021-07-24 14:11:27 -0700
committerKeith Randall <khr@golang.org>2021-07-24 22:49:24 +0000
commitb27c7e30dc5d222766057e62c16cb765b636d244 (patch)
tree44c9e86c068a2f8e5e8d5a387693502a15e39788 /src/cmd/compile/internal/types/type.go
parenta2e2b0362bb2e7b93de668007027d08888bc9a38 (diff)
downloadgo-b27c7e30dc5d222766057e62c16cb765b636d244.tar.gz
go-b27c7e30dc5d222766057e62c16cb765b636d244.zip
[dev.typeparams] cmd/compile: fix HasShape, add dottype test
HasShape needs a TINTER case. Add a test for x.(T) in various situations. Needs the fix above. Also remove ONEW unshapify case. It is ok for ONEW to have a shape type, as it will just be passed to mallocgc, or possibly used as a stack object type, both of which are ok. Change-Id: Ibddf8f5c8c254d32cb5ebcaca7dc94b4c00ab893 Reviewed-on: https://go-review.googlesource.com/c/go/+/337231 Trust: Keith Randall <khr@golang.org> Trust: Dan Scales <danscales@google.com> Run-TryBot: Keith Randall <khr@golang.org> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Dan Scales <danscales@google.com>
Diffstat (limited to 'src/cmd/compile/internal/types/type.go')
-rw-r--r--src/cmd/compile/internal/types/type.go8
1 files changed, 7 insertions, 1 deletions
diff --git a/src/cmd/compile/internal/types/type.go b/src/cmd/compile/internal/types/type.go
index e6ae0e7bc1..58ac4db95a 100644
--- a/src/cmd/compile/internal/types/type.go
+++ b/src/cmd/compile/internal/types/type.go
@@ -2189,7 +2189,13 @@ func (t *Type) HasShape1(visited map[*Type]bool) bool {
}
}
}
- // TODO: TINTER - check methods?
+ case TINTER:
+ for _, f := range t.Methods().Slice() {
+ if f.Type.HasShape1(visited) {
+ return true
+ }
+ }
+ return false
}
return false
}