some renames before main fixes commences

This commit is contained in:
Torsten Rüger 2019-09-12 13:10:31 +03:00
parent dced6b12e6
commit e33b9f565d
33 changed files with 63 additions and 94 deletions

View File

@ -7,7 +7,7 @@ module Risc
def setup def setup
super super
@input = as_block("return 5") @input = as_block("return 5")
@mom = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_mom(as_test_main) @mom = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_mom(as_main)
end end
def main_risc def main_risc
@mom.to_risc.method_compilers.find{|c| c.callable.name == :main } @mom.to_risc.method_compilers.find{|c| c.callable.name == :main }

View File

@ -22,13 +22,13 @@ module Risc
def as_block( block_input , method_input = "main_local = 5") def as_block( block_input , method_input = "main_local = 5")
"#{method_input} ; self.main{|val| #{block_input}}" "#{method_input} ; self.main{|val| #{block_input}}"
end end
def as_test_main def as_main
"class Test; #{@class_input if @class_input};def main(arg);#{@input};end;end" "class Space; #{@class_input if @class_input};def main(arg);#{@input};end;end"
end end
def to_target def to_target
assert @expect , "No output given" assert @expect , "No output given"
compiler = RubyX::RubyXCompiler.new(RubyX.default_test_options) compiler = RubyX::RubyXCompiler.new(RubyX.default_test_options)
vool = compiler.ruby_to_vool(as_test_main) vool = compiler.ruby_to_vool(as_main)
compiler.to_target(:interpreter) compiler.to_target(:interpreter)
end end
def produce_main def produce_main

View File

@ -5,7 +5,7 @@ module Mom
class BootTest < MiniTest::Test class BootTest < MiniTest::Test
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
Builtin.compiler_for( Parfait.object_space.get_class.instance_type , Space , :main) MomCollection.compiler_for( Parfait.object_space.get_class.instance_type , Parfait::Space , :main)
end end
def get_int_compiler(name) def get_int_compiler(name)
obj_type = Parfait.object_space.get_type_by_class_name(:Integer) obj_type = Parfait.object_space.get_type_by_class_name(:Integer)

View File

@ -5,7 +5,7 @@ module Mom
include ScopeHelper include ScopeHelper
def setup def setup
code = as_test_main_block("return 5" , "a = 1") code = as_main_block("return 5" , "a = 1")
@risc = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_risc(code) @risc = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_risc(code)
end end
@ -24,7 +24,7 @@ module Mom
include ScopeHelper include ScopeHelper
def setup def setup
code = as_test_main_block("return arg" , "arg = 1") code = as_main_block("return arg" , "arg = 1")
@risc = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_risc(code) @risc = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_risc(code)
end end

View File

@ -6,7 +6,7 @@ module Vool
include MomCompile include MomCompile
def setup def setup
@ret = compile_mom( as_test_main("self.main {|elem| elem = 5 } ")) @ret = compile_mom( as_main("self.main {|elem| elem = 5 } "))
end end
def test_is_compiler def test_is_compiler
assert_equal Mom::MomCollection , @ret.class assert_equal Mom::MomCollection , @ret.class
@ -21,7 +21,7 @@ module Vool
class TestBlockLocal < MiniTest::Test class TestBlockLocal < MiniTest::Test
include MomCompile include MomCompile
def setup def setup
@ret = compile_mom( as_test_main("self.main {|elem| local = 5 } ")) @ret = compile_mom( as_main("self.main {|elem| local = 5 } "))
@block = @ret.method_compilers.first.get_method.blocks @block = @ret.method_compilers.first.get_method.blocks
end end
def test_block_arg_type def test_block_arg_type
@ -43,11 +43,11 @@ module Vool
def setup def setup
end end
def test_method_arg_compiles def test_method_arg_compiles
ret = compile_mom( as_test_main("self.main {|elem| arg = 5 } ")) ret = compile_mom( as_main("self.main {|elem| arg = 5 } "))
assert ret assert ret
end end
def test_method_local_compiles def test_method_local_compiles
ret = compile_mom( as_test_main("local = 5 ; self.main {|elem| local = 10 } ")) ret = compile_mom( as_main("local = 5 ; self.main {|elem| local = 10 } "))
assert ret assert ret
end end
end end

View File

@ -1,23 +0,0 @@
require_relative "helper"
module Mom
class TestBuiltinFunction < MiniTest::Test
def setup
Parfait.boot!(Parfait.default_test_options)
@functions = Builtin.boot_functions({})
end
def test_has_boot_function
assert @functions
end
def test_boot_function_type
assert_equal Array, @functions.class
end
def test_boot_function_length
assert_equal 21, @functions.length
end
def test_boot_function_first
assert_equal Mom::MethodCompiler, @functions.first.class
end
end
end

