rubyx/lib/parfait/hash.rb

64 lines
903 B
Ruby
Raw Normal View History

# almost simplest hash imaginable. make good use of arrays
2014-09-04 14:22:28 +03:00
module Parfait
end
class Parfait::Hash
def initialize
@keys = Array.new()
@values = Array.new()
end
2014-09-16 16:05:38 +03:00
def values()
@values
end
def keys()
@keys
end
def empty?
@keys.empty?
end
def length()
return @keys.length()
end
def get(key)
index = key_index(key)
if( index )
@values[index]
else
nil
end
end
2014-09-16 16:05:38 +03:00
def [](key)
get(key)
end
def key_index(key)
len = @keys.length()
index = 0
found = nil
while(index < len)
if( @keys[index] == key)
found = index
break
end
index += 1
end
found
end
def set(key , value)
index = key_index(key)
if( index )
@keys[index] = value
else
@keys.push(key)
@values.push(value)
end
value
end
2014-09-16 16:05:38 +03:00
def []=(key,val)
set(key,val)
end
end