1
0
mirror of https://github.com/golang/go synced 2024-11-25 03:57:56 -07:00

cmd/gc: do not confuse unexported methods of same name

Fixes #3146.

R=ken2
CC=golang-dev
https://golang.org/cl/5756074
This commit is contained in:
Russ Cox 2012-03-07 01:55:17 -05:00
parent 105c5fa666
commit 987a580b9f
4 changed files with 27 additions and 15 deletions

View File

@ -1195,10 +1195,17 @@ methodsym(Sym *nsym, Type *t0, int iface)
if(t0->width < types[tptr]->width)
suffix = "·i";
}
if(t0->sym == S && isptr[t0->etype])
p = smprint("(%-hT).%s%s", t0, nsym->name, suffix);
else
p = smprint("%-hT.%s%s", t0, nsym->name, suffix);
if(nsym->pkg != s->pkg && !exportname(nsym->name)) {
if(t0->sym == S && isptr[t0->etype])
p = smprint("(%-hT).%s.%s%s", t0, nsym->pkg->prefix, nsym->name, suffix);
else
p = smprint("%-hT.%s.%s%s", t0, nsym->pkg->prefix, nsym->name, suffix);
} else {
if(t0->sym == S && isptr[t0->etype])
p = smprint("(%-hT).%s%s", t0, nsym->name, suffix);
else
p = smprint("%-hT.%s%s", t0, nsym->name, suffix);
}
s = pkglookup(p, s->pkg);
free(p);
return s;

View File

@ -1,9 +0,0 @@
// $G $D/$F.dir/lib.go && $G $D/$F.dir/main.go && $L main.$A && $A.out
// 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.
// Test case for embedded method invocation.
ignored

View File

@ -1,3 +1,5 @@
// run
// 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.
@ -9,7 +11,9 @@
package main
import "./lib"
import "./bug424.dir"
import "reflect"
import "fmt"
type localI interface {
m() string
@ -53,9 +57,19 @@ func main() {
println("BUG: myT2:", i.m(), "called")
}
i = new(myT3)
if i.m() != "main.localT.m" {
println("BUG: myT3:", i.m(), "called")
t3 := new(myT3)
if t3.m() != "main.localT.m" {
println("BUG: t3:", t3.m(), "called")
}
i = new(myT3)
if i.m() != "main.localT.m" {
t := reflect.TypeOf(i)
n := t.NumMethod()
for j := 0; j < n; j++ {
m := t.Method(j)
fmt.Printf("#%d: %s.%s %s\n", j, m.PkgPath, m.Name, m.Type)
}
println("BUG: myT3:", i.m(), "called")
}
}