This commit is contained in:
Brevven 2025-01-01 04:30:31 -08:00
parent 682b86d641
commit e294b3d5c3
2 changed files with 54 additions and 13 deletions

View file

@ -3,6 +3,7 @@ local me = require("me")
local util = {}
util.me = me
local regenerate_command = "bz-regenerate"
local list_command = "bz-list"
function decode(data)
if type(data) == "string" then return data end
@ -27,8 +28,8 @@ function util.check_fluid_mining()
end
end
function util.get_list()
local p = game.item_prototypes[me.name.."-list"]
function get_list()
local p = prototypes.item[me.name.."-list"]
if p then
data = p.localised_description
return decode(data)
@ -41,6 +42,30 @@ function util.force_enable_recipe(event, recipe_name)
end
end
function list(event)
if event.command and string.lower(event.command) == "bz-list" then
local player = game.players[event.player_index]
if player and player.connected then
local list = get_list()
if list and #list>0 then
local filename = util.me.name..".txt"
helpers.write_file(filename, list, false, event.player_index)
player.print("Wrote recipes to script-output/"..filename)
else
player.print("Please change your mod startup setting for this mod's modified recipes list.")
end
end
end
end
function util.add_list_command_handler()
script.on_event(defines.events.on_console_command, list)
if not commands.commands[list_command] then
commands.add_command(list_command, "", function() end)
end
end
function util.warptorio2_expansion_helper()
if script.active_mods["warptorio2_expansion"] then
@ -96,7 +121,7 @@ function util.warptorio2_expansion_helper()
end
end
local usage = [[
local usage_regenerate = [[
Usage: /bz-regenerate all
or /bz-regenerate <planet> <resource> [<frequency> <size> <richness>]
planet must be an internal name like nauvis
@ -108,15 +133,17 @@ Regenerates ore patches. If frequency/size/richness are provided, the planet wil
- Ores can sometimes overlap on regeneration.
]]
function util.add_regenerate_command_handler()
log("I am here ".. util.me.name)
script.on_event(defines.events.on_console_command, regenerate_ore)
if not commands.commands[regenerate_command] then
commands.add_command( regenerate_command, usage, function() end)
commands.add_command( regenerate_command, usage_regenerate, function() end)
end
end
function regenerate_ore(event)
if event.command == regenerate_command then
game.print("I am trying ".. util.me.name)
local params = {}
for w in event.parameters:gmatch("%S+") do table.insert(params, w) end
if #params == 1 and params[1] == "all" then
@ -127,11 +154,12 @@ function regenerate_ore(event)
return
end
if not (#params == 2 or #params == 5) then
game.print(usage)
game.print(usage_regenerate)
return
end
local planet = params[1]
for _, resource in pairs(me.resources) do
game.print("I am trying ".. util.me.name .. " " .. resource)
if not game.surfaces[planet] then
game.print("Could not find surface for "..planet..". May not exist, or may not yet be explored.")
return