Integer macros tests and defs

This commit is contained in:
Torsten Rüger 2019-09-11 19:23:56 +03:00
parent e8bfb9a58c
commit 5ea91df4c1
10 changed files with 266 additions and 6 deletions

View File

@ -28,6 +28,33 @@ module Mom
return compiler return compiler
end end
end end
end
class Comparison < ::Mom::Instruction
attr_reader :operator
def initialize(name , operator)
super(name)
@operator = operator.value
end
def to_risc(compiler)
builder = compiler.builder(compiler.source)
operator = @operator # make accessible in block
builder.build do
integer! << message[:receiver]
integer.reduce_int
integer_reg! << message[:arg1] #"other"
integer_reg.reduce_int
swap_names(:integer , :integer_reg) if(operator.to_s.start_with?('<') )
integer.op :- , integer_reg
if_minus false_label
if_zero( false_label ) if operator.to_s.length == 1
object! << Parfait.object_space.true_object
branch merge_label
add_code false_label
object << Parfait.object_space.false_object
add_code merge_label
message[:return_value] << object
end
return compiler
end
end end
end end

View File

@ -62,4 +62,65 @@ module Mom
end end
end end
end end
class Div10 < ::Mom::Instruction
def to_risc(compiler)
s = "div_10 "
builder = compiler.builder(compiler.source)
integer_tmp = builder.allocate_int
builder.build do
integer_self! << message[:receiver]
integer_self.reduce_int
integer_1! << integer_self
integer_reg! << integer_self
integer_const! << 1
integer_1.op :>> , integer_const
integer_const << 2
integer_reg.op :>> , integer_const
integer_reg.op :+ , integer_1
integer_const << 4
integer_1 << integer_reg
integer_reg.op :>> , integer_1
integer_reg.op :+ , integer_1
integer_const << 8
integer_1 << integer_reg
integer_1.op :>> , integer_const
integer_reg.op :+ , integer_1
integer_const << 16
integer_1 << integer_reg
integer_1.op :>> , integer_const
integer_reg.op :+ , integer_1
integer_const << 3
integer_reg.op :>> , integer_const
integer_const << 10
integer_1 << integer_reg
integer_1.op :* , integer_const
integer_self.op :- , integer_1
integer_1 << integer_self
integer_const << 6
integer_1.op :+ , integer_const
integer_const << 4
integer_1.op :>> , integer_const
integer_reg.op :+ , integer_1
integer_tmp[Parfait::Integer.integer_index] << integer_reg
message[:return_value] << integer_tmp
end
return compiler
end
end
end end

View File

@ -16,4 +16,19 @@ module Mom
end end
end end
end end
class Div4 < ::Mom::Instruction
def to_risc(compiler)
builder = compiler.builder(compiler.source)
integer_tmp = builder.allocate_int
builder.build do
integer_self! << message[:receiver]
integer_self.reduce_int
integer_1! << 2
integer_self.op :>> , integer_1
integer_tmp[Parfait::Integer.integer_index] << integer_self
message[:return_value] << integer_tmp
end
return compiler
end
end
end end

View File

@ -61,7 +61,7 @@ module Mom
# - returns the new int # - returns the new int
def operator_method( op_sym ) def operator_method( op_sym )
compiler = compiler_for(:Integer, op_sym ,{other: :Integer }) compiler = compiler_for(:Integer, op_sym ,{other: :Integer })
compiler.add_code Operator.new("operator" , op_sym) compiler.add_code Operator.new( "op:#{op_sym}" , op_sym)
return compiler return compiler
end end

View File

@ -23,13 +23,12 @@ module Mom
return compiler return compiler
end end
end end
end end
class IntOperator < Instruction class IntOperator < Instruction
attr_reader :operator attr_reader :operator
def initialize(name , operator) def initialize(name , operator)
super(name) super(name)
@operator = operator @operator = operator.value
end end
def to_risc(compiler) def to_risc(compiler)

View File

