From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository. --- gcc/testsuite/go.test/test/initialize.go | 62 ++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 gcc/testsuite/go.test/test/initialize.go (limited to 'gcc/testsuite/go.test/test/initialize.go') diff --git a/gcc/testsuite/go.test/test/initialize.go b/gcc/testsuite/go.test/test/initialize.go new file mode 100644 index 000000000..6dd7d67dc --- /dev/null +++ b/gcc/testsuite/go.test/test/initialize.go @@ -0,0 +1,62 @@ +// $G $D/$F.go && $L $F.$A && ./$A.out + +// Copyright 2009 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 "fmt" +import "reflect" + +type S struct { + A, B, C, X, Y, Z int +} + +type T struct { + S +} + +var a1 = S { 0, 0, 0, 1, 2, 3 } +var b1 = S { X: 1, Z: 3, Y: 2 } + +var a2 = S { 0, 0, 0, 0, 0, 0, } +var b2 = S { } + +var a3 = T { S { 1, 2, 3, 0, 0, 0, } } +var b3 = T { S: S{ A: 1, B: 2, C: 3 } } + +var a4 = &[16]byte { 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, } +var b4 = &[16]byte { 4: 1, 1, 1, 1, 12: 1, 1, } + +var a5 = &[16]byte { 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, } +var b5 = &[16]byte { 1, 4: 1, 1, 1, 1, 12: 1, 1, } + +var a6 = &[16]byte { 1, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 0, 0, } +var b6 = &[...]byte { 1, 4: 1, 1, 1, 1, 12: 1, 1, 0, 0,} + +type Same struct { + a, b interface{} +} + +var same = []Same { + Same{ a1, b1 }, + Same{ a2, b2 }, + Same{ a3, b3 }, + Same{ a4, b4 }, + Same{ a5, b5 }, + Same{ a6, b6 }, +} + +func main() { + ok := true + for _, s := range same { + if !reflect.DeepEqual(s.a, s.b) { + ok = false + fmt.Printf("not same: %v and %v\n", s.a, s.b) + } + } + if !ok { + fmt.Println("BUG: test/initialize") + } +} -- cgit v1.2.3