Class: Immutable::Map::RedFork
Overview
Constant Summary
Leaf
Instance Attribute Summary
Attributes inherited from Fork
#key, #left, #right, #value
Instance Method Summary
collapse
Methods inherited from Fork
#[], #del, #each, #empty?, extract, #foldl_with_key, #foldr_with_key, #initialize
#[], [], #delete, empty, #foldl, #foldr, #insert, #inspect, #map, #map_with_key, singleton
Instance Method Details
#black? ⇒ Boolean
334
335
336
|
# File 'lib/immutable/map.rb', line 334
def black?
false
end
|
#ins(key, value) ⇒ Object
346
347
348
349
350
351
352
353
354
|
# File 'lib/immutable/map.rb', line 346
def ins(key, value)
if key < self.key
RedFork[left.ins(key, value), self.key, self.value, right]
elsif key > self.key
RedFork[left, self.key, self.value, right.ins(key, value)]
else
RedFork[left, key, value, right]
end
end
|
#make_black ⇒ Object
342
343
344
|
# File 'lib/immutable/map.rb', line 342
def make_black
BlackFork[left, key, value, right]
end
|
#make_red ⇒ Object
338
339
340
|
# File 'lib/immutable/map.rb', line 338
def make_red
self
end
|
#red? ⇒ Boolean
330
331
332
|
# File 'lib/immutable/map.rb', line 330
def red?
true
end
|