X Node
Ntype Ntype
- // Runtime type information provided by walkDotType.
- // Caution: These aren't always populated; see walkDotType.
- SrcType *AddrExpr `mknode:"-"` // *runtime._type for X's type
- DstType *AddrExpr `mknode:"-"` // *runtime._type for Type
- Itab *AddrExpr `mknode:"-"` // *runtime.itab for Type implementing X's type
+ // Runtime type information provided by walkDotType for
+ // assertions from non-empty interface to concrete type.
+ Itab *AddrExpr `mknode:"-"` // *runtime.itab for Type implementing X's type
}
func NewTypeAssertExpr(pos src.XPos, x Node, typ Ntype) *TypeAssertExpr {
// commaok indicates whether to panic or return a bool.
// If commaok is false, resok will be nil.
func (s *state) dottype(n *ir.TypeAssertExpr, commaok bool) (res, resok *ssa.Value) {
- iface := s.expr(n.X) // input interface
- target := s.expr(n.DstType) // target type
+ iface := s.expr(n.X) // input interface
+ target := s.reflectType(n.Type()) // target type
byteptr := s.f.Config.Types.BytePtr
if n.Type().IsInterface() {
if !commaok {
// on failure, panic by calling panicdottype
s.startBlock(bFail)
- taddr := s.expr(n.SrcType)
+ taddr := s.reflectType(n.X.Type())
if n.X.Type().IsEmptyInterface() {
s.rtcall(ir.Syms.PanicdottypeE, false, nil, itab, target, taddr)
} else {
func walkDotType(n *ir.TypeAssertExpr, init *ir.Nodes) ir.Node {
n.X = walkExpr(n.X, init)
// Set up interface type addresses for back end.
-
- n.DstType = reflectdata.TypePtr(n.Type())
- if n.Op() == ir.ODOTTYPE {
- n.SrcType = reflectdata.TypePtr(n.X.Type())
- }
if !n.Type().IsInterface() && !n.X.Type().IsEmptyInterface() {
n.Itab = reflectdata.ITabAddr(n.Type(), n.X.Type())
}