@ -13,8 +13,9 @@ module Risc
class OperatorInstruction < Instruction class OperatorInstruction < Instruction
def initialize( source , operator , left , right ) def initialize( source , operator , left , right )
super(source) super(source)
operator = operator.value if operator.is_a?(Vool::Constant)
@operator = operator @operator = operator
raise "unsuported operator :#{operator}:" unless Risc.operators.include?(operator) raise "unsuported operator :#{operator}:#{operator.class}:" unless Risc.operators.include?(operator)
@left = left @left = left
@right = right @right = right
raise "Not register #{left}" unless RegisterValue.look_like_reg(left) raise "Not register #{left}" unless RegisterValue.look_like_reg(left)

View File

@ -0,0 +1,47 @@
require_relative "helper"
module RubyX
module Builtin
class TestIntegerSame < MiniTest::Test
include BuiltinHelper
def op ; :== ; end
def len ; 25 ; end
def source
<<GET
class Integer
def #{op}(other)
X.comparison(:"#{op}")
end
end
GET
end
def test_mom_meth
assert_equal op , compiler.callable.name
end
def test_instr_len
assert_equal 7 , compiler.mom_instructions.length
end
def test_instr_op
assert_equal Mom::Comparison , compiler.mom_instructions.next.class
assert_equal op , compiler.mom_instructions.next.operator
end
def test_risc
assert_equal len , compiler.to_risc.risc_instructions.length
end
end
class TestIntegerLg < TestIntegerSame
def op ; :> ; end
def len ; 26 ; end
end
class TestIntegerSm < TestIntegerSame
def op ; :< ; end
def len ; 26 ; end
end
class TestIntegerLe < TestIntegerSame
def op ; :>= ; end
end
class TestIntegerSe < TestIntegerSame
def op ; :<= ; end
end
end
end

View File

@ -0,0 +1,30 @@
require_relative "helper"
module RubyX
module Builtin
class TestIntegerDiv10 < MiniTest::Test
include BuiltinHelper
def source
<<GET
class Integer
def div10
X.div10
end
end
GET
end
def test_mom_meth
assert_equal :div10 , compiler.callable.name
end
def test_instr_len
assert_equal 7 , compiler.mom_instructions.length
end
def test_instr_get
assert_equal Mom::Div10 , compiler.mom_instructions.next.class
end
def test_risc
assert_equal 70 , compiler.to_risc.risc_instructions.length
end
end
end
end

View File

@ -0,0 +1,30 @@
require_relative "helper"
module RubyX
module Builtin
class TestIntegerDiv4 < MiniTest::Test
include BuiltinHelper
def source
<<GET
class Integer
def div4
X.div4
end
end
GET
end
def test_mom_meth
assert_equal :div4 , compiler.callable.name
end
def test_instr_len
assert_equal 7 , compiler.mom_instructions.length
end
def test_instr_get
assert_equal Mom::Div4 , compiler.mom_instructions.next.class
end
def test_risc
assert_equal 41 , compiler.to_risc.risc_instructions.length
end
end
end
end

View File

@ -0,0 +1,50 @@
require_relative "helper"
module RubyX
module Builtin
class TestIntegerPlus < MiniTest::Test
include BuiltinHelper
def op ; :+ ; end
def source
<<GET
class Integer
def #{op}(other)
X.int_operator(:"#{op}")
end
end
GET
end
def test_mom_meth
assert_equal op , compiler.callable.name
end
def test_instr_len
assert_equal 7 , compiler.mom_instructions.length
end
def test_instr_op
assert_equal Mom::IntOperator , compiler.mom_instructions.next.class
assert_equal op , compiler.mom_instructions.next.operator
end
def test_risc
assert_equal 42 , compiler.to_risc.risc_instructions.length
end
end
class TestIntegerMinus < TestIntegerPlus
def op ; :- ; end
end
class TestIntegerRS < TestIntegerPlus
def op ; :<< ; end
end
class TestIntegerRS < TestIntegerPlus
def op ; :>> ; end
end
class TestIntegerMul < TestIntegerPlus
def op ; :* ; end
end
class TestIntegerAnd < TestIntegerPlus
def op ; :& ; end
end
class TestIntegerOr < TestIntegerPlus
def op ; :| ; end
end
end
end