filing at dependencies
This commit is contained in:
parent
af94d40cab
commit
46ed4285a2
@ -15,7 +15,6 @@ module Vool
|
|||||||
def initialize(name , receiver , arguments )
|
def initialize(name , receiver , arguments )
|
||||||
@name , @receiver , @arguments = name , receiver , arguments
|
@name , @receiver , @arguments = name , receiver , arguments
|
||||||
@arguments ||= []
|
@arguments ||= []
|
||||||
@dynamic = Mom::DynamicCall.new()
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def normalize
|
def normalize
|
||||||
@ -30,6 +29,11 @@ module Vool
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# lazy init this, to keep the dependency (which goes to parfait and booting) at bay
|
||||||
|
def dynamic_call
|
||||||
|
@dynamic ||= Mom::DynamicCall.new()
|
||||||
|
end
|
||||||
|
|
||||||
# A Send breaks down to 2 steps:
|
# A Send breaks down to 2 steps:
|
||||||
# - Setting up the next message, with receiver, arguments, and (importantly) return address
|
# - Setting up the next message, with receiver, arguments, and (importantly) return address
|
||||||
# - a CachedCall , or a SimpleCall, depending on wether the receiver type can be determined
|
# - a CachedCall , or a SimpleCall, depending on wether the receiver type can be determined
|
||||||
@ -92,22 +96,22 @@ module Vool
|
|||||||
# 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
|
||||||
# the method until run-time. Alas the setup is the same
|
# the method until run-time. Alas the setup is the same
|
||||||
def call_cached_method(in_method)
|
def call_cached_method(in_method)
|
||||||
message_setup(in_method) << @dynamic
|
message_setup(in_method) << dynamic_call
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
def build_condition
|
def build_condition
|
||||||
cached_type = Mom::SlotDefinition.new(@dynamic.cache_entry , [:cached_type])
|
cached_type = Mom::SlotDefinition.new(dynamic_call.cache_entry , [:cached_type])
|
||||||
current_type = Mom::SlotDefinition.new(:message , [:receiver , :type])
|
current_type = Mom::SlotDefinition.new(:message , [:receiver , :type])
|
||||||
Mom::NotSameCheck.new(cached_type , current_type)
|
Mom::NotSameCheck.new(cached_type , current_type)
|
||||||
end
|
end
|
||||||
def build_type_cache_update
|
def build_type_cache_update
|
||||||
Mom::SlotLoad.new([@dynamic.cache_entry, :cached_type] , [:message , :receiver , :type])
|
Mom::SlotLoad.new([dynamic_call.cache_entry, :cached_type] , [:message , :receiver , :type])
|
||||||
end
|
end
|
||||||
def build_method_cache_update(in_method)
|
def build_method_cache_update(in_method)
|
||||||
receiver = StringConstant.new(@name)
|
receiver = StringConstant.new(@name)
|
||||||
resolve = SendStatement.new(:resolve_method , receiver , [SelfExpression.new])
|
resolve = SendStatement.new(:resolve_method , receiver , [SelfExpression.new])
|
||||||
move_method = Mom::SlotLoad.new([@dynamic.cache_entry, :cached_method] , [:message , :return_value])
|
move_method = Mom::SlotLoad.new([dynamic_call.cache_entry, :cached_method] , [:message , :return_value])
|
||||||
resolve.to_mom(in_method) << move_method
|
resolve.to_mom(in_method) << move_method
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user