2017-04-01 15:57:39 +03:00
|
|
|
module Vool
|
2017-04-08 12:11:52 +03:00
|
|
|
class ClassStatement < Statement
|
2017-04-01 15:57:39 +03:00
|
|
|
attr_reader :name, :super_class_name , :body
|
2017-04-08 12:11:52 +03:00
|
|
|
attr_reader :clazz
|
2017-04-01 15:57:39 +03:00
|
|
|
|
|
|
|
def initialize( name , supe , body)
|
2018-06-29 23:29:10 +03:00
|
|
|
@name , @super_class_name = name , supe
|
|
|
|
case body
|
|
|
|
when MethodStatement
|
|
|
|
@body = Statements.new([body])
|
|
|
|
when Statements
|
|
|
|
@body = body
|
|
|
|
when nil
|
|
|
|
@body = Statements.new([])
|
|
|
|
else
|
|
|
|
raise "what body #{body}"
|
|
|
|
end
|
2017-04-08 12:11:52 +03:00
|
|
|
end
|
|
|
|
|
2017-04-12 11:52:23 +03:00
|
|
|
def to_mom( _ )
|
2018-06-26 20:46:58 +03:00
|
|
|
create_class_object
|
2018-07-06 20:01:17 +03:00
|
|
|
method_compilers = body.statements.collect do |node|
|
2018-06-30 10:08:18 +03:00
|
|
|
raise "Only methods for now #{node}" unless node.is_a?(MethodStatement)
|
2018-07-06 20:01:17 +03:00
|
|
|
node.to_mom(@clazz)
|
2018-06-26 20:46:58 +03:00
|
|
|
end
|
2018-07-01 21:26:45 +03:00
|
|
|
Mom::MomCompiler.new(method_compilers)
|
2017-04-12 11:52:23 +03:00
|
|
|
end
|
|
|
|
|
2018-03-15 17:22:56 +05:30
|
|
|
def each(&block)
|
|
|
|
block.call(self)
|
2018-03-16 11:03:29 +05:30
|
|
|
@body.each(&block) if @body
|
2017-04-08 12:11:52 +03:00
|
|
|
end
|
|
|
|
|
2018-03-14 17:41:09 +05:30
|
|
|
def create_class_object
|
2017-04-08 12:11:52 +03:00
|
|
|
@clazz = Parfait.object_space.get_class_by_name(@name )
|
|
|
|
if(@clazz)
|
|
|
|
#FIXME super class check with "sup"
|
2017-04-08 19:20:11 +03:00
|
|
|
#existing class, don't overwrite type (parfait only?)
|
|
|
|
else
|
2017-04-08 12:11:52 +03:00
|
|
|
@clazz = Parfait.object_space.create_class(@name , @super_class_name )
|
2017-04-08 19:20:11 +03:00
|
|
|
ivar_hash = {}
|
2018-03-15 17:22:56 +05:30
|
|
|
self.each do |node|
|
|
|
|
next unless node.is_a?(InstanceVariable) or node.is_a?(IvarAssignment)
|
|
|
|
ivar_hash[node.name] = :Object
|
|
|
|
end
|
2017-04-08 19:20:11 +03:00
|
|
|
@clazz.set_instance_type( Parfait::Type.for_hash( @clazz , ivar_hash ) )
|
2017-04-08 12:11:52 +03:00
|
|
|
end
|
2017-04-01 15:57:39 +03:00
|
|
|
end
|
2018-07-03 22:18:19 +03:00
|
|
|
|
|
|
|
def to_s(depth = 0)
|
|
|
|
at_depth(depth , "class #{name}" , @body.to_s(depth + 1) , "end")
|
|
|
|
end
|
2017-04-01 15:57:39 +03:00
|
|
|
end
|
|
|
|
end
|