View File

@ -6,7 +6,7 @@ module Vool
include MomCompile include MomCompile
def setup def setup
@ret = compile_mom( as_test_main("return 1")) @ret = compile_mom( as_main("return 1"))
end end
def test_return_class def test_return_class

View File

@ -12,13 +12,13 @@ module Mom
assert_equal MomCollection , @comp.class assert_equal MomCollection , @comp.class
end end
def test_compilers def test_compilers
assert_equal 23 , @comp.compilers.length assert_equal 2 , @comp.compilers.length
end end
def test_boot_compilers def test_init_compiler
assert_equal 22 , @comp.boot_compilers.length assert_equal Mom::MethodCompiler , @comp.init_compiler.class
end end
def test_compilers_bare def test_compilers_bare
assert_equal 22 , MomCollection.new.compilers.length assert_equal 1 , MomCollection.new.compilers.length
end end
def test_append_class def test_append_class
assert_equal MomCollection, (@comp.append @comp).class assert_equal MomCollection, (@comp.append @comp).class
@ -31,7 +31,7 @@ module Mom
include MomCompile include MomCompile
def setup def setup
@comp = compile_mom( "class Test ; def main(); return 'Hi'; end; end;") @comp = compile_mom( "class Space ; def main(); return 'Hi'; end; end;")
@collection = @comp.to_risc() @collection = @comp.to_risc()
end end
def compiler def compiler
@ -42,7 +42,7 @@ module Mom
end end
def test_has_risc_compiler def test_has_risc_compiler
assert_equal Risc::MethodCompiler, compiler.class assert_equal Risc::MethodCompiler, compiler.class
assert_equal 23, @collection.method_compilers.length assert_equal 2, @collection.method_compilers.length
end end
def test_has_risc_instructions def test_has_risc_instructions
assert_equal Risc::Label, compiler.risc_instructions.class assert_equal Risc::Label, compiler.risc_instructions.class

View File

@ -6,7 +6,7 @@ module Vool
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
ruby_tree = Ruby::RubyCompiler.compile( as_test_main("a = 5") ) ruby_tree = Ruby::RubyCompiler.compile( as_main("a = 5") )
@clazz = ruby_tree.to_vool @clazz = ruby_tree.to_vool
end end
def method def method

View File

@ -49,11 +49,11 @@ module Ruby
include RubyTests include RubyTests
def test_compile_one_method def test_compile_one_method
lst = compile( as_test_main("@ivar = 4") ) lst = compile( as_main("@ivar = 4") )
assert_equal IvarAssignment , lst.body.first.body.class assert_equal IvarAssignment , lst.body.first.body.class
end end
def test_compile_two_stats def test_compile_two_stats
lst = compile( as_test_main("false; true;") ) lst = compile( as_main("false; true;") )
assert_equal ScopeStatement , lst.body.first.body.class assert_equal ScopeStatement , lst.body.first.body.class
assert_equal TrueConstant , lst.body.first.body.statements[1].class assert_equal TrueConstant , lst.body.first.body.statements[1].class
end end

View File

@ -1,10 +1,6 @@
module ScopeHelper module ScopeHelper
def in_Test(statements)
"class Test ; #{statements} ; end"
end
def in_Space(statements) def in_Space(statements)
"class Space ; #{statements} ; end" "class Space ; #{statements} ; end"
end end
@ -13,12 +9,8 @@ module ScopeHelper
in_Space("def main(arg) ; #{statements}; end") in_Space("def main(arg) ; #{statements}; end")
end end
def as_test_main( statements ) def as_main_block( block_input = "return 5", method_input = "main_local = 5")
in_Test("def main(arg) ; #{statements}; end") as_main("#{method_input} ; self.main{|val| #{block_input}}")
end
def as_test_main_block( block_input = "return 5", method_input = "main_local = 5")
as_test_main("#{method_input} ; self.main{|val| #{block_input}}")
end end
end end
@ -26,8 +18,8 @@ module VoolCompile
include ScopeHelper include ScopeHelper
include Mom include Mom
def compile_first_method( input ) def compile_main( input )
input = as_test_main( input ) input = as_main( input )
collection = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_mom(input) collection = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_mom(input)
assert collection.is_a?(Mom::MomCollection) , collection.class.name assert collection.is_a?(Mom::MomCollection) , collection.class.name
compiler = collection.compilers.first compiler = collection.compilers.first
@ -35,8 +27,8 @@ module VoolCompile
assert_equal Mom::MethodCompiler , compiler.class assert_equal Mom::MethodCompiler , compiler.class
compiler compiler
end end
def compile_first_block( block_input , method_input = "main_local = 5") def compile_main_block( block_input , method_input = "main_local = 5")
source = as_test_main("#{method_input} ; self.main{|val| #{block_input}}") source = as_main("#{method_input} ; self.main{|val| #{block_input}}")
mom_col = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_mom( source ) mom_col = RubyX::RubyXCompiler.new(RubyX.default_test_options).ruby_to_mom( source )
compiler = mom_col.method_compilers.find{|c| c.get_method.name.to_s.start_with?("main") } compiler = mom_col.method_compilers.find{|c| c.get_method.name.to_s.start_with?("main") }
block = compiler.block_compilers.first block = compiler.block_compilers.first

