2014-06-25 15:20:46 +03:00
|
|
|
require_relative '../helper'
|
|
|
|
require 'parslet/convenience'
|
2014-08-21 22:57:20 +03:00
|
|
|
require "yaml"
|
2014-06-25 15:20:46 +03:00
|
|
|
|
2014-06-26 11:34:48 +03:00
|
|
|
module VirtualHelper
|
2015-05-05 14:04:37 +03:00
|
|
|
# need a code generator, for arm
|
2014-06-25 15:20:46 +03:00
|
|
|
def setup
|
2015-05-12 15:36:44 +03:00
|
|
|
# @object_space = Boot::Space.new "Arm"
|
2014-06-25 15:20:46 +03:00
|
|
|
end
|
|
|
|
|
2014-07-30 21:07:48 +03:00
|
|
|
def check
|
2015-06-01 08:33:23 +03:00
|
|
|
machine = Virtual::Machine.boot
|
2014-07-30 21:43:12 +03:00
|
|
|
expressions = machine.compile_main @string_input
|
2015-05-24 16:55:03 +03:00
|
|
|
if( expressions.first.is_a? Parfait::Method )
|
|
|
|
# stops the whole objectspace beeing tested
|
|
|
|
# with the class comes superclass and all methods
|
|
|
|
expressions.first.instance_variable_set :@for_class , nil
|
|
|
|
end
|
|
|
|
if( expressions.first.is_a? Virtual::Self )
|
|
|
|
# stops the whole objectspace beeing tested
|
|
|
|
# with the class comes superclass and all methods
|
|
|
|
expressions.first.type.instance_variable_set :@of_class , nil
|
|
|
|
end
|
2015-05-05 15:11:09 +03:00
|
|
|
is = Sof::Writer.write(expressions)
|
2015-05-06 08:38:29 +03:00
|
|
|
#puts is
|
2015-05-05 15:11:09 +03:00
|
|
|
is.gsub!("\n" , "*^*")
|
2015-05-05 14:04:37 +03:00
|
|
|
assert_equal is , @output
|
2014-06-25 15:20:46 +03:00
|
|
|
end
|
2015-05-05 14:04:37 +03:00
|
|
|
|
2014-06-25 15:20:46 +03:00
|
|
|
end
|
2015-06-01 17:31:35 +03:00
|
|
|
|
2015-05-24 18:05:20 +03:00
|
|
|
class UnusedSofEquality
|
|
|
|
# simple thought: don't recurse for Blocks, just check their names
|
|
|
|
def == other
|
|
|
|
return false unless other.class == self.class
|
|
|
|
Sof::Util.attributes(self).each do |a|
|
|
|
|
begin
|
|
|
|
left = send(a)
|
|
|
|
rescue NoMethodError
|
|
|
|
next # not using instance variables that are not defined as attr_readers for equality
|
|
|
|
end
|
|
|
|
begin
|
|
|
|
right = other.send(a)
|
|
|
|
rescue NoMethodError
|
|
|
|
return false
|
|
|
|
end
|
|
|
|
return false unless left.class == right.class
|
|
|
|
if( left.is_a? Block)
|
|
|
|
return false unless left.name == right.name
|
|
|
|
else
|
|
|
|
return false unless left == right
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return true
|
|
|
|
end
|
|
|
|
end
|