github.com/akaros/go-akaros@v0.0.0-20181004170632-85005d477eab/test/ken/rob1.go (about)

     1  // run
     2  
     3  // Copyright 2009 The Go Authors. All rights reserved.
     4  // Use of this source code is governed by a BSD-style
     5  // license that can be found in the LICENSE file.
     6  
     7  // Test general operation using a list implementation.
     8  
     9  package main
    10  
    11  type Item interface {
    12  	Print() string
    13  }
    14  
    15  type ListItem struct {
    16  	item Item
    17  	next *ListItem
    18  }
    19  
    20  type List struct {
    21  	head *ListItem
    22  }
    23  
    24  func (list *List) Init() {
    25  	list.head = nil
    26  }
    27  
    28  func (list *List) Insert(i Item) {
    29  	item := new(ListItem)
    30  	item.item = i
    31  	item.next = list.head
    32  	list.head = item
    33  }
    34  
    35  func (list *List) Print() string {
    36  	r := ""
    37  	i := list.head
    38  	for i != nil {
    39  		r += i.item.Print()
    40  		i = i.next
    41  	}
    42  	return r
    43  }
    44  
    45  // Something to put in a list
    46  type Integer struct {
    47  	val int
    48  }
    49  
    50  func (this *Integer) Init(i int) *Integer {
    51  	this.val = i
    52  	return this
    53  }
    54  
    55  func (this *Integer) Print() string {
    56  	return string(this.val + '0')
    57  }
    58  
    59  func main() {
    60  	list := new(List)
    61  	list.Init()
    62  	for i := 0; i < 10; i = i + 1 {
    63  		integer := new(Integer)
    64  		integer.Init(i)
    65  		list.Insert(integer)
    66  	}
    67  
    68  	r := list.Print()
    69  	if r != "9876543210" {
    70  		panic(r)
    71  	}
    72  }