2016-12-20 19:02:52 +01:00
|
|
|
module Melon
|
|
|
|
|
2016-12-21 09:51:33 +01:00
|
|
|
class MethodCollector < TotalProcessor
|
2016-12-20 19:02:52 +01:00
|
|
|
|
|
|
|
def initialize
|
|
|
|
@methods = []
|
|
|
|
end
|
|
|
|
|
|
|
|
def collect(statement)
|
|
|
|
process statement
|
|
|
|
@methods
|
|
|
|
end
|
|
|
|
|
|
|
|
def on_def(statement)
|
|
|
|
name , args , body = *statement
|
|
|
|
args_type = make_type(args)
|
2016-12-21 10:30:35 +01:00
|
|
|
locals_type = make_locals(body)
|
|
|
|
@methods << RubyMethod.new(name , args_type , locals_type , body )
|
2016-12-20 19:02:52 +01:00
|
|
|
end
|
|
|
|
|
2016-12-21 10:30:35 +01:00
|
|
|
private
|
|
|
|
|
2016-12-20 19:02:52 +01:00
|
|
|
def make_type( statement )
|
|
|
|
type = Parfait::Space.object_space.get_class_by_name(:Message ).instance_type
|
|
|
|
statement.children.each do |arg|
|
|
|
|
type = type.add_instance_variable( arg.children[0] , :Object )
|
|
|
|
end
|
|
|
|
type
|
|
|
|
end
|
|
|
|
|
2016-12-21 10:30:35 +01:00
|
|
|
def make_locals(body)
|
|
|
|
locals = LocalsCollector.new.collect(body)
|
|
|
|
type = Parfait::Space.object_space.get_class_by_name(:Frame ).instance_type
|
|
|
|
locals.each do |name , local_type |
|
|
|
|
type = type.add_instance_variable( name , local_type )
|
|
|
|
end
|
|
|
|
type
|
|
|
|
end
|
2016-12-20 19:02:52 +01:00
|
|
|
end
|
|
|
|
end
|