fxes for add test

This commit is contained in:
Torsten Ruger 2015-08-04 21:46:33 +03:00
parent 4a51bdd643
commit 9680ff2a71
9 changed files with 42 additions and 13 deletions

View File

@ -4,8 +4,8 @@ gem "salama" , :path => "."
gem "rake" gem "rake"
gem "salama-reader" , :github => "salama/salama-reader" #gem "salama-reader" , :github => "salama/salama-reader"
#gem "salama-reader" , :path => "../salama-reader" gem "salama-reader" , :path => "../salama-reader"
gem "salama-object-file" , :github => "salama/salama-object-file" gem "salama-object-file" , :github => "salama/salama-object-file"
#gem "salama-object-file" , :path => "../salama-object-file" #gem "salama-object-file" , :path => "../salama-object-file"
gem "salama-arm" , :github => "salama/salama-arm" gem "salama-arm" , :github => "salama/salama-arm"

View File

@ -10,13 +10,6 @@ GIT
specs: specs:
salama-object-file (0.2.0) salama-object-file (0.2.0)
GIT
remote: git://github.com/salama/salama-reader.git
revision: 841592c667acea1e796f950851262e6938b231bc
specs:
salama-reader (0.2.0)
parslet (~> 1.7.0)
PATH PATH
remote: . remote: .
specs: specs:
@ -24,6 +17,12 @@ PATH
salama-object-file (~> 0.2) salama-object-file (~> 0.2)
salama-reader (~> 0.2) salama-reader (~> 0.2)
PATH
remote: ../salama-reader
specs:
salama-reader (0.2.0)
parslet (~> 1.7.0)
GEM GEM
remote: http://rubygems.org/ remote: http://rubygems.org/
specs: specs:

View File

@ -3,6 +3,14 @@ module Register
module Builtin module Builtin
module Integer module Integer
module ClassMethods module ClassMethods
def plus c
plus_function = Virtual::MethodSource.create_method(:Integer,:plus , [Virtual::Integer] )
plus_function.source.return_type = Virtual::Integer
plus_function.source.receiver = Virtual::Integer
plus_function.source.add_code Register::Math.new( plus_function, :add , 0 )
return plus_function
end
# The conversion to base10 is quite a bit more complicated than i thought. # The conversion to base10 is quite a bit more complicated than i thought.
# The bulk of it is in div10 # The bulk of it is in div10
# We set up variables, do the devision and write the result to the string # We set up variables, do the devision and write the result to the string

View File

@ -12,7 +12,7 @@ module Virtual
if( r.value.is_a? Parfait::Class ) if( r.value.is_a? Parfait::Class )
class_name = r.value.name class_name = r.value.name
else else
raise "unimplemented #{r}" raise "unimplemented case in function #{r}"
end end
else else
r = Self.new() r = Self.new()

View File

@ -7,6 +7,10 @@ module Virtual
@args = args @args = args
end end
attr_reader :name , :me , :args attr_reader :name , :me , :args
def to_s
"MessageSend.new(:#{name} , #{me} , #{args})"
end
end end
end end

View File

@ -134,6 +134,7 @@ module Virtual
def compile_main bytes def compile_main bytes
syntax = @parser.parse_with_debug(bytes) syntax = @parser.parse_with_debug(bytes)
parts = Parser::Transform.new.apply(syntax) parts = Parser::Transform.new.apply(syntax)
#puts parts.to_s
Compiler.compile( parts , @space.get_main ) Compiler.compile( parts , @space.get_main )
end end

View File

@ -19,7 +19,7 @@ module Virtual
if(ref.value) if(ref.value)
me = ref.value me = ref.value
if( me.is_a? Parfait::Class ) if( me.is_a? Parfait::Class )
raise "unimplemented #{code}" raise "unimplemented #{code} me is #{me}"
elsif( me.is_a? Parfait::Object ) elsif( me.is_a? Parfait::Object )
# get the function from my class. easy peasy # get the function from my class. easy peasy
puts "Me is #{me.class}" puts "Me is #{me.class}"
@ -31,6 +31,11 @@ module Virtual
method = Virtual.machine.space.get_class_by_name(:Word).get_instance_method(code.name) method = Virtual.machine.space.get_class_by_name(:Word).get_instance_method(code.name)
raise "Method not implemented #{me.class}.#{code.name}" unless method raise "Method not implemented #{me.class}.#{code.name}" unless method
new_codes << MethodCall.new( method ) new_codes << MethodCall.new( method )
elsif( me.is_a? Fixnum )
# get the function from my class. easy peasy
method = Virtual.machine.space.get_class_by_name(:Integer).get_instance_method(code.name)
raise "Method not implemented #{me.class}.#{code.name}" unless method
new_codes << MethodCall.new( method )
else else
# note: this is the current view: call internal send, even the method name says else # note: this is the current view: call internal send, even the method name says else
# but send is "special" and accesses the internal method name and resolves. # but send is "special" and accesses the internal method name and resolves.

View File

@ -27,6 +27,9 @@ module Virtual
attr_accessor :type , :value attr_accessor :type , :value
def to_s
"#{self.class.name}.new(#{type}, #{value})"
end
private #abstract base class private #abstract base class
def initialize type , value def initialize type , value

View File

@ -81,13 +81,22 @@ HERE
check check
end end
def ttest_function_ops_simple def test_function_ops_simple
@string_input = <<HERE @string_input = <<HERE
def foo() def foo()
2 + 5 2 + 5
end end
HERE HERE
@output = nil @output = [[Virtual::MethodEnter],[Virtual::MethodReturn]]
check
end
def test_ops_simple
@string_input = <<HERE
2 + 5
HERE
@output = [[Virtual::MethodEnter , Virtual::Set,Virtual::NewMessage,Virtual::Set,
Virtual::Set ,Virtual::Set,Virtual::Set,Virtual::MessageSend] , [Virtual::MethodReturn]]
check check
end end