Export a term as a pair (tilde, type) rather than (type, tilde)
to match the new Union/Term API.
Change-Id: I221c09c2c746ae19fbae0c970ffb26fa7a8ac736
Reviewed-on: https://go-review.googlesource.com/c/go/+/340251
Trust: Robert Griesemer <gri@golang.org>
Trust: Dan Scales <danscales@google.com>
Run-TryBot: Robert Griesemer <gri@golang.org>
TryBot-Result: Go Bot <gobot@golang.org>
Reviewed-by: Dan Scales <danscales@google.com>
Reviewed-by: Matthew Dempsky <mdempsky@google.com>
if r.p.exportVersion < iexportVersionGenerics {
errorf("unexpected instantiation type")
}
- nt := int(r.uint64())
- terms := make([]*types2.Term, nt)
+ terms := make([]*types2.Term, r.uint64())
for i := range terms {
- typ := r.typ()
- tilde := r.bool()
- terms[i] = types2.NewTerm(tilde, typ)
+ terms[i] = types2.NewTerm(r.bool(), r.typ())
}
return types2.NewUnion(terms)
}
func (r *reader2) unionType() *types2.Union {
terms := make([]*types2.Term, r.len())
for i := range terms {
- typ := r.typ()
- tilde := r.bool()
- terms[i] = types2.NewTerm(tilde, typ)
+ terms[i] = types2.NewTerm(r.bool(), r.typ())
}
return types2.NewUnion(terms)
}
w.len(typ.Len())
for i := 0; i < typ.Len(); i++ {
t := typ.Term(i)
- w.typ(t.Type())
w.bool(t.Tilde())
+ w.typ(t.Type())
}
}
nt := t.NumTerms()
w.uint64(uint64(nt))
for i := 0; i < nt; i++ {
- t, b := t.Term(i)
- w.typ(t)
- w.bool(b)
+ typ, tilde := t.Term(i)
+ w.bool(tilde)
+ w.typ(typ)
}
default:
terms := make([]*types.Type, nt)
tildes := make([]bool, nt)
for i := range terms {
- terms[i] = r.typ()
tildes[i] = r.bool()
+ terms[i] = r.typ()
}
return types.NewUnion(terms, tildes)
}