add to_s for statements
This commit is contained in:
parent
e099014d63
commit
2ad24ab0bb
@ -40,6 +40,11 @@ module Vool
|
|||||||
block.call(self)
|
block.call(self)
|
||||||
@value.each(&block)
|
@value.each(&block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
at_depth(depth , "#{@name} = #{@value}")
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
class IvarAssignment < Assignment
|
class IvarAssignment < Assignment
|
||||||
|
@ -52,5 +52,9 @@ module Vool
|
|||||||
@clazz.set_instance_type( Parfait::Type.for_hash( @clazz , ivar_hash ) )
|
@clazz.set_instance_type( Parfait::Type.for_hash( @clazz , ivar_hash ) )
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
at_depth(depth , "class #{name}" , @body.to_s(depth + 1) , "end")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -62,5 +62,11 @@ module Vool
|
|||||||
@if_true != nil
|
@if_true != nil
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
parts = ["if (#{@condition})" , @body.to_s(depth + 1) ]
|
||||||
|
parts += ["else" , "@if_false.to_s(depth + 1)"] if(@false)
|
||||||
|
parts << "end"
|
||||||
|
at_depth(depth , *parts )
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -8,5 +8,9 @@ module Vool
|
|||||||
@name , @left , @right = name , left , right
|
@name , @left , @right = name , left , right
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
at_depth(depth , "#{left} #{name} #{right}")
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -35,6 +35,11 @@ module Vool
|
|||||||
Parfait::NamedList.type_for( type_hash )
|
Parfait::NamedList.type_for( type_hash )
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
arg_str = @args.collect{|a| a.to_s}.join(', ')
|
||||||
|
at_depth(depth , "def #{name}(#{arg_str})" , @body.to_s(depth + 1) , "end")
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def make_frame
|
def make_frame
|
||||||
|
@ -29,5 +29,8 @@ module Vool
|
|||||||
ret << Mom::ReturnSequence.new
|
ret << Mom::ReturnSequence.new
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
at_depth(depth , "return #{@return_value.to_s}")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -129,6 +129,11 @@ module Vool
|
|||||||
message_setup(in_method,dynamic_call.cache_entry) << dynamic_call
|
message_setup(in_method,dynamic_call.cache_entry) << dynamic_call
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
sen = "#{receiver}.#{name}(#{@arguments.collect{|a| a.to_s}.join(', ')})"
|
||||||
|
at_depth(depth , sen)
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def receiver_type_definition(in_method)
|
def receiver_type_definition(in_method)
|
||||||
defi = @receiver.slot_definition(in_method)
|
defi = @receiver.slot_definition(in_method)
|
||||||
|
@ -36,6 +36,11 @@ module Vool
|
|||||||
raise "Not implemented for #{self}"
|
raise "Not implemented for #{self}"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def at_depth(depth , *strings)
|
||||||
|
prefix = " " * 2 * depth
|
||||||
|
strings.collect{|str| prefix + str}.join("\n")
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
class Expression
|
class Expression
|
||||||
|
@ -55,6 +55,10 @@ module Vool
|
|||||||
Statements.new(@statements.collect{|s| s.normalize})
|
Statements.new(@statements.collect{|s| s.normalize})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
def to_s(depth = 0)
|
||||||
|
at_depth(depth , *@statements.collect{|st| st.to_s(depth)})
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
class ScopeStatement < Statements
|
class ScopeStatement < Statements
|
||||||
|
@ -18,6 +18,9 @@ module Vool
|
|||||||
end
|
end
|
||||||
Mom::SlotDefinition.new(:message , [type , @name])
|
Mom::SlotDefinition.new(:message , [type , @name])
|
||||||
end
|
end
|
||||||
|
def to_s
|
||||||
|
name.to_s
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class InstanceVariable < Expression
|
class InstanceVariable < Expression
|
||||||
@ -29,6 +32,9 @@ module Vool
|
|||||||
def add_ivar( array )
|
def add_ivar( array )
|
||||||
array << @name
|
array << @name
|
||||||
end
|
end
|
||||||
|
def to_s
|
||||||
|
"@#{name}"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class ClassVariable < Expression
|
class ClassVariable < Expression
|
||||||
|
@ -34,5 +34,9 @@ module Vool
|
|||||||
@body.each(&block)
|
@body.each(&block)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def to_s(depth = 0)
|
||||||
|
at_depth(depth , "while (#{@condition})" , @body.to_s(depth + 1) , "end" )
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user