remove to_mom / create_objects dichotomy

wsa supposed to be clearer, but even to me seems confusing now.
This commit is contained in:
Torsten Ruger 2018-06-26 20:46:58 +03:00
parent c6a903073a
commit f0ba863721
6 changed files with 20 additions and 31 deletions

View File

@ -22,7 +22,7 @@ module Parfait
raise "source must be vool" unless source.is_a?(Vool::Statement) raise "source must be vool" unless source.is_a?(Vool::Statement)
end end
def create_parfait_method( type ) def create_typed_method( type )
raise "create_method #{type.inspect} is not a Type" unless type.is_a? Parfait::Type raise "create_method #{type.inspect} is not a Type" unless type.is_a? Parfait::Type
type.create_method( @name , @args_type , @frame_type) type.create_method( @name , @args_type , @frame_type)
end end

View File

@ -11,9 +11,13 @@ module Vool
ClassStatement.new(@name , @super_class_name, @body&.normalize ) ClassStatement.new(@name , @super_class_name, @body&.normalize )
end end
# there is no mom equivalent for a class, this should never be called
def to_mom( _ ) def to_mom( _ )
raise "should not be called (call create_objects)" create_class_object
mom = nil #return mom for test purpose
self.each do |node|
mom = node.to_mom(@clazz) if node.is_a?(MethodStatement)
end
mom
end end
def each(&block) def each(&block)
@ -21,13 +25,6 @@ module Vool
@body.each(&block) if @body @body.each(&block) if @body
end end
def create_objects
create_class_object
mom = nil #return mom for test purpose
self.each {|node| mom = node.create_objects(@clazz) if node.is_a?(MethodStatement) }
mom
end
def create_class_object def create_class_object
@clazz = Parfait.object_space.get_class_by_name(@name ) @clazz = Parfait.object_space.get_class_by_name(@name )
if(@clazz) if(@clazz)

View File

@ -8,10 +8,16 @@ module Vool
@clazz = clazz @clazz = clazz
end end
# there is no mom equivalent for a method definition, only a vool/parfait one def to_mom(clazz)
# Only the source of gets momed, this should never be called @clazz = clazz
def to_mom( _ ) raise "no class" unless clazz
raise "should not be called (call create_objects)" method = Parfait::VoolMethod.new(name , make_type , make_frame , body )
@clazz.add_method( method )
typed_method = method.create_typed_method(clazz.instance_type)
head = @body.to_mom( typed_method )
compiler = Risc::MethodCompiler.new( typed_method )
compiler.add_mom(head)
head # return for testing
end end
def each(&block) def each(&block)
@ -23,20 +29,6 @@ module Vool
MethodStatement.new( @name , @args , @body.normalize) MethodStatement.new( @name , @args , @body.normalize)
end end
def create_objects(clazz)
@clazz = clazz
raise "no class" unless clazz
args_type = make_type
frame_type = make_frame
method = Parfait::VoolMethod.new(name , args_type , frame_type , body )
@clazz.add_method( method )
typed_method = method.create_parfait_method(clazz.instance_type)
head = @body.to_mom( typed_method )
compiler = Risc::MethodCompiler.new( typed_method )
compiler.add_mom(head)
head # return for testing
end
private private
def make_type( ) def make_type( )

View File

@ -6,7 +6,7 @@ module Vool
def self.ruby_to_vool( ruby_source ) def self.ruby_to_vool( ruby_source )
statements = RubyCompiler.compile( ruby_source ) statements = RubyCompiler.compile( ruby_source )
statements = statements.normalize statements = statements.normalize
statements.create_objects statements.to_mom(nil)
statements statements
end end
def self.ruby_to_mom(source) def self.ruby_to_mom(source)

View File

@ -4,7 +4,7 @@ module Risc
class TestPadding < MiniTest::Test class TestPadding < MiniTest::Test
def setup def setup
Risc.machine.boot unless Risc.machine.booted Risc.machine.boot
end end
def test_small def test_small

View File

@ -26,7 +26,7 @@ module MomCompile
# but here we return the intermediate mom instructions that are otherwise not available # but here we return the intermediate mom instructions that are otherwise not available
statements = Vool::RubyCompiler.compile as_test_main( input ) statements = Vool::RubyCompiler.compile as_test_main( input )
statements = statements.normalize statements = statements.normalize
res = statements.create_objects res = statements.to_mom(nil)
assert_equal Parfait::Class , statements.clazz.class , statements assert_equal Parfait::Class , statements.clazz.class , statements
@method = statements.clazz.get_method(:main) @method = statements.clazz.get_method(:main)
assert_equal Parfait::VoolMethod , @method.class assert_equal Parfait::VoolMethod , @method.class