small code climate inspired clean

This commit is contained in:
Torsten Ruger 2018-03-20 13:48:17 +05:30
parent 2c6ea7ea46
commit dba08ba8ce

View File

@ -26,29 +26,30 @@ module Mom
class SlotLoad < Instruction class SlotLoad < Instruction
attr_reader :left , :right attr_reader :left , :right
def initialize(left , right) def initialize(left , right)
left = SlotDefinition.new(left.shift , left) if left.is_a? Array
right = SlotDefinition.new(right.shift , right) if right.is_a? Array
raise "right not Mom, #{right.to_s}" unless right.is_a?( SlotDefinition )#or right.is_a? Mom::Constant
@left , @right = left , right @left , @right = left , right
@left = SlotDefinition.new(@left.shift , @left) if @left.is_a? Array
@right = SlotDefinition.new(@right.shift , @right) if @right.is_a? Array
raise "right not Mom, #{@right.to_s}" unless @right.is_a?( SlotDefinition )
end end
def to_risc(compiler) def to_risc(compiler)
const = @right.to_register(compiler , self) const = @right.to_register(compiler , self)
left_slots = @left.slots
case @left.known_object case @left.known_object
when Symbol when Symbol
left = Risc.message_reg left = Risc.message_reg
left_index = Risc.resolve_to_index(@left.known_object , @left.slots.first) left_index = Risc.resolve_to_index(@left.known_object , left_slots.first)
if @left.slots.length > 1 if left_slots.length > 1
# swap the existing target (with a new reg) and update the index # swap the existing target (with a new reg) and update the index
new_left = compiler.use_reg( :int ) new_left = compiler.use_reg( :int )
const << Risc::SlotToReg.new( self , left ,left_index, new_left) const << Risc::SlotToReg.new( self , left ,left_index, new_left)
left = new_left left = new_left
left_index = SlotLoad.resolve_to_index(@left.slots[0] , @left.slots[1] ,compiler) left_index = SlotLoad.resolve_to_index(left_slots[0] , left_slots[1] ,compiler)
raise "more slots not implemented #{@left.slots}" if @left.slots.length > 2 raise "more slots not implemented #{left_slots}" if left_slots.length > 2
end end
when Parfait::CacheEntry when Parfait::CacheEntry
left = compiler.use_reg( :int ) left = compiler.use_reg( :int )
left_index = Risc.resolve_to_index(:cache_entry , @left.slots.first) left_index = Risc.resolve_to_index(:cache_entry , left_slots.first)
else else
raise "We have left #{@left.known_object}" raise "We have left #{@left.known_object}"
end end
@ -90,22 +91,22 @@ module Mom
end end
def to_register(compiler, instruction) def to_register(compiler, instruction)
type = self.known_object.respond_to?(:ct_type) ? self.known_object.ct_type : :int type = known_object.respond_to?(:ct_type) ? known_object.ct_type : :int
right = compiler.use_reg( type ) right = compiler.use_reg( type )
case self.known_object case known_object
when Constant when Constant
const = Risc.load_constant(instruction, self , right) const = Risc.load_constant(instruction, self , right)
when Symbol when Symbol
const = Risc::SlotToReg.new( instruction , Risc.resolve_to_register(self.known_object) , const = Risc::SlotToReg.new( instruction , Risc.resolve_to_register(known_object) ,
Risc.resolve_to_index(:message , self.slots[0]), right) Risc.resolve_to_index(:message , slots[0]), right)
if self.slots.length > 1 if slots.length > 1
# desctructively replace the existing value to be loaded if more slots # desctructively replace the existing value to be loaded if more slots
index = SlotLoad.resolve_to_index(self.slots[0] , self.slots[1] ,compiler) index = SlotLoad.resolve_to_index(slots[0] , slots[1] ,compiler)
const << Risc::SlotToReg.new( instruction , right ,index, right) const << Risc::SlotToReg.new( instruction , right ,index, right)
raise "more slots not implemented #{self.slots}" if self.slots.length > 2 raise "more slots not implemented #{slots}" if slots.length > 2
end end
else else
raise "We have a #{self} #{self.known_object}" raise "We have a #{self} #{known_object}"
end end
const const
end end