diff options
author | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
---|---|---|
committer | upstream source tree <ports@midipix.org> | 2015-03-15 20:14:05 -0400 |
commit | 554fd8c5195424bdbcabf5de30fdc183aba391bd (patch) | |
tree | 976dc5ab7fddf506dadce60ae936f43f58787092 /gcc/testsuite/go.test/test/ken/rob1.go | |
download | cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.bz2 cbb-gcc-4.6.4-554fd8c5195424bdbcabf5de30fdc183aba391bd.tar.xz |
obtained gcc-4.6.4.tar.bz2 from upstream website;upstream
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.
Diffstat (limited to 'gcc/testsuite/go.test/test/ken/rob1.go')
-rw-r--r-- | gcc/testsuite/go.test/test/ken/rob1.go | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/gcc/testsuite/go.test/test/ken/rob1.go b/gcc/testsuite/go.test/test/ken/rob1.go new file mode 100644 index 000000000..03350662a --- /dev/null +++ b/gcc/testsuite/go.test/test/ken/rob1.go @@ -0,0 +1,67 @@ +// $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 + +type Item interface { + Print(); +} + +type ListItem struct { + item Item; + next *ListItem; +} + +type List struct { + head *ListItem; +} + +func (list *List) Init() { + list.head = nil; +} + +func (list *List) Insert(i Item) { + item := new(ListItem); + item.item = i; + item.next = list.head; + list.head = item; +} + +func (list *List) Print() { + i := list.head; + for i != nil { + i.item.Print(); + i = i.next; + } +} + +// Something to put in a list +type Integer struct { + val int; +} + +func (this *Integer) Init(i int) *Integer { + this.val = i; + return this; +} + +func (this *Integer) Print() { + print(this.val); +} + +func +main() { + list := new(List); + list.Init(); + for i := 0; i < 10; i = i + 1 { + integer := new(Integer); + integer.Init(i); + list.Insert(integer); + } + + list.Print(); + print("\n"); +} |