2015-10-14 21:49:05 +03:00
|
|
|
require_relative '../../helper'
|
2014-06-25 15:20:46 +03:00
|
|
|
require 'parslet/convenience'
|
|
|
|
|
2015-10-23 14:22:55 +03:00
|
|
|
Soml::Compiler.class_eval do
|
2015-10-14 15:17:33 +03:00
|
|
|
def set_main main
|
2015-10-22 18:16:29 +03:00
|
|
|
@clazz = Register.machine.space.get_class_by_name :Object
|
2015-10-14 15:17:33 +03:00
|
|
|
@method = main
|
2015-10-28 21:40:48 +02:00
|
|
|
@current = main.instructions.next
|
2015-10-14 15:17:33 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-10-10 10:02:28 +03:00
|
|
|
module CompilerHelper
|
2015-07-02 10:44:44 +03:00
|
|
|
|
2015-10-14 13:48:42 +03:00
|
|
|
def set_main compiler
|
2015-10-22 18:16:29 +03:00
|
|
|
compiler.set_main Register.machine.space.get_main
|
2015-10-14 13:48:42 +03:00
|
|
|
end
|
2015-10-10 10:02:28 +03:00
|
|
|
def check
|
2015-10-22 18:16:29 +03:00
|
|
|
machine = Register.machine
|
2015-10-13 16:42:53 +03:00
|
|
|
machine.boot unless machine.booted
|
2015-10-10 10:02:28 +03:00
|
|
|
parser = Parser::Salama.new
|
|
|
|
parser = parser.send @root
|
|
|
|
syntax = parser.parse_with_debug(@string_input)
|
|
|
|
parts = Parser::Transform.new.apply(syntax)
|
|
|
|
#puts parts.inspect
|
2015-10-23 14:22:55 +03:00
|
|
|
compiler = Soml::Compiler.new
|
2015-10-14 13:48:42 +03:00
|
|
|
set_main(compiler)
|
2015-10-10 10:02:28 +03:00
|
|
|
produced = compiler.process( parts )
|
|
|
|
assert @output , "No output given"
|
2015-10-13 16:42:53 +03:00
|
|
|
assert_equal produced.class, @output , "Wrong class"
|
2015-10-15 09:07:47 +03:00
|
|
|
produced
|
2015-05-24 18:05:20 +03:00
|
|
|
end
|
2015-10-10 10:02:28 +03:00
|
|
|
|
2015-05-24 18:05:20 +03:00
|
|
|
end
|