local Global = require 'utils.global' local pairs = pairs local Game = {} local bad_name_players = {} Global.register( bad_name_players, function(tbl) bad_name_players = tbl end ) --[[ Due to a bug in the Factorio api the following expression isn't guaranteed to be true. game.players[player.index] == player get_player_by_index(index) will always return the correct player. When looking up players by name or iterating through all players use game.players instead. ]] function Game.get_player_by_index(index) local p = game.players[index] if not p then return nil end if p.index == index then return p end p = bad_name_players[index] if p then if p.valid then return p else return nil end end for k, v in pairs(game.players) do if k == index then bad_name_players[index] = v return v end end end --- Returns a valid LuaPlayer if given a number, string, or LuaPlayer. Returns nil otherwise. -- obj function Game.get_player_from_any(obj) local o_type = type(obj) local p if type == 'number' then p = Game.get_player_by_index(obj) elseif o_type == 'string' then p = game.players[obj] elseif o_type == 'table' and obj.valid and obj.is_player() then return obj end if p and p.valid then return p end end --- Prints to player or console. function Game.player_print(str) if game.player then game.player.print(str) else print(str) end end function Game.get_player(mixed) if type(mixed) == 'table' then if mixed.__self then return mixed and mixed.valid and mixed elseif mixed.player_index then local player = game.players[mixed.player_index] return player and player.valid and player end elseif mixed then local player = game.players[mixed] return player and player.valid and player end end --[[ @param Position String to display at @param text String to display @param color table in {r = 0~1, g = 0~1, b = 0~1}, defaults to white. @param surface LuaSurface @return the created entity ]] function Game.print_floating_text(surface, position, text, color) color = color return surface.create_entity { name = 'tutorial-flying-text', color = color, text = text, position = position } end --[[ Creates a floating text entity at the player location with the specified color in {r, g, b} format. Example: "+10 iron" or "-10 coins" @param text String to display @param color table in {r = 0~1, g = 0~1, b = 0~1}, defaults to white. @return the created entity ]] function Game.print_player_floating_text_position(player_index, text, color, x_offset, y_offset) local player = Game.get_player_by_index(player_index) if not player or not player.valid then return end local position = player.position return Game.print_floating_text(player.surface, {x = position.x + x_offset, y = position.y + y_offset}, text, color) end function Game.print_player_floating_text(player_index, text, color) Game.print_player_floating_text_position(player_index, text, color, 0, -1.5) end return Game