2019-08-06 17:33:27 +02:00
|
|
|
module Mom
|
|
|
|
# The Compiler/Collection for the Mom level is a collection of Mom level Method
|
|
|
|
# compilers These will transform to Risc MethodCompilers on the way down.
|
|
|
|
#
|
|
|
|
# As RubyCompiler pools source at the vool level, when several classes are compiled
|
|
|
|
# from vool to mom, several MomCompilers get instantiated. They must be merged before
|
|
|
|
# proceeding with translate. Thus we have a append method.
|
|
|
|
#
|
|
|
|
class MomCollection
|
|
|
|
attr_reader :method_compilers
|
|
|
|
|
|
|
|
# Initialize with an array of risc MethodCompilers
|
|
|
|
def initialize(compilers = [])
|
|
|
|
@method_compilers = compilers
|
|
|
|
end
|
|
|
|
|
2019-09-15 14:13:11 +02:00
|
|
|
# lazily instantiate the compiler for __init__ function and __method_missing__
|
2019-09-12 12:09:30 +02:00
|
|
|
def init_compiler
|
2019-09-15 14:13:11 +02:00
|
|
|
@init_compilers ||= [
|
|
|
|
MomCollection.create_init_compiler ,
|
|
|
|
MomCollection.create_mm_compiler ,
|
|
|
|
]
|
2019-08-06 17:33:27 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
# Return all compilers, namely the MethodCompilers passed in, plus the
|
|
|
|
# boot_function's compilers (boot_compilers)
|
|
|
|
def compilers
|
2019-09-15 14:13:11 +02:00
|
|
|
@method_compilers + init_compiler
|
2019-08-06 17:33:27 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
# Append another MomCompilers method_compilers to this one.
|
|
|
|
def append(mom_compiler)
|
|
|
|
@method_compilers += mom_compiler.method_compilers
|
|
|
|
self
|
|
|
|
end
|
|
|
|
|
2019-08-12 15:12:17 +02:00
|
|
|
def to_risc( )
|
|
|
|
riscs = compilers.collect do | mom_c |
|
2019-08-10 20:30:00 +02:00
|
|
|
mom_c.to_risc
|
|
|
|
end
|
2019-08-08 11:19:27 +02:00
|
|
|
# to_risc all compilers
|
|
|
|
# for each suffling constnts and fist label, then all instructions (see below)
|
|
|
|
# then create risc collection
|
|
|
|
Risc::RiscCollection.new(riscs)
|
|
|
|
end
|
|
|
|
|
2019-09-15 14:13:11 +02:00
|
|
|
# See Init instruction. We must have an init (ie we need it in code), so it is created in code
|
|
|
|
def self.create_init_compiler
|
|
|
|
compiler = compiler_for(:Object,:__init__ ,{})
|
|
|
|
compiler._reset_for_init # no return, just for init
|
|
|
|
compiler.add_code Init.new("missing")
|
|
|
|
return compiler
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.create_mm_compiler
|
|
|
|
compiler = compiler_for(:Object,:__method_missing__ ,{})
|
2019-09-17 19:18:00 +02:00
|
|
|
compiler.add_code MethodMissing.new("missing" , :r1)
|
2019-09-15 14:13:11 +02:00
|
|
|
return compiler
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.compiler_for( clazz_name , method_name , arguments , locals = {})
|
2019-09-18 21:07:58 +02:00
|
|
|
frame = Parfait::Type.for_hash( locals )
|
|
|
|
args = Parfait::Type.for_hash( arguments )
|
2019-09-15 14:13:11 +02:00
|
|
|
MethodCompiler.compiler_for_class(clazz_name , method_name , args, frame )
|
|
|
|
end
|
2019-09-12 12:09:30 +02:00
|
|
|
|
2019-08-06 17:33:27 +02:00
|
|
|
end
|
|
|
|
end
|