rubyx/lib/parfait/object.rb

111 lines
3.9 KiB
Ruby
Raw Normal View History

# to be precise, this should be an ObjectReference, as the Reference is a Value
# but we don't want to make that distinction all the time , so we don't.
2014-08-05 15:55:24 +03:00
# that does lead to the fact that we have Reference functions on the Object though
2014-08-05 15:55:24 +03:00
2015-05-17 14:40:02 +03:00
# Objects are arranged or layed out (in memory) according to their Layout
# every object has a Layout. Layout objects are immutalbe and may be resued for a group/class
# off objects.
# The Layout of an object may change, but then a new Layout is created
# The Layout also defines the class of the object
# The Layout is **always** the first entry (index 1) in an object, but the type word is index 0
module Parfait
LAYOUT_INDEX = 1
class Object < Value
2015-05-17 14:40:02 +03:00
2015-07-20 13:01:15 +03:00
def self.new *args
object = self.allocate
#HACK, but used to do the adapter in the init, bu that is too late now
object.fake_init if object.respond_to?(:fake_init) # at compile, not run-time
# have to grab the class, because we are in the ruby class not the parfait one
cl = Space.object_space.get_class_by_name( self.name.split("::").last.to_sym)
# and have to set the layout before we let the object do anything. otherwise boom
object.set_layout cl.object_layout
2015-07-20 13:01:15 +03:00
object.send :initialize , *args
object
end
def self.attributes names
names.each{|name| attribute(name) }
end
def self.attribute name
define_method(name) { get_instance_variable(name) }
define_method("#{name}=".to_sym) { |value| set_instance_variable(name , value) }
end
2015-06-03 10:01:59 +03:00
def == other
self.object_id == other.object_id
end
# This is the crux of the object system. The class of an object is stored in the objects
# memory (as opposed to an integer that has no memory and so always has the same class)
#
# In Salama we store the class in the Layout, and so the Layout is the only fixed
# data that every object carries.
def get_class()
l = get_layout()
#puts "Layout #{l.class} in #{self.class} , #{self}"
l.object_class()
end
# private
def set_layout(layout)
2015-07-18 11:52:30 +03:00
# puts "Layout was set for #{self.class}"
2015-05-31 11:07:49 +03:00
raise "Nil layout" unless layout
internal_object_set(LAYOUT_INDEX , layout)
end
# so we can keep the raise in get_layout
def has_layout?
! internal_object_get(LAYOUT_INDEX).nil?
end
def get_layout()
2015-05-25 18:48:35 +03:00
l = internal_object_get(LAYOUT_INDEX)
#puts "get layout for #{self.class} returns #{l.class}"
raise "No layout #{self.object_id}:#{self.class} " unless l
2015-05-25 18:48:35 +03:00
return l
end
2015-05-20 10:57:20 +03:00
def get_instance_variables
get_layout().instance_names
2015-05-14 19:53:56 +03:00
end
2015-05-20 10:57:20 +03:00
def get_instance_variable name
2015-05-14 19:53:56 +03:00
index = instance_variable_defined(name)
#puts "getting #{name} at #{index}"
2015-05-14 19:53:56 +03:00
return nil if index == nil
2015-07-20 13:01:15 +03:00
return internal_object_get(index)
2015-05-14 19:53:56 +03:00
end
2015-05-20 10:57:20 +03:00
def set_instance_variable name , value
2015-05-14 19:53:56 +03:00
index = instance_variable_defined(name)
return nil if index == nil
2015-07-20 13:01:15 +03:00
return internal_object_set(index , value)
2015-05-14 19:53:56 +03:00
end
def instance_variable_defined name
get_layout().variable_index(name)
2015-05-14 19:53:56 +03:00
end
def padded_length
padded_words( get_layout().instance_length )
end
# Object
# :nil?, :===, :=~, :!~, :eql?, :hash, :<=>, :class, :singleton_class, :clone, :dup, :taint, :tainted?, :untaint,
# :untrust, :untrusted?, :trust, :freeze, :frozen?, :to_s, :inspect, :methods, :singleton_methods, :protected_methods,
2015-05-20 10:57:20 +03:00
# :private_methods, :public_methods, :get_instance_variables, :get_instance_variable, :set_instance_variable, :instance_variable_defined?,
# :remove_instance_variable, :instance_of?, :kind_of?, :is_a?, :tap, :send, :public_send, :respond_to?,
# :extend, :display, :method, :public_method, :singleton_method, :define_singleton_method,
# :object_id, :to_enum, :enum_for
#
# BasicObject
# :==, :equal?, :!, :!=, :instance_eval, :instance_exec, :__send__, :__id__
end
2014-07-30 21:43:12 +03:00
end