Commit 7dd90621 authored by Russ Cox's avatar Russ Cox

gc: diagnose field+method of same name

Fixes #2828.

R=ken2
CC=golang-dev
https://golang.org/cl/5653065
parent 2aafad25
......@@ -1303,6 +1303,14 @@ addmethod(Sym *sf, Type *t, int local)
}
pa = f;
if(pa->etype == TSTRUCT) {
for(f=pa->type; f; f=f->down) {
if(f->sym == sf) {
yyerror("type %T has both field and method named %S", pa, sf);
return;
}
}
}
n = nod(ODCLFIELD, newname(sf), N);
n->type = t;
......
// errchk $G $D/$F.go
// Copyright 2012 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.
package p
type T struct {
X int
}
func (t *T) X() {} // ERROR "type T has both field and method named X"
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