2018-03-13 08:00:51 +01:00
|
|
|
module Mom
|
|
|
|
# just name scoping the same stuff to mom
|
|
|
|
# so we know we are on the way down, keeping our layers seperated
|
|
|
|
# and we can put constant adding into the to_risc methods (instead of on vool classes)
|
|
|
|
class Constant
|
|
|
|
end
|
|
|
|
|
2018-07-09 15:48:23 +02:00
|
|
|
class BlockConstant < Constant
|
|
|
|
attr_reader :block
|
|
|
|
def initialize(bl)
|
|
|
|
@block = bl
|
|
|
|
end
|
|
|
|
def to_parfait(compiler)
|
|
|
|
@block
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-03-13 08:00:51 +01:00
|
|
|
class IntegerConstant < Constant
|
|
|
|
attr_reader :value
|
|
|
|
def initialize(value)
|
|
|
|
@value = value
|
|
|
|
end
|
2018-03-31 12:25:59 +02:00
|
|
|
def to_parfait(compiler)
|
2018-05-29 19:26:00 +02:00
|
|
|
value = Parfait.object_space.get_integer
|
|
|
|
value.set_value(@value)
|
2018-03-31 12:25:59 +02:00
|
|
|
compiler.add_constant(value)
|
|
|
|
value
|
|
|
|
end
|
2018-03-13 08:00:51 +01:00
|
|
|
def ct_type
|
2018-07-13 20:50:40 +02:00
|
|
|
Parfait.object_space.get_type_by_class_name(:Integer)
|
2018-03-13 08:00:51 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
class FloatConstant < Constant
|
|
|
|
attr_reader :value
|
|
|
|
def initialize(value)
|
|
|
|
@value = value
|
|
|
|
end
|
|
|
|
def ct_type
|
|
|
|
true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
class TrueConstant < Constant
|
2018-03-31 12:47:02 +02:00
|
|
|
def to_parfait(compiler)
|
|
|
|
Parfait.object_space.true_object
|
|
|
|
end
|
2018-03-13 08:00:51 +01:00
|
|
|
def ct_type
|
2018-07-13 20:50:40 +02:00
|
|
|
Parfait.object_space.get_type_by_class_name(:TrueClass)
|
2018-03-13 08:00:51 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
class FalseConstant < Constant
|
2018-03-31 12:47:02 +02:00
|
|
|
def to_parfait(compiler)
|
|
|
|
Parfait.object_space.false_object
|
|
|
|
end
|
2018-03-13 08:00:51 +01:00
|
|
|
def ct_type
|
2018-07-13 20:50:40 +02:00
|
|
|
Parfait.object_space.get_type_by_class_name(:FalseClass)
|
2018-03-13 08:00:51 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
class NilConstant < Constant
|
2018-03-31 12:47:02 +02:00
|
|
|
def to_parfait(compiler)
|
|
|
|
Parfait.object_space.nil_object
|
|
|
|
end
|
2018-03-13 08:00:51 +01:00
|
|
|
def ct_type
|
2018-07-13 20:50:40 +02:00
|
|
|
Parfait.object_space.get_type_by_class_name(:NilClass)
|
2018-03-13 08:00:51 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
class StringConstant < Constant
|
|
|
|
attr_reader :value
|
|
|
|
def initialize(value)
|
|
|
|
@value = value
|
|
|
|
end
|
2018-03-31 12:47:02 +02:00
|
|
|
def to_parfait(compiler)
|
|
|
|
value = Parfait.new_word(@value)
|
|
|
|
compiler.add_constant(value)
|
|
|
|
value
|
|
|
|
end
|
2018-03-13 08:00:51 +01:00
|
|
|
def ct_type
|
2018-07-13 20:50:40 +02:00
|
|
|
Parfait.object_space.get_type_by_class_name(:Word)
|
2018-03-13 08:00:51 +01:00
|
|
|
end
|
|
|
|
end
|
2018-03-25 12:27:15 +02:00
|
|
|
class SymbolConstant < Constant
|
2018-03-13 08:00:51 +01:00
|
|
|
def ct_type
|
2018-07-13 20:50:40 +02:00
|
|
|
Parfait.object_space.get_type_by_class_name(:Word)
|
2018-03-13 08:00:51 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|