Skip to content

Commit

Permalink
cmd/compile: propagate correct line numbers in treecopy
Browse files Browse the repository at this point in the history
Added a lineno parameter to treecopy and listtreecopy
(ignored if = 0).  When nodes are copied the copy is
assigned the non-zero lineno (normally this would be
the destination).

Fixes golang#8183

Change-Id: Iffb767a745093fb89aa08bf8a7692c2f0122be98
Reviewed-on: https://go-review.googlesource.com/10334
Reviewed-by: Russ Cox <[email protected]>
  • Loading branch information
dr2chase committed May 27, 2015
1 parent 2150001 commit 05d8f1d
Show file tree
Hide file tree
Showing 5 changed files with 45 additions and 10 deletions.
5 changes: 3 additions & 2 deletions src/cmd/compile/internal/gc/dcl.go
Original file line number Diff line number Diff line change
Expand Up @@ -313,18 +313,19 @@ func variter(vl *NodeList, t *Node, el *NodeList) *NodeList {
* new_name_list [[type] = expr_list]
*/
func constiter(vl *NodeList, t *Node, cl *NodeList) *NodeList {
lno := int32(0) // default is to leave line number alone in listtreecopy
if cl == nil {
if t != nil {
Yyerror("const declaration cannot have type without expression")
}
cl = lastconst
t = lasttype
lno = vl.N.Lineno
} else {
lastconst = cl
lasttype = t
}

cl = listtreecopy(cl)
cl = listtreecopy(cl, lno)

var v *Node
var c *Node
Expand Down
2 changes: 1 addition & 1 deletion src/cmd/compile/internal/gc/order.go
Original file line number Diff line number Diff line change
Expand Up @@ -498,7 +498,7 @@ func orderstmt(n *Node, order *Order) {

orderexpr(&n.Left, order, nil)
n.Left = ordersafeexpr(n.Left, order)
tmp1 := treecopy(n.Left)
tmp1 := treecopy(n.Left, 0)
if tmp1.Op == OINDEXMAP {
tmp1.Etype = 0 // now an rvalue not an lvalue
}
Expand Down
2 changes: 1 addition & 1 deletion src/cmd/compile/internal/gc/racewalk.go
Original file line number Diff line number Diff line change
Expand Up @@ -483,7 +483,7 @@ func callinstr(np **Node, init **NodeList, wr int, skip int) bool {
*np = n
}

n = treecopy(n)
n = treecopy(n, 0)
makeaddable(n)
var f *Node
if t.Etype == TSTRUCT || Isfixedarray(t) {
Expand Down
23 changes: 17 additions & 6 deletions src/cmd/compile/internal/gc/subr.go
Original file line number Diff line number Diff line change
Expand Up @@ -736,7 +736,12 @@ func aindex(b *Node, t *Type) *Type {
return r
}

func treecopy(n *Node) *Node {
// treecopy recursively copies n, with the exception of
// ONAME, OLITERAL, OTYPE, and non-iota ONONAME leaves.
// Copies of iota ONONAME nodes are assigned the current
// value of iota_. If lineno != 0, it sets the line number
// of newly allocated nodes to lineno.
func treecopy(n *Node, lineno int32) *Node {
if n == nil {
return nil
}
Expand All @@ -747,9 +752,12 @@ func treecopy(n *Node) *Node {
m = Nod(OXXX, nil, nil)
*m = *n
m.Orig = m
m.Left = treecopy(n.Left)
m.Right = treecopy(n.Right)
m.List = listtreecopy(n.List)
m.Left = treecopy(n.Left, lineno)
m.Right = treecopy(n.Right, lineno)
m.List = listtreecopy(n.List, lineno)
if lineno != -1 {
m.Lineno = lineno
}
if m.Defn != nil {
panic("abort")
}
Expand All @@ -764,6 +772,9 @@ func treecopy(n *Node) *Node {

*m = *n
m.Iota = iota_
if lineno != 0 {
m.Lineno = lineno
}
break
}
fallthrough
Expand Down Expand Up @@ -3092,10 +3103,10 @@ func Simsimtype(t *Type) int {
return et
}

func listtreecopy(l *NodeList) *NodeList {
func listtreecopy(l *NodeList, lineno int32) *NodeList {
var out *NodeList
for ; l != nil; l = l.Next {
out = list(out, treecopy(l.N))
out = list(out, treecopy(l.N, lineno))
}
return out
}
Expand Down
23 changes: 23 additions & 0 deletions test/fixedbugs/issue8183.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
// errorcheck

// Copyright 2015 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

// Tests correct reporting of line numbers for errors involving iota,
// Issue #8183.
package foo

const (
ok = byte(iota + 253)
bad
barn
bard // ERROR "constant 256 overflows byte"
)

const (
c = len([1 - iota]int{})
d
e // ERROR "array bound must be non-negative" "const initializer len\(composite literal\) is not a constant"
f // ERROR "array bound must be non-negative" "const initializer len\(composite literal\) is not a constant"
)

0 comments on commit 05d8f1d

Please sign in to comment.