send refactor, green by stubbing
This commit is contained in:
parent
2739747453
commit
c3318f8f61
@ -74,16 +74,11 @@ module Vool
|
|||||||
# if not, change and find method for the type (simple_call to resolve_method)
|
# if not, change and find method for the type (simple_call to resolve_method)
|
||||||
# conceptually easy in ruby, but we have to compile that "easy" ruby
|
# conceptually easy in ruby, but we have to compile that "easy" ruby
|
||||||
def cache_check(in_method)
|
def cache_check(in_method)
|
||||||
# return if cached_type == current_type
|
# if cached_type != current_type
|
||||||
# cached_type = current_type
|
# cached_type = current_type
|
||||||
# cached_method = current_type.resolve_method(method.name)
|
# cached_method = current_type.resolve_method(method.name)
|
||||||
check = []
|
if_true = [build_type_cache_update , build_method_cache_update] #@if_true.to_mom( in_method ) #find and assign
|
||||||
cached_type = Mom::SlotDefinition.new(:message , [:frame , type_var_name])
|
[Mom::IfStatement.new( build_condition , if_true )]
|
||||||
current_type = Mom::SlotDefinition.new(:message , [:self , :type])
|
|
||||||
cond = Mom::NotSameCheck.new(cached_type , current_type)
|
|
||||||
if_true = nil #@if_true.to_mom( in_method ) #find and assign
|
|
||||||
check << Mom::IfStatement.new( cond , if_true )
|
|
||||||
check
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# this may look like a simple_call, but the difference is that we don't know
|
# this may look like a simple_call, but the difference is that we don't know
|
||||||
@ -105,5 +100,17 @@ module Vool
|
|||||||
def type_var_name
|
def type_var_name
|
||||||
"cached_type_#{object_id}"
|
"cached_type_#{object_id}"
|
||||||
end
|
end
|
||||||
|
private
|
||||||
|
def build_condition
|
||||||
|
cached_type = Mom::SlotDefinition.new(:message , [:frame , type_var_name])
|
||||||
|
current_type = Mom::SlotDefinition.new(:message , [:self , :type])
|
||||||
|
Mom::NotSameCheck.new(cached_type , current_type)
|
||||||
|
end
|
||||||
|
def build_type_cache_update
|
||||||
|
|
||||||
|
end
|
||||||
|
def build_method_cache_update
|
||||||
|
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -13,8 +13,14 @@ module Vool
|
|||||||
def test_compiles_not_array
|
def test_compiles_not_array
|
||||||
assert Array != @stats.class , @stats
|
assert Array != @stats.class , @stats
|
||||||
end
|
end
|
||||||
def test_class_compiles
|
def test_if_first
|
||||||
assert_equal Mom::IfStatement , @first.class , @stats
|
assert_equal Mom::IfStatement , @first.class , @first
|
||||||
|
end
|
||||||
|
def test_if_condition_set
|
||||||
|
assert_equal Mom::NotSameCheck , @first.condition.class , @first
|
||||||
|
end
|
||||||
|
def test_if_true_set
|
||||||
|
assert @first.if_true , @first
|
||||||
end
|
end
|
||||||
def est_slot_is_set
|
def est_slot_is_set
|
||||||
assert @stats.first.left
|
assert @stats.first.left
|
||||||
|
Loading…
x
Reference in New Issue
Block a user