fixes from the method argument change

Affects
method creation
argument manipulation
compiler / to_code
This commit is contained in:
Torsten Ruger 2016-12-13 18:49:45 +02:00
parent 2c5541fb19
commit 16b3a77350
8 changed files with 26 additions and 25 deletions

View File

@ -104,16 +104,10 @@ module Typed
# return the compiler (for chaining) # return the compiler (for chaining)
def create_method_for clazz , method_name , args def create_method_for clazz , method_name , args
@clazz = clazz @clazz = clazz
raise "Args must be Hash #{args}" unless args.is_a?(Hash)
raise "create_method #{method_name}.#{method_name.class}" unless method_name.is_a? Symbol raise "create_method #{method_name}.#{method_name.class}" unless method_name.is_a? Symbol
arguments = [] arguments = Parfait::Type.new_for_hash( clazz , args )
if( args.is_a? Array) @method = clazz.create_instance_method( method_name , arguments)
arguments = args
else
args.each do | name , type |
arguments << Parfait::Variable.new( type , name.to_sym)
end
end
@method = clazz.create_instance_method( method_name , Parfait.new_list(arguments))
self self
end end

View File

@ -5,9 +5,7 @@ module Typed
# return_type , name , parameters, kids , receiver = *statement # return_type , name , parameters, kids , receiver = *statement
raise "Already in method #{@method}" if @method raise "Already in method #{@method}" if @method
args = statement.parameters.collect do |p| args = statement.parameters
Parfait::Variable.new( *p )
end
class_method = handle_receiver( statement ) #nil for instance method class_method = handle_receiver( statement ) #nil for instance method

View File

@ -12,7 +12,8 @@ module Typed
end end
# either an argument, so it's stored in message # either an argument, so it's stored in message
if( index = @method.has_arg(name)) if( index = @method.has_arg(name))
ret = use_reg @method.arguments[index].value_type ret = use_reg @method.argument_type(index)
#puts "For #{name} at #{index} got #{@method.arguments.inspect}"
add_code Register.get_slot(statement , :message , Parfait::Message.get_indexed(index), ret ) add_code Register.get_slot(statement , :message , Parfait::Message.get_indexed(index), ret )
return ret return ret
end end
@ -24,7 +25,7 @@ module Typed
def handle_local statement def handle_local statement
index = @method.has_local( statement.name ) index = @method.has_local( statement.name )
raise "must define variable '#{name}' before using it" unless index raise "must define variable '#{statement.name}' before using it" unless index
frame = use_reg :Frame frame = use_reg :Frame
add_code Register.get_slot(statement , :message , :frame , frame ) add_code Register.get_slot(statement , :message , :frame , frame )
ret = use_reg @method.locals[index].value_type ret = use_reg @method.locals[index].value_type

View File

@ -25,15 +25,21 @@ module Typed
w = Tree::FunctionStatement.new() w = Tree::FunctionStatement.new()
w.return_type = return_type w.return_type = return_type
w.name = name.children.first w.name = name.children.first
w.parameters = parameters.to_a.collect do |p| w.parameters = process parameters
raise "error, argument must be a identifier, not #{p}" unless p.type == :parameter
p.children
end
w.statements = process(statements) w.statements = process(statements)
w.receiver = receiver w.receiver = receiver
w w
end end
def on_parameters statement
params = {}
statement.children.each do |param , type , name|
type , name = *param
params[name] = type
end
params
end
def on_field_def statement def on_field_def statement
type , name , value = *statement type , name , value = *statement
w = Tree::FieldDef.new() w = Tree::FieldDef.new()

View File

@ -24,7 +24,7 @@ module Register
end end
def test_args def test_args
Register.machine.space.get_main.arguments.push Parfait::Variable.new(:Integer , :bar) Register.machine.space.get_main.add_argument(:bar , :Integer)
@input = s(:name, :bar) @input = s(:name, :bar)
@output = Register::RegisterValue @output = Register::RegisterValue
check check

View File

@ -8,7 +8,7 @@ class TestClass < MiniTest::Test
end end
def foo_method for_class = :Try def foo_method for_class = :Try
args = Parfait.new_list [ Parfait::Variable.new(:Integer , :bar )] args = Parfait::Type.new_for_hash( @try , { bar: :Integer})
::Parfait::TypedMethod.new @space.get_class_by_name(for_class) , :foo , args ::Parfait::TypedMethod.new @space.get_class_by_name(for_class) , :foo , args
end end
@ -42,7 +42,8 @@ class TestClass < MiniTest::Test
end end
end end
def test_create_method def test_create_method
@try.create_instance_method :bar, Parfait.new_list( [ Parfait::Variable.new(:Integer , :bar )]) args = Parfait::Type.new_for_hash( @try , { bar: :Integer})
@try.create_instance_method :bar, args
assert_equal ":bar" , @try.method_names.inspect assert_equal ":bar" , @try.method_names.inspect
end end
def test_method_get def test_method_get

View File

@ -8,7 +8,7 @@ class TestMeta < MiniTest::Test
end end
def foo_method for_class = :Try def foo_method for_class = :Try
args = Parfait.new_list [ Parfait::Variable.new(:Integer , :bar )] args = Parfait::Type.new_for_hash( @try , { bar: :Integer})
::Parfait::TypedMethod.new @space.get_class_by_name(for_class) , :foo , args ::Parfait::TypedMethod.new @space.get_class_by_name(for_class) , :foo , args
end end
@ -24,7 +24,8 @@ class TestMeta < MiniTest::Test
end end
def test_create_method def test_create_method
@try.create_instance_method :bar, Parfait.new_list( [ Parfait::Variable.new(:Integer , :bar )]) args = Parfait::Type.new_for_hash( @try , { bar: :Integer})
@try.create_instance_method :bar, args
assert_equal ":bar" , @try.method_names.inspect assert_equal ":bar" , @try.method_names.inspect
end end
def test_add_method def test_add_method

View File

@ -58,7 +58,7 @@ class TestAssignStatement < MiniTest::Test
end end
def test_assign_arg def test_assign_arg
Register.machine.space.get_main.arguments.push Parfait::Variable.new(:Integer , :blar) Register.machine.space.get_main.add_argument(:blar , :Integer)
@input = s(:statements, s(:assignment, s(:name, :blar), s(:int, 5))) @input = s(:statements, s(:assignment, s(:name, :blar), s(:int, 5)))
@expect = [Label, LoadConstant, SetSlot, Label, FunctionReturn] @expect = [Label, LoadConstant, SetSlot, Label, FunctionReturn]
was = check was = check
@ -69,7 +69,7 @@ class TestAssignStatement < MiniTest::Test
def test_arg_get def test_arg_get
# have to define bar externally, just because redefining main. Otherwise that would be automatic # have to define bar externally, just because redefining main. Otherwise that would be automatic
Register.machine.space.get_main.arguments.push Parfait::Variable.new(:Integer , :balr) Register.machine.space.get_main.add_argument(:balr , :Integer)
@input = s(:statements, s(:return, s(:name, :balr))) @input = s(:statements, s(:return, s(:name, :balr)))
@expect = [Label, GetSlot, SetSlot, Label, FunctionReturn] @expect = [Label, GetSlot, SetSlot, Label, FunctionReturn]
was = check was = check