mirror of
https://github.com/golang/go
synced 2024-11-13 18:00:30 -07:00
45515011cc
R=ken2 CC=golang-dev https://golang.org/cl/199046
168 lines
3.2 KiB
Go
168 lines
3.2 KiB
Go
// $G $D/$F.go && $L $F.$A && ./$A.out
|
|
|
|
// Copyright 2010 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
|
|
|
|
func sum(args ...int) int {
|
|
s := 0
|
|
for _, v := range args {
|
|
s += v
|
|
}
|
|
return s
|
|
}
|
|
|
|
func sumC(args ...int) int {
|
|
return func() int { return sum(args) } ()
|
|
}
|
|
|
|
var sumD = func(args ...int) int { return sum(args) }
|
|
|
|
var sumE = func() func(...int) int { return func(args ...int) int { return sum(args) } } ()
|
|
|
|
var sumF = func(args ...int) func() int { return func() int { return sum(args) } }
|
|
|
|
func sumA(args []int) int {
|
|
s := 0
|
|
for _, v := range args {
|
|
s += v
|
|
}
|
|
return s
|
|
}
|
|
|
|
func sum2(args ...int) int { return 2 * sum(args) }
|
|
|
|
func sum3(args ...int) int { return 3 * sumA(args) }
|
|
|
|
func intersum(args ...interface{}) int {
|
|
s := 0
|
|
for _, v := range args {
|
|
s += v.(int)
|
|
}
|
|
return s
|
|
}
|
|
|
|
type T []T
|
|
|
|
func ln(args ...T) int { return len(args) }
|
|
|
|
func ln2(args ...T) int { return 2 * ln(args) }
|
|
|
|
func (*T) Sum(args ...int) int {
|
|
return sum(args)
|
|
}
|
|
|
|
type U struct {
|
|
*T
|
|
}
|
|
|
|
func main() {
|
|
if x := sum(1, 2, 3); x != 6 {
|
|
panicln("sum 6", x)
|
|
}
|
|
if x := sum(); x != 0 {
|
|
panicln("sum 0", x)
|
|
}
|
|
if x := sum(10); x != 10 {
|
|
panicln("sum 10", x)
|
|
}
|
|
if x := sum(1, 8); x != 9 {
|
|
panicln("sum 9", x)
|
|
}
|
|
if x := sumC(4, 5, 6); x != 15 {
|
|
panicln("sumC 15", x)
|
|
}
|
|
if x := sumD(4, 5, 7); x != 16 {
|
|
panicln("sumD 16", x)
|
|
}
|
|
if x := sumE(4, 5, 8); x != 17 {
|
|
panicln("sumE 17", x)
|
|
}
|
|
if x := sumF(4, 5, 9)(); x != 18 {
|
|
panicln("sumF 18", x)
|
|
}
|
|
if x := sum2(1, 2, 3); x != 2*6 {
|
|
panicln("sum 6", x)
|
|
}
|
|
if x := sum2(); x != 2*0 {
|
|
panicln("sum 0", x)
|
|
}
|
|
if x := sum2(10); x != 2*10 {
|
|
panicln("sum 10", x)
|
|
}
|
|
if x := sum2(1, 8); x != 2*9 {
|
|
panicln("sum 9", x)
|
|
}
|
|
if x := sum3(1, 2, 3); x != 3*6 {
|
|
panicln("sum 6", x)
|
|
}
|
|
if x := sum3(); x != 3*0 {
|
|
panicln("sum 0", x)
|
|
}
|
|
if x := sum3(10); x != 3*10 {
|
|
panicln("sum 10", x)
|
|
}
|
|
if x := sum3(1, 8); x != 3*9 {
|
|
panicln("sum 9", x)
|
|
}
|
|
if x := intersum(1, 2, 3); x != 6 {
|
|
panicln("intersum 6", x)
|
|
}
|
|
if x := intersum(); x != 0 {
|
|
panicln("intersum 0", x)
|
|
}
|
|
if x := intersum(10); x != 10 {
|
|
panicln("intersum 10", x)
|
|
}
|
|
if x := intersum(1, 8); x != 9 {
|
|
panicln("intersum 9", x)
|
|
}
|
|
|
|
if x := ln(nil, nil, nil); x != 3 {
|
|
panicln("ln 3", x)
|
|
}
|
|
if x := ln([]T{}); x != 1 {
|
|
panicln("ln 1", x)
|
|
}
|
|
if x := ln2(nil, nil, nil); x != 2*3 {
|
|
panicln("ln2 3", x)
|
|
}
|
|
if x := ln2([]T{}); x != 2*1 {
|
|
panicln("ln2 1", x)
|
|
}
|
|
if x := ((*T)(nil)).Sum(1,3,5,7); x != 16 {
|
|
panicln("(*T)(nil).Sum", x)
|
|
}
|
|
if x := (*T).Sum(nil, 1, 3, 5, 6); x != 15 {
|
|
panicln("(*T).Sum", x)
|
|
}
|
|
if x := (&U{}).Sum(1,3,5,5); x != 14 {
|
|
panicln("(&U{}).Sum", x)
|
|
}
|
|
var u U
|
|
if x := u.Sum(1,3,5,4); x != 13 {
|
|
panicln("u.Sum", x)
|
|
}
|
|
if x := (&u).Sum(1,3,5,3); x != 12 {
|
|
panicln("(&u).Sum", x)
|
|
}
|
|
var i interface { Sum(...int) int } = &u
|
|
if x := i.Sum(2,3,5,7); x != 17 {
|
|
panicln("i(=&u).Sum", x)
|
|
}
|
|
i = u
|
|
if x := i.Sum(2,3,5,6); x != 16 {
|
|
panicln("i(=u).Sum", x)
|
|
}
|
|
/* TODO(rsc): Enable once nested method expressions work.
|
|
if x := (*U).Sum(&U{}, 1, 3, 5, 2); x != 11 {
|
|
panicln("(*U).Sum", x)
|
|
}
|
|
if x := U.Sum(U{}, 1, 3, 5, 1); x != 10 {
|
|
panicln("U.Sum", x)
|
|
}
|
|
*/
|
|
}
|