start better if mom test
This commit is contained in:
parent
349dd37c82
commit
c3939ef622
@ -20,6 +20,10 @@ module Rubyx
|
|||||||
type.create_method( @name , @args_type )#FIXME, @locals_type)
|
type.create_method( @name , @args_type )#FIXME, @locals_type)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def create_tmp
|
||||||
|
tmp_name = "tmp_#{@locals_type.instance_length}"
|
||||||
|
@locals_type = @locals_type.add_instance_variable( tmp_name , :Object )
|
||||||
|
tmp_name
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -131,8 +131,8 @@ module Vm
|
|||||||
Tree::KnownName.new(statement.children.first)
|
Tree::KnownName.new(statement.children.first)
|
||||||
end
|
end
|
||||||
|
|
||||||
def on_string expression
|
def on_string expressions
|
||||||
Tree::StringExpression.new(expression.children.first)
|
Tree::StringExpression.new(expressions.children.first)
|
||||||
end
|
end
|
||||||
|
|
||||||
def on_class_name expression
|
def on_class_name expression
|
||||||
|
@ -185,6 +185,10 @@ module Vool
|
|||||||
w
|
w
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def handler_missing(node)
|
||||||
|
raise "Handler missing #{node}"
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def instance_name sym
|
def instance_name sym
|
||||||
|
@ -10,18 +10,18 @@ module Vool
|
|||||||
end
|
end
|
||||||
|
|
||||||
def to_mom( method )
|
def to_mom( method )
|
||||||
if_true = @if_true.to_mom( method )
|
|
||||||
if_false = @if_false.to_mom( method )
|
|
||||||
merge = Mom::Noop.new(:merge)
|
merge = Mom::Noop.new(:merge)
|
||||||
make_condition( add_jump(if_true,merge) , add_jump(if_false,merge) , merge)
|
if_true = add_jump(@if_true.to_mom( method ) , merge)
|
||||||
|
if_false = add_jump(@if_false.to_mom( method ) , merge)
|
||||||
|
cond = hoist_condition( method )
|
||||||
|
check = Mom::TruthCheck.new( cond.pop , if_true , if_false , merge)
|
||||||
|
[ *check , if_true , if_false , merge ]
|
||||||
end
|
end
|
||||||
|
|
||||||
# conditions in ruby are almost always method sends (as even comparisons are)
|
def hoist_condition( method )
|
||||||
# currently we just deal with straight up values which get tested
|
return [@condition] if @condition.is_a?(Vool::Named)
|
||||||
# for the funny ruby logic (everything but false and nil is true)
|
local = method.create_tmp
|
||||||
def make_condition( if_true , if_false , merge)
|
puts local
|
||||||
check = Mom::TruthCheck.new( @condition , if_true , if_false , merge)
|
|
||||||
[ check , if_true , if_false , merge ]
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def collect(arr)
|
def collect(arr)
|
||||||
|
@ -14,6 +14,18 @@ module Rubyx
|
|||||||
test.get_method(:meth)
|
test.get_method(:meth)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def create_method_arg
|
||||||
|
RubyCompiler.compile in_Test("def meth_arg(arg); arg ;end")
|
||||||
|
test = Parfait.object_space.get_class_by_name(:Test)
|
||||||
|
test.get_method(:meth_arg)
|
||||||
|
end
|
||||||
|
|
||||||
|
def create_method_local
|
||||||
|
RubyCompiler.compile in_Test("def meth_local(arg); local = 5 ;end")
|
||||||
|
test = Parfait.object_space.get_class_by_name(:Test)
|
||||||
|
test.get_method(:meth_arg)
|
||||||
|
end
|
||||||
|
|
||||||
def test_creates_method_in_class
|
def test_creates_method_in_class
|
||||||
method = create_method
|
method = create_method
|
||||||
assert method , "No method created"
|
assert method , "No method created"
|
||||||
@ -34,5 +46,15 @@ module Rubyx
|
|||||||
assert_equal 1 , method.locals_type.instance_length
|
assert_equal 1 , method.locals_type.instance_length
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_method_has_args
|
||||||
|
method = create_method_arg
|
||||||
|
assert_equal 2 , method.args_type.instance_length
|
||||||
|
end
|
||||||
|
|
||||||
|
def Test_method_has_locals
|
||||||
|
method = create_method_local
|
||||||
|
assert_equal 2 , method.locals_type.instance_length
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
28
test/vool/to_mom/test_condition_if.rb
Normal file
28
test/vool/to_mom/test_condition_if.rb
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
|
||||||
|
require_relative "helper"
|
||||||
|
|
||||||
|
module Vool
|
||||||
|
class TestIfMom #< MiniTest::Test
|
||||||
|
include MomCompile
|
||||||
|
|
||||||
|
def setup
|
||||||
|
Risc.machine.boot
|
||||||
|
@stats = compile_first_method( "if(@a == 5) ; 5.mod4 ; else; 4.mod4 ; end")
|
||||||
|
@first = @stats.first
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_if_compiles_as_array
|
||||||
|
assert_equal Array , @first.class , @stats
|
||||||
|
end
|
||||||
|
def test_condition_compiles_to_check
|
||||||
|
assert_equal Mom::TruthCheck , @first.first.class , @stats
|
||||||
|
end
|
||||||
|
def test_condition_is_instance
|
||||||
|
assert_equal Vool::LocalVariable , @first.first.condition.class , @stats
|
||||||
|
end
|
||||||
|
def est_true_block_is_second
|
||||||
|
assert_equal @first[1] , @first.first.true_block , @stats
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
Loading…
x
Reference in New Issue
Block a user