File: Link.st

package info (click to toggle)
gnu-smalltalk 3.2.4-2.1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 32,688 kB
  • ctags: 14,104
  • sloc: ansic: 87,424; sh: 22,729; asm: 8,465; perl: 4,513; cpp: 3,548; xml: 1,669; awk: 1,581; yacc: 1,357; makefile: 1,237; lisp: 855; lex: 843; sed: 258; objc: 124
file content (107 lines) | stat: -rw-r--r-- 2,807 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
"======================================================================
|
|   Link Method Definitions
|
|
 ======================================================================"

"======================================================================
|
| Copyright 1988,92,94,95,99,2000,2001,2002
| Free Software Foundation, Inc.
| Written by Steve Byrne.
|
| This file is part of the GNU Smalltalk class library.
|
| The GNU Smalltalk class library is free software; you can redistribute it
| and/or modify it under the terms of the GNU Lesser General Public License
| as published by the Free Software Foundation; either version 2.1, or (at
| your option) any later version.
| 
| The GNU Smalltalk class library is distributed in the hope that it will be
| useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser
| General Public License for more details.
| 
| You should have received a copy of the GNU Lesser General Public License
| along with the GNU Smalltalk class library; see the file COPYING.LIB.
| If not, write to the Free Software Foundation, 59 Temple Place - Suite
| 330, Boston, MA 02110-1301, USA.  
|
 ======================================================================"



Object subclass: Link [
    | nextLink |
    
    <category: 'Collections-Sequenceable'>
    <comment: 'I represent simple linked lists.  Generally, I am not used by myself, but
rather a subclass adds other instance variables that hold the information
for each node, and I hold the glue that keeps them together.'>

    Link class >> nextLink: aLink [
	"Create an instance with the given next link"

	<category: 'instance creation'>
	^self new nextLink: aLink
    ]

    at: index [
	"Retrieve a node (instance of Link) that is at a distance of `index'
	 after the receiver."

	<category: 'iteration'>
	| i element |
	i := 1.
	element := self.
	
	[i = index ifTrue: [^element].
	i := i + 1.
	(element := element nextLink) isNil] 
		whileFalse.
	SystemExceptions.IndexOutOfRange signalOn: self withIndex: index
    ]

    at: index put: object [
	<category: 'iteration'>
	self shouldNotImplement
    ]

    do: aBlock [
	"Evaluate aBlock for each element in the list"

	<category: 'iteration'>
	| item |
	item := self.
	
	[aBlock value: item.
	(item := item nextLink) isNil] whileFalse
    ]

    size [
	"Answer the number of elements in the list. Warning: this is O(n)"

	<category: 'iteration'>
	| item count |
	item := self.
	count := 1.
	[(item := item nextLink) isNil] whileFalse: [count := count + 1].
	^count
    ]

    nextLink [
	"Answer the next item in the list"

	<category: 'basic'>
	^nextLink
    ]

    nextLink: aLink [
	"Set the next item in the list"

	<category: 'basic'>
	nextLink := aLink
    ]
]