View File

@ -7,7 +7,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( send_method ) @compiler = compile_main( send_method )
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module VoolBlocks
include VoolCompile include VoolCompile
def setup def setup
@ins = compile_first_block( "local = 5" ) @ins = compile_main_block( "local = 5" )
end end
def test_block_compiles def test_block_compiles
assert_equal Mom::SlotLoad , @ins.class , @ins assert_equal Mom::SlotLoad , @ins.class , @ins
@ -30,7 +30,7 @@ module VoolBlocks
class TestAssignMomInstanceToLocal < MiniTest::Test class TestAssignMomInstanceToLocal < MiniTest::Test
include VoolCompile include VoolCompile
def setup def setup
@ins = compile_first_block( "local = @a" , "@a = 5") #second arg in method scope @ins = compile_main_block( "local = @a" , "@a = 5") #second arg in method scope
end end
def test_class_compiles def test_class_compiles
assert_equal Mom::SlotLoad , @ins.class , @ins assert_equal Mom::SlotLoad , @ins.class , @ins
@ -47,7 +47,7 @@ module VoolBlocks
include VoolCompile include VoolCompile
def setup def setup
@ins = compile_first_block( "arg = 5") @ins = compile_main_block( "arg = 5")
end end
def test_class_compiles def test_class_compiles
@ -66,12 +66,12 @@ module VoolBlocks
def setup def setup
end end
def test_assigns_const def test_assigns_const
@ins = compile_first_block( "@a = 5") @ins = compile_main_block( "@a = 5")
assert_equal Mom::SlotLoad , @ins.class , @ins assert_equal Mom::SlotLoad , @ins.class , @ins
assert_equal Mom::IntegerConstant , @ins.right.known_object.class , @ins assert_equal Mom::IntegerConstant , @ins.right.known_object.class , @ins
end end
def test_assigns_move def test_assigns_move
@ins = compile_first_block( "@a = arg") @ins = compile_main_block( "@a = arg")
assert_equal Mom::SlotLoad , @ins.class , @ins assert_equal Mom::SlotLoad , @ins.class , @ins
assert_equal Mom::SlotDefinition , @ins.right.class , @ins assert_equal Mom::SlotDefinition , @ins.right.class , @ins
end end

View File

@ -5,7 +5,7 @@ module VoolBlocks
include VoolCompile include VoolCompile
def setup def setup
@ins = compile_first_block( "if(5.div4) ; @a = 6 ; else; @a = 5 ; end") @ins = compile_main_block( "if(5.div4) ; @a = 6 ; else; @a = 5 ; end")
end end
def test_condition def test_condition

View File

@ -5,7 +5,7 @@ module VoolBlocks
include VoolCompile include VoolCompile
def setup def setup
@ins = compile_first_block( "while(@a) ; @a = 5 ; end") @ins = compile_main_block( "while(@a) ; @a = 5 ; end")
end end
def test_compiles_as_while def test_compiles_as_while

View File

