random tries

This commit is contained in:
Torsten Ruger 2018-03-15 10:46:17 +05:30
parent 0a9997f549
commit 163cad456f
7 changed files with 16 additions and 21 deletions

View File

@ -31,12 +31,9 @@ module Mom
left = SlotDefinition.new(left.shift , left) if left.is_a? Array left = SlotDefinition.new(left.shift , left) if left.is_a? Array
@left , @right = left , right @left , @right = left , right
raise "left not SlotDefinition, #{left}" unless left.is_a? SlotDefinition raise "left not SlotDefinition, #{left}" unless left.is_a? SlotDefinition
raise "right not Mom, #{right.to_rxf}" unless right.class.name.include?("Mom")
end end
end end
class SlotDefinition class SlotDefinition
attr_reader :known_object , :slots attr_reader :known_object , :slots
def initialize( object , slots) def initialize( object , slots)

View File

@ -5,11 +5,17 @@ module Mom
def initialize(left , right) def initialize(left , right)
right = SlotDefinition.new(right.shift , right) if right.is_a? Array right = SlotDefinition.new(right.shift , right) if right.is_a? Array
raise "right not Mom, #{right.to_s}" unless right.is_a?( SlotDefinition )
super(left , right) super(left , right)
end end
def to_risc(context) def to_risc(context)
Risc::Label.new(self,"SlotMove") reg = context.use_reg(:int)#( @right.ct_type)
end const = Risc.load_constant(self, @right , reg)
# const.set_next Risc.reg_to_slot(self, reg , @left.known_object, @left.slots.first)
# context.release_reg(reg)
return const
end
end end
end end

View File

@ -12,7 +12,9 @@ module Vool
else else
type = :frame type = :frame
end end
@value.slot_class.new(Mom::SlotDefinition.new(:message , [type , @name]) , @value.to_mom(method)) statements = @value.to_mom(method)
statements << @value.slot_class.new([:message , type , @name] , @value.slot_definition)
return statements
end end
end end

View File

@ -15,8 +15,10 @@ module Vool
# - store the given return value, this is a SlotMove / SlotConstant # - store the given return value, this is a SlotMove / SlotConstant
# - activate return sequence (reinstantiate old message and jump to return address) # - activate return sequence (reinstantiate old message and jump to return address)
def to_mom( method ) def to_mom( method )
move = @return_value.slot_class.new( [:message , :return_value] , @return_value.to_mom(method)) statements = @return_value.to_mom(method)
Mom::Statements.new [move , Mom::ReturnSequence.new] statements << @return_value.slot_class.new( [:message , :return_value] , @return_value.slot_definition )
statements << Mom::ReturnSequence.new
return statements
end end
end end

View File

@ -66,10 +66,6 @@ module Vool
Mom::Statements.new( cache_check(in_method) + call_cached_method(in_method) ) Mom::Statements.new( cache_check(in_method) + call_cached_method(in_method) )
end end
def flatten
raise "flat"
end
# check that current type is the cached type # check that current type is the cached type
# if not, change and find method for the type (simple_call to resolve_method) # if not, change and find method for the type (simple_call to resolve_method)
# conceptually easy in ruby, but we have to compile that "easy" ruby # conceptually easy in ruby, but we have to compile that "easy" ruby

View File

@ -41,9 +41,7 @@ module Risc
end end
def check_nil def check_nil
assert @expect , "No output given" assert @expect , "No output given"
Vool::VoolCompiler.ruby_to_vool "class Space; def main(arg);#{@input};end;end" Vool::VoolCompiler.ruby_to_vool "class Space; def main(arg);#{@input};end;end"
produced = Parfait.object_space.get_main.instructions produced = Parfait.object_space.get_main.instructions
compare_instructions produced , @expect compare_instructions produced , @expect
end end

View File

@ -5,22 +5,16 @@ module Risc
class TestAssignStatement < MiniTest::Test class TestAssignStatement < MiniTest::Test
include Statements include Statements
def test_assign_local_assign def pest_assign_local_assign
Parfait.object_space.get_main.add_local(:r , :Integer) Parfait.object_space.get_main.add_local(:r , :Integer)
@input = "r = 5" @input = "r = 5"
@expect = [LoadConstant, RegToSlot] @expect = [LoadConstant, RegToSlot]
assert_nil msg = check_nil , msg assert_nil msg = check_nil , msg
end end
def pest_assign_op def pest_assign_op
Parfait.object_space.get_main.add_local(:r , :Integer) Parfait.object_space.get_main.add_local(:r , :Integer)
@input = "r = 10.mod4" @input = "r = 10.mod4"
@expect = [Label, LoadConstant, SlotToReg, RegToSlot, Label, FunctionReturn] @expect = [Label, LoadConstant, SlotToReg, RegToSlot, Label, FunctionReturn]
assert_nil msg = check_nil , msg assert_nil msg = check_nil , msg
end end