49 lines
1.6 KiB
Ruby
Raw Normal View History

2018-03-19 21:19:46 +05:30
module Mom
# A Label is the only legal target for a branch (in Mom, in Risc a BinaryCode is ok too)
2018-03-19 21:19:46 +05:30
#
# In the dynamic view (runtime) where the instructions form a graph,
# branches fan out, Labels collect. In other words a branch is the place where
# several roads lead off, and a Label where several roads arrive.
#
# A Label has a name which is mainly used for debugging.
#
# A Mom::Label converts one2one to a Risc::Label. So in a way it could not be more
# simple.
# Alas, since almost by definition several roads lead to this label, all those
# several converted instructions must also point to the identical label on the
# risc level.
#
# This is achieved by caching the created Risc::Label in an instance variable.
# All branches that lead to this label can thus safely call the to_risc and
# whoever calls first triggers the labels creation, but all get the same label.
#
# Off course some specific place still has to be responsible for actually
# adding the label to the instruction list (usually an if/while)
2018-03-19 21:19:46 +05:30
class Label < Instruction
attr_reader :name
def initialize(source , name)
super(source)
2018-03-19 21:19:46 +05:30
@name = name
end
2018-04-17 20:26:15 +03:00
def to_s
"Label: #{name}"
end
# generate the risc label lazily
2019-08-10 12:42:47 +03:00
def risc_label(compiler)
@risc_label ||= Risc.label(self,name)
2019-08-10 12:42:47 +03:00
compiler.add_constant(@risc_label.address)
@risc_label
2018-03-19 21:19:46 +05:30
end
# add the risc_label to the compiler (instruction flow)
# should only be called once
def to_risc(compiler)
compiler.add_code( risc_label(compiler) )
end
2018-03-19 21:19:46 +05:30
end
end