source: mainline/uspace/dist/sysel/list.sy@ 94d484a

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since 94d484a was 94d484a, checked in by Jiri Svoboda <jiri@…>, 16 years ago

Update SBI to rev. 90.

  • Property mode set to 100644
File size: 2.5 KB
Line 
1--
2-- Copyright (c) 2010 Jiri Svoboda
3-- All rights reserved.
4--
5-- Redistribution and use in source and binary forms, with or without
6-- modification, are permitted provided that the following conditions
7-- are met:
8--
9-- o Redistributions of source code must retain the above copyright
10-- notice, this list of conditions and the following disclaimer.
11-- o Redistributions in binary form must reproduce the above copyright
12-- notice, this list of conditions and the following disclaimer in the
13-- documentation and/or other materials provided with the distribution.
14-- o The name of the author may not be used to endorse or promote products
15-- derived from this software without specific prior written permission.
16--
17-- THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18-- IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19-- OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20-- IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21-- INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22-- NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23-- DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24-- THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25-- (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26-- THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27--
28
29class List is
30 var head : ListNode;
31
32 fun Init() is
33 head = new ListNode();
34 head.prev = head;
35 head.next = head;
36 end
37
38 fun Append(data : int) is
39 var n : ListNode;
40 var ntl : ListNode;
41
42 ntl = head.prev;
43
44 n = new ListNode();
45 n.value = data;
46
47 n.prev = ntl;
48 n.next = head;
49 n.head = head;
50
51 ntl.next = n;
52 head.prev = n;
53 end
54
55 fun GetFirst() : ListNode is
56 return head.next;
57 end
58end
59
60class ListNode is
61 var value : int;
62
63 var prev : ListNode;
64 var next : ListNode;
65 var head : ListNode;
66
67 fun GetNext() : ListNode is
68 if next != head then
69 return next;
70 else
71 return nil;
72 end
73 end
74
75 fun GetPrev() : ListNode is
76 if prev != head then
77 return next;
78 else
79 return nil;
80 end
81 end
82
83 fun GetValue() : int is
84 return value;
85 end
86end
87
88class ListDemo is
89 fun Main() is
90 var list : List;
91
92 list = new List();
93 list.Init();
94
95 list.Append(5);
96 list.Append(6);
97 list.Append(7);
98 list.Append(8);
99
100 var n : ListNode;
101
102 n = list.GetFirst();
103 while n != nil do
104 Builtin.WriteLine(n.value);
105 n = n.GetNext();
106 end
107 end
108end
Note: See TracBrowser for help on using the repository browser.