rubyx/lib/melon/ruby_compiler.rb

60 lines
1.7 KiB
Ruby
Raw Normal View History

require "parser/ruby22"
require_relative "compilers/total_processor"
require_relative "compilers/type_collector"
require_relative "compilers/method_collector"
require_relative "compilers/method_compiler"
require_relative "compilers/locals_collector"
require_relative "compilers/normalizer"
require_relative "ruby_method"
module Melon
class RubyCompiler < Compilers::TotalProcessor
2017-01-12 19:38:04 +01:00
def self.compile( input )
ast = Parser::Ruby22.parse( input )
self.new.process( ast )
2016-12-18 16:17:58 +01:00
end
def on_class statement
name , sup , body = *statement
2017-01-01 20:50:54 +01:00
class_name = get_name(name)
2017-01-12 19:38:04 +01:00
clazz = Parfait.object_space.get_class_by_name!(class_name , get_name(sup) )
ivar_hash = Compilers::TypeCollector.new.collect(body)
clazz.set_instance_type( Parfait::Type.for_hash( clazz , ivar_hash ) )
methods = create_methods(clazz , body)
compile_methods(clazz,methods)
2017-01-12 19:38:04 +01:00
end
2017-01-12 19:38:04 +01:00
def create_methods(clazz , body)
methods = Compilers::MethodCollector.new.collect(body)
2017-01-12 19:38:04 +01:00
methods.each do |method|
clazz.add_method( method )
normalizer = Compilers::Normalizer.new(method)
method.normalize_source { |sourc| normalizer.process( sourc ) }
end
methods
end
def compile_methods(clazz , methods)
methods.each do |method|
typed_method = method.create_vm_method(clazz.instance_type)
raise "NIL" unless method
code = Compilers::MethodCompiler.new(method).get_code
Vm::MethodCompiler.new( typed_method ).init_method.process( code)
2017-01-12 19:38:04 +01:00
end
end
2017-01-12 19:38:04 +01:00
private
2017-01-14 18:52:16 +01:00
2017-01-12 19:38:04 +01:00
def get_name( statement )
return nil unless statement
name = statement.children[1]
raise "Not symbol #{name}" unless name.is_a? Symbol
name
2017-01-12 19:38:04 +01:00
end
end
end