1
0
mirror of https://github.com/golang/go synced 2024-11-26 21:51:44 -07:00
go/test/fixedbugs/issue11053.dir/p_test.go
Matthew Dempsky 999589e148 test: use dot-relative imports where appropriate
Currently, run.go's *dir tests allow "x.go" to be imported
interchangeably as either "x" or "./x". This is generally fine, but
can cause problems when "x" is the name of a standard library
package (e.g., "fixedbugs/bug345.dir/io.go").

This CL is an automated rewrite to change all `import "x"` directives
to use `import "./x"` instead. It has no effect today, but will allow
subsequent CLs to update test/run.go to resolve "./x" to "test/x" to
avoid stdlib collisions.

Change-Id: Ic76cd7140e83b47e764f8a499e59936be2b3c876
Reviewed-on: https://go-review.googlesource.com/c/go/+/395116
Trust: Matthew Dempsky <mdempsky@google.com>
Run-TryBot: Matthew Dempsky <mdempsky@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Ian Lance Taylor <iant@golang.org>
2022-03-24 02:14:15 +00:00

52 lines
828 B
Go

// Copyright 2015 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 main
import (
"./p"
"fmt"
)
type I interface {
Add(out *P)
}
type P struct {
V *int32
}
type T struct{}
var x int32 = 42
func Int32x(i int32) *int32 {
return &i
}
func (T) Add(out *P) {
out.V = p.Int32(x) // inlined, p.i.2 moved to heap
}
var PP P
var out *P = &PP
func F(s I) interface{} {
s.Add(out) // not inlined.
return out
}
var s T
func main() {
println("Starting")
fmt.Sprint(new(int32))
resp := F(s).(*P)
println("Before, *resp.V=", *resp.V) // Trashes *resp.V in process of printing.
println("After, *resp.V=", *resp.V)
if got, want := *resp.V, int32(42); got != want {
fmt.Printf("FAIL, got %v, want %v", got, want)
}
}