fixes parfaits hash by implementing array

basic concept holds up as parfaits hash is now
working on parfaits own array
This commit is contained in:
Torsten Ruger 2015-05-12 18:52:01 +03:00
parent b980def84e
commit 398516a596
9 changed files with 103 additions and 13 deletions

View File

@ -23,19 +23,28 @@ end
class Parfait::Object class Parfait::Object
include FakeMem include FakeMem
def self.new_object &args def self.new_object *args
puts "I am #{self}" puts "I am #{self}"
object = self.new(*args) object = self.new(*args)
object object
end end
def object_length def internal_object_length
@memory.length @memory.length
end end
def internal_object_get(index)
@memory[index]
end
def internal_object_set(index , value)
@memory[index] = value
end
def internal_object_grow(index)
@memory[index] = niL
end
end end
class Parfait::Class class Parfait::Class
end end
class Parfait::Array class Parfait::Array
def length def length
object_length internal_object_length
end end
end end

View File

@ -2,6 +2,43 @@
module Parfait module Parfait
class Array < Object class Array < Object
# push means add to the end
# this automatically grows the array
def push value
self.set( length , value)
end
def set( index , value)
raise "negative index for set #{len}" if index < 0
if index >= self.length
grow_to(index)
end
internal_object_set( index , value)
end
def get(index)
raise "negative index for get #{len}" if index < 0
if index >= self.length
return nil
else
return internal_object_get(index)
end
end
def empty?
self.length == 0
end
def grow_to(len)
raise "negative length for grow #{len}" if len < 0
return unless len > self.length
index = self.length
internal_object_grow(length)
while( index < self.length )
internal_object_set( index , nil)
end
end
#many basic array functions can not be defined in ruby, such as #many basic array functions can not be defined in ruby, such as
# get/set/length/add/delete # get/set/length/add/delete
# so they must be defined as CompiledMethods in Builtin::Kernel # so they must be defined as CompiledMethods in Builtin::Kernel

View File

@ -23,7 +23,7 @@ module Parfait
def get(key) def get(key)
index = key_index(key) index = key_index(key)
if( index ) if( index )
@values[index] @values.get(index)
else else
nil nil
end end
@ -37,7 +37,7 @@ module Parfait
index = 0 index = 0
found = nil found = nil
while(index < len) while(index < len)
if( @keys[index] == key) if( @keys.get(index) == key)
found = index found = index
break break
end end
@ -49,7 +49,7 @@ module Parfait
def set(key , value) def set(key , value)
index = key_index(key) index = key_index(key)
if( index ) if( index )
@keys[index] = value @keys.set(index , value)
else else
@keys.push(key) @keys.push(key)
@values.push(value) @values.push(value)

View File

@ -12,7 +12,7 @@
# may be added to any object at run-time # may be added to any object at run-time
module Parfait module Parfait
class Module class Module < Object
# :<, :<=, :>, :>=, :included_modules, :include?, :name, :ancestors, :instance_methods, :public_instance_methods, # :<, :<=, :>, :>=, :included_modules, :include?, :name, :ancestors, :instance_methods, :public_instance_methods,
# :protected_instance_methods, :private_instance_methods, :constants, :const_get, :const_set, :const_defined?, # :protected_instance_methods, :private_instance_methods, :constants, :const_get, :const_set, :const_defined?,
# :const_missing, :class_variables, :remove_class_variable, :class_variable_get, :class_variable_set, # :const_missing, :class_variables, :remove_class_variable, :class_variable_get, :class_variable_set,

View File

@ -92,11 +92,11 @@ module Virtual
def boot_classes! def boot_classes!
# very fiddly chicken 'n egg problem. Functions need to be in the right order, and in fact we have to define some # very fiddly chicken 'n egg problem. Functions need to be in the right order, and in fact we have to define some
# dummies, just for the other to compile # dummies, just for the other to compile
obj = get_or_create_class :Object obj = @space.get_or_create_class :Object
[:index_of , :_get_instance_variable , :_set_instance_variable].each do |f| [:index_of , :_get_instance_variable , :_set_instance_variable].each do |f|
obj.add_instance_method Builtin::Object.send(f , nil) obj.add_instance_method Builtin::Object.send(f , nil)
end end
obj = get_or_create_class :Kernel obj = @space.get_or_create_class :Kernel
# create main first, __init__ calls it # create main first, __init__ calls it
@main = Builtin::Kernel.send(:main , @context) @main = Builtin::Kernel.send(:main , @context)
obj.add_instance_method @main obj.add_instance_method @main
@ -107,13 +107,13 @@ module Virtual
end end
# and the @init block in turn _jumps_ to __init__ # and the @init block in turn _jumps_ to __init__
# the point of which is that by the time main executes, all is "normal" # the point of which is that by the time main executes, all is "normal"
@init = Virtual::Block.new(:_init_ , nil ) @init = Block.new(:_init_ , nil )
@init.add_code(Register::RegisterMain.new(underscore_init)) @init.add_code(Register::RegisterMain.new(underscore_init))
obj = get_or_create_class :Integer obj = @space.get_or_create_class :Integer
[:putint,:fibo].each do |f| [:putint,:fibo].each do |f|
obj.add_instance_method Builtin::Integer.send(f , nil) obj.add_instance_method Builtin::Integer.send(f , nil)
end end
obj = get_or_create_class :String obj = @space.get_or_create_class :String
[:get , :set , :puts].each do |f| [:get , :set , :puts].each do |f|
obj.add_instance_method Builtin::String.send(f , nil) obj.add_instance_method Builtin::String.send(f , nil)
end end

2
test/parfait/test_all.rb Normal file
View File

@ -0,0 +1,2 @@
require_relative "test_array"
require_relative "test_hash"

42
test/parfait/test_hash.rb Normal file
View File

@ -0,0 +1,42 @@
require_relative "../helper"
class TestLists < MiniTest::Test
def setup
@list = ::Parfait::Hash.new
end
def test_list_create
assert @list.empty?
end
def test_empty_list_doesnt_return
assert_equal nil , @list.get(3)
assert_equal nil , @list.get(:any)
end
def test_one_set1
assert_equal 1 , @list.set(1,1)
end
def test_one_set2
assert_equal :some , @list.set(1,:some)
end
def test_two_sets
assert_equal 1 , @list.set(1,1)
assert_equal :some , @list.set(1,:some)
end
def test_one_get1
test_one_set1
assert_equal 1 , @list.get(1)
end
def test_one_get2
test_one_set2
assert_equal :some , @list.get(1)
end
def test_many_get
shouldda = { :one => 1 , :two => 2 , :three => 3}
shouldda.each do |k,v|
@list.set(k,v)
end
shouldda.each do |k,v|
assert_equal v , @list.get(k)
end
end
end

View File

@ -1,5 +1,5 @@
# All working tests (ahm), still working on the others, so no use to be constantly reminded # All working tests (ahm), still working on the others, so no use to be constantly reminded
require_relative "arm/test_all" require_relative "arm/test_all"
require "parfait/hash_test" require "parfait/test_all"
require_relative "virtual/test_all" require_relative "virtual/test_all"