TSTreeNode.st
author Claus Gittinger <cg@exept.de>
Sat, 02 May 2020 21:40:13 +0200
changeset 5476 7355a4b11cb6
parent 5393 b39d48159130
permissions -rw-r--r--
#FEATURE by cg class: Socket class added: #newTCPclientToHost:port:domain:domainOrder:withTimeout: changed: #newTCPclientToHost:port:domain:withTimeout:
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5393
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
     1
"{ Encoding: utf8 }"
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
     2
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     3
"{ Package: 'stx:libbasic2' }"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     4
3676
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
     5
"{ NameSpace: Smalltalk }"
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
     6
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     7
Object subclass:#TSTreeNode
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     8
	instanceVariableNames:'key value low high equal'
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
     9
	classVariableNames:''
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    10
	poolDictionaries:''
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    11
	category:'Collections-Ordered-Trees-Private'
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    12
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    13
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    14
!TSTreeNode class methodsFor:'documentation'!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    15
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    16
documentation
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    17
"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    18
    [author:]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    19
        Avi Bryant
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    20
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    21
    [license:]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    22
        Dual licensed under both SqueakL and MIT. 
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    23
        This enables both base Squeak inclusion and 100% reuse.
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    24
"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    25
! !
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    26
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    27
!TSTreeNode class methodsFor:'as yet unclassified'!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    28
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    29
key: aCharacter
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    30
	^ self basicNew initializeWithKey: aCharacter
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    31
! !
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    32
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    33
!TSTreeNode methodsFor:'private'!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    34
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    35
canBeCulled
3676
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
    36
        ^ self value isNil
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
    37
            and: [low isNil
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
    38
            and: [equal isNil
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
    39
            and: [high isNil]]]
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    40
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    41
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    42
cullNode: aNode
5393
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
    43
        low == aNode ifTrue: [^ low := nil].
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
    44
        equal == aNode ifTrue: [^ equal := nil].
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
    45
        high == aNode ifTrue: [^ high := nil]
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    46
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    47
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    48
do: aBlock
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    49
    self nodesDo: [:ea | 
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    50
        |t|
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    51
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    52
        (t := ea value) notNil ifTrue:[
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    53
            aBlock value:t
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    54
        ]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    55
    ].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    56
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    57
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    58
initializeWithKey: aCharacter
5393
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
    59
        key := aCharacter
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    60
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    61
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    62
lookupString: aString startingAt: i
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    63
"inlined for performance"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    64
"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    65
        self
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    66
                lookupString: aString
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    67
                startingAt: i
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    68
                whenFound: [^ value]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    69
                whenNil: [:c | ^ nil]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    70
                recurseWith: [:node :j | ^ node lookupString: aString startingAt: j]"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    71
        | char |
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    72
        char := aString at: i.
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    73
        char = key
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    74
                ifTrue:
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    75
                        [aString size = i
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    76
                                ifTrue: [^ value]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    77
                                ifFalse: [^ equal notNil ifTrue: [equal lookupString: aString startingAt: i+1] ifFalse:[nil]]]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    78
                ifFalse:
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    79
                        [char < key
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    80
                                ifTrue: [^ low notNil ifTrue: [low lookupString: aString startingAt: i] ifFalse:[nil]]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    81
                                ifFalse: [^ high notNil ifTrue: [high lookupString: aString startingAt: i] ifFalse:[nil]]]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    82
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    83
    "Modified: / 08-08-2010 / 15:18:03 / cg"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    84
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    85
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    86
lookupString: aString startingAt: i insert: anObject
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    87
	self
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    88
		lookupString: aString
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    89
		startingAt: i
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    90
		whenFound: [self value: anObject]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    91
		whenNil: [:c | self newNodeWithKey: c]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    92
		recurseWith: [:node :j | node lookupString: aString startingAt: j insert: anObject]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    93
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    94
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    95
lookupString: aString startingAt: i whenFound: foundBlock whenNil: nilBlock recurseWith: recurseBlock
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    96
	| char |
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    97
	char := aString at: i.
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    98
	char = key
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
    99
		ifTrue:
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   100
			[aString size = i
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   101
				ifTrue: [foundBlock value]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   102
				ifFalse: [equal ifNil: [equal := nilBlock value: (aString at: i+1)].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   103
						 recurseBlock value: equal value: i+1]]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   104
		ifFalse:
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   105
			[char < key
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   106
				ifTrue: [low ifNil: [low := nilBlock value: char].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   107
						recurseBlock value: low value: i]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   108
				ifFalse: [high ifNil: [high := nilBlock value: char].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   109
						recurseBlock value: high value: i]]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   110
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   111
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   112
matchesForPrefix: aString startingAt: i do: aBlock
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   113
        self
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   114
                lookupString: aString
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   115
                startingAt: i
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   116
                whenFound: [value notNil ifTrue: [aBlock value: value].  equal notNil ifTrue: [equal do: aBlock]]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   117
                whenNil: [:c | ^ self]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   118
                recurseWith: [:n :j | n matchesForPrefix: aString startingAt: j do: aBlock]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   119
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   120
    "Modified: / 08-08-2010 / 15:18:44 / cg"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   121
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   122
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   123
matchesForString: aString startingAt: i distance: d do: aBlock nodesDo: nodeBlock
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   124
        
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   125
        | char d2 |
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   126
        nodeBlock value: self.
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   127
        d < 0 ifTrue: [^ self].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   128
        
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   129
        char := aString at: i.
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   130
        (d > 0 or: [char < key])
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   131
                ifTrue: [low notNil ifTrue: [low matchesForString: aString startingAt: i distance: d do: aBlock nodesDo: nodeBlock]].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   132
                
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   133
        d2 := char = key ifTrue: [d] ifFalse: [d-1].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   134
        (i + d2 = aString size and: [value notNil]) ifTrue: [aBlock value: value].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   135
        equal ifNotNil: [equal matchesForString: aString startingAt: (i+1 min: aString size) distance: d2 do: aBlock nodesDo: nodeBlock].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   136
        
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   137
        (d > 0 or: [char > key])
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   138
                ifTrue: [high notNil ifTrue: [high matchesForString: aString startingAt: i distance: d do: aBlock nodesDo: nodeBlock]]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   139
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   140
    "Modified: / 08-08-2010 / 15:18:57 / cg"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   141
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   142
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   143
newNodeWithKey: aCharacter
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   144
	^ self class key: aCharacter
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   145
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   146
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   147
nodesDo: aBlock
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   148
        aBlock value: self.
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   149
        low notNil ifTrue: [low nodesDo: aBlock].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   150
        equal notNil ifTrue: [equal nodesDo: aBlock].
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   151
        high notNil ifTrue: [high nodesDo: aBlock]
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   152
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   153
    "Modified: / 08-08-2010 / 15:19:05 / cg"
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   154
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   155
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   156
removeString: aString startingAt: i
5393
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   157
        | val |
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   158
        self
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   159
                lookupString: aString
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   160
                startingAt: i
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   161
                whenFound: [val := self value. self value: nil]
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   162
                whenNil: [:c | ^ nil]
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   163
                recurseWith:
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   164
                        [:node :j |
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   165
                        val := node removeString:aString startingAt:j.
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   166
                        node canBeCulled ifTrue:
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   167
                                [self cullNode: node]].
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   168
        ^ val
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   169
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   170
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   171
value
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   172
	^ value
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   173
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   174
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   175
value: anObject
5393
b39d48159130 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 3676
diff changeset
   176
        value := anObject
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   177
! !
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   178
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   179
!TSTreeNode class methodsFor:'documentation'!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   180
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   181
version
3676
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
   182
    ^ '$Header$'
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   183
!
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   184
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   185
version_CVS
3676
29e4fbe103d6 #REFACTORING
Claus Gittinger <cg@exept.de>
parents: 3251
diff changeset
   186
    ^ '$Header$'
3251
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   187
! !
69fcab18aec5 initial checkin
Jan Vrany <jan.vrany@fit.cvut.cz>
parents:
diff changeset
   188