go source for verification 2026-05-22
This commit is contained in:
29
test/fixedbugs/issue42284.dir/a.go
Normal file
29
test/fixedbugs/issue42284.dir/a.go
Normal file
@@ -0,0 +1,29 @@
|
||||
// Copyright 2020 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 I interface{ M() }
|
||||
type T int
|
||||
|
||||
func (T) M() {} // ERROR "can inline T.M"
|
||||
|
||||
func E() I { // ERROR "can inline E"
|
||||
return T(0) // ERROR "T\(0\) escapes to heap"
|
||||
}
|
||||
|
||||
func F(i I) I { // ERROR "can inline F" "leaking param: i to result ~r0 level=0"
|
||||
i = nil
|
||||
return i
|
||||
}
|
||||
|
||||
func g() {
|
||||
h := E() // ERROR "inlining call to E" "T\(0\) does not escape"
|
||||
h.M() // ERROR "devirtualizing h.M to T" "inlining call to T.M"
|
||||
|
||||
i := F(T(0)) // ERROR "inlining call to F" "T\(0\) does not escape"
|
||||
|
||||
// It is fine that we devirtualize here, as we add an additional nilcheck.
|
||||
i.M() // ERROR "devirtualizing i.M to T" "inlining call to T.M"
|
||||
}
|
||||
17
test/fixedbugs/issue42284.dir/b.go
Normal file
17
test/fixedbugs/issue42284.dir/b.go
Normal file
@@ -0,0 +1,17 @@
|
||||
// Copyright 2020 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 g() {
|
||||
h := a.E() // ERROR "inlining call to a.E" "T\(0\) does not escape"
|
||||
h.M() // ERROR "devirtualizing h.M to a.T" "inlining call to a.T.M"
|
||||
|
||||
i := a.F(a.T(0)) // ERROR "inlining call to a.F" "a.T\(0\) does not escape"
|
||||
|
||||
// It is fine that we devirtualize here, as we add an additional nilcheck.
|
||||
i.M() // ERROR "devirtualizing i.M to a.T" "inlining call to a.T.M"
|
||||
}
|
||||
Reference in New Issue
Block a user