From b65b77cc80885f72f710da4134f05fc6b12fc8c5 Mon Sep 17 00:00:00 2001 From: Ian Lance Taylor Date: Wed, 8 May 2019 04:39:19 +0000 Subject: reflect: correctly handle direct interface typed receiver in Value.call A direct interface type's value method takes value receiver now. Don't pass pointer to the method function. Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/175798 From-SVN: r271000 --- libgo/go/reflect/value.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'libgo/go') diff --git a/libgo/go/reflect/value.go b/libgo/go/reflect/value.go index d3a6243..298fbac 100644 --- a/libgo/go/reflect/value.go +++ b/libgo/go/reflect/value.go @@ -401,7 +401,7 @@ func (v Value) call(op string, in []Value) []Value { if v.flag&flagMethod != 0 { nin++ } - firstPointer := len(in) > 0 && t.In(0).Kind() != Ptr && v.flag&flagMethodFn != 0 + firstPointer := len(in) > 0 && ifaceIndir(t.In(0).common()) && v.flag&flagMethodFn != 0 params := make([]unsafe.Pointer, nin) off := 0 if v.flag&flagMethod != 0 { -- cgit v1.1