2012-02-17 04:48:57 +00:00
|
|
|
// run
|
2008-09-03 22:54:33 +00:00
|
|
|
|
|
|
|
// 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.
|
|
|
|
|
2012-02-19 02:19:43 +00:00
|
|
|
// Test composite literals.
|
|
|
|
|
2008-09-03 22:54:33 +00:00
|
|
|
package main
|
|
|
|
|
2011-01-20 04:09:00 +00:00
|
|
|
type T struct {
|
|
|
|
i int
|
|
|
|
f float64
|
|
|
|
s string
|
|
|
|
next *T
|
|
|
|
}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2011-01-20 04:09:00 +00:00
|
|
|
type R struct {
|
|
|
|
num int
|
|
|
|
}
|
2008-09-04 20:35:19 +00:00
|
|
|
|
|
|
|
func itor(a int) *R {
|
2010-09-04 00:36:13 +00:00
|
|
|
r := new(R)
|
|
|
|
r.num = a
|
|
|
|
return r
|
2008-09-04 20:35:19 +00:00
|
|
|
}
|
|
|
|
|
2008-12-19 06:37:22 +00:00
|
|
|
func eq(a []*R) {
|
2008-09-04 20:35:19 +00:00
|
|
|
for i := 0; i < len(a); i++ {
|
2011-01-20 04:09:00 +00:00
|
|
|
if a[i].num != i {
|
|
|
|
panic("bad")
|
|
|
|
}
|
2008-09-04 20:35:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-02 19:13:12 +00:00
|
|
|
func teq(t *T, n int) {
|
|
|
|
for i := 0; i < n; i++ {
|
|
|
|
if t == nil || t.i != i {
|
|
|
|
panic("bad")
|
|
|
|
}
|
|
|
|
t = t.next
|
|
|
|
}
|
|
|
|
if t != nil {
|
|
|
|
panic("bad")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-01-20 04:09:00 +00:00
|
|
|
type P struct {
|
|
|
|
a, b int
|
|
|
|
}
|
|
|
|
|
2009-01-20 22:40:40 +00:00
|
|
|
func NewP(a, b int) *P {
|
2009-03-03 16:39:12 +00:00
|
|
|
return &P{a, b}
|
2008-10-21 23:53:54 +00:00
|
|
|
}
|
|
|
|
|
2008-09-03 22:54:33 +00:00
|
|
|
func main() {
|
2010-09-04 00:36:13 +00:00
|
|
|
var t T
|
|
|
|
t = T{0, 7.2, "hi", &t}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
var tp *T
|
|
|
|
tp = &T{0, 7.2, "hi", &t}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2011-12-05 19:22:41 +00:00
|
|
|
tl := &T{i: 0, next: &T{i: 1, next: &T{i: 2, next: &T{i: 3, next: &T{i: 4}}}}}
|
2011-12-02 19:13:12 +00:00
|
|
|
teq(tl, 5)
|
|
|
|
|
2011-01-20 04:09:00 +00:00
|
|
|
a1 := []int{1, 2, 3}
|
|
|
|
if len(a1) != 3 {
|
|
|
|
panic("a1")
|
|
|
|
}
|
|
|
|
a2 := [10]int{1, 2, 3}
|
|
|
|
if len(a2) != 10 || cap(a2) != 10 {
|
|
|
|
panic("a2")
|
|
|
|
}
|
2009-01-07 18:35:43 +00:00
|
|
|
|
2011-01-20 04:09:00 +00:00
|
|
|
a3 := [10]int{1, 2, 3}
|
|
|
|
if len(a3) != 10 || a2[3] != 0 {
|
|
|
|
panic("a3")
|
|
|
|
}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
var oai []int
|
2011-01-20 04:09:00 +00:00
|
|
|
oai = []int{1, 2, 3}
|
|
|
|
if len(oai) != 3 {
|
|
|
|
panic("oai")
|
|
|
|
}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
at := [...]*T{&t, tp, &t}
|
2011-01-20 04:09:00 +00:00
|
|
|
if len(at) != 3 {
|
|
|
|
panic("at")
|
|
|
|
}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
c := make(chan int)
|
|
|
|
ac := []chan int{c, c, c}
|
2011-01-20 04:09:00 +00:00
|
|
|
if len(ac) != 3 {
|
|
|
|
panic("ac")
|
|
|
|
}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
aat := [][len(at)]*T{at, at}
|
2011-01-20 04:09:00 +00:00
|
|
|
if len(aat) != 2 || len(aat[1]) != 3 {
|
|
|
|
panic("aat")
|
|
|
|
}
|
2008-12-19 11:05:37 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
s := string([]byte{'h', 'e', 'l', 'l', 'o'})
|
2011-01-20 04:09:00 +00:00
|
|
|
if s != "hello" {
|
|
|
|
panic("s")
|
|
|
|
}
|
2008-09-03 22:54:33 +00:00
|
|
|
|
2011-01-20 04:09:00 +00:00
|
|
|
m := map[string]float64{"one": 1.0, "two": 2.0, "pi": 22. / 7.}
|
|
|
|
if len(m) != 3 {
|
|
|
|
panic("m")
|
|
|
|
}
|
2008-09-04 20:35:19 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
eq([]*R{itor(0), itor(1), itor(2), itor(3), itor(4), itor(5)})
|
2011-12-02 19:13:12 +00:00
|
|
|
eq([]*R{{0}, {1}, {2}, {3}, {4}, {5}})
|
2008-12-19 11:05:37 +00:00
|
|
|
|
2010-09-04 00:36:13 +00:00
|
|
|
p1 := NewP(1, 2)
|
|
|
|
p2 := NewP(1, 2)
|
2011-01-20 04:09:00 +00:00
|
|
|
if p1 == p2 {
|
|
|
|
panic("NewP")
|
|
|
|
}
|
2008-09-03 22:54:33 +00:00
|
|
|
}
|