1
0
mirror of https://github.com/golang/go synced 2024-11-12 05:40:22 -07:00

cmd/compile: eliminate IterParams

It's only used once, so just make the caller responsible for iterating
both the receiver and input params.

Change-Id: Icb34f3f0cf96e80fbe27f3f49d12eddc26599b92
Reviewed-on: https://go-review.googlesource.com/20454
Reviewed-by: Dave Cheney <dave@cheney.net>
This commit is contained in:
Matthew Dempsky 2016-03-08 17:45:55 -08:00
parent 33fd4535a4
commit aa3650f019
2 changed files with 21 additions and 32 deletions

View File

@ -618,16 +618,12 @@ func typeinit() {
func Argsize(t *Type) int {
var w int64
for fp, ip := IterFields(t.Results()); fp != nil; fp = ip.Next() {
if x := fp.Width + fp.Type.Width; x > w {
for _, p := range recvParamsResults {
for f, it := IterFields(p(t)); f != nil; f = it.Next() {
if x := f.Width + f.Type.Width; x > w {
w = x
}
}
for fp, ip := IterParams(t); fp != nil; fp = ip.Next() {
if x := fp.Width + fp.Type.Width; x > w {
w = x
}
}
w = (w + int64(Widthptr) - 1) &^ (int64(Widthptr) - 1)

View File

@ -164,10 +164,10 @@ type Type struct {
Lastfn *Node // for usefield
}
// Iter provides an abstraction for iterating across struct fields,
// interface methods, and function parameters.
// Iter provides an abstraction for iterating across struct fields and
// interface methods.
type Iter struct {
a, b *Type
x *Type
}
// IterFields returns the first field or method in struct or interface type t
@ -176,35 +176,21 @@ func IterFields(t *Type) (*Type, Iter) {
if t.Etype != TSTRUCT && t.Etype != TINTER {
Fatalf("IterFields: type %v does not have fields", t)
}
i := Iter{a: t.Type}
i := Iter{x: t.Type}
f := i.Next()
return f, i
}
// IterParams returns the first reeiver or input parameter in function type t
// and an Iter value to continue iterating across the rest.
func IterParams(t *Type) (*Type, Iter) {
if t.Etype != TFUNC {
Fatalf("IterParams: type %v does not have params", t)
}
i := Iter{a: t.Recv().Type, b: t.Params().Type}
f := i.Next()
return f, i
}
// Next returns the next field, method, or parameter, if any.
// Next returns the next field or method, if any.
func (i *Iter) Next() *Type {
if i.a == nil {
if i.b == nil {
if i.x == nil {
return nil
}
i.a, i.b = i.b, nil
}
t := i.a
t := i.x
if t.Etype != TFIELD {
Fatalf("Iter.Next: type %v is not a field", t)
}
i.a = t.Down
i.x = t.Down
return t
}
@ -233,6 +219,13 @@ func (t *Type) Recv() *Type { return *t.RecvP() }
func (t *Type) Params() *Type { return *t.ParamsP() }
func (t *Type) Results() *Type { return *t.ResultsP() }
// recvParamsResults stores the accessor functions for a function Type's
// receiver, parameters, and result parameters, in that order.
// It can be used to iterate over all of a function's parameter lists.
var recvParamsResults = [3]func(*Type) *Type{
(*Type).Recv, (*Type).Params, (*Type).Results,
}
func (t *Type) Size() int64 {
dowidth(t)
return t.Width