mirror of
https://github.com/golang/go
synced 2024-11-24 06:40:17 -07:00
4e565f7372
In CL 327872, there's a fix for crawling of embeddable types directly reached by the user, so all of its methods need to be re-exported. But we missed the cased when an un-exported type may be reachable by embedding in exported type. Example: type t struct {} func (t) M() {} func F() interface{} { return struct{ t }{} } We generate the wrapper for "struct{ t }".M, and when inlining call to "struct{ t }".M makes "t.M" reachable. It works well, and only be revealed in CL 327871, when we changed methodWrapper to always call inline.InlineCalls, thus causes the crash in #49016, which involve dot type in inlined function. Fixes #49016 Change-Id: If174fa5575132da5cf60e4bd052f7011c4e76c5d Reviewed-on: https://go-review.googlesource.com/c/go/+/356254 Trust: Cuong Manh Le <cuong.manhle.vn@gmail.com> Run-TryBot: Cuong Manh Le <cuong.manhle.vn@gmail.com> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Matthew Dempsky <mdempsky@google.com>
37 lines
543 B
Go
37 lines
543 B
Go
// Copyright 2021 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 a
|
|
|
|
type Node interface {
|
|
Position()
|
|
}
|
|
|
|
type noder struct{}
|
|
|
|
func (noder) Position() {}
|
|
|
|
type Scope map[int][]Node
|
|
|
|
func (s Scope) M1() Scope {
|
|
if x, ok := s[0]; ok {
|
|
return x[0].(struct {
|
|
noder
|
|
Scope
|
|
}).Scope
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (s Scope) M2() Scope {
|
|
if x, ok := s[0]; ok {
|
|
st, _ := x[0].(struct {
|
|
noder
|
|
Scope
|
|
})
|
|
return st.Scope
|
|
}
|
|
return nil
|
|
}
|