57 lines
1.3 KiB
Ruby
57 lines
1.3 KiB
Ruby
module Virtual
|
|
|
|
class Constant < ::Virtual::Object
|
|
|
|
end
|
|
|
|
# another abstract "marker" class (so we can check for it)
|
|
# derived classes are Boot/Meta Class and StringConstant
|
|
class ObjectConstant < Constant
|
|
end
|
|
|
|
class IntegerConstant < Constant
|
|
def initialize int
|
|
@integer = int
|
|
end
|
|
attr_reader :integer
|
|
def attributes
|
|
[:integer]
|
|
end
|
|
def inspect
|
|
self.class.name + ".new(#{@integer})"
|
|
end
|
|
end
|
|
|
|
# The name really says it all.
|
|
# The only interesting thing is storage.
|
|
# Currently string are stored "inline" , ie in the code segment.
|
|
# Mainly because that works an i aint no elf expert.
|
|
|
|
class StringConstant < ObjectConstant
|
|
attr_reader :string
|
|
# currently aligned to 4 (ie padded with 0) and off course 0 at the end
|
|
def initialize str
|
|
str = str.to_s if str.is_a? Symbol
|
|
length = str.length
|
|
# rounding up to the next 4 (always adding one for zero pad)
|
|
pad = ((length / 4 ) + 1 ) * 4 - length
|
|
raise "#{pad} #{self}" unless pad >= 1
|
|
@string = str + " " * pad
|
|
end
|
|
|
|
def result= value
|
|
class_for(MoveInstruction).new(value , self , :opcode => :mov)
|
|
end
|
|
|
|
# the strings length plus padding
|
|
def length
|
|
string.length
|
|
end
|
|
|
|
# just writing the string
|
|
def assemble(io)
|
|
io << string
|
|
end
|
|
end
|
|
|
|
end |