small rename and new test for layout
This commit is contained in:
parent
0a54d030b5
commit
5d838056fa
@ -60,12 +60,18 @@ module Parfait
|
|||||||
names
|
names
|
||||||
end
|
end
|
||||||
|
|
||||||
|
alias :list_index :index_of
|
||||||
|
# private inheritance is something to think off, we don't really want the list api exported
|
||||||
|
def index_of name
|
||||||
|
raise "should not rely on layout internal structure, use variable_index"
|
||||||
|
end
|
||||||
|
|
||||||
# index of a variable name into the layout.
|
# index of a variable name into the layout.
|
||||||
# layout is a list, so lowest index is 1
|
# layout is a list, so lowest index is 1
|
||||||
# :layout is a variable for every object, so 1 is taken for :layout
|
# :layout is a variable for every object, so 1 is taken for :layout
|
||||||
# still, the index is the same.
|
# still, the index is the same.
|
||||||
def variable_index name
|
def variable_index name
|
||||||
index_of(name)
|
list_index(name)
|
||||||
end
|
end
|
||||||
|
|
||||||
def sof_reference_name
|
def sof_reference_name
|
||||||
|
@ -98,7 +98,7 @@ module Register
|
|||||||
real_name = clazz_name.to_s.split('_').last.capitalize.to_sym
|
real_name = clazz_name.to_s.split('_').last.capitalize.to_sym
|
||||||
clazz = Parfait::Space.object_space.get_class_by_name(real_name)
|
clazz = Parfait::Space.object_space.get_class_by_name(real_name)
|
||||||
raise "Class name not given #{real_name}" unless clazz
|
raise "Class name not given #{real_name}" unless clazz
|
||||||
index = clazz.object_layout.index_of( instance_name )
|
index = clazz.object_layout.variable_index( instance_name )
|
||||||
raise "Instance name=#{instance_name} not found on #{real_name}" unless index.is_a?(Numeric)
|
raise "Instance name=#{instance_name} not found on #{real_name}" unless index.is_a?(Numeric)
|
||||||
return index # the type word is at index 0, but layout is a list and starts at 1 == layout
|
return index # the type word is at index 0, but layout is a list and starts at 1 == layout
|
||||||
end
|
end
|
||||||
|
36
test/parfait/test_layout.rb
Normal file
36
test/parfait/test_layout.rb
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
require_relative "../helper"
|
||||||
|
|
||||||
|
class TestLayout < MiniTest::Test
|
||||||
|
|
||||||
|
def setup
|
||||||
|
@mess = Virtual.machine.boot.space.first_message
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_message_layout
|
||||||
|
layout = @mess.get_layout
|
||||||
|
assert layout
|
||||||
|
assert @mess.instance_variable_defined :next_message
|
||||||
|
assert_equal @mess.next_message , @mess.get_instance_variable(:next_message)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_message_by_index
|
||||||
|
assert_equal @mess.next_message , @mess.get_instance_variable(:next_message)
|
||||||
|
index = @mess.get_layout.variable_index :next_message
|
||||||
|
assert_equal 2 , index
|
||||||
|
assert_equal @mess.next_message , @mess.internal_object_get(index)
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_layout_index
|
||||||
|
assert_equal @mess.get_layout , @mess.internal_object_get(1) , "mess"
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_no_index_below_2
|
||||||
|
layout = @mess.get_layout
|
||||||
|
names = layout.object_instance_names
|
||||||
|
assert_equal 7 , names.get_length
|
||||||
|
names.each do |n|
|
||||||
|
assert layout.variable_index(n) > 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -76,14 +76,4 @@ class TestSpace < MiniTest::Test
|
|||||||
assert all.include?(:next_message)
|
assert all.include?(:next_message)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_message_layout
|
|
||||||
mess = @machine.space.first_message
|
|
||||||
one_way = mess.get_layout
|
|
||||||
assert one_way
|
|
||||||
assert mess.instance_variable_defined :next_message
|
|
||||||
# other_way = mess.get_instance_variable :layout
|
|
||||||
# assert other_way
|
|
||||||
# assert_equal one_way , other_way , "not same "
|
|
||||||
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user