2019-10-03 21:07:55 +03:00
|
|
|
module SlotMachine
|
2019-08-06 18:33:27 +03:00
|
|
|
|
|
|
|
# A BlockCompiler is much like a MehtodCompiler, exept for blocks
|
|
|
|
#
|
|
|
|
class BlockCompiler < CallableCompiler
|
|
|
|
|
2019-10-03 21:07:55 +03:00
|
|
|
attr_reader :block , :slot_instructions
|
2019-08-06 18:33:27 +03:00
|
|
|
alias :block :callable
|
|
|
|
|
|
|
|
def initialize( block , method)
|
|
|
|
@method = method
|
|
|
|
super(block)
|
|
|
|
end
|
|
|
|
|
|
|
|
def source_name
|
|
|
|
"#{@method.self_type.name}.init"
|
|
|
|
end
|
|
|
|
|
2019-09-28 17:24:10 +03:00
|
|
|
def to_risc
|
2019-10-03 21:07:55 +03:00
|
|
|
risc_compiler = Risc::BlockCompiler.new(@callable , @method , slot_instructions)
|
2019-08-13 19:32:17 +03:00
|
|
|
instructions_to_risc(risc_compiler)
|
|
|
|
#recursive blocks not done
|
|
|
|
risc_compiler
|
|
|
|
end
|
|
|
|
|
2019-08-06 18:33:27 +03:00
|
|
|
# determine how given name need to be accsessed.
|
|
|
|
# For blocks the options are args or frame
|
|
|
|
# or then the methods arg or frame
|
|
|
|
def slot_type_for(name)
|
2019-08-22 22:56:44 +03:00
|
|
|
if index = @callable.arguments_type.variable_index(name)
|
2019-08-23 10:23:01 +03:00
|
|
|
slot_def = ["arg#{index}".to_sym]
|
|
|
|
elsif index = @callable.frame_type.variable_index(name)
|
|
|
|
slot_def = ["local#{index}".to_sym]
|
2019-08-22 22:56:44 +03:00
|
|
|
elsif index = @method.arguments_type.variable_index(name)
|
2019-08-23 10:23:01 +03:00
|
|
|
slot_def = [:caller , :caller , "arg#{index}".to_sym]
|
|
|
|
elsif index = @method.frame_type.variable_index(name)
|
|
|
|
slot_def = [:caller ,:caller , "local#{index}".to_sym ]
|
2019-08-06 18:33:27 +03:00
|
|
|
elsif
|
|
|
|
raise "no variable #{name} , need to resolve at runtime"
|
|
|
|
end
|
2019-08-23 10:23:01 +03:00
|
|
|
return slot_def
|
2019-08-06 18:33:27 +03:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|