2016-12-21 10:51:33 +02:00
|
|
|
require_relative "compiler/total_processor"
|
2016-12-20 20:02:52 +02:00
|
|
|
require_relative "compiler/type_collector"
|
|
|
|
require_relative "compiler/method_collector"
|
2016-12-21 11:20:36 +02:00
|
|
|
require_relative "compiler/locals_collector"
|
2016-12-20 20:02:52 +02:00
|
|
|
require_relative "compiler/ruby_method"
|
2016-12-18 17:02:55 +02:00
|
|
|
|
|
|
|
|
|
|
|
module Melon
|
|
|
|
class Compiler < AST::Processor
|
|
|
|
|
|
|
|
def self.compile input
|
|
|
|
ast = Parser::Ruby22.parse input
|
|
|
|
compiler = self.new
|
|
|
|
compiler.process ast
|
|
|
|
end
|
|
|
|
|
2016-12-18 17:17:58 +02:00
|
|
|
def get_name( statement )
|
|
|
|
return nil unless statement
|
|
|
|
statement.children[1]
|
|
|
|
end
|
|
|
|
|
2016-12-18 17:02:55 +02:00
|
|
|
def on_class statement
|
2016-12-18 20:05:11 +02:00
|
|
|
name , sup , body = *statement
|
2017-01-01 21:50:54 +02:00
|
|
|
class_name = get_name(name)
|
|
|
|
clazz = Parfait.object_space.create_class(class_name , get_name(sup) )
|
2016-12-19 14:20:47 +02:00
|
|
|
ivar_hash = TypeCollector.new.collect(body)
|
2016-12-20 20:02:52 +02:00
|
|
|
clazz.set_instance_type( Parfait::Type.for_hash( clazz , ivar_hash ) )
|
|
|
|
|
|
|
|
MethodCollector.new.collect(body)
|
|
|
|
|
2016-12-18 17:02:55 +02:00
|
|
|
end
|
2016-12-20 20:02:52 +02:00
|
|
|
|
|
|
|
def handler_missing(node)
|
|
|
|
node.children.each do |kid |
|
|
|
|
process(kid) if kid.is_a?(AST::Node)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-12-18 17:02:55 +02:00
|
|
|
end
|
|
|
|
end
|