mirror of
https://github.com/golang/go
synced 2024-11-17 16:14:42 -07:00
3cdf8b429e
In this case, we can't use an itab for doing a bound call, since we're converting from an interface to an interface. We do a static or dynamic type assert in new function assertToBound(). The dynamic type assert in assertToBound() is only needed if a bound is parameterized. In that case, we must do a dynamic type assert, and therefore need a dictionary entry for the type bound (see change in getGfInfo). I'm not sure if we can somehow limit this case, since using an interface as a type arg AND having the type bound of the type arg be parameterized is a very unlikely case. Had to add the TUNION case to parameterizedBy1() (which is only used for extra checking). Added a bunch of these test cases to 13.go, which now passes. Change-Id: Ic22eed637fa879b5bbb46d36b40aaad6f90b9d01 Reviewed-on: https://go-review.googlesource.com/c/go/+/339898 Trust: Dan Scales <danscales@google.com> Reviewed-by: Keith Randall <khr@golang.org> |
||
---|---|---|
.. | ||
1.dir | ||
3.dir | ||
4.dir | ||
7.dir | ||
8.dir | ||
10.dir | ||
12.dir | ||
1.go | ||
2.go | ||
3.go | ||
4.go | ||
5.go | ||
6.go | ||
7.go | ||
8.go | ||
9.go | ||
10.go | ||
11.go | ||
12.go | ||
13.go | ||
14.go | ||
15.go |