2008-12-19 13:05:22 -07:00
|
|
|
// $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";
|
2009-04-16 21:52:37 -06:00
|
|
|
"os";
|
2008-12-19 13:05:22 -07:00
|
|
|
)
|
|
|
|
|
2009-01-20 15:40:40 -07:00
|
|
|
type T struct {
|
2008-12-19 13:05:22 -07:00
|
|
|
a float64;
|
|
|
|
b int64;
|
|
|
|
c string;
|
|
|
|
d byte;
|
|
|
|
}
|
|
|
|
|
2009-03-03 09:39:12 -07:00
|
|
|
var a = []int{ 1, 2, 3 }
|
2009-01-20 15:40:40 -07:00
|
|
|
var NIL []int;
|
2008-12-19 13:05:22 -07:00
|
|
|
|
|
|
|
func arraycmptest() {
|
|
|
|
a1 := a;
|
|
|
|
if NIL != nil {
|
|
|
|
println("fail1:", NIL, "!= nil");
|
|
|
|
}
|
|
|
|
if nil != NIL {
|
|
|
|
println("fail2: nil !=", NIL);
|
|
|
|
}
|
|
|
|
if a == nil || nil == a {
|
|
|
|
println("fail3:", a, "== nil");
|
|
|
|
}
|
2008-12-19 18:11:54 -07:00
|
|
|
}
|
|
|
|
|
2009-01-20 15:40:40 -07:00
|
|
|
func SameArray(a, b []int) bool {
|
2008-12-19 18:11:54 -07:00
|
|
|
if len(a) != len(b) || cap(a) != cap(b) {
|
|
|
|
return false;
|
2008-12-19 13:05:22 -07:00
|
|
|
}
|
2008-12-19 18:11:54 -07:00
|
|
|
if len(a) > 0 && &a[0] != &b[0] {
|
|
|
|
return false;
|
2008-12-19 13:05:22 -07:00
|
|
|
}
|
2008-12-19 18:11:54 -07:00
|
|
|
return true;
|
2008-12-19 13:05:22 -07:00
|
|
|
}
|
|
|
|
|
2009-03-03 09:39:12 -07:00
|
|
|
var t = T{1.5, 123, "hello", 255}
|
2009-01-06 16:19:02 -07:00
|
|
|
var mt = make(map[int]T)
|
|
|
|
var ma = make(map[int][]int)
|
2008-12-19 13:05:22 -07:00
|
|
|
|
|
|
|
func maptest() {
|
|
|
|
mt[0] = t;
|
|
|
|
t1 := mt[0];
|
|
|
|
if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d {
|
|
|
|
println("fail: map val struct", t1.a, t1.b, t1.c, t1.d);
|
|
|
|
}
|
|
|
|
|
|
|
|
ma[1] = a;
|
|
|
|
a1 := ma[1];
|
2008-12-19 18:11:54 -07:00
|
|
|
if !SameArray(a, a1) {
|
2008-12-19 13:05:22 -07:00
|
|
|
println("fail: map val array", a, a1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-01-06 16:19:02 -07:00
|
|
|
var ct = make(chan T)
|
|
|
|
var ca = make(chan []int)
|
2008-12-19 13:05:22 -07:00
|
|
|
|
|
|
|
func send() {
|
|
|
|
ct <- t;
|
|
|
|
ca <- a;
|
|
|
|
}
|
|
|
|
|
|
|
|
func chantest() {
|
|
|
|
go send();
|
|
|
|
|
|
|
|
t1 := <-ct;
|
|
|
|
if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d {
|
2008-12-19 18:11:54 -07:00
|
|
|
println("fail: map val struct", t1.a, t1.b, t1.c, t1.d);
|
2008-12-19 13:05:22 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
a1 := <-ca;
|
2008-12-19 18:11:54 -07:00
|
|
|
if !SameArray(a, a1) {
|
|
|
|
println("fail: map val array", a, a1);
|
2008-12-19 13:05:22 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-01-20 15:40:40 -07:00
|
|
|
type E struct { }
|
2008-12-19 18:11:54 -07:00
|
|
|
var e E
|
|
|
|
|
|
|
|
func interfacetest() {
|
|
|
|
var i interface{};
|
|
|
|
|
|
|
|
i = a;
|
|
|
|
a1 := i.([]int);
|
|
|
|
if !SameArray(a, a1) {
|
|
|
|
println("interface <-> []int", a, a1);
|
|
|
|
}
|
2009-01-06 16:19:02 -07:00
|
|
|
pa := new([]int);
|
2008-12-19 18:11:54 -07:00
|
|
|
*pa = a;
|
|
|
|
i = pa;
|
|
|
|
a1 = *i.(*[]int);
|
|
|
|
if !SameArray(a, a1) {
|
|
|
|
println("interface <-> *[]int", a, a1);
|
|
|
|
}
|
|
|
|
|
|
|
|
i = t;
|
|
|
|
t1 := i.(T);
|
|
|
|
if t1.a != t.a || t1.b != t.b || t1.c != t.c || t1.d != t.d {
|
|
|
|
println("interface <-> struct", t1.a, t1.b, t1.c, t1.d);
|
|
|
|
}
|
|
|
|
|
|
|
|
i = e;
|
|
|
|
e1 := i.(E);
|
|
|
|
// nothing to check; just verify it doesn't crash
|
|
|
|
}
|
|
|
|
|
2008-12-19 13:05:22 -07:00
|
|
|
func main() {
|
|
|
|
arraycmptest();
|
|
|
|
maptest();
|
|
|
|
chantest();
|
2008-12-19 18:11:54 -07:00
|
|
|
interfacetest();
|
2008-12-19 13:05:22 -07:00
|
|
|
}
|