]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/compile: only look for struct type when crawling inline body
authorCuong Manh Le <cuong.manhle.vn@gmail.com>
Thu, 21 Oct 2021 07:31:40 +0000 (14:31 +0700)
committerCuong Manh Le <cuong.manhle.vn@gmail.com>
Fri, 22 Oct 2021 00:57:18 +0000 (00:57 +0000)
CL 356254 fixed crawling of embeddable types during inline. However, we
are too agressive, since when we call markEmbed for every type seen
during inlining function body. That leads to false positive that for a
non-embedded type, its unexported methods are also marked inline.

Instead, we should only look at struct type that we seen during inlining
function body, and calling markEmbed for all of its embedded fields.

Fixes #49094

Change-Id: I6ef9a8bf1fc649ec6bf75e4883f6031ec8560ba1
Reviewed-on: https://go-review.googlesource.com/c/go/+/357232
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>
src/cmd/compile/internal/typecheck/crawler.go
test/fixedbugs/issue49094.dir/a.go [new file with mode: 0644]
test/fixedbugs/issue49094.dir/b.go [new file with mode: 0644]
test/fixedbugs/issue49094.dir/p.go [new file with mode: 0644]
test/fixedbugs/issue49094.go [new file with mode: 0644]

index b214ef22799dc84c1edb40c16e0594343f03db6e..e1489ceeddd840f25924a5aef4e8f0ee725b0b0e 100644 (file)
@@ -217,7 +217,13 @@ func (p *crawler) markInlBody(n *ir.Name) {
                                //
                                // We generate the wrapper for "struct{ t }".M, and inline call
                                // to "struct{ t }".M, which makes "t.M" reachable.
-                               p.markEmbed(t)
+                               if t.IsStruct() {
+                                       for _, f := range t.FieldSlice() {
+                                               if f.Embedded != 0 {
+                                                       p.markEmbed(f.Type)
+                                               }
+                                       }
+                               }
                        }
                }
 
diff --git a/test/fixedbugs/issue49094.dir/a.go b/test/fixedbugs/issue49094.dir/a.go
new file mode 100644 (file)
index 0000000..9ec0fd9
--- /dev/null
@@ -0,0 +1,11 @@
+// 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 A struct{}
+
+func (a *A) f() bool {
+       return true
+}
diff --git a/test/fixedbugs/issue49094.dir/b.go b/test/fixedbugs/issue49094.dir/b.go
new file mode 100644 (file)
index 0000000..f236195
--- /dev/null
@@ -0,0 +1,11 @@
+// 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 b
+
+import "./a"
+
+func M(r *a.A) string {
+       return ""
+}
diff --git a/test/fixedbugs/issue49094.dir/p.go b/test/fixedbugs/issue49094.dir/p.go
new file mode 100644 (file)
index 0000000..581faf1
--- /dev/null
@@ -0,0 +1,15 @@
+// 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 p
+
+import (
+       "./b"
+)
+
+type S struct{}
+
+func (S) M() {
+       b.M(nil)
+}
diff --git a/test/fixedbugs/issue49094.go b/test/fixedbugs/issue49094.go
new file mode 100644 (file)
index 0000000..b83fbd7
--- /dev/null
@@ -0,0 +1,7 @@
+// compiledir
+
+// 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 ignored