2017-04-01 20:28:57 +02:00
|
|
|
module Vool
|
|
|
|
class Statements < Statement
|
2018-03-15 16:10:21 +01:00
|
|
|
attr_reader :statements
|
|
|
|
def initialize(statements)
|
|
|
|
@statements = statements
|
|
|
|
end
|
|
|
|
|
|
|
|
def empty?
|
|
|
|
@statements.empty?
|
|
|
|
end
|
|
|
|
def single?
|
|
|
|
@statements.length == 1
|
|
|
|
end
|
|
|
|
def first
|
|
|
|
@statements.first
|
|
|
|
end
|
|
|
|
def last
|
|
|
|
@statements.last
|
|
|
|
end
|
|
|
|
def length
|
|
|
|
@statements.length
|
|
|
|
end
|
|
|
|
def [](i)
|
|
|
|
@statements[i]
|
|
|
|
end
|
|
|
|
def <<(o)
|
|
|
|
@statements << o
|
|
|
|
self
|
|
|
|
end
|
2017-04-12 10:52:23 +02:00
|
|
|
|
|
|
|
# create machine instructions
|
|
|
|
def to_mom( method )
|
2018-03-15 16:03:38 +01:00
|
|
|
raise "Empty list ? #{statements.length}" unless @statements[0]
|
|
|
|
flat = @statements.shift.to_mom(method)
|
|
|
|
while( nekst = @statements.shift )
|
|
|
|
flat.append nekst.to_mom(method)
|
|
|
|
end
|
|
|
|
flat
|
2017-04-08 11:10:42 +02:00
|
|
|
end
|
2017-04-09 09:14:28 +02:00
|
|
|
|
|
|
|
def create_objects
|
|
|
|
@statements.each{ |s| s.create_objects }
|
|
|
|
end
|
2018-03-10 14:31:38 +01:00
|
|
|
|
2018-03-15 12:52:56 +01:00
|
|
|
def each(&block)
|
|
|
|
block.call(self)
|
2018-03-15 16:10:21 +01:00
|
|
|
@statements.each{|a| a.each(&block)}
|
2018-03-15 12:52:56 +01:00
|
|
|
end
|
|
|
|
|
2018-03-15 17:24:03 +01:00
|
|
|
def normalize
|
|
|
|
Statements.new(@statements.collect{|s| s.normalize})
|
|
|
|
end
|
2017-04-02 12:24:09 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
class ScopeStatement < Statements
|
2018-03-15 17:24:03 +01:00
|
|
|
def normalize
|
|
|
|
ScopeStatement.new(@statements.collect{|s| s.normalize})
|
|
|
|
end
|
2017-04-01 20:28:57 +02:00
|
|
|
end
|
|
|
|
end
|