diff options
author | Tianon Gravi <admwiggin@gmail.com> | 2015-05-02 10:03:50 -0600 |
---|---|---|
committer | Tianon Gravi <admwiggin@gmail.com> | 2015-05-02 10:03:50 -0600 |
commit | 900a90fa45bc1ef792101287b5c997c287c7f88b (patch) | |
tree | 2be89b4956247b3354c8f7f51269621beb5684be /test/fixedbugs/issue9537.dir | |
parent | f913cbd2a32ec6764e4b7be9c8a300322459a9c2 (diff) | |
parent | 839657a730bd3c82d1b7932f996dd87448eb7d38 (diff) | |
download | golang-900a90fa45bc1ef792101287b5c997c287c7f88b.tar.gz |
Merge tag 'upstream/1.4.2' into debian-sid
* tag 'upstream/1.4.2':
Imported Upstream version 1.4.2
Diffstat (limited to 'test/fixedbugs/issue9537.dir')
-rw-r--r-- | test/fixedbugs/issue9537.dir/a.go | 25 | ||||
-rw-r--r-- | test/fixedbugs/issue9537.dir/b.go | 43 |
2 files changed, 68 insertions, 0 deletions
diff --git a/test/fixedbugs/issue9537.dir/a.go b/test/fixedbugs/issue9537.dir/a.go new file mode 100644 index 000000000..818c9eb4a --- /dev/null +++ b/test/fixedbugs/issue9537.dir/a.go @@ -0,0 +1,25 @@ +// 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 a + +type X struct { + T [32]byte +} + +func (x *X) Get() []byte { + t := x.T + return t[:] +} + +func (x *X) RetPtr(i int) *int { + i++ + return &i +} + +func (x *X) RetRPtr(i int) (r1 int, r2 *int) { + r1 = i + 1 + r2 = &r1 + return +} diff --git a/test/fixedbugs/issue9537.dir/b.go b/test/fixedbugs/issue9537.dir/b.go new file mode 100644 index 000000000..52e64c81f --- /dev/null +++ b/test/fixedbugs/issue9537.dir/b.go @@ -0,0 +1,43 @@ +// 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 ( + "bytes" + + "./a" +) + +type X struct { + *a.X +} + +type Intf interface { + Get() []byte + RetPtr(int) *int + RetRPtr(int) (int, *int) +} + +func main() { + x := &a.X{T: [32]byte{1, 2, 3, 4}} + var ix Intf = X{x} + t1 := ix.Get() + t2 := x.Get() + if !bytes.Equal(t1, t2) { + panic(t1) + } + + p1 := ix.RetPtr(5) + p2 := x.RetPtr(7) + if *p1 != 6 || *p2 != 8 { + panic(*p1) + } + + r1, r2 := ix.RetRPtr(10) + r3, r4 := x.RetRPtr(13) + if r1 != 11 || *r2 != 11 || r3 != 14 || *r4 != 14 { + panic("bad RetRPtr") + } +} |