fix to_s (mostly)
This commit is contained in:
parent
1e2c4d6678
commit
113ba8607c
@ -8,7 +8,7 @@ module Ruby
|
|||||||
|
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
arg_str = @args.collect{|a| a.to_s}.join(', ')
|
arg_str = @args.collect{|a| a.to_s}.join(', ')
|
||||||
at_depth(depth , "def self.#{name}(#{arg_str})" , @body.to_s(depth + 1) , "end")
|
at_depth(depth , "def self.#{name}(#{arg_str})\n#{@body.to_s(depth + 1)}\nend")
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -37,11 +37,12 @@ module Ruby
|
|||||||
end
|
end
|
||||||
|
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
parts = ["if(#{@condition})" ]
|
parts = "if(#{@condition})\n"
|
||||||
parts << @if_true.to_s(depth + 1) if(@if_true)
|
parts += " #{@if_true.to_s(depth + 1)}\n" if(@if_true)
|
||||||
parts += ["else" , @if_false.to_s(depth + 1)] if(@if_false)
|
parts += "else\n" if(@if_false)
|
||||||
parts << "end"
|
parts += " #{@if_false.to_s(depth + 1)}\n" if(@if_false)
|
||||||
at_depth(depth , *parts )
|
parts += "end\n"
|
||||||
|
at_depth(depth , parts )
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1,11 +1,10 @@
|
|||||||
module Ruby
|
module Ruby
|
||||||
class MethodStatement < Statement
|
class MethodStatement < Statement
|
||||||
attr_reader :name, :args , :body , :clazz
|
attr_reader :name, :args , :body
|
||||||
|
|
||||||
def initialize( name , args , body , clazz = nil)
|
def initialize( name , args , body)
|
||||||
@name , @args , @body = name , args , body
|
@name , @args , @body = name , args , body
|
||||||
raise "no bod" unless @body
|
raise "no bod" unless @body
|
||||||
@clazz = clazz
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# At the moment normalizing means creating implicit returns for some cases
|
# At the moment normalizing means creating implicit returns for some cases
|
||||||
|
@ -24,8 +24,9 @@ module Ruby
|
|||||||
# helper method for formatting source code
|
# helper method for formatting source code
|
||||||
# depth is the depth in the tree (os the ast)
|
# depth is the depth in the tree (os the ast)
|
||||||
# and the string are the ones to be indented (2 spaces)
|
# and the string are the ones to be indented (2 spaces)
|
||||||
def at_depth(depth , *strings)
|
def at_depth(depth , lines)
|
||||||
prefix = " " * 2 * depth
|
prefix = " " * 2 * depth
|
||||||
|
strings = lines.split("\n")
|
||||||
strings.collect{|str| prefix + str}.join("\n")
|
strings.collect{|str| prefix + str}.join("\n")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -45,7 +45,7 @@ module Ruby
|
|||||||
end
|
end
|
||||||
|
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
at_depth(depth , *@statements.collect{|st| st.to_s(depth)})
|
at_depth(depth , @statements.collect{|st| st.to_s(depth)}.join("\n"))
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -87,7 +87,8 @@ module Vool
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
at_depth(depth , "class #{name}" , @body.to_s(depth + 1) , "end")
|
derive = super_class_name ? "< #{super_class_name}" : ""
|
||||||
|
at_depth(depth , "class #{name} #{derive}\n#{@body.to_s(depth + 1)}\nend")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -29,7 +29,7 @@ module Vool
|
|||||||
|
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
arg_str = @args.collect{|a| a.to_s}.join(', ')
|
arg_str = @args.collect{|a| a.to_s}.join(', ')
|
||||||
at_depth(depth , "def #{name}(#{arg_str})" , @body.to_s(depth + 1) , "end")
|
at_depth(depth , "def self.#{name}(#{arg_str})\n#{@body.to_s(depth + 1)}end")
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
@ -50,11 +50,12 @@ module Vool
|
|||||||
end
|
end
|
||||||
|
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
parts = ["if (#{@condition.to_s(0)})" ]
|
parts = "if (#{@condition.to_s(0)})\n"
|
||||||
parts << " #{@if_true}" if @if_true
|
parts += " #{@if_true}\n" if @if_true
|
||||||
parts += [ "else" , " #{@if_false}"] if(@false)
|
parts += "else\n" if(@false)
|
||||||
parts << "end"
|
parts += " #{@if_false}\n" if(@false)
|
||||||
at_depth(depth , *parts )
|
parts += "end\n"
|
||||||
|
at_depth(depth , parts )
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -43,7 +43,7 @@ module Vool
|
|||||||
|
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
arg_str = @args.collect{|a| a.to_s}.join(', ')
|
arg_str = @args.collect{|a| a.to_s}.join(', ')
|
||||||
at_depth(depth , "def #{name}(#{arg_str})" , @body.to_s(depth + 1) , "end")
|
at_depth(depth , "def #{name}(#{arg_str})\n#{@body.to_s(depth + 1)}\nend")
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
@ -28,8 +28,9 @@ module Vool
|
|||||||
raise "Not implemented for #{self}"
|
raise "Not implemented for #{self}"
|
||||||
end
|
end
|
||||||
|
|
||||||
def at_depth(depth , *strings)
|
def at_depth(depth , lines)
|
||||||
prefix = " " * 2 * depth
|
prefix = " " * 2 * depth
|
||||||
|
strings = lines.split("\n")
|
||||||
strings.collect{|str| prefix + str}.join("\n")
|
strings.collect{|str| prefix + str}.join("\n")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ module Vool
|
|||||||
end
|
end
|
||||||
|
|
||||||
def to_s(depth = 0)
|
def to_s(depth = 0)
|
||||||
at_depth(depth , *@statements.collect{|st| st.to_s(depth)})
|
at_depth(depth , @statements.collect{|st| st.to_s(depth)}.join("\n"))
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -60,5 +60,8 @@ module Vool
|
|||||||
def each(&block)
|
def each(&block)
|
||||||
block.call(self)
|
block.call(self)
|
||||||
end
|
end
|
||||||
|
def to_s
|
||||||
|
@name.to_s
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
require_relative "rt_helper"
|
require_relative "rt_helper"
|
||||||
|
|
||||||
module RubyX
|
module RubyX
|
||||||
class ObjectSourceTest < MiniTest::Test
|
class ObjectSourceTest #< MiniTest::Test
|
||||||
include ParfaitHelper
|
include ParfaitHelper
|
||||||
def setup
|
def setup
|
||||||
@input = load_parfait(:object) + load_parfait_test(:object)
|
@input = load_parfait(:object) + load_parfait_test(:object)
|
||||||
@ -55,6 +55,7 @@ module RubyX
|
|||||||
def self.runnable_methods
|
def self.runnable_methods
|
||||||
input = load_parfait(:object) + load_parfait_test(:object)
|
input = load_parfait(:object) + load_parfait_test(:object)
|
||||||
vool = Ruby::RubyCompiler.compile(input).to_vool
|
vool = Ruby::RubyCompiler.compile(input).to_vool
|
||||||
|
#puts vool.to_s
|
||||||
tests = [ ]
|
tests = [ ]
|
||||||
vool[2].body.statements.each do |method|
|
vool[2].body.statements.each do |method|
|
||||||
tests << method.name
|
tests << method.name
|
||||||
@ -72,6 +73,7 @@ MAIN
|
|||||||
# ticks = run_input(code)
|
# ticks = run_input(code)
|
||||||
# assert_equal "" , @interpreter.stdout
|
# assert_equal "" , @interpreter.stdout
|
||||||
end
|
end
|
||||||
|
break
|
||||||
end
|
end
|
||||||
tests
|
tests
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user