mirror of
https://github.com/golang/go
synced 2024-11-19 12:44:51 -07:00
cmd/compile: compute number of arguments correctly
The outCount value includes a flag bit for dotdotdot. If we have this count incorrect, then the offset for the methodset *rtype are in the wrong place. Fixes #14783 Change-Id: If5acb16af08d4ffe36c8c9ee389c32f2712ce757 Reviewed-on: https://go-review.googlesource.com/20566 Reviewed-by: Ian Lance Taylor <iant@golang.org> Run-TryBot: Ian Lance Taylor <iant@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org>
This commit is contained in:
parent
ae00df128d
commit
7c546566c3
@ -1068,7 +1068,7 @@ ok:
|
||||
ot += 4 // align for *rtype
|
||||
}
|
||||
|
||||
dataAdd := (inCount + outCount) * Widthptr
|
||||
dataAdd := (inCount + t.Outtuple) * Widthptr
|
||||
ot = dextratype(s, ot, t, dataAdd)
|
||||
|
||||
// Array of rtype pointers follows funcType.
|
||||
|
@ -2410,6 +2410,17 @@ func TestEmbeddedMethods(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
type FuncDDD func(...interface{}) error
|
||||
|
||||
func (f FuncDDD) M() {}
|
||||
|
||||
func TestNumMethodOnDDD(t *testing.T) {
|
||||
rv := ValueOf((FuncDDD)(nil))
|
||||
if n := rv.NumMethod(); n != 1 {
|
||||
t.Fatalf("NumMethod()=%d, want 1", n)
|
||||
}
|
||||
}
|
||||
|
||||
func TestPtrTo(t *testing.T) {
|
||||
var i int
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user