Commit 8b68fafd authored by Josh Bleecher Snyder's avatar Josh Bleecher Snyder

cmd/compile: simplify walkprint

Superficial simplifications: reduce variable scope,
eliminate pointless temporaries, use a switch statement.

Passes toolstash-check.

Change-Id: I6450493a0583a6ce8ec0461b66954cf1445a754f
Reviewed-on: https://go-review.googlesource.com/55095
Run-TryBot: Josh Bleecher Snyder <josharian@gmail.com>
Reviewed-by: default avatarDaniel Martí <mvdan@mvdan.cc>
Reviewed-by: default avatarMarvin Stenger <marvin.stenger94@gmail.com>
Reviewed-by: default avatarMatthew Dempsky <mdempsky@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
parent d647b612
...@@ -2019,29 +2019,18 @@ ret: ...@@ -2019,29 +2019,18 @@ ret:
// generate code for print // generate code for print
func walkprint(nn *Node, init *Nodes) *Node { func walkprint(nn *Node, init *Nodes) *Node {
var r *Node
var n *Node
var on *Node
var t *types.Type
var et types.EType
op := nn.Op
all := nn.List
var calls []*Node
notfirst := false
// Hoist all the argument evaluation up before the lock. // Hoist all the argument evaluation up before the lock.
walkexprlistcheap(all.Slice(), init) walkexprlistcheap(nn.List.Slice(), init)
calls = append(calls, mkcall("printlock", nil, init)) notfirst := false
for i1, n1 := range all.Slice() { calls := []*Node{mkcall("printlock", nil, init)}
for i1, n := range nn.List.Slice() {
if notfirst { if notfirst {
calls = append(calls, mkcall("printsp", nil, init)) calls = append(calls, mkcall("printsp", nil, init))
} }
notfirst = op == OPRINTN notfirst = nn.Op == OPRINTN
n = n1
if n.Op == OLITERAL { if n.Op == OLITERAL {
switch n.Val().Ctype() { switch n.Val().Ctype() {
case CTRUNE: case CTRUNE:
...@@ -2059,27 +2048,29 @@ func walkprint(nn *Node, init *Nodes) *Node { ...@@ -2059,27 +2048,29 @@ func walkprint(nn *Node, init *Nodes) *Node {
n = defaultlit(n, types.Types[TINT64]) n = defaultlit(n, types.Types[TINT64])
} }
n = defaultlit(n, nil) n = defaultlit(n, nil)
all.SetIndex(i1, n) nn.List.SetIndex(i1, n)
if n.Type == nil || n.Type.Etype == TFORW { if n.Type == nil || n.Type.Etype == TFORW {
continue continue
} }
t = n.Type t := n.Type
et = n.Type.Etype et := n.Type.Etype
if n.Type.IsInterface() { var on *Node
switch {
case n.Type.IsInterface():
if n.Type.IsEmptyInterface() { if n.Type.IsEmptyInterface() {
on = syslook("printeface") on = syslook("printeface")
} else { } else {
on = syslook("printiface") on = syslook("printiface")
} }
on = substArgTypes(on, n.Type) // any-1 on = substArgTypes(on, n.Type) // any-1
} else if n.Type.IsPtr() || et == TCHAN || et == TMAP || et == TFUNC || et == TUNSAFEPTR { case n.Type.IsPtr() || et == TCHAN || et == TMAP || et == TFUNC || et == TUNSAFEPTR:
on = syslook("printpointer") on = syslook("printpointer")
on = substArgTypes(on, n.Type) // any-1 on = substArgTypes(on, n.Type) // any-1
} else if n.Type.IsSlice() { case n.Type.IsSlice():
on = syslook("printslice") on = syslook("printslice")
on = substArgTypes(on, n.Type) // any-1 on = substArgTypes(on, n.Type) // any-1
} else if isInt[et] { case isInt[et]:
if et == TUINT64 { if et == TUINT64 {
if isRuntimePkg(t.Sym.Pkg) && t.Sym.Name == "hex" { if isRuntimePkg(t.Sym.Pkg) && t.Sym.Name == "hex" {
on = syslook("printhex") on = syslook("printhex")
...@@ -2089,15 +2080,15 @@ func walkprint(nn *Node, init *Nodes) *Node { ...@@ -2089,15 +2080,15 @@ func walkprint(nn *Node, init *Nodes) *Node {
} else { } else {
on = syslook("printint") on = syslook("printint")
} }
} else if isFloat[et] { case isFloat[et]:
on = syslook("printfloat") on = syslook("printfloat")
} else if isComplex[et] { case isComplex[et]:
on = syslook("printcomplex") on = syslook("printcomplex")
} else if et == TBOOL { case et == TBOOL:
on = syslook("printbool") on = syslook("printbool")
} else if et == TSTRING { case et == TSTRING:
on = syslook("printstring") on = syslook("printstring")
} else { default:
badtype(OPRINT, n.Type, nil) badtype(OPRINT, n.Type, nil)
continue continue
} }
...@@ -2109,12 +2100,12 @@ func walkprint(nn *Node, init *Nodes) *Node { ...@@ -2109,12 +2100,12 @@ func walkprint(nn *Node, init *Nodes) *Node {
n.Type = t n.Type = t
} }
r = nod(OCALL, on, nil) r := nod(OCALL, on, nil)
r.List.Append(n) r.List.Append(n)
calls = append(calls, r) calls = append(calls, r)
} }
if op == OPRINTN { if nn.Op == OPRINTN {
calls = append(calls, mkcall("printnl", nil, nil)) calls = append(calls, mkcall("printnl", nil, nil))
} }
...@@ -2123,7 +2114,7 @@ func walkprint(nn *Node, init *Nodes) *Node { ...@@ -2123,7 +2114,7 @@ func walkprint(nn *Node, init *Nodes) *Node {
typecheckslice(calls, Etop) typecheckslice(calls, Etop)
walkexprlist(calls, init) walkexprlist(calls, init)
r = nod(OEMPTY, nil, nil) r := nod(OEMPTY, nil, nil)
r = typecheck(r, Etop) r = typecheck(r, Etop)
r = walkexpr(r, init) r = walkexpr(r, init)
r.Ninit.Set(calls) r.Ninit.Set(calls)
......
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