rubyx/lib/parfait/class.rb

104 lines
3.6 KiB
Ruby
Raw Normal View History

2018-06-27 17:09:50 +03:00
# Class is mainly a list of methods with a name.
# The methods are untyped, sis VoolMethod.
2016-02-25 12:03:11 -08:00
# The memory layout of an object is determined by the Type (see there).
2018-06-27 17:09:50 +03:00
# The class carries the "current" type, ie the type an object would be if you
# created an instance of the class.
# Note that this changes over time and so many types share the same class.
2016-02-25 12:03:11 -08:00
2016-12-06 11:38:09 +02:00
# For dynamic OO it is essential that the class (the object defining the class)
2018-06-27 17:09:50 +03:00
# can carry methods. It does so in an instance variable methods.
2016-12-06 11:38:09 +02:00
# An Object carries the data for the instance variables it has.
2016-12-06 15:08:29 +02:00
# The Type lists the names of the instance variables
2018-06-27 17:09:50 +03:00
# The Class keeps a list of instance methods, these have a name and (vool) code
# Each type in turn has a list of CallableMethods that hold binary code
module Parfait
class Class < Object
include Behaviour
attr :type, :instance_type , :name , :instance_methods
attr :super_class_name , :meta_class
def self.type_length
6
end
def initialize( name , superclass , instance_type)
super()
self.name = name
self.super_class_name = superclass
self.instance_methods = List.new
2016-12-31 14:54:53 +02:00
set_instance_type( instance_type )
self.meta_class = MetaClass.new( self )
end
def rxf_reference_name
2015-06-19 19:50:53 +03:00
name
end
def inspect
"Class(#{name})"
end
2018-06-27 17:09:50 +03:00
def add_method_for(name , type , frame , body )
method = Parfait::VoolMethod.new(name , type , frame , body )
add_method( method )
method
end
2017-01-12 20:38:04 +02:00
def add_method(method)
2017-12-10 20:47:26 +02:00
raise "Must be untyped method #{method}" unless method.is_a? Parfait::VoolMethod
instance_methods.push(method)
2017-01-12 20:38:04 +02:00
end
def get_method(name)
instance_methods.find{|m| m.name == name }
2017-01-12 20:38:04 +02:00
end
2017-01-15 14:21:57 +02:00
# adding an instance changes the instance_type to include that variable
def add_instance_variable( name , type)
self.instance_type = instance_type.add_instance_variable( name , type )
2017-01-15 14:21:57 +02:00
end
# setting the type generates all methods for this type
2016-12-31 14:54:53 +02:00
# (or will do, once we store the methods code to do that)
def set_instance_type( type )
2016-12-31 14:54:53 +02:00
raise "type must be type #{type}" unless type.is_a?(Type)
self.instance_type = type
end
# return the super class, but raise exception if either the super class name
# or the super classs is nil.
# Use only for non Object base class
def super_class!
raise "No super_class for class #{name}" unless super_class_name
s = super_class
raise "superclass not found for class #{name} (#{super_class_name})" unless s
s
end
# return the super class
# we only store the name, and so have to resolve.
# Nil name means no superclass, and so nil is a valid return value
def super_class
return nil unless super_class_name
Parfait.object_space.get_class_by_name(super_class_name)
end
# ruby 2.1 list (just for reference, keep at bottom)
#:allocate, :new, :superclass
# + modules
# :<, :<=, :>, :>=, :included_modules, :include?, :name, :ancestors, :instance_methods, :public_instance_methods,
# :protected_instance_methods, :private_instance_methods, :constants, :const_get, :const_set, :const_defined?,
# :const_missing, :class_variables, :remove_class_variable, :class_variable_get, :class_variable_set,
# :class_variable_defined?, :public_constant, :private_constant, :singleton_class?, :include, :prepend,
# :module_exec, :class_exec, :module_eval, :class_eval, :method_defined?, :public_method_defined?,
# :private_method_defined?, :protected_method_defined?, :public_class_method, :private_class_method, :autoload,
# :autoload?, :instance_method, :public_instance_method
end
2015-04-06 11:38:11 +03:00
end