compile from mom compiler to risc
This commit is contained in:
parent
5994cd3276
commit
d5f89a4979
@ -33,9 +33,9 @@ module Mom
|
|||||||
end
|
end
|
||||||
|
|
||||||
# generate the risc label lazily
|
# generate the risc label lazily
|
||||||
def risc_label(comiler)
|
def risc_label(compiler)
|
||||||
@risc_label ||= Risc.label(self,name)
|
@risc_label ||= Risc.label(self,name)
|
||||||
comiler.add_constant(@risc_label.address)
|
compiler.add_constant(@risc_label.address)
|
||||||
@risc_label
|
@risc_label
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -27,6 +27,21 @@ module Mom
|
|||||||
@callable
|
@callable
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# drop down to risc
|
||||||
|
def to_risc
|
||||||
|
risc_comp = Risc::MethodCompiler.new(@callable , mom_instructions)
|
||||||
|
instruction = mom_instructions.next
|
||||||
|
while( instruction )
|
||||||
|
raise "whats this a #{instruction}" unless instruction.is_a?(Mom::Instruction)
|
||||||
|
#puts "adding mom #{instruction.to_s}:#{instruction.next.to_s}"
|
||||||
|
instruction.to_risc( risc_comp )
|
||||||
|
risc_comp.reset_regs
|
||||||
|
#puts "adding risc #{risc.to_s}:#{risc.next.to_s}"
|
||||||
|
instruction = instruction.next
|
||||||
|
end
|
||||||
|
risc_comp
|
||||||
|
end
|
||||||
|
|
||||||
# helper method for builtin mainly
|
# helper method for builtin mainly
|
||||||
# the class_name is a symbol, which is resolved to the instance_type of that class
|
# the class_name is a symbol, which is resolved to the instance_type of that class
|
||||||
#
|
#
|
||||||
|
@ -45,19 +45,6 @@ module Mom
|
|||||||
Risc::RiscCollection.new(riscs)
|
Risc::RiscCollection.new(riscs)
|
||||||
end
|
end
|
||||||
|
|
||||||
# convert the given mom instruction to_risc and then add it (see add_code)
|
|
||||||
# continue down the instruction chain unti depleted
|
|
||||||
# (adding moves the insertion point so the whole mom chain is added as a risc chain)
|
|
||||||
def add_mom( instruction )
|
|
||||||
while( instruction )
|
|
||||||
raise "whats this a #{instruction}" unless instruction.is_a?(Mom::Instruction)
|
|
||||||
#puts "adding mom #{instruction.to_s}:#{instruction.next.to_s}"
|
|
||||||
instruction.to_risc( self )
|
|
||||||
reset_regs
|
|
||||||
#puts "adding risc #{risc.to_s}:#{risc.next.to_s}"
|
|
||||||
instruction = instruction.next
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -11,14 +11,14 @@ module Risc
|
|||||||
#
|
#
|
||||||
class CallableCompiler
|
class CallableCompiler
|
||||||
|
|
||||||
# Must pass the callable (method/block) and the constants that were parsed
|
# Must pass the callable (method/block)
|
||||||
# Also start instuction, usually a label is mandatory
|
# Also start instuction, usually a label is mandatory
|
||||||
def initialize( callable , constants , start)
|
def initialize( callable , mom_label)
|
||||||
@callable = callable
|
@callable = callable
|
||||||
@regs = []
|
@regs = []
|
||||||
@constants = constants
|
@constants = []
|
||||||
@block_compilers = []
|
@block_compilers = []
|
||||||
@current = @risc_instructions = start
|
@current = @risc_instructions = mom_label.risc_label(self)
|
||||||
reset_regs
|
reset_regs
|
||||||
end
|
end
|
||||||
attr_reader :risc_instructions , :constants , :block_compilers , :callable , :current
|
attr_reader :risc_instructions , :constants , :block_compilers , :callable , :current
|
||||||
|
@ -5,8 +5,10 @@ module Risc
|
|||||||
|
|
||||||
class MethodCompiler < CallableCompiler
|
class MethodCompiler < CallableCompiler
|
||||||
|
|
||||||
def initialize( method )
|
# Methods starts with a Label, both in risc and mom.
|
||||||
super(method)
|
# Pass in the callable(method) and the mom label that the method starts with
|
||||||
|
def initialize( method , mom_label)
|
||||||
|
super(method , mom_label)
|
||||||
end
|
end
|
||||||
|
|
||||||
#include block_compilers constants
|
#include block_compilers constants
|
||||||
|
@ -7,20 +7,30 @@ module Mom
|
|||||||
def setup
|
def setup
|
||||||
end
|
end
|
||||||
|
|
||||||
def in_test_vool(str)
|
def in_test_vool(body = "@ivar = 5")
|
||||||
vool = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_vool(in_Test(str))
|
code = in_Test("def meth; #{body};end")
|
||||||
vool.to_mom(nil)
|
RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_mom(code)
|
||||||
vool
|
|
||||||
end
|
|
||||||
def create_method(body = "@ivar = 5")
|
|
||||||
in_test_vool("def meth; #{body};end")
|
|
||||||
test = Parfait.object_space.get_class_by_name(:Test)
|
|
||||||
test.get_method(:meth)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_method_has_source
|
def test_method
|
||||||
method = create_method
|
in_test_vool()
|
||||||
assert_equal Vool::IvarAssignment , method.source.class
|
method = Parfait.object_space.get_class_by_name(:Test).get_method(:meth)
|
||||||
|
assert_equal Parfait::VoolMethod , method.class
|
||||||
|
end
|
||||||
|
def test_method_mom_col
|
||||||
|
mom = in_test_vool()
|
||||||
|
assert_equal Mom::MomCollection , mom.class
|
||||||
|
assert_equal Mom::MethodCompiler , mom.compilers.first.class
|
||||||
|
end
|
||||||
|
def test_compiles_risc
|
||||||
|
compiler = in_test_vool().compilers.first.to_risc
|
||||||
|
assert_equal Risc::MethodCompiler , compiler.class
|
||||||
|
assert_equal Risc::Label , compiler.risc_instructions.class
|
||||||
|
end
|
||||||
|
def test_compiles_all_risc
|
||||||
|
compiler = in_test_vool().compilers.first.to_risc
|
||||||
|
assert_equal Risc::LoadConstant , compiler.risc_instructions.next.class
|
||||||
|
assert_equal 17 , compiler.risc_instructions.length
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -3,8 +3,8 @@ module Risc
|
|||||||
class FakeCallable
|
class FakeCallable
|
||||||
end
|
end
|
||||||
class FakeCallableCompiler < CallableCompiler
|
class FakeCallableCompiler < CallableCompiler
|
||||||
def initialize(a,b,c)
|
def initialize(a,c)
|
||||||
super(a,b,c)
|
super(a,c)
|
||||||
end
|
end
|
||||||
def source_name
|
def source_name
|
||||||
"luke"
|
"luke"
|
||||||
@ -14,8 +14,8 @@ module Risc
|
|||||||
|
|
||||||
def setup
|
def setup
|
||||||
Parfait.boot!({})
|
Parfait.boot!({})
|
||||||
label = Risc.label("hi","ho")
|
label = Mom::Label.new("hi","ho")
|
||||||
@compiler = FakeCallableCompiler.new(FakeCallable.new , [] , label)
|
@compiler = FakeCallableCompiler.new(FakeCallable.new , label)
|
||||||
end
|
end
|
||||||
def test_ok
|
def test_ok
|
||||||
assert @compiler
|
assert @compiler
|
||||||
|
@ -67,14 +67,6 @@ module Risc
|
|||||||
assert_equal Mom::MethodCompiler , compiler.class
|
assert_equal Mom::MethodCompiler , compiler.class
|
||||||
compiler
|
compiler
|
||||||
end
|
end
|
||||||
def test_has_method_constant
|
|
||||||
compiler = constant_setup("def meth; return 'Hi';end")
|
|
||||||
assert compiler.constants.include?("Hi")
|
|
||||||
end
|
|
||||||
def test_has_block_constant
|
|
||||||
compiler = constant_setup("def meth; meth{return 'Ho'};return 'Hi';end")
|
|
||||||
assert compiler.constants.include?("Ho")
|
|
||||||
end
|
|
||||||
def test_return_label
|
def test_return_label
|
||||||
compiler = constant_setup("def meth; return 'Hi';end")
|
compiler = constant_setup("def meth; return 'Hi';end")
|
||||||
assert_equal "return_label", compiler.return_label.name
|
assert_equal "return_label", compiler.return_label.name
|
||||||
|
Loading…
Reference in New Issue
Block a user