2015-04-08 20:24:50 +03:00
|
|
|
# An Object is really a hash like structure. It is dynamic and
|
|
|
|
# you want to store values by name.
|
|
|
|
# One could (like mri), store the names in each object, but that is wasteful
|
|
|
|
# Instead we store only the values, and access them by index.
|
|
|
|
# The Layout allows the mapping of names to index.
|
|
|
|
|
|
|
|
# The Layout of an object describes the memory layout of the object
|
|
|
|
# The Layout is a simple list of the names of instance variables.
|
2015-05-11 18:55:49 +03:00
|
|
|
#
|
|
|
|
# As every object has a Layout to describe it, the name "layout" is the
|
2015-04-08 20:24:50 +03:00
|
|
|
# first name in the list for every Layout.
|
|
|
|
# But as we want every Object to have a class, this is the second
|
|
|
|
# entry in the list. The name for the entry is "object_class"
|
|
|
|
|
|
|
|
# In other words, the Layout is a list of names that describe
|
|
|
|
# the values stored in an actual object.
|
2015-05-12 19:10:45 +03:00
|
|
|
# The object is an List of values of length n and
|
|
|
|
# the Layout is an List of names of length n
|
2015-05-11 18:55:49 +03:00
|
|
|
# Together they turn the object into a hash like structure
|
2015-04-08 20:24:50 +03:00
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
module Parfait
|
|
|
|
class Layout < Object
|
2015-04-08 20:24:50 +03:00
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
# given a name as symbol, return the integer index of that entry
|
|
|
|
# we use 0 as "not found" as we don't want negatives, and can't raise
|
|
|
|
# luckily 0 is always the type-word in an object and so by returning
|
|
|
|
# one-offsets we can use the return value straight without adding 1
|
|
|
|
def index_of( name )
|
|
|
|
#internal implementation....
|
|
|
|
end
|
2015-04-08 20:24:50 +03:00
|
|
|
|
2015-05-11 18:55:49 +03:00
|
|
|
end
|
2015-04-08 20:24:50 +03:00
|
|
|
end
|