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, #empty?, extract, #foldl_with_key, #foldr_with_key, #initialize
#[], [], #delete, #each, empty, #foldl, #foldr, #insert, #inspect, #map, #map_with_key, singleton
Methods included from Foldable
#length, #product, #sum
Instance Method Details
#black? ⇒ Boolean
360
361
362
|
# File 'lib/immutable/map.rb', line 360
def black?
true
end
|
#ins(key, value) ⇒ Object
372
373
374
375
376
377
378
379
380
|
# File 'lib/immutable/map.rb', line 372
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
368
369
370
|
# File 'lib/immutable/map.rb', line 368
def make_black
self
end
|
#make_red ⇒ Object
364
365
366
|
# File 'lib/immutable/map.rb', line 364
def make_red
RedFork[left, key, value, right]
end
|
#red? ⇒ Boolean
356
357
358
|
# File 'lib/immutable/map.rb', line 356
def red?
false
end
|