rubyx/lib/util/list.rb

66 lines
1.8 KiB
Ruby
Raw Normal View History

module Util
module List
# set the next instruction (also aliased as <<)
# throw an error if that is set, use insert for that use case
# return the instruction, so chaining works as one wants (not backwards)
2018-03-11 16:11:15 +05:30
def set_next( nekst )
raise "Next already set #{@next}" if @next
@next = nekst
nekst
end
# during translation we replace one by one
# TODO avoid this by building a new list
# Make arm instruction not derive from risc (which is weird anyway)
# and include the List into it, translate in same way we go from mom->risc
2018-03-11 16:11:15 +05:30
def replace_next( nekst )
old = @next
@next = nekst
@next.append old.next if old
end
# get the next instruction (without arg given )
# when given an interger, advance along the line that many time and return.
def next( amount = 1)
(amount == 1) ? @next : @next.next(amount-1)
end
# set the give instruction as the next, while moving any existing
# instruction along to the given ones's next.
# ie insert into the linked list that the instructions form
# but allowing the instruction to be a list too (ie more than one)
2018-03-11 16:11:15 +05:30
def insert( instruction )
instruction.last.set_next @next
2018-03-19 13:05:08 +05:30
@next = instruction
end
# return last set instruction. ie follow the linked list until it stops
def last
code = self
code = code.next while( code.next )
return code
end
# set next for the last (see last)
# so append the given code to the linked list at the end
2018-03-11 16:11:15 +05:30
def append( code )
last.set_next code
2018-03-15 21:54:03 +05:30
self
end
alias :<< :append
def length
ret = 0
self.each { ret += 1}
ret
end
def each(&block)
block.call(self)
@next.each(&block) if @next
end
end
end