}
default:
- Fatalf("exporter: unexpected export symbol: %v %v", oconv(n.Op, 0), sym)
+ Fatalf("exporter: unexpected export symbol: %v %v", n.Op, sym)
}
}
}
if !n.Type.IsBoolean() {
- Fatalf("bgen: bad type %v for %v", n.Type, oconv(n.Op, 0))
+ Fatalf("bgen: bad type %v for %v", n.Type, n.Op)
}
for n.Op == OCONVNOP {
func cgen_callinter(n *Node, res *Node, proc int) {
i := n.Left
if i.Op != ODOTINTER {
- Fatalf("cgen_callinter: not ODOTINTER %v", oconv(i.Op, 0))
+ Fatalf("cgen_callinter: not ODOTINTER %v", i.Op)
}
i = i.Left // interface
switch uint32(n.Op)<<16 | uint32(v.Ctype()) {
default:
if n.Diag == 0 {
- Yyerror("illegal constant expression %v %v", oconv(n.Op, 0), nl.Type)
+ Yyerror("illegal constant expression %v %v", n.Op, nl.Type)
n.Diag = 1
}
return
illegal:
if n.Diag == 0 {
- Yyerror("illegal constant expression: %v %v %v", nl.Type, oconv(n.Op, 0), nr.Type)
+ Yyerror("illegal constant expression: %v %v %v", nl.Type, n.Op, nr.Type)
n.Diag = 1
}
}
switch n.Op {
default:
Dump("complexgen: unknown op", n)
- Fatalf("complexgen: unknown op %v", oconv(n.Op, 0))
+ Fatalf("complexgen: unknown op %v", n.Op)
case ODOT,
ODOTPTR,
switch n.Op {
default:
- Fatalf("complexgen: unknown op %v", oconv(n.Op, 0))
+ Fatalf("complexgen: unknown op %v", n.Op)
case OCONV:
Complexmove(nl, res)
func funcargs(nt *Node) {
if nt.Op != OTFUNC {
- Fatalf("funcargs %v", oconv(nt.Op, 0))
+ Fatalf("funcargs %v", nt.Op)
}
// re-start the variable generation number
if nt.Left != nil {
n := nt.Left
if n.Op != ODCLFIELD {
- Fatalf("funcargs receiver %v", oconv(n.Op, 0))
+ Fatalf("funcargs receiver %v", n.Op)
}
if n.Left != nil {
n.Left.Op = ONAME
for _, n := range nt.List.Slice() {
if n.Op != ODCLFIELD {
- Fatalf("funcargs in %v", oconv(n.Op, 0))
+ Fatalf("funcargs in %v", n.Op)
}
if n.Left != nil {
n.Left.Op = ONAME
var i int = 0
for _, n := range nt.Rlist.Slice() {
if n.Op != ODCLFIELD {
- Fatalf("funcargs out %v", oconv(n.Op, 0))
+ Fatalf("funcargs out %v", n.Op)
}
if n.Left == nil {
if Debug['m'] > 2 {
fmt.Printf("%v:[%d] %v escassign: %v(%v)[%v] = %v(%v)[%v]\n",
linestr(lineno), e.loopdepth, funcSym(Curfn),
- Nconv(dst, FmtShort), Jconv(dst, FmtShort), oconv(dst.Op, 0),
- Nconv(src, FmtShort), Jconv(src, FmtShort), oconv(src.Op, 0))
+ Nconv(dst, FmtShort), Jconv(dst, FmtShort), dst.Op,
+ Nconv(src, FmtShort), Jconv(src, FmtShort), src.Op)
}
setlineno(dst)
if Debug['m'] > 2 {
fmt.Printf("escwalk: level:%d depth:%d %.*s op=%v %v(%v) scope:%v[%d] extraloopdepth=%v\n",
- level, e.pdepth, e.pdepth, "\t\t\t\t\t\t\t\t\t\t", oconv(src.Op, 0), Nconv(src, FmtShort), Jconv(src, FmtShort), e.curfnSym(src), srcE.Escloopdepth, extraloopdepth)
+ level, e.pdepth, e.pdepth, "\t\t\t\t\t\t\t\t\t\t", src.Op, Nconv(src, FmtShort), Jconv(src, FmtShort), e.curfnSym(src), srcE.Escloopdepth, extraloopdepth)
}
e.pdepth++
switch s.Def.Op {
default:
- Yyerror("unexpected export symbol: %v %v", oconv(s.Def.Op, 0), s)
+ Yyerror("unexpected export symbol: %v %v", s.Def.Op, s)
case OLITERAL:
dumpexportconst(s)
case OSELECT, OSWITCH:
if fmtmode == FErr {
- f += fmt.Sprintf("%v statement", oconv(n.Op, 0))
+ f += fmt.Sprintf("%v statement", n.Op)
break
}
}
}
- return fmt.Sprintf("<node %v>", oconv(n.Op, 0))
+ return fmt.Sprintf("<node %v>", n.Op)
}
func nodefmt(n *Node, flag FmtFlag) string {
}
if n.Ninit.Len() != 0 {
- fmt.Fprintf(&buf, "%v-init%v", oconv(n.Op, 0), n.Ninit)
+ fmt.Fprintf(&buf, "%v-init%v", n.Op, n.Ninit)
indent(&buf)
}
}
switch n.Op {
default:
- fmt.Fprintf(&buf, "%v%v", oconv(n.Op, 0), Jconv(n, 0))
+ fmt.Fprintf(&buf, "%v%v", n.Op, Jconv(n, 0))
case OREGISTER, OINDREG:
- fmt.Fprintf(&buf, "%v-%v%v", oconv(n.Op, 0), obj.Rconv(int(n.Reg)), Jconv(n, 0))
+ fmt.Fprintf(&buf, "%v-%v%v", n.Op, obj.Rconv(int(n.Reg)), Jconv(n, 0))
case OLITERAL:
- fmt.Fprintf(&buf, "%v-%v%v", oconv(n.Op, 0), Vconv(n.Val(), 0), Jconv(n, 0))
+ fmt.Fprintf(&buf, "%v-%v%v", n.Op, Vconv(n.Val(), 0), Jconv(n, 0))
case ONAME, ONONAME:
if n.Sym != nil {
- fmt.Fprintf(&buf, "%v-%v%v", oconv(n.Op, 0), n.Sym, Jconv(n, 0))
+ fmt.Fprintf(&buf, "%v-%v%v", n.Op, n.Sym, Jconv(n, 0))
} else {
- fmt.Fprintf(&buf, "%v%v", oconv(n.Op, 0), Jconv(n, 0))
+ fmt.Fprintf(&buf, "%v%v", n.Op, Jconv(n, 0))
}
if recur && n.Type == nil && n.Name != nil && n.Name.Param != nil && n.Name.Param.Ntype != nil {
indent(&buf)
- fmt.Fprintf(&buf, "%v-ntype%v", oconv(n.Op, 0), n.Name.Param.Ntype)
+ fmt.Fprintf(&buf, "%v-ntype%v", n.Op, n.Name.Param.Ntype)
}
case OASOP:
- fmt.Fprintf(&buf, "%v-%v%v", oconv(n.Op, 0), oconv(Op(n.Etype), 0), Jconv(n, 0))
+ fmt.Fprintf(&buf, "%v-%v%v", n.Op, Op(n.Etype), Jconv(n, 0))
case OTYPE:
- fmt.Fprintf(&buf, "%v %v%v type=%v", oconv(n.Op, 0), n.Sym, Jconv(n, 0), n.Type)
+ fmt.Fprintf(&buf, "%v %v%v type=%v", n.Op, n.Sym, Jconv(n, 0), n.Type)
if recur && n.Type == nil && n.Name.Param.Ntype != nil {
indent(&buf)
- fmt.Fprintf(&buf, "%v-ntype%v", oconv(n.Op, 0), n.Name.Param.Ntype)
+ fmt.Fprintf(&buf, "%v-ntype%v", n.Op, n.Name.Param.Ntype)
}
}
}
if n.List.Len() != 0 {
indent(&buf)
- fmt.Fprintf(&buf, "%v-list%v", oconv(n.Op, 0), n.List)
+ fmt.Fprintf(&buf, "%v-list%v", n.Op, n.List)
}
if n.Rlist.Len() != 0 {
indent(&buf)
- fmt.Fprintf(&buf, "%v-rlist%v", oconv(n.Op, 0), n.Rlist)
+ fmt.Fprintf(&buf, "%v-rlist%v", n.Op, n.Rlist)
}
if n.Nbody.Len() != 0 {
indent(&buf)
- fmt.Fprintf(&buf, "%v-body%v", oconv(n.Op, 0), n.Nbody)
+ fmt.Fprintf(&buf, "%v-body%v", n.Op, n.Nbody)
}
}
func cgen_proc(n *Node, proc int) {
switch n.Left.Op {
default:
- Fatalf("cgen_proc: unknown call %v", oconv(n.Left.Op, 0))
+ Fatalf("cgen_proc: unknown call %v", n.Left.Op)
case OCALLMETH:
cgen_callmeth(n.Left, proc)
a := a // copy to let escape into Ctxt.Dconv
Debug['h'] = 1
Dump("naddr", n)
- Fatalf("naddr: bad %v %v", oconv(n.Op, 0), Ctxt.Dconv(a))
+ Fatalf("naddr: bad %v %v", n.Op, Ctxt.Dconv(a))
case OREGISTER:
a.Type = obj.TYPE_REG
if !n.Left.Type.IsStruct() || n.Left.Type.Field(0).Sym != n.Sym {
Debug['h'] = 1
Dump("naddr", n)
- Fatalf("naddr: bad %v %v", oconv(n.Op, 0), Ctxt.Dconv(a))
+ Fatalf("naddr: bad %v %v", n.Op, Ctxt.Dconv(a))
}
Naddr(a, n.Left)
}
if a.Type != obj.TYPE_MEM {
a := a // copy to let escape into Ctxt.Dconv
- Fatalf("naddr: OADDR %v (from %v)", Ctxt.Dconv(a), oconv(n.Left.Op, 0))
+ Fatalf("naddr: OADDR %v (from %v)", Ctxt.Dconv(a), n.Left.Op)
}
a.Type = obj.TYPE_ADDR
a.Right = r
return typecheck(&a, Erv)
default:
- Fatalf("ordersafeexpr %v", oconv(n.Op, 0))
+ Fatalf("ordersafeexpr %v", n.Op)
return nil // not reached
}
}
func ordermapassign(n *Node, order *Order) {
switch n.Op {
default:
- Fatalf("ordermapassign %v", oconv(n.Op, 0))
+ Fatalf("ordermapassign %v", n.Op)
case OAS:
order.out = append(order.out, n)
switch n.Op {
default:
- Fatalf("orderstmt %v", oconv(n.Op, 0))
+ Fatalf("orderstmt %v", n.Op)
case OVARKILL, OVARLIVE:
order.out = append(order.out, n)
var r *Node
for _, n2 := range n.List.Slice() {
if n2.Op != OXCASE {
- Fatalf("order select case %v", oconv(n2.Op, 0))
+ Fatalf("order select case %v", n2.Op)
}
r = n2.Left
setlineno(n2)
if r != nil {
switch r.Op {
default:
- Yyerror("unknown op in select %v", oconv(r.Op, 0))
+ Yyerror("unknown op in select %v", r.Op)
Dump("select case", r)
// If this is case x := <-ch or case x, y := <-ch, the case has
n.Left = orderexpr(n.Left, order, nil)
for _, n4 := range n.List.Slice() {
if n4.Op != OXCASE {
- Fatalf("order switch case %v", oconv(n4.Op, 0))
+ Fatalf("order switch case %v", n4.Op)
}
orderexprlistinplace(n4.List, order)
orderblockNodes(&n4.Nbody)
switch n.Op {
default:
- Fatalf("instrument: unknown node type %v", oconv(n.Op, 0))
+ Fatalf("instrument: unknown node type %v", n.Op)
case OAS, OASWB, OAS2FUNC:
instrumentnode(&n.Left, init, 1, 0)
OAS2RECV,
OAS2MAPR,
OASOP:
- Yyerror("instrument: %v must be lowered by now", oconv(n.Op, 0))
+ Yyerror("instrument: %v must be lowered by now", n.Op)
goto ret
// impossible nodes: only appear in backend.
case ORROTC, OEXTEND:
- Yyerror("instrument: %v cannot exist now", oconv(n.Op, 0))
+ Yyerror("instrument: %v cannot exist now", n.Op)
goto ret
case OGETG:
ncase = n1
setlineno(ncase)
if ncase.Op != OXCASE {
- Fatalf("typecheckselect %v", oconv(ncase.Op, 0))
+ Fatalf("typecheckselect %v", ncase.Op)
}
if ncase.List.Len() == 0 {
var ch *Node
switch n.Op {
default:
- Fatalf("select %v", oconv(n.Op, 0))
+ Fatalf("select %v", n.Op)
// ok already
case OSEND:
r.Ninit.Set(cas.Ninit.Slice())
switch n.Op {
default:
- Fatalf("select %v", oconv(n.Op, 0))
+ Fatalf("select %v", n.Op)
// if selectnbsend(c, v) { body } else { default body }
case OSEND:
} else {
switch n.Op {
default:
- Fatalf("select %v", oconv(n.Op, 0))
+ Fatalf("select %v", n.Op)
// selectsend(sel *byte, hchan *chan any, elem *any) (selected bool);
case OSEND:
// want to set it here.
case OCALLINTER:
if fn.Op != ODOTINTER {
- Fatalf("OCALLINTER: n.Left not an ODOTINTER: %v", oconv(fn.Op, 0))
+ Fatalf("OCALLINTER: n.Left not an ODOTINTER: %v", fn.Op)
}
i := s.expr(fn.Left)
itab := s.newValue1(ssa.OpITab, Types[TUINTPTR], i)
return s.call(n, callNormal)
default:
- s.Unimplementedf("unhandled addr %v", oconv(n.Op, 0))
+ s.Unimplementedf("unhandled addr %v", n.Op)
return nil
}
}
}
switch n.Op {
case ONAME:
- fmt.Printf("%v %v G%d %v width=%d\n", oconv(n.Op, 0), n.Sym, n.Name.Vargen, n.Type, w)
+ fmt.Printf("%v %v G%d %v width=%d\n", n.Op, n.Sym, n.Name.Vargen, n.Type, w)
case OTYPE:
- fmt.Printf("%v %v width=%d\n", oconv(n.Op, 0), n.Type, w)
+ fmt.Printf("%v %v width=%d\n", n.Op, n.Type, w)
}
}
}
s := fmt_
- Yyerror("illegal types for operand: %v%s", oconv(op, 0), s)
+ Yyerror("illegal types for operand: %v%s", op, s)
}
// Brcom returns !(op).
case OGE:
return OLT
}
- Fatalf("brcom: no com for %v\n", oconv(op, 0))
+ Fatalf("brcom: no com for %v\n", op)
return op
}
case OGE:
return OLE
}
- Fatalf("brrev: no rev for %v\n", oconv(op, 0))
+ Fatalf("brrev: no rev for %v\n", op)
return op
}
for i, n := range sw.List.Slice() {
setlineno(n)
if n.Op != OXCASE {
- Fatalf("casebody %v", oconv(n.Op, 0))
+ Fatalf("casebody %v", n.Op)
}
n.Op = OCASE
needvar := n.List.Len() != 1 || n.List.First().Op == OLITERAL
default:
Dump("typecheck", n)
- Fatalf("typecheck %v", oconv(n.Op, 0))
+ Fatalf("typecheck %v", n.Op)
// names
case OLITERAL:
aop = assignop(l.Type, r.Type, nil)
if aop != 0 {
if r.Type.IsInterface() && !l.Type.IsInterface() && !l.Type.IsComparable() {
- Yyerror("invalid operation: %v (operator %v not defined on %s)", n, oconv(op, 0), typekind(l.Type))
+ Yyerror("invalid operation: %v (operator %v not defined on %s)", n, op, typekind(l.Type))
n.Type = nil
return n
}
aop = assignop(r.Type, l.Type, nil)
if aop != 0 {
if l.Type.IsInterface() && !r.Type.IsInterface() && !r.Type.IsComparable() {
- Yyerror("invalid operation: %v (operator %v not defined on %s)", n, oconv(op, 0), typekind(r.Type))
+ Yyerror("invalid operation: %v (operator %v not defined on %s)", n, op, typekind(r.Type))
n.Type = nil
return n
}
}
if !okfor[op][et] {
- Yyerror("invalid operation: %v (operator %v not defined on %s)", n, oconv(op, 0), typekind(t))
+ Yyerror("invalid operation: %v (operator %v not defined on %s)", n, op, typekind(t))
n.Type = nil
return n
}
return n
}
if !okfor[n.Op][t.Etype] {
- Yyerror("invalid operation: %v %v", oconv(n.Op, 0), t)
+ Yyerror("invalid operation: %v %v", n.Op, t)
n.Type = nil
return n
}
case OCAP, OLEN, OREAL, OIMAG:
ok |= Erv
- if !onearg(n, "%v", oconv(n.Op, 0)) {
+ if !onearg(n, "%v", n.Op) {
n.Type = nil
return n
}
break OpSwitch
badcall1:
- Yyerror("invalid argument %v for %v", Nconv(n.Left, FmtLong), oconv(n.Op, 0))
+ Yyerror("invalid argument %v for %v", Nconv(n.Left, FmtLong), n.Op)
n.Type = nil
return n
break OpSwitch
case OCLOSE:
- if !onearg(n, "%v", oconv(n.Op, 0)) {
+ if !onearg(n, "%v", n.Op) {
n.Type = nil
return n
}
return true
}
if n.List.Len() == 0 {
- Yyerror("missing argument to %v - %v", oconv(n.Op, 0), n)
+ Yyerror("missing argument to %v - %v", n.Op, n)
return false
}
n.Left = n.List.First()
if n.List.Len() == 1 {
- Yyerror("missing argument to %v - %v", oconv(n.Op, 0), n)
+ Yyerror("missing argument to %v - %v", n.Op, n)
n.List.Set(nil)
return false
}
if n.List.Len() > 2 {
- Yyerror("too many arguments to %v - %v", oconv(n.Op, 0), n)
+ Yyerror("too many arguments to %v - %v", n.Op, n)
n.List.Set(nil)
return false
}
if call != nil {
Yyerror("invalid use of ... in call to %v", call)
} else {
- Yyerror("invalid use of ... in %v", oconv(op, 0))
+ Yyerror("invalid use of ... in %v", op)
}
}
Yyerror("not enough arguments in call to %v", call)
}
} else {
- Yyerror("not enough arguments to %v", oconv(op, 0))
+ Yyerror("not enough arguments to %v", op)
}
if n != nil {
n.Diag = 1
if call != nil {
Yyerror("too many arguments in call to %v", call)
} else {
- Yyerror("too many arguments to %v", oconv(op, 0))
+ Yyerror("too many arguments to %v", op)
}
goto out
}
switch n.Op {
default:
- Fatalf("typecheckdef %v", oconv(n.Op, 0))
+ Fatalf("typecheckdef %v", n.Op)
// not really syms
case OGOTO, OLABEL:
if n.Op == ONAME {
Yyerror("%v is not a top level statement", n.Sym)
} else {
- Yyerror("%v is not a top level statement", oconv(n.Op, 0))
+ Yyerror("%v is not a top level statement", n.Op)
}
Dump("nottop", n)
// ifaceeq(i1 any-1, i2 any-2) (ret bool);
case OCMPIFACE:
if !Eqtype(n.Left.Type, n.Right.Type) {
- Fatalf("ifaceeq %v %v %v", oconv(n.Op, 0), n.Left.Type, n.Right.Type)
+ Fatalf("ifaceeq %v %v %v", n.Op, n.Left.Type, n.Right.Type)
}
var fn *Node
if n.Left.Type.IsEmptyInterface() {
var nln, nrn Nodes
nln.Set(nl)
nrn.Set(nr)
- Yyerror("error in shape across %v %v %v / %d %d [%s]", Hconv(nln, FmtSign), oconv(op, 0), Hconv(nrn, FmtSign), len(nl), len(nr), Curfn.Func.Nname.Sym.Name)
+ Yyerror("error in shape across %v %v %v / %d %d [%s]", Hconv(nln, FmtSign), op, Hconv(nrn, FmtSign), len(nl), len(nr), Curfn.Func.Nname.Sym.Name)
}
return nn
}
l1 := dumptypes(nl, "expected")
l2 := dumpnodetypes(lr0, "given")
if l != nil {
- Yyerror("not enough arguments to %v\n\t%s\n\t%s", oconv(op, 0), l1, l2)
+ Yyerror("not enough arguments to %v\n\t%s\n\t%s", op, l1, l2)
} else {
- Yyerror("too many arguments to %v\n\t%s\n\t%s", oconv(op, 0), l1, l2)
+ Yyerror("too many arguments to %v\n\t%s\n\t%s", op, l1, l2)
}
}
func convas(n *Node, init *Nodes) *Node {
if n.Op != OAS {
- Fatalf("convas: not OAS %v", oconv(n.Op, 0))
+ Fatalf("convas: not OAS %v", n.Op)
}
n.Typecheck = 1
switch n.Op {
default:
- Fatalf("usefield %v", oconv(n.Op, 0))
+ Fatalf("usefield %v", n.Op)
case ODOT, ODOTPTR:
break