Commit ddd558e7 authored by Austin Clements's avatar Austin Clements

runtime: clean up and improve reflect.methodValue comments

The runtime no longer hard-codes the offset of
reflect.methodValue.stack, so remove these obsolete comments. Also,
reflect.methodValue and runtime.reflectMethodValue must also agree
with reflect.makeFuncImpl, so update the comments on all three to
mention this.

This was pointed out by Minux on CL 31138.

Change-Id: Ic5ed1beffb65db76aca2977958da35de902e8e58
Reviewed-on: https://go-review.googlesource.com/34590Reviewed-by: default avatarKeith Randall <khr@golang.org>
parent 8d216910
...@@ -12,9 +12,12 @@ import ( ...@@ -12,9 +12,12 @@ import (
// makeFuncImpl is the closure value implementing the function // makeFuncImpl is the closure value implementing the function
// returned by MakeFunc. // returned by MakeFunc.
// The first two words of this type must be kept in sync with
// methodValue and runtime.reflectMethodValue.
// Any changes should be reflected in all three.
type makeFuncImpl struct { type makeFuncImpl struct {
code uintptr code uintptr
stack *bitVector // stack bitmap for args - offset known to runtime stack *bitVector
typ *funcType typ *funcType
fn func([]Value) []Value fn func([]Value) []Value
} }
...@@ -70,11 +73,12 @@ func MakeFunc(typ Type, fn func(args []Value) (results []Value)) Value { ...@@ -70,11 +73,12 @@ func MakeFunc(typ Type, fn func(args []Value) (results []Value)) Value {
// word in the passed-in argument frame. // word in the passed-in argument frame.
func makeFuncStub() func makeFuncStub()
// This type is partially duplicated as runtime.reflectMethodValue. // The first two words of this type must be kept in sync with
// Any changes should be reflected in both. // makeFuncImpl and runtime.reflectMethodValue.
// Any changes should be reflected in all three.
type methodValue struct { type methodValue struct {
fn uintptr fn uintptr
stack *bitVector // stack bitmap for args - offset known to runtime stack *bitVector
method int method int
rcvr Value rcvr Value
} }
......
...@@ -546,7 +546,8 @@ func gentraceback(pc0, sp0, lr0 uintptr, gp *g, skip int, pcbuf *uintptr, max in ...@@ -546,7 +546,8 @@ func gentraceback(pc0, sp0, lr0 uintptr, gp *g, skip int, pcbuf *uintptr, max in
return n return n
} }
// reflectMethodValue is a partial duplicate of reflect.methodValue. // reflectMethodValue is a partial duplicate of reflect.makeFuncImpl
// and reflect.methodValue.
type reflectMethodValue struct { type reflectMethodValue struct {
fn uintptr fn uintptr
stack *bitvector // args bitmap stack *bitvector // args bitmap
......
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