@ -7,7 +7,7 @@ module Vool
include Mom include Mom
def setup def setup
@compiler = compile_first_method( send_method ) @compiler = compile_main( send_method )
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "5.div8") @compiler = compile_main( "5.div8")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
def test_check_type def test_check_type

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "a = main(1 + 2);return a" ) @compiler = compile_main( "a = main(1 + 2);return a" )
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "a = 5; a.div4;return ") @compiler = compile_main( "a = 5; a.div4;return ")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
def test_check_type def test_check_type

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "local = 5;return") @compiler = compile_main( "local = 5;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
@ -33,7 +33,7 @@ module Vool
class TestAssignMomInstanceToLocal < MiniTest::Test class TestAssignMomInstanceToLocal < MiniTest::Test
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "@a = 5 ; local = @a;return") @compiler = compile_main( "@a = 5 ; local = @a;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
def test_class_compiles def test_class_compiles
@ -46,7 +46,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "arg = 5;return") @compiler = compile_main( "arg = 5;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
@ -70,13 +70,13 @@ module Vool
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
end end
def test_assigns_const def test_assigns_const
@compiler = compile_first_method( "@a = 5;return") @compiler = compile_main( "@a = 5;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
assert_equal Mom::SlotLoad , @ins.class , @ins assert_equal Mom::SlotLoad , @ins.class , @ins
assert_equal Mom::IntegerConstant , @ins.right.known_object.class , @ins assert_equal Mom::IntegerConstant , @ins.right.known_object.class , @ins
end end
def test_assigns_move def test_assigns_move
@compiler = compile_first_method( "@a = arg;return") @compiler = compile_main( "@a = arg;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
assert_equal Mom::SlotLoad , @ins.class , @ins assert_equal Mom::SlotLoad , @ins.class , @ins
assert_equal Mom::SlotDefinition , @ins.right.class , @ins assert_equal Mom::SlotDefinition , @ins.right.class , @ins

View File

@ -6,7 +6,7 @@ module Vool
include ScopeHelper include ScopeHelper
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
ruby_tree = Ruby::RubyCompiler.compile( as_test_main("@a = 5") ) ruby_tree = Ruby::RubyCompiler.compile( as_main("@a = 5") )
@vool = ruby_tree.to_vool @vool = ruby_tree.to_vool
end end
def test_class def test_class
@ -31,7 +31,7 @@ module Vool
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
end end
def assert_type_for(input) def assert_type_for(input)
ruby_tree = Ruby::RubyCompiler.compile( as_test_main(input) ) ruby_tree = Ruby::RubyCompiler.compile( as_main(input) )
vool = ruby_tree.to_vool vool = ruby_tree.to_vool
assert_equal ClassExpression , vool.class assert_equal ClassExpression , vool.class
clazz = vool.create_class_object clazz = vool.create_class_object
@ -67,7 +67,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "if(@a) ; @a = 5 ; else; @a = 6 ; end; return") @compiler = compile_main( "if(@a) ; @a = 5 ; else; @a = 6 ; end; return")
@ins = @compiler.mom_instructions @ins = @compiler.mom_instructions
end end

View File

@ -6,7 +6,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "if(@a) ; @a = 5 ; end;return") @compiler = compile_main( "if(@a) ; @a = 5 ; end;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -6,7 +6,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "unless(@a) ; @a = 5 ; end;return") @compiler = compile_main( "unless(@a) ; @a = 5 ; end;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -6,7 +6,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "if(@a) ; @a = 5 ; else; @a = 6 ; end;return") @compiler = compile_main( "if(@a) ; @a = 5 ; else; @a = 6 ; end;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "if(5.div4) ; @a = 6 ; else; @a = 5 ; end;return") @compiler = compile_main( "if(5.div4) ; @a = 6 ; else; @a = 5 ; end;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "@a = 5") @compiler = compile_main( "@a = 5")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "a = 5") @compiler = compile_main( "a = 5")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
@ -37,7 +37,7 @@ module Vool
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
@compiler = compile_first_method( "arg = 5") @compiler = compile_main( "arg = 5")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -15,7 +15,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "X.plus_equals(arg,1)") @compiler = compile_main( "X.plus_equals(arg,1)")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -6,7 +6,7 @@ module Vool
def setup def setup
Parfait.boot!(Parfait.default_test_options) Parfait.boot!(Parfait.default_test_options)
ruby_tree = Ruby::RubyCompiler.compile( as_test_main("a = 5") ) ruby_tree = Ruby::RubyCompiler.compile( as_main("a = 5") )
@clazz = ruby_tree.to_vool @clazz = ruby_tree.to_vool
end end
def method def method

View File

@ -1,11 +1,11 @@
require_relative "helper" require_relative "helper"
module Vool module Vool
class TestReturnMom < MiniTest::Test class TestReturnMom #< MiniTest::Test
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "return 5") @compiler = compile_main( "return 5")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
@ -41,7 +41,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "return 5.div4") @compiler = compile_main( "return 5.div4")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "while(@a) ; @a = 5 ; end;return") @compiler = compile_main( "while(@a) ; @a = 5 ; end;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -6,7 +6,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "while(5.div4) ; 5.div4 ; end;return") @compiler = compile_main( "while(5.div4) ; 5.div4 ; end;return")
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end

View File

@ -5,7 +5,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "return yield(1)" ) @compiler = compile_main( "return yield(1)" )
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
@ -69,7 +69,7 @@ module Vool
include VoolCompile include VoolCompile
def setup def setup
@compiler = compile_first_method( "return yield(some.extra.calls)" ) @compiler = compile_main( "return yield(some.extra.calls)" )
@ins = @compiler.mom_instructions.next @ins = @compiler.mom_instructions.next
end end
def test_check_label def test_check_label