aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/compile/internal/noder/writer.go
diff options
context:
space:
mode:
authorRobert Griesemer <gri@golang.org>2021-08-23 21:04:56 -0700
committerRobert Griesemer <gri@golang.org>2021-08-24 16:36:59 +0000
commite6798795ff523b9b5df2514bffd8d5ce743c312e (patch)
treeefad5a35171abae03abfc18c0753222814a9debd /src/cmd/compile/internal/noder/writer.go
parentb1cdf860dd5f517a2835c6bd48d12dad29ade1da (diff)
downloadgo-e6798795ff523b9b5df2514bffd8d5ce743c312e.tar.gz
go-e6798795ff523b9b5df2514bffd8d5ce743c312e.zip
cmd/compile/internal/types2: use TypeList in the Inferred struct
This is a port of CL 343934 from go/types with the necessary adjustments to the compiler. Change-Id: I810144e6e2eb2bc8fa0d34dc206403c993cbbe7a Reviewed-on: https://go-review.googlesource.com/c/go/+/344616 Trust: Robert Griesemer <gri@golang.org> Reviewed-by: Matthew Dempsky <mdempsky@google.com> Reviewed-by: Dan Scales <danscales@google.com>
Diffstat (limited to 'src/cmd/compile/internal/noder/writer.go')
-rw-r--r--src/cmd/compile/internal/noder/writer.go13
1 files changed, 7 insertions, 6 deletions
diff --git a/src/cmd/compile/internal/noder/writer.go b/src/cmd/compile/internal/noder/writer.go
index a6bd8b2426..1405c77161 100644
--- a/src/cmd/compile/internal/noder/writer.go
+++ b/src/cmd/compile/internal/noder/writer.go
@@ -1212,12 +1212,12 @@ func (w *writer) expr(expr syntax.Expr) {
if obj != nil {
if isGlobal(obj) {
w.code(exprName)
- w.obj(obj, types2.NewTypeList(targs))
+ w.obj(obj, targs)
return
}
obj := obj.(*types2.Var)
- assert(len(targs) == 0)
+ assert(targs.Len() == 0)
w.code(exprLocal)
w.useLocal(expr.Pos(), obj)
@@ -1321,7 +1321,7 @@ func (w *writer) expr(expr syntax.Expr) {
// As if w.expr(expr.Fun), but using inf.TArgs instead.
w.code(exprName)
- w.obj(obj, types2.NewTypeList(inf.TArgs))
+ w.obj(obj, inf.TArgs)
} else {
w.expr(expr.Fun)
}
@@ -1770,7 +1770,7 @@ func isGlobal(obj types2.Object) bool {
// lookupObj returns the object that expr refers to, if any. If expr
// is an explicit instantiation of a generic object, then the type
// arguments are returned as well.
-func lookupObj(info *types2.Info, expr syntax.Expr) (obj types2.Object, targs []types2.Type) {
+func lookupObj(info *types2.Info, expr syntax.Expr) (obj types2.Object, targs *types2.TypeList) {
if index, ok := expr.(*syntax.IndexExpr); ok {
if inf, ok := info.Inferred[index]; ok {
targs = inf.TArgs
@@ -1785,13 +1785,14 @@ func lookupObj(info *types2.Info, expr syntax.Expr) (obj types2.Object, targs []
}
}
- targs = make([]types2.Type, len(args))
+ list := make([]types2.Type, len(args))
for i, arg := range args {
tv, ok := info.Types[arg]
assert(ok)
assert(tv.IsType())
- targs[i] = tv.Type
+ list[i] = tv.Type
}
+ targs = types2.NewTypeList(list)
}
expr = index.X