1
0
mirror of https://github.com/Refactorio/RedMew.git synced 2025-01-18 03:21:47 +02:00
RedMew/map_gen/maps/quadrants/item_to_chest.lua
2020-11-24 16:39:21 +00:00

86 lines
2.6 KiB
Lua

local RS = require 'map_gen.shared.redmew_surface'
local Event = require 'utils.event'
local Public = {}
local function create_chest(player, position, radius, bounding_box)
local surface = RS.get_surface()
position = position ~= nil and position or player.position
local pos
if radius then
pos = surface.find_non_colliding_position('steel-chest', position, radius, 1)
elseif bounding_box then
pos = surface.find_non_colliding_position_in_box('steel-chest', bounding_box, 1)
end
if pos ~= nil then
local chest = surface.create_entity {name = 'steel-chest', position = pos, force = player.force}
chest.minable = false
return chest
end
return false
end
function Public.transfer_inventory(player_index, inventories, position, radius, bounding_box)
if inventories == nil or player_index == nil then
return 'You need to specify a player index and a table of define.inventory'
end
local player = game.get_player(player_index)
player.clear_cursor()
while player.crafting_queue_size ~= 0 do
player.cancel_crafting(player.crafting_queue[1])
end
local chest
for _, inventory in pairs(inventories) do
inventory = player.get_inventory(inventory)
for name, count in pairs(inventory.get_contents()) do
local ItemStack = {name = name, count = count}
inventory.remove(ItemStack)
while count > 0 do
if not chest or not chest.can_insert(ItemStack) then
chest = create_chest(player, position, radius, bounding_box)
if not chest then
return false
end
end
count = count - chest.insert(ItemStack)
ItemStack = {name = name, count = count}
end
end
end
if not chest then
return false
end
return chest.position
end
local function on_gui_closed(event)
local entity = event.entity
if entity == nil or not entity.valid then
return
end
if entity.name == 'steel-chest' and entity.minable == false and not entity.has_items_inside() then
entity.destroy()
end
end
local function ctrl_empty(event)
local entity = event.last_entity
if entity == nil or not entity.valid then
return
end
if entity.name == 'steel-chest' and not entity.minable then
event.entity = entity
on_gui_closed(event)
end
end
Event.add(defines.events.on_gui_closed, on_gui_closed)
Event.add(defines.events.on_selected_entity_changed, ctrl_empty)
Event.add(defines.events.on_pre_player_mined_item)
return Public