Class: Immutable::Map::BlackFork
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
362
363
364
|
# File 'lib/immutable/map.rb', line 362
def black?
true
end
|
#ins(key, value) ⇒ Object
374
375
376
377
378
379
380
381
382
|
# File 'lib/immutable/map.rb', line 374
def ins(key, value)
if key < self.key
balance(left.ins(key, value), self.key, self.value, right)
elsif key > self.key
balance(left, self.key, self.value, right.ins(key, value))
else
BlackFork[left, key, value, right]
end
end
|
#make_black ⇒ Object
370
371
372
|
# File 'lib/immutable/map.rb', line 370
def make_black
self
end
|
#make_red ⇒ Object
366
367
368
|
# File 'lib/immutable/map.rb', line 366
def make_red
RedFork[left, key, value, right]
end
|
#red? ⇒ Boolean
358
359
360
|
# File 'lib/immutable/map.rb', line 358
def red?
false
end
|