start with block_compiler
as a copy of method_compiler re-merge later, when we know what's needed
This commit is contained in:
@ -14,12 +14,19 @@ module Vool
|
||||
# This means we do the compiler here (rather than to_mom, which is in
|
||||
# fact never called)
|
||||
def slot_definition(compiler)
|
||||
@parfait_block = to_parfait(compiler)
|
||||
return Mom::SlotDefinition.new(Mom::IntegerConstant.new(1) , [])
|
||||
return Mom::SlotDefinition.new(Mom::BlockConstant.new(parfait_block(compiler)) , [])
|
||||
end
|
||||
|
||||
# create a block, a compiler for it, comile the bock and add the compiler(code)
|
||||
# to the method compiler for further processing
|
||||
def to_mom( compiler )
|
||||
# raise "should not be called "
|
||||
parfait_block = self.parfait_block(compiler)
|
||||
block_compiler = Risc::BlockCompiler.new( parfait_block , compiler.method )
|
||||
compiler.add_block_compiler(block_compiler)
|
||||
puts "BODY #{body}"
|
||||
head = body.to_mom( block_compiler )
|
||||
block_compiler.add_mom(head)
|
||||
block_compiler
|
||||
end
|
||||
|
||||
def each(&block)
|
||||
@ -31,10 +38,14 @@ module Vool
|
||||
BlockStatement.new( @args , @body.normalize)
|
||||
end
|
||||
|
||||
private
|
||||
def to_parfait(compiler)
|
||||
compiler.method.create_block( make_arg_type , make_frame)
|
||||
# create the parfait block (parfait representation of the block, a Callable similar
|
||||
# to CallableMethod)
|
||||
def parfait_block(compiler)
|
||||
return @parfait_block if @parfait_block
|
||||
@parfait_block = compiler.method.create_block( make_arg_type , make_frame)
|
||||
end
|
||||
|
||||
private
|
||||
def make_arg_type( )
|
||||
type_hash = {}
|
||||
@args.each {|arg| type_hash[arg] = :Object }
|
||||
|
@ -11,7 +11,11 @@ module Vool
|
||||
def to_mom(clazz)
|
||||
@clazz = clazz || raise( "no class in #{self}")
|
||||
method = @clazz.add_method_for(name , make_arg_type , make_frame , body )
|
||||
method.compiler_for(clazz.instance_type)
|
||||
compiler = method.compiler_for(clazz.instance_type)
|
||||
each do |node| ## TODO: must account for nested blocks (someday)
|
||||
node.to_mom(compiler) if node.is_a?(BlockStatement)
|
||||
end
|
||||
compiler
|
||||
end
|
||||
|
||||
def each(&block)
|
||||
|
Reference in New Issue
Block a user