passing frame (locals) into method creation
so typed_method have correct frame information and can resolve slots correctly (next step)
This commit is contained in:
parent
0813312ddc
commit
af94d40cab
@ -74,14 +74,18 @@ module Parfait
|
|||||||
names
|
names
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_method( method_name , arguments )
|
def create_method( method_name , arguments , frame)
|
||||||
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)
|
||||||
#puts "Self: #{self.class} clazz: #{clazz.name}"
|
#puts "Self: #{self.class} clazz: #{clazz.name}"
|
||||||
found = get_method( method_name )
|
found = get_method( method_name )
|
||||||
|
#TODO check types and then what ?
|
||||||
return found if found
|
return found if found
|
||||||
arg_type = arguments
|
if arguments.is_a?(Hash)
|
||||||
arg_type = NamedList.type_for( arguments ) if arguments.is_a?(Hash)
|
raise "May want to get rid of this way"
|
||||||
add_method TypedMethod.new( self , method_name , arg_type )
|
arguments = NamedList.type_for( arguments )
|
||||||
|
end
|
||||||
|
raise "frame must be a type, not:#{frame}" unless frame.is_a?(Type)
|
||||||
|
add_method TypedMethod.new( self , method_name , arguments , frame )
|
||||||
end
|
end
|
||||||
|
|
||||||
def add_method( method )
|
def add_method( method )
|
||||||
|
@ -26,16 +26,17 @@ module Parfait
|
|||||||
# not part of the parfait model, hence ruby accessor
|
# not part of the parfait model, hence ruby accessor
|
||||||
attr_accessor :source
|
attr_accessor :source
|
||||||
|
|
||||||
def initialize( type , name , arguments )
|
def initialize( type , name , arguments , frame)
|
||||||
super()
|
super()
|
||||||
raise "No class #{name}" unless type
|
raise "No class #{name}" unless type
|
||||||
raise "For type, not class #{type}" unless type.is_a?(Type)
|
raise "For type, not class #{type}" unless type.is_a?(Type)
|
||||||
raise "Wrong argument type, expect Type not #{arguments.class}" unless arguments.is_a? Type
|
raise "Wrong argument type, expect Type not #{arguments.class}" unless arguments.is_a? Type
|
||||||
|
raise "Wrong frame type, expect Type not #{frame.class}" unless frame.is_a? Type
|
||||||
@for_type = type
|
@for_type = type
|
||||||
@name = name
|
@name = name
|
||||||
@binary = BinaryCode.new 0
|
@binary = BinaryCode.new 0
|
||||||
@arguments = arguments
|
@arguments = arguments
|
||||||
@frame = Parfait.object_space.get_class_by_name( :NamedList ).instance_type
|
@frame = frame
|
||||||
end
|
end
|
||||||
|
|
||||||
def set_instructions(inst)
|
def set_instructions(inst)
|
||||||
|
@ -28,7 +28,7 @@ module Parfait
|
|||||||
|
|
||||||
def create_parfait_method( type )
|
def create_parfait_method( type )
|
||||||
raise "create_method #{type.inspect} is not a Type" unless type.is_a? Parfait::Type
|
raise "create_method #{type.inspect} is not a Type" unless type.is_a? Parfait::Type
|
||||||
type.create_method( @name , @args_type )#FIXME, @frame_type)
|
type.create_method( @name , @args_type , @frame_type)
|
||||||
end
|
end
|
||||||
|
|
||||||
def create_tmp
|
def create_tmp
|
||||||
|
@ -50,16 +50,28 @@ module Vool
|
|||||||
assert_equal Parfait::Class , clazz.body.clazz.class
|
assert_equal Parfait::Class , clazz.body.clazz.class
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_method_statement_has_class_in_main
|
def test_typed_method_instance_type
|
||||||
clazz = VoolCompiler.ruby_to_vool in_Space("def meth; @ivar = 5;end")
|
VoolCompiler.ruby_to_vool in_Test("def meth; @ivar = 5; @ibar = 4;end")
|
||||||
assert clazz.body.clazz
|
test = Parfait.object_space.get_class_by_name(:Test)
|
||||||
|
method = test.instance_type.get_method(:meth)
|
||||||
|
assert_equal 2, method.for_type.variable_index(:ivar)
|
||||||
|
assert_equal 3, method.for_type.variable_index(:ibar)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_method_has_one_local
|
def test_vool_method_has_one_local
|
||||||
VoolCompiler.ruby_to_vool in_Test("def meth; local = 5 ;end")
|
VoolCompiler.ruby_to_vool in_Test("def meth; local = 5 ; a = 6;end")
|
||||||
test = Parfait.object_space.get_class_by_name(:Test)
|
test = Parfait.object_space.get_class_by_name(:Test)
|
||||||
method = test.get_method(:meth)
|
method = test.get_method(:meth)
|
||||||
assert_equal 2 , method.frame_type.instance_length
|
assert_equal 3 , method.frame_type.instance_length
|
||||||
|
assert_equal 2 , method.frame_type.variable_index(:local)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_typed_method_has_one_local
|
||||||
|
VoolCompiler.ruby_to_vool in_Test("def meth; local = 5 ; a = 6;end")
|
||||||
|
test = Parfait.object_space.get_class_by_name(:Test)
|
||||||
|
method = test.instance_type.get_method(:meth)
|
||||||
|
assert_equal 3 , method.frame.instance_length
|
||||||
|
assert_equal 2 , method.frame.variable_index(:local)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user