Added FriendlyHash for orders, refactored Order#execute arguments

This commit is contained in:
2019-10-03 11:45:58 -05:00
parent 3dd067612a
commit fd3b847449
6 changed files with 78 additions and 10 deletions

View File

@@ -24,6 +24,7 @@ require_relative "lib/entity"
# require_relative "lib/entities/"
require_relative "lib/order"
require_relative "lib/friendly_hash"
require_relative "lib/director"
require_relative "lib/player"
require_relative "lib/connection"

View File

@@ -32,9 +32,12 @@ class IMICRTS
@players.find { |player| player.id == id }
end
def issue_order(player_id, order_id, *args)
# pp Order.order_name(order_id)
# pp args
def issue_order(order_id, *args)
if order = Order.get(order_id)
order.execute(self, *args)
else
raise "Undefined order: #{Order.order_name(order_id)}"
end
end

23
lib/friendly_hash.rb Normal file
View File

@@ -0,0 +1,23 @@
class IMICRTS
class FriendlyHash
def initialize
@hash = {}
end
def [](key)
@hash[key.to_sym]
end
def []=(key, value)
@hash[key.to_sym] = value
end
def method_missing(method)
if value = @hash.dig(method)
value
else
raise "Unknown value for: #{method}"
end
end
end
end

View File

@@ -6,18 +6,42 @@ class IMICRTS
IMICRTS::Order.constants(false).find { |const| IMICRTS::Order.const_get(const) == order_id }
end
def self.get(order_id)
@@orders.dig(order_id)
end
def self.define_handler(order_id, arguments: [], &handler)
raise "Handler from #{order_name(order_id)} already defined!" if @@orders.dig(order_id)
@@orders[order_id] = IMICRTS::Order.new(id: order_id, arguments: arguments, &handler)
end
attr_reader :id
def initialize(id:, arguments:, &handler)
@id = id
@arguments = arguments
@handler = handler
end
def execute
@handler.call(self, Director.instance)
def execute(director, *arguments)
@handler.call(arguments(arguments), director)
end
def arguments(args)
raise "Did not receive correct number of arguments: got #{args.size} expected #{@arguments.size}." unless @arguments.size == args.size
hash = FriendlyHash.new
@arguments.each_with_index do |key, value|
hash[key] = args[value]
end
return hash
end
def serialize
end
def deserialize
end
end

View File

@@ -0,0 +1,5 @@
IMICRTS::Order.define_handler(IMICRTS::Order::SELECTED_UNITS, arguments: [:player_id, :ids]) do |order, director|
director.player(order.player_id).selected_entities.clear
director.player(order.player_id).selected_entities.push(order.ids)
end

View File

@@ -8,7 +8,7 @@ class IMICRTS
@selected_entities = []
@mouse_pos = CyberarmEngine::Text.new("X: 0\nY: 0", x: 500, y: 10, z: Float::INFINITY)
@debug_info = CyberarmEngine::Text.new("X: 0\nY: 0", x: 500, y: 10, z: Float::INFINITY)
@sidebar = stack(height: 1.0) do
background [0x55555555, 0x55666666]
@@ -66,7 +66,7 @@ class IMICRTS
Gosu.draw_rect(@box.min.x, @box.min.y, @box.width, @box.height, Gosu::Color.rgba(50, 50, 50, 150), Float::INFINITY) if @box
end
@mouse_pos.draw
@debug_info.draw
end
def update
@@ -84,7 +84,19 @@ class IMICRTS
end
mouse = @player.camera.mouse_pick(window.mouse_x, window.mouse_y)
@mouse_pos.text = "Aspect Ratio: #{@player.camera.aspect_ratio}\nZoom: #{@player.camera.zoom}\nX: #{window.mouse_x}\nY: #{window.mouse_y}\n\nX: #{mouse.x}\nY: #{mouse.y}"
@debug_info.text = %(
Aspect Ratio: #{@player.camera.aspect_ratio}
Zoom: #{@player.camera.zoom}
Window Mouse X: #{window.mouse_x}
Window Mouse Y: #{window.mouse_y}
World Mouse X: #{mouse.x}
World Mouse Y: #{mouse.y}
Director Tick: #{@director.current_tick}
).lines.map { |line| line.strip }.join("\n")
@debug_info.x = @sidebar.width + 20
end
def button_down(id)
@@ -111,7 +123,7 @@ class IMICRTS
@box = nil
@selection_start = nil
@director.issue_order(@player.id, Order::SELECTED_UNITS, @selected_entities)
@director.issue_order(Order::SELECTED_UNITS, @player.id, @selected_entities)
end
@player.camera.button_up(id)