Commit 04845fe7 authored by Keith Randall's avatar Keith Randall Committed by Keith Randall

reflect: special-case panic message when returning Value{} from MakeFunc function

Before this CL we used to panic with "nil pointer dereference" because
the value we're calling assignTo on is the zero Value. Provide a better
error message.

Fixes #28748

Change-Id: I7dd4c9e30b599863664d91e78cc45878d8b0052e
Reviewed-on: https://go-review.googlesource.com/c/go/+/175440
Run-TryBot: Keith Randall <khr@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent 31c4e099
......@@ -560,6 +560,10 @@ func callReflect(ctxt *makeFuncImpl, frame unsafe.Pointer, retValid *bool) {
}
for i, typ := range ftyp.out() {
v := out[i]
if v.typ == nil {
panic("reflect: function created by MakeFunc using " + funcName(f) +
" returned zero Value")
}
if v.flag&flagRO != 0 {
panic("reflect: function created by MakeFunc using " + funcName(f) +
" returned value obtained from unexported field")
......
// run
package main
import (
"fmt"
"reflect"
"strings"
)
// Copyright 2019 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
func main() {
defer func() {
e := recover()
if e == nil {
panic("should have panicked")
}
text := fmt.Sprintf("%s", e) // handles both string and runtime.errorString
if !strings.HasPrefix(text, "reflect:") {
panic("wanted a reflect error, got this instead:\n" + text)
}
}()
r := reflect.MakeFunc(reflect.TypeOf(func() error { return nil }),
func(args []reflect.Value) []reflect.Value {
var x [1]reflect.Value
return x[:]
}).Interface().(func() error)
r